@charset "UTF-8";

.animate__delay-05s {
  -webkit-animation-delay: calc(var(--animate-delay) * .5);
  animation-delay: calc(var(--animate-delay) * .5);
}

.animate__delay-08s {
  -webkit-animation-delay: calc(var(--animate-delay) * .8);
  animation-delay: calc(var(--animate-delay) * .8);
}

.animate__delay-13s {
  -webkit-animation-delay: calc(var(--animate-delay) * 1.3);
  animation-delay: calc(var(--animate-delay) * 1.3);
}

.animate__delay-16s {
  -webkit-animation-delay: calc(var(--animate-delay) * 1.6);
  animation-delay: calc(var(--animate-delay) * 1.6);
}

/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */

html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  line-height: 1.15;
}

body {
  margin: 0;
}

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

h1 {
  font-size: 2em;
  margin: .67em 0;
}

figcaption,
figure,
main {
  display: block;
}

figure {
  margin: 1em 40px;
}

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

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

a {
  -webkit-text-decoration-skip: objects;
  background-color: transparent;
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: inherit;
}

b,
strong {
  font-weight: bolder;
}

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

dfn {
  font-style: italic;
}

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

small {
  font-size: 80%;
}

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

sub {
  bottom: -.25em;
}

sup {
  top: -.5em;
}

audio,
video {
  display: inline-block;
}

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

img {
  border-style: none;
}

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

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

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

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

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

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

fieldset {
  padding: .35em .75em .625em;
}

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

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

textarea {
  overflow: auto;
}

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

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

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

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

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

details,
menu {
  display: block;
}

summary {
  display: list-item;
}

canvas {
  display: inline-block;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

* {
  box-sizing: border-box;
}

body,
html {
  height: 100%;
}

html {
  font-size: 62.5%;
}

body {
  color: #231815;
  font-family: "Noto Sans JP",游ゴシック,"Yu Gothic",游ゴシック体,YuGothic,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","Meiryo UI",メイリオ,Meiryo,sans-serif;
  font-size: 1.6rem;
  letter-spacing: .5px;
  margin: 0;
  padding: 0;
  word-break: break-all;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 1.6rem;
  font-weight: 400;
  margin: 0;
  padding: 0;
}

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

a:hover {
  text-decoration: none;
}

a:link {
  border-radius: 0;
}

ol {
  list-style: none;
}

li {
  list-style: none;
}

ul {
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  padding: 0;
}

ol,
ul {
  margin-bottom: 0;
  margin-top: 0;
}

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

dl {
  margin-bottom: 0;
  margin-top: 0;
}

em {
  font-style: normal;
}

.main {
  margin-top: 100px;
}

.l-wrapper {
  margin: 0 auto;
  width: calc((100% / 12) * 10);
}

.l-wrapper.news-single {
  width: calc((100% / 12) * 9);
}

.lower-kv {
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 80vh;
  position: relative;
  width: 100%;
}

.lower-kv.about-kv {
  background-image: url(../../assets/images/about/kv-pc.jpg);
}

.lower-kv.service-kv {
  background-image: url(../../assets/images/service/kv-pc_1.jpg);
}

.lower-kv.company-kv {
  background-image: url(../../assets/images/company/kv-pc_1.jpg);
}

.lower-kv.sdgs-kv {
  background-image: url(../../assets/images/sdgs/kv-pc.jpg);
}

.lower-kv.recruit-kv {
  background-image: url(../../assets/images/recruit/kv-pc.jpg);
}

.lower-kv__heading {
  bottom: -8%;
  left: calc((100% / 12) * .75);
  position: absolute;
  z-index: 2;
}

.lower-kv__heading span {
  background-color: #fff;
  font-family: Jost,sans-serif;
  font-size: 9.5rem;
  font-style: normal;
  font-weight: 600;
  padding: 0 24px;
}

.other-heading {
  width: 100%;
}

.other-heading__news-bg {
  position: relative;
  width: 100%;
}

.other-heading__news-bg::before {
  background-color: #f5ba13;
  content: '';
  display: block;
  display: block;
  height: 35px;
  left: 0;
  top: 0;
  width: 100%;
}

.other-heading__news-bg::after {
  background-color: #002957;
  content: '';
  display: block;
  display: block;
  height: 65px;
  width: 100%;
}

.other-heading__item {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
  height: 85px;
  margin: -84px auto 0 auto;
  position: relative;
  width: calc((100% / 12) * 10.5);
  z-index: 1;
}

.other-heading__item.single-item {
  margin: 0 auto;
}

.other-heading__items .heading-txt {
  background-color: #fff;
  font-size: 3.5rem;
  font-weight: 600;
  padding: 22px 20px;
  text-align: center;
}

.page-top {
  bottom: 24px;
  position: fixed;
  right: 16px;
  z-index: 2;
}

.page-top svg {
  height: 45px;
  width: 63px;
}

.page-top svg path {
  fill: #000;
  transition: 1s;
}

.page-top.js-page-top svg path {
  fill: #fff;
}

.footer-about {
  margin: 0 auto 80px auto;
  position: relative;
  width: calc((100% / 12) * 10.5);
}

.footer-about::after {
  background-color: rgba(0,0,0,.548);
  content: '';
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.footer-about img {
  display: block;
}

.footer-about__item {
  -webkit-transform: translate(-50%,-50%);
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 100%;
  z-index: 1;
}

.footer-about__item .txt-area {
  color: #fff;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.75;
  text-align: center;
}

.footer-about__item .btn-area {
  margin-top: 40px;
}

.footer-magazine {
  background-color: #004380;
  color: #fff;
  display: none;
  font-family: Jost,sans-serif;
  font-style: normal;
  margin: 0 auto 80px auto;
  outline: 1px solid #fff;
  outline-offset: -16px;
  padding: 120px 0;
  position: relative;
  text-align: center;
  width: calc((100% / 12) * 10.5);
}

.footer-magazine .magazine-txt {
  font-size: 6rem;
  font-weight: 600;
  letter-spacing: .1em;
}

.footer-magazine .magazine-date {
  font-size: 4rem;
  margin-top: 40px;
}

.l-footer {
  background-image: url(../../assets/images/common/footer-bg.jpg);
  background-size: cover;
  position: relative;
  width: 100%;
}

.l-footer .footer-wrapper {
  margin: 0 auto;
  position: relative;
  width: calc((100% / 12) * 10.5);
  z-index: 1;
}

.l-footer .footer-item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.l-footer .footer-items.-logo {
  width: calc((100% / 10.5) * 2.5);
}

.l-footer .footer-items.-nav {
  width: calc((100% / 10.5) * 2.5);
}

.l-footer .footer-items.-nav .footer-nav {
  margin-top: 40px;
}

.l-footer .footer-items.-nav .footer-nav li {
  margin-bottom: 30px;
  width: 100%;
}

.l-footer .footer-items.-nav .footer-nav li:last-child {
  margin-bottom: 0;
}

.l-footer .footer-items.-nav .footer-nav li a {
  color: #fff;
}

.l-footer .footer-items.-contact {
  color: #fff;
  letter-spacing: .1em;
  margin-top: 40px;
  margin-top: 40px;
  width: calc((100% / 10.5) * 3.5);
}

.l-footer .footer-items.-contact .tel-area .txt {
  font-size: 1.5rem;
}

.l-footer .footer-items.-contact .tel-area .tel {
  font-family: Jost,sans-serif;
  font-size: 4rem;
  font-style: normal;
  font-weight: 600;
  letter-spacing: .1em;
  margin: 10px 0;
}

.l-footer .footer-items.-contact .tel-area .tel a {
  color: #fff;
}

.l-footer .footer-items.-contact .tel-area .hour {
  font-size: 1.4rem;
}

.l-footer .footer-items.-contact .btn-area {
  margin-top: 40px;
}

.l-footer .footer-items.-contact .btn-area .contact-btn {
  border: 1px solid #fff;
  border-radius: 24px;
  max-width: 300px;
}

.l-footer .footer-items.-contact .btn-area .contact-btn.gutter {
  margin-top: 40px;
}

.l-footer .footer-items.-contact .btn-area .contact-btn a {
  color: #fff;
  display: block;
  padding: 20px 0;
  text-align: center;
}

.l-footer .footer-items.-contact .btn-area .contact-btn a span {
  position: relative;
}

.l-footer .footer-items.-contact .btn-area .contact-btn a span::before {
  content: url(../../assets/images/common/mail-icon.svg);
  display: inline-block;
  margin-right: 6px;
}

.l-footer .footer-copy {
  padding: 80px 0;
  width: 100%;
}

.l-footer .footer-copy__item {
  width: calc((100% / 10.5) * 2.5);
}

.l-footer .footer-copy__item .sns-item {
  display: flex;
  flex-flow: wrap;
  justify-content: center;
  text-align: center;
}

.l-footer .footer-copy__item .sns-items {
  padding: 0 16px;
}

.l-footer .footer-copy__item .sns-items a {
  color: #fff;
}

.l-footer .footer-copy__item .sns-items a i {
  font-size: 4rem;
}

.l-footer .footer-copy__item .copy-txt {
  color: #fff;
  font-size: 1.1rem;
  margin-top: 20px;
  text-align: center;
}

.l-header {
  background-color: #fff;
  height: 100px;
  left: 0;
  line-height: 100px;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 3;
}

.l-header__logo {
  left: calc((100% / 12) * .5);
  max-width: 300px;
  position: absolute;
  top: 8px;
}

.l-header nav .gloval-nav {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: flex-end;
  padding-right: calc((100% / 12) * 1);
}

.l-header nav .nav-item {
  margin-right: 24px;
}

.l-header nav .nav-item a {
  color: #231815;
  font-weight: 700;
  padding: 0 8px;
  position: relative;
}

.l-header nav .nav-item a::before {
  background-color: #f5ba13;
  bottom: -5px;
  content: '';
  height: 2px;
  left: 0;
  position: absolute;
  transition: .5s;
  width: 0;
}

.l-header nav .nav-item a:hover::before {
  content: '';
  width: 100%;
}

.l-header__menu {
  align-items: center;
  background-color: #002957;
  display: flex;
  flex-direction: column;
  height: 100px;
  justify-content: center;
  position: fixed;
  right: 0;
  top: 0;
  width: 100px;
  z-index: 5;
}

.l-header__menu span {
  display: block;
  font-style: normal;
  height: 2px;
  position: relative;
  transition: ease-in-out .5s;
}

.l-header__menu span:nth-of-type(1) {
  background-color: #fff;
  width: 35px;
}

.l-header__menu span:nth-of-type(2) {
  background-color: #fff;
  margin-top: 10px;
  width: 35px;
}

.l-header__menu.js-menu {
  background-color: #0f3f75;
}

.l-header__menu.js-menu span:nth-of-type(1) {
  -webkit-transform: translate(0,6px) rotate(45deg);
  transform: translate(0,6px) rotate(45deg);
}

.l-header__menu.js-menu span:nth-of-type(2) {
  -webkit-transform: translate(0,-6px) rotate(-45deg);
  transform: translate(0,-6px) rotate(-45deg);
}

.l-header__drower-menu {
  background-color: #002957;
  height: 100%;
  overflow: scroll;
  position: fixed;
  right: -100%;
  top: 0;
  transition: .5s;
  width: 100%;
  z-index: 3;
}

.l-header__drower-menu.js-nav {
  right: 0;
}

.l-header__drower-menu .drower-item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin: 68px auto 0 auto;
  width: calc((100% / 12) * 10);
}

.l-header__drower-menu .drower-items.-left {
  display: flex;
  flex-flow: column;
  justify-content: space-between;
  width: calc((100% / 10) * 3);
}

.l-header__drower-menu .drower-items.-left .item-logo {
  width: 100%;
}

.l-header__drower-menu .drower-items.-left .item-logo img {
  display: block;
  margin: 0 auto;
  width: 320px;
}

.l-header__drower-menu .drower-items.-left .item-copy {
  width: 100%;
}

.l-header__drower-menu .drower-items.-left .item-copy .sns-item {
  display: flex;
  flex-flow: wrap;
  justify-content: center;
  text-align: center;
}

.l-header__drower-menu .drower-items.-left .item-copy .sns-items {
  padding: 0 16px;
}

.l-header__drower-menu .drower-items.-left .item-copy .sns-items a {
  color: #fff;
}

.l-header__drower-menu .drower-items.-left .item-copy .sns-items a i {
  font-size: 4rem;
}

.l-header__drower-menu .drower-items.-left .item-copy .copy-txt {
  color: #fff;
  font-size: 1.2rem;
  margin-top: 20px;
  text-align: center;
}

.l-header__drower-menu .drower-items.-right {
  width: calc((100% / 10) * 6);
}

.l-header__drower-menu .drower-items.-right .drower-nav__item {
  align-items: flex-start;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items {
  width: 45%;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents.gutter-bottom-hight {
  margin-bottom: 64px;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents.gutter-bottom-low {
  margin-bottom: 30px;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title a {
  color: #fff;
  display: block;
  font-family: Jost,sans-serif;
  font-size: 3.5rem;
  font-style: normal;
  font-weight: 600;
  letter-spacing: .1em;
  margin-bottom: 16px;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title.color-yellow a {
  color: #f5ba13;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title.ja a {
  font-family: 'Noto Sans JP',sans-serif;
  font-size: 3rem;
  font-style: normal;
  font-weight: 400;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-list {
  width: 100%;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-list__item {
  margin-bottom: 16px;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-list__item:last-child {
  margin-bottom: 0;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-list__item a {
  color: #99a6b7;
  display: block;
  font-family: Jost,sans-serif;
  font-style: normal;
}

.l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-list__item.color-yellow a {
  color: #f5ba13;
}

.l-header__drower-menu .drower-footer-copy__mb {
  display: none;
}

.l-header__drower-menu .drower-footer {
  margin-top: 80px;
  padding: 0 10px;
  width: 100%;
}

.main-btn {
  border-radius: 50px;
  display: block;
  max-width: 150px;
}

.main-btn.news-btn {
  max-width: 300px;
}

.main-btn.bg-black {
  background-color: #000;
}

.main-btn.bg-black a {
  color: #fff;
}

.main-btn.bg-yellow {
  background-color: #fff343;
}

.main-btn.bg-yellow a {
  color: #000;
}

.main-btn.bg-orange {
  background-color: #f5ba13;
}

.main-btn.bg-orange a {
  color: #fff;
}

.main-btn.bg-blue {
  background-color: #004381;
}

.main-btn.bg-blue a {
  color: #fff;
}

.main-btn.bg-green {
  background-color: #138046;
}

.main-btn.bg-green a {
  color: #fff;
}

.main-btn.center {
  margin: 0 auto;
}

.main-btn.gutter-top {
  margin-top: 80px;
}

.main-btn a {
  display: block;
  font-family: ttnorms_medium;
  height: 50px;
  line-height: 50px;
  text-align: center;
}

.branch-btn {
  margin: 0 auto;
  width: calc((100% / 12) * 10);
}

.branch-btn__item {
  display: flex;
  flex-flow: wrap;
}

.branch-btn__item.service-branch {
  align-items: flex-end;
}

.branch-btn__items {
  border-right: 1px solid #acacac;
  position: relative;
  width: 50%;
}

.branch-btn__items.service-btn {
  border: 0;
}

.branch-btn__items.service-btn:nth-child(1) {
  border-right: 1px solid #acacac;
  width: calc((100% / 10) * 2.7);
}

.branch-btn__items.service-btn:nth-child(2) {
  width: calc((100% / 10) * 4.6);
}

.branch-btn__items.service-btn:nth-child(3) {
  border-left: 1px solid #acacac;
  border-right: 1px solid #acacac;
  width: calc((100% / 10) * 2.7);
}

.branch-btn__items.service-btn.current a {
  color: #004380;
}

.branch-btn__items.service-btn.current a svg path {
  fill: #004380;
}

.branch-btn__items:first-child {
  border-left: 1px solid #acacac;
}

.branch-btn__items a {
  color: #acacac;
  display: block;
  font-size: 2.4rem;
  font-weight: 700;
  padding: 32px 0;
  position: relative;
  text-align: center;
}

.branch-btn__items a span {
  -webkit-transform: translateX(-50%);
  bottom: -16px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
}

.branch-btn__items a span svg {
  height: 15px;
  width: 30px;
}

.branch-btn__items a:focus {
  color: #004380;
}

.branch-btn__items a:focus svg path {
  fill: #004380;
}

.branch-btn__items a:first-child {
  border-left: 1px solid #acacac;
}

.branch-btn__items.sdgs-btn.current a {
  color: #008d3d;
}

.branch-btn__items.sdgs-btn.current a svg path {
  fill: #008d3d;
}

.branch-btn__items.sdgs-btn a:focus {
  color: #008d3d;
}

.branch-btn__items.sdgs-btn a:focus svg path {
  fill: #008d3d;
}

.branch-btn__items.recruit-btn.current a {
  color: #e09000;
}

.branch-btn__items.recruit-btn.current a svg path {
  fill: #e09000;
}

.branch-btn__items.recruit-btn a:focus {
  color: #e09000;
}

.branch-btn__items.recruit-btn a:focus svg path {
  fill: #e09000;
}

.embed-container {
  height: 0;
  margin-bottom: 5px;
  margin-top: 8px;
  overflow: hidden;
  padding-bottom: 56.25%;
  padding-top: 30px;
  position: relative;
}

.embed-container embed,
.embed-container iframe,
.embed-container object {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.ggmap {
  height: 0;
  margin-top: 0;
  overflow: hidden;
  padding-bottom: 60%;
  position: relative;
}

.ggmap embed,
.ggmap iframe,
.ggmap object {
  height: 100%;
  left: 0;
  margin-top: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.googlecal {
  height: 0;
  padding-bottom: 100%;
  position: relative;
}

.googlecal iframe {
  height: 100%!important;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%!important;
}

@font-face {
  src: url(../fonts/TTNorms-Bold.woff) format("woff2"),url(../fonts/TTNorms-Bold.woff2) format("woff");
  font-family: ttnorms_bold;
  font-style: normal;
  font-weight: 400;
}

@font-face {
  src: url(../fonts/TTNorms-Medium.woff) format("woff2"),url(../fonts/TTNorms-Medium.woff2) format("woff");
  font-family: ttnorms_medium;
  font-style: normal;
  font-weight: 400;
}

[lang=ja] {
  font-family: 'Noto Sans JP',sans-serif;
  font-style: normal;
  font-weight: 400;
}

.top-heading {
  font-family: Jost,sans-serif;
  font-size: 5rem;
  font-style: normal;
  font-weight: 600;
  letter-spacing: .1em;
  position: relative;
}

.top-heading::after {
  background-color: #000;
  bottom: -20px;
  content: '';
  height: 3px;
  left: 0;
  position: absolute;
  width: 30px;
}

.top-heading.center {
  text-align: center;
}

.top-heading.center::after {
  -webkit-transform: translateX(-50%);
  left: 50%;
  transform: translateX(-50%);
}

.top-heading.c-blue {
  color: #004381;
}

.top-heading.c-blue::after {
  background-color: #004381;
}

.top-heading.c-green {
  color: #138046;
}

.top-heading.c-green::after {
  background-color: #138046;
}

.top-heading.c-yellow {
  color: #f5ba13;
}

.top-heading.c-yellow::after {
  background-color: #f5ba13;
}

.about-page {
  background-color: #ececec;
  margin-bottom: 40px;
  overflow: hidden;
  padding: 120px 0;
}

.about-top {
  position: relative;
}

.about-top__decoration-circle {
  -webkit-transform: translateY(-50%);
  background-color: #fff343;
  border-radius: 50%;
  display: block;
  height: 240px;
  left: -24px;
  position: absolute;
  top: 60%;
  transform: translateY(-50%);
  width: 240px;
}

.about-top__decoration-pumpkin {
  -webkit-transform: translateY(-50%);
  display: block;
  height: 100%;
  position: absolute;
  right: -50px;
  top: 80%;
  transform: translateY(-50%);
  width: 380px;
}

.about-top__decoration-pumpkin img {
  display: block;
}

.about-top__container {
  margin-bottom: 80px;
  z-index: 1;
}

.about-top__container .txt-img img {
  display: block;
  margin: 0 auto;
  max-width: 500px;
}

.about-top__container .txt-area {
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 1.5px;
  line-height: 2.5;
  margin: 80px auto;
  position: relative;
  text-align: center;
  width: calc((100% / 12) * 10);
  z-index: 1;
}

.about-top__container .txt-logo {
  margin-top: -200px;
  position: relative;
  z-index: 0;
}

.about-top__container .txt-logo img {
  width: 100%;
}

.about-contents {
  margin-top: 120px;
}

.about-contents.gutter-top {
  margin-top: 120px;
}

.about-contents__container {
  position: relative;
}

.about-contents__container .contents01-title {
  -webkit-transform: translateY(-50%);
  left: calc((100% / 12) * 2.1);
  position: absolute;
  top: 70%;
  transform: translateY(-50%);
  width: 108px;
}

.about-contents__container .contents01-deco01 {
  position: absolute;
  right: calc((100% / 12) * -1.9);
  top: -160px;
  width: 419px;
}

.about-contents__container .contents01-deco2 {
  bottom: 0;
  left: -10px;
  position: absolute;
  width: 159px;
}

.about-contents__container .contents02-title {
  -webkit-transform: translateY(-50%);
  position: absolute;
  right: calc((100% / 12) * 2.1);
  top: 50%;
  transform: translateY(-50%);
  width: 108px;
  z-index: 2;
}

.about-contents__container .contents02-deco01 {
  position: absolute;
  right: 0;
  top: -30px;
  width: 203px;
}

.about-contents__container .contents02-deco02 {
  left: 0;
  position: absolute;
  top: -270px;
  width: 386px;
}

.about-contents__container .contents02-deco03 {
  bottom: 120px;
  position: absolute;
  right: -60px;
  width: 250px;
}

.about-contents__container .img-area {
  display: flex;
  flex-flow: nowrap;
}

.about-contents__container .img-area li {
  width: 50%;
}

.about-contents__container .img-area li.gutter-top {
  margin-top: 80px;
}

.about-contents__container .img-area.reverse {
  flex-flow: row-reverse;
  margin-top: 200px;
}

.about-contents__container .txt-area {
  margin-left: calc((100% / 12) * 4);
  margin-top: 120px;
  position: relative;
  width: calc((100% / 12) * 7);
}

.about-contents__container .txt-area__title {
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  margin-bottom: 40px;
}

.about-contents__container .txt-area__sentence {
  font-size: 2rem;
  line-height: 2.2;
}

.about-contents__container .txt-area.other-contents {
  margin-left: calc((100% / 12) * 1);
}

.about-link {
  margin: 120px auto 0 auto;
  width: calc((100% / 12) * 10);
}

.about-link__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.about-link__items {
  background-color: #fff;
  margin-bottom: 40px;
  padding-bottom: 30px;
  width: 48%;
}

.about-link__img {
  display: block;
}

.about-link__title {
  font-family: Jost,sans-serif;
  font-size: 5rem;
  font-style: normal;
  font-weight: 600;
  margin-top: 30px;
  text-align: center;
}

.about-link__link {
  margin: 20px auto 0 auto;
  width: 50px;
}

.philosophy {
  background-color: #002957;
  padding: 120px 0 180px 0;
  position: relative;
}

.philosophy__item {
  text-align: center;
}

.philosophy__item.gutter-top {
  margin-top: 80px;
}

.philosophy__title {
  color: #fff;
  font-size: 4rem;
  font-weight: 400;
  letter-spacing: .15em;
}

.philosophy__sub-title {
  color: #f5ba13;
  font-family: Jost,sans-serif;
  font-size: 2rem;
  font-style: normal;
  font-weight: 600;
  margin-top: 16px;
}

.philosophy__main-txt {
  color: #fff;
  margin-top: 24px;
}

.philosophy__main-txt em {
  display: block;
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: .2em;
  line-height: 1.75;
}

.philosophy__main-txt strong {
  display: block;
  font-family: Jost,sans-serif;
  font-size: 6rem;
  font-style: normal;
  font-weight: 600;
  margin-top: 16px;
}

.philosophy__logo {
  -webkit-transform: translateX(-50%);
  bottom: 0;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: calc((100% / 12) * 8);
  z-index: 2;
}

.top-message {
  background-color: #ececec;
  margin: 0 auto;
  padding-top: 80px;
}

.top-message__title {
  font-family: Jost,sans-serif;
  font-size: 8rem;
  font-style: normal;
  font-weight: 700;
  text-align: center;
}

.top-message__message-title {
  font-size: 4.5rem;
  font-weight: 700;
  letter-spacing: .1em;
  margin-top: 60px;
  text-align: center;
}

.top-message__name {
  color: #004380;
  font-size: 2.5rem;
  font-weight: 700;
  margin-top: 24px;
  text-align: center;
}

.top-message__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin: 56px auto;
  width: calc((100% / 12) * 10);
}

.top-message__items {
  font-size: 2rem;
  line-height: 1.75;
  width: 48%;
}

.top-message__img {
  width: 100%;
}

.company-page {
  background-color: #ececec;
  margin-bottom: 40px;
  padding: 40px 0 10px 0;
}

.company-info {
  margin: 80px auto;
  width: calc((100% / 12) * 10);
}

.company-info__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.company-info__items.-nav-container {
  width: 30%;
}

.company-info__items.-company-container {
  width: 65%;
}

.nav-company {
  position: sticky;
  top: 120px;
}

.nav-company__item {
  border-bottom: 1px solid #000;
}

.nav-company__item:nth-of-type(1) {
  border-top: 1px solid #000;
}

.nav-company__item a {
  color: #000;
  display: block;
  font-weight: 500;
  padding: 16px 0;
}

.nav-company__item a:hover {
  color: #f5ba13;
}

.nav-company__item span {
  cursor: pointer;
  display: block;
  padding: 16px 0;
  position: relative;
}

.nav-company__item span:hover {
  color: #f5ba13;
  cursor: pointer;
}

.nav-company__item span::after {
  -webkit-transform: translateY(-50%);
  content: "\f107";
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  position: absolute;
  right: 5px;
  top: 50%;
  transform: translateY(-50%);
}

.nav-company__item.current .list-link {
  color: #f5ba13;
  font-size: 2rem;
}

.nav-company__item.current span {
  color: #f5ba13;
  font-size: 2rem;
}

.nav-company__item.current_none .list-link {
  color: #000;
  font-size: 1.6rem;
}

.nav-company__inner-nav {
  display: none;
  margin-left: auto;
  padding-bottom: 10px;
  width: 90%;
}

.nav-company__inner-nav li {
  border-bottom: 1px solid #000;
  width: 100%;
}

.nav-company__inner-nav li:last-child {
  border-bottom: none;
}

.nav-company__inner-nav li a {
  display: block;
  padding: 16px 0;
}

.nav-company__inner-nav li.current-inner a {
  color: #daae34;
  font-size: 2rem;
}

.l-contents {
  margin-bottom: 40px;
  position: relative;
}

.l-contents__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin-bottom: 40px;
}

.l-contents__items.-title {
  width: 5%;
}

.l-contents__items.-title .contents-heading {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  color: #004380;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .2em;
  padding-top: 16px;
  position: relative;
  text-align: center;
  writing-mode: vertical-rl;
}

.l-contents__items.-title .contents-heading::before {
  -webkit-transform: translateX(-50%);
  background-color: #f3d345;
  content: '';
  height: 6px;
  left: 50%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 30px;
}

.l-contents__items.-container {
  background-color: #fff;
  width: 92%;
}

.l-contents__items.-container.company {
  padding: 30px;
}

.l-company {
  border-collapse: collapse;
  width: 100%;
}

.l-company tr:first-of-type {
  border-top: 1px solid #000;
}

.l-company tr td,
.l-company tr th {
  border-bottom: 1px solid #000;
  border-top: 1px solid #000;
  line-height: 1.75;
}

.l-company tr th {
  font-size: 1.4rem;
  font-weight: 600;
  padding: 8px 0;
  text-align: left;
  vertical-align: top;
  width: 30%;
}

.l-company tr td {
  font-size: 1.4rem;
  padding: 8px 0;
  width: 80%;
}

.l-company tr td p {
  margin-bottom: 8px;
}

.l-company tr td p:last-of-type {
  margin-bottom: 0;
}

.l-company.other tr:first-of-type {
  margin-top: none;
}

.l-company.other tr:last-of-type td .txt-area {
  border-bottom: none;
}

.l-company.other tr th {
  background-color: #004380;
  border: none;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 500;
  padding-left: 8px;
  width: 100%;
}

.l-company.other tr td {
  border: none;
  display: block;
  padding-bottom: 16px;
  width: 100%;
}

.l-company.other tr td .txt-area {
  border-bottom: 1px solid #000;
  padding-bottom: 16px;
  padding-top: 16px;
}

.l-company.other tr td .txt-area:first-of-type {
  padding-top: 8px;
}

.l-company.other tr td .txt-area .c-blue {
  color: #004380;
  font-weight: 700;
}

.l-company.other tr td .txt-area .indent {
  display: block;
  text-indent: 1em;
}

.conpany-info__data {
  padding: 24px;
}

.conpany-info__data .name {
  color: #004380;
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 8px;
}

.conpany-info__data .adress {
  line-height: 1.75;
}

.conpany-info__img {
  width: 100%;
}

.conpany-info__map {
  padding: 10px;
}

.l-company-list li {
  border-bottom: 1px solid #000;
  color: #004380;
  font-weight: 500;
  letter-spacing: 1.2px;
  padding: 10px 0;
}

.l-company-list li:first-child {
  border-top: 1px solid #000;
}

.l-company-list__item {
  padding: 0;
}

.l-company-list__item a {
  color: #000;
  display: block;
  font-weight: 700;
  padding: 10px 0;
  position: relative;
}

.l-company-list__item a::after {
  -webkit-transform: translateY(-50%);
  content: "\f105";
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  position: absolute;
  right: 5px;
  top: 50%;
  transform: translateY(-50%);
}

.contact-page {
  background-color: #eee;
  padding: 140px 0 80px 0;
}

.contact-form {
  margin: 80px auto 0 auto;
  width: calc((100% / 12) * 8);
}

.contact-form__heading {
  color: #004380;
  font-size: 3.5rem;
  font-weight: 700;
  text-align: center;
}

.contact-form .l-form {
  margin-top: 24px;
  width: 100%;
}

.contact-form .l-form__item {
  align-items: flex-start;
  display: flex;
  flex-flow: wrap;
}

.contact-form .l-form__item:nth-child(odd) {
  background-color: #fff;
}

.contact-form .l-form__items {
  padding: 24px 20px;
}

.contact-form .l-form__items.-title {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
  width: 40%;
}

.contact-form .l-form__items.-title span.badge {
  background-color: silver;
  color: #fff;
  margin-right: 16px;
  padding: 3px 10px;
  text-align: center;
}

.contact-form .l-form__items.-title span.txt {
  font-weight: 700;
}

.contact-form .l-form__items.-title span.required {
  background-color: #1c3070;
  color: #fff;
  margin-right: 16px;
  padding: 3px 10px;
  text-align: center;
}

.contact-form .l-form__items.-contents {
  width: 60%;
}

.contact-form .l-form__items.-contents .radio-list {
  display: flex;
  flex-flow: wrap;
}

.contact-form .l-form__items.-contents .radio-list p {
  margin-right: 16px;
}

.contact-form .l-form__items.-contents .radio-list p:last-of-type {
  margin-right: 0;
}

.contact-form .l-form__items.-contents .radio-list.row-100 {
  flex-flow: column;
}

.contact-form .l-form__items.-contents .radio-list.row-100 p {
  margin-bottom: 10px;
  margin-right: 0;
  width: 100%;
}

.contact-form .l-form__items.-contents .adress-post-code {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
  width: 50%;
}

.contact-form .l-form__items.-contents .adress-post-code span {
  padding: 0 5px;
}

.contact-form .l-form__items.-contents .adress-txt-area {
  margin-top: 16px;
}

.contact-form .l-form__items.-txt-area {
  padding: 0;
  width: 100%;
}

.contact-form .l-form__items .tel-area {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
  width: 70%;
}

.contact-form .l-form__items .tel-area span {
  padding: 0 5px;
}

.wpcf7-submit {
  background: #002957;
  border: 1px solid #002957;
  border-radius: 15px;
  color: #fff;
  cursor: pointer;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .2rem;
  margin: 64px auto 0 auto;
  max-width: 350px;
  padding: 20px 0;
  width: 100%;
}

.radio-input {
  display: none;
}

.radio-input+label {
  margin-right: 20px;
  padding-left: 20px;
  position: relative;
}

.radio-input+label::before {
  border: 1px solid #999;
  content: "";
  display: block;
  height: 15px;
  left: 0;
  position: absolute;
  top: 5px;
  width: 15px;
}

.radio-input:checked+label {
  color: #24668d;
}

.radio-input:checked+label::after {
  -webkit-transform: rotate(45deg);
  border-bottom: 3px solid #24668d;
  border-right: 3px solid #24668d;
  content: "";
  display: block;
  height: 10px;
  left: 5px;
  position: absolute;
  top: 5px;
  transform: rotate(45deg);
  width: 6px;
}

.check-btns input[type=checkbox]+label::after {
  -webkit-transform: rotate(45deg);
  border-bottom: 3px solid #24668d;
  border-right: 3px solid #24668d;
  content: '';
  display: block;
  height: 10px;
  left: 4px;
  opacity: 0;
  position: absolute;
  top: 0;
  transform: rotate(45deg);
  transition: .3s;
  width: 6px;
}

input[type=text] {
  width: 100%;
}

.form-control {
  background-color: #fff;
  background-image: none;
  border: 1px solid #ccc;
  border-radius: 8px;
  box-shadow: rgba(228,229,230,.2) 0 0 40px;
  color: #555;
  display: block;
  font-size: 14px;
  height: 34px;
  line-height: 1.42857143;
  margin: 0;
  padding: 6px 12px;
  transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
}

.form-control:focus {
  border-color: #66afe9;
  box-shadow: rgba(149,157,165,.2) 0 8px 24px;
  outline: 0;
}

.form-control.txt-area {
  height: auto;
  width: 100%;
}

.form-control.txt-area-enquiry {
  height: auto;
  width: 100%;
}

.contact-confirm {
  margin: 100px auto 0 auto;
  width: calc((100% / 12) * 8);
}

.contact-confirm__heading {
  color: #004380;
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: 64px;
  text-align: center;
}

.contact-confirm__item {
  display: flex;
  flex-flow: wrap;
  margin-bottom: 30px;
}

.contact-confirm__items.-title {
  width: 20%;
}

.contact-confirm__items.-detail {
  width: 80%;
}

.thanks {
  color: #004380;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.75;
  padding: 80px 0 24px 0;
  text-align: center;
}

.faq {
  padding: 80px 0 220px 0;
}

.faq__heading {
  color: #004380;
  font-size: 3.5rem;
  font-weight: 700;
  text-align: center;
}

.faq__item {
  margin: 64px auto 0 auto;
  width: calc((100% / 12) * 8);
}

.faq__title {
  background-color: orange;
  border-radius: 100px 100px 0 0;
  font-size: 1.8rem;
  font-weight: 700;
  height: 40px;
  line-height: 40px;
  text-align: center;
  width: 100%;
}

.faq__items {
  border-bottom: 1px solid orange;
  padding: 24px 0;
}

.faq__items .faq-list {
  align-items: flex-start;
  display: flex;
  flex-flow: nowrap;
  padding-left: 8px;
}

.faq__items .faq-list__item.-title {
  font-family: Jost,sans-serif;
  font-size: 4rem;
  font-style: normal;
  font-weight: 700;
}

.faq__items .faq-list__item.-title.question {
  color: #004380;
}

.faq__items .faq-list__item.-title.ansower {
  color: orange;
}

.faq__items .faq-list__item.-contents {
  line-height: 1.75;
  margin-left: 16px;
  padding-top: 12px;
}

.logo {
  background-color: #ececec;
  margin-bottom: 40px;
  overflow: hidden;
  padding-bottom: 0;
}

.logo__img {
  position: relative;
  width: 100%;
}

.logo__heading {
  -webkit-transform: translateY(-70%);
  background-color: #fff;
  font-family: Jost,sans-serif;
  font-size: 9.5rem;
  font-style: normal;
  font-weight: 500;
  left: calc((100% / 12) * 1);
  padding: 5px 16px;
  position: absolute;
  text-align: center;
  top: 70%;
  transform: translateY(-70%);
  z-index: 1;
}

.logo__top {
  padding-top: 300px;
  position: relative;
}

.logo__top::after {
  -webkit-transform: translateX(-50%);
  background: #ececec;
  border-radius: 250% 250% 0 0;
  content: '';
  height: 300px;
  left: 50%;
  position: absolute;
  top: -80px;
  transform: translateX(-50%);
  width: 120vw;
}

.logo__top .top-container {
  margin-top: -300px;
  position: relative;
  z-index: 1;
}

.logo__top .top-container::before {
  -webkit-transform: translateY(-50%);
  background-image: url(../../assets/images/logo/top-decoration.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 100%;
  left: -130px;
  position: absolute;
  top: 60%;
  transform: translateY(-50%);
  width: 356px;
}

.logo__top .top-container::after {
  -webkit-transform: translateY(-50%);
  background-image: url(../../assets/images/logo/top-decoration_01.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 100%;
  position: absolute;
  right: -130px;
  top: 60%;
  transform: translateY(-50%);
  width: 455px;
}

.logo__top .top-container .logo-img {
  margin-bottom: 60px;
}

.logo__top .top-container .logo-img img {
  display: block;
  margin: 0 auto;
  max-width: 430px;
}

.logo__top .top-container .txt-img img {
  display: block;
  margin: 0 auto;
  max-width: 700px;
}

.logo__top .top-container .txt-area {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.75;
  margin: 80px auto;
  position: relative;
  text-align: center;
  width: calc((100% / 12) * 10);
  z-index: 1;
}

.logo__top .top-container .txt-logo {
  margin-top: -200px;
  position: relative;
  z-index: 0;
}

.logo__top .top-container .txt-logo img {
  width: 100%;
}

.logo__explanation {
  margin-top: 120px;
  position: relative;
}

.logo__explanation::before {
  -webkit-transform: translateY(-50%);
  background-image: url(../../assets/images/logo/explanation-decoration_03.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 100%;
  left: -130px;
  position: absolute;
  top: 85%;
  transform: translateY(-50%);
  width: 310px;
}

.logo__explanation::after {
  -webkit-transform: translateY(-50%);
  background-image: url(../../assets/images/logo/explanation-decoration_04.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 100%;
  position: absolute;
  right: -130px;
  top: 90%;
  transform: translateY(-50%);
  width: 386px;
}

.logo__explanation .explanation-container {
  margin: 0 auto 120px auto;
  max-width: 1200px;
  position: relative;
  z-index: 1;
}

.logo__explanation .explanation-container.gutter-top {
  margin-top: 400px;
}

.logo__explanation .explanation-container__title {
  text-align: center;
}

.logo__explanation .explanation-container__title span {
  color: #e09000;
  display: inline-block;
  font-size: 3.5rem;
  font-weight: 700;
  padding-bottom: 8px;
  position: relative;
}

.logo__explanation .explanation-container__title span::after {
  -webkit-transform: translateX(-50%);
  background-color: #000;
  bottom: -8px;
  content: '';
  height: 2px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 100%;
}

.logo__explanation .explanation-container__txt {
  line-height: 1.75;
  margin-top: 64px;
  position: relative;
  z-index: 2;
}

.logo__explanation .explanation-container__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin-top: 64px;
}

.logo__explanation .explanation-container__items.-txt {
  font-size: 2rem;
  line-height: 2.2;
  width: 55%;
}

.logo__explanation .explanation-container__items.-img {
  width: 40%;
}

.logo__explanation .explanation-container__items.-btn {
  background-color: #f5ba13;
  border-radius: 40px;
  margin-top: 40px;
  width: 100%;
  width: 100%;
}

.logo__explanation .explanation-container__items.-btn a {
  color: #000;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  padding: 30px 0;
  position: relative;
  text-align: center;
}

.logo__explanation .explanation-container__items.-btn a::after {
  -webkit-transform: translateY(-50%);
  content: url(../../assets/images/logo/arrow.png);
  position: absolute;
  right: 100px;
  top: 48%;
  transform: translateY(-50%);
  z-index: 1;
}

.logo__explanation .explanation-decoration {
  position: relative;
  width: 100%;
}

.logo__explanation .explanation-decoration .left-img {
  left: 0;
  position: absolute;
  top: 0;
}

.logo__explanation .explanation-decoration .left-img img {
  max-width: 780px;
}

.logo__explanation .explanation-decoration .right-img {
  position: absolute;
  right: 0;
  top: -200px;
}

.logo__explanation .explanation-decoration .right-img img {
  max-width: 351px;
}

.news-top {
  width: 100%;
}

.news-top__kv img {
  display: block;
}

.news-top__news-bg {
  position: relative;
  width: 100%;
}

.news-top__news-bg::before {
  background-color: #f5ba13;
  content: '';
  display: block;
  display: block;
  height: 35px;
  left: 0;
  top: 0;
  width: 100%;
}

.news-top__news-bg::after {
  background-color: #002957;
  content: '';
  display: block;
  display: block;
  height: 65px;
  width: 100%;
}

.news-top__item {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
  height: 85px;
  margin: -89px auto 0 auto;
  position: relative;
  width: calc((100% / 12) * 10.5);
  z-index: 1;
}

.news-top__item.single-item {
  margin: 0 auto;
}

.news-top__items .heading-txt {
  background-color: #fff;
  font-family: Jost,sans-serif;
  font-size: 8rem;
  font-style: normal;
  font-weight: 600;
  padding: 0 20px;
  text-align: center;
}

.news-top__items .breadcrumb-list {
  display: flex;
  flex-flow: wrap;
  margin-left: 40px;
  margin-top: 24px;
}

.news-top__items .breadcrumb-list li {
  color: #fff;
  font-size: 1.4rem;
  font-weight: 600;
  margin-right: 40px;
  position: relative;
}

.news-top__items .breadcrumb-list li:last-child::after {
  content: none;
}

.news-top__items .breadcrumb-list li::after {
  -webkit-transform: translateY(-50%);
  color: #fff;
  content: "\f105";
  font-family: 'Font Awesome 5 Free';
  font-size: 2rem;
  font-style: normal;
  font-weight: 900;
  position: absolute;
  right: -24px;
  top: 50%;
  transform: translateY(-50%);
}

.news-top__items .breadcrumb-list li a {
  color: #fff;
}

.l-news-archive {
  background-color: #ececec;
  margin-bottom: 56px;
  padding: 80px 0 120px 0;
}

.l-news-archive__item {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin: 64px auto 0 auto;
  position: relative;
  width: calc((100% / 12) * 10);
}

.l-news-archive__item::after {
  background-color: #fff;
  bottom: -32px;
  content: '';
  height: 1px;
  position: absolute;
  right: 0;
  width: calc((100% / 9) * 5.5);
}

.l-news-archive__items a {
  color: #000;
  transition: opacity .3s;
}

.l-news-archive__items a:hover {
  opacity: .5;
}

.l-news-archive__items.-thumbnail {
  width: calc((100% / 9) * 3);
}

.l-news-archive__items.-thumbnail span {
  background-position: center;
  background-size: cover;
  display: block;
  transition: opacity .3s;
}

.l-news-archive__items.-thumbnail span::before {
  content: '';
  display: block;
  padding-top: 100%;
}

.l-news-archive__items.-thumbnail span:hover {
  opacity: .7;
}

.l-news-archive__items.-sentence {
  width: calc((100% / 9) * 5.5);
}

.l-news-archive__items.-sentence .archive-info {
  align-items: center;
  display: flex;
  flex-flow: wrap;
}

.l-news-archive__items.-sentence .archive-info__category {
  margin-right: 10px;
}

.l-news-archive__items.-sentence .archive-info__category span {
  color: #fff;
  display: inline-block;
  padding: 8px 48px;
  text-align: center;
}

.l-news-archive__items.-sentence .archive-info__category span.daily {
  background-color: #138046;
}

.l-news-archive__items.-sentence .archive-info__category span.news {
  background-color: #eea900;
}

.l-news-archive__items.-sentence .archive-info__category span.topic {
  background-color: #004380;
}

.l-news-archive__items.-sentence .archive-info__category span.holiday {
  background-color: #929292;
}

.l-news-archive__items.-sentence .archive-info__date {
  color: #004380;
  font-family: Jost,sans-serif;
  font-size: 2rem;
  font-style: normal;
  font-weight: 700;
}

.l-news-archive__items.-sentence .title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.75;
  margin-top: 10px;
  margin-top: 24px;
}

.l-news-archive__items.-sentence .title a {
  color: #000;
}

.l-news-archive__items.-sentence .txt-area {
  line-height: 1.75;
  margin-top: 24px;
}

.l-news-archive__items.-sentence .txt-area a {
  color: #000;
}

.l-news-archive__arrow-link {
  -webkit-transform: translateY(-50%);
  font-size: 2rem;
  position: absolute;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
}

.l-news-archive__arrow-link a {
  color: #9fa0a0;
}

.page-nav {
  display: flex;
  flex-flow: wrap;
  justify-content: center;
  margin: 120px 0;
}

.page-nav li a {
  color: #004380;
  display: block;
  font-family: Jost,sans-serif;
  font-size: 3rem;
  font-style: normal;
  font-weight: 600;
  padding: 0 24px;
  position: relative;
}

.page-nav li a::after {
  background-color: #004380;
  content: '';
  height: 100%;
  position: absolute;
  right: 0;
  width: 2px;
}

.page-nav li a::before {
  background-color: #f5ba13;
  content: '';
  height: 2px;
  left: 35%;
  position: absolute;
  top: 50%;
  transition: .5s;
  width: 0;
}

.page-nav li a:hover::before {
  content: '';
  width: 20px;
}

.page-nav li:last-child a::after {
  display: none;
}

.l-news-single {
  background-color: #ececec;
  margin-bottom: 56px;
  padding: 80px 0 120px 0;
}

.l-news-single__info .news-title {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.75;
}

.l-news-single__info .news-data {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin-top: 24px;
}

.l-news-single__info .news-data__items.-left {
  align-items: center;
  display: flex;
  flex-flow: wrap;
}

.l-news-single__info .news-data__items.-left .single-category {
  margin-right: 10px;
}

.l-news-single__info .news-data__items.-left .single-category span {
  color: #fff;
  display: inline-block;
  padding: 8px 48px;
  text-align: center;
}

.l-news-single__info .news-data__items.-left .single-category span.daily {
  background-color: #138046;
}

.l-news-single__info .news-data__items.-left .single-category span.news {
  background-color: #eea900;
}

.l-news-single__info .news-data__items.-left .single-category span.topic {
  background-color: #004380;
}

.l-news-single__info .news-data__items.-left .single-category span.holiday {
  background-color: #929292;
}

.l-news-single__info .news-data__items.-left .single-date {
  color: #004380;
  font-family: Jost,sans-serif;
  font-size: 2rem;
  font-style: normal;
  font-weight: 700;
}

.l-news-single__info .news-data__items.-right {
  display: flex;
  flex-flow: wrap;
}

.l-news-single__info .news-data__items.-right .sns-link {
  margin-right: 24px;
}

.l-news-single__info .news-data__items.-right .sns-link a {
  color: #000;
  font-size: 4rem;
}

.l-news-single__info .news-data__items.-right .sns-link:last-of-type {
  margin-right: 0;
}

.l-news-single__contents {
  border-bottom: 1px solid #000;
  margin: 40px 0 80px 0;
  padding-bottom: 64px;
}

.l-news-single__contents .heading-txt {
  font-size: 3rem;
  font-weight: 500;
  margin-top: 40px;
}

.l-news-single__contents p {
  line-height: 1.75;
  margin-top: 24px;
}

.l-news-single__page-feed .single-info {
  align-items: center;
  display: flex;
  flex-flow: wrap;
}

.l-news-single__page-feed .single-info__category {
  margin-right: 10px;
}

.l-news-single__page-feed .single-info__category span {
  color: #fff;
  display: inline-block;
  padding: 8px 48px;
  text-align: center;
}

.l-news-single__page-feed .single-info__category span.daily {
  background-color: #138046;
}

.l-news-single__page-feed .single-info__category span.news {
  background-color: #eea900;
}

.l-news-single__page-feed .single-info__category span.topic {
  background-color: #004380;
}

.l-news-single__page-feed .single-info__category span.holiday {
  background-color: #929292;
}

.l-news-single__page-feed .single-info__text {
  font-size: 1.6rem;
}

.l-news-single__page-feed .single-page-nav {
  display: flex;
  flex-flow: column;
  margin-top: 24px;
}

.l-news-single__page-feed .single-page-nav li {
  background-color: #fff;
  border: 1px solid #000;
  margin-bottom: 8px;
  width: 100%;
}

.l-news-single__page-feed .single-page-nav li a {
  color: #000;
  display: block;
  font-size: 2rem;
  padding: 16px 0 16px 40px;
  position: relative;
}

.l-news-single__page-feed .single-page-nav li.prev a::before {
  -webkit-transform: translateY(-50%);
  content: "\f104";
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  left: 16px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.l-news-single__page-feed .single-page-nav li.next a::before {
  -webkit-transform: translateY(-50%);
  content: "\f105";
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  left: 16px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.privacy {
  background-color: #ececec;
  margin-bottom: 40px;
  padding: 80px 0 120px 0;
}

.privacy p {
  font-size: 2rem;
  line-height: 1.75;
  margin-bottom: 24px;
}

.privacy__item {
  margin: 0 auto;
  width: calc((100% / 12) * 10);
}

.recruit-page {
  background-color: #ececec;
  margin-bottom: 64px;
  overflow: hidden;
  padding: 120px 0 80px 0;
}

.recruit-info {
  margin: 0 auto;
  padding: 80px 0 200px 0;
  position: relative;
  width: calc((100% / 12) * 10);
}

.recruit-info::after {
  -webkit-transform: translateY(-50%);
  background-color: #fff343;
  border-radius: 50%;
  content: '';
  height: 204px;
  position: absolute;
  right: calc((100% / 12) * -2.3);
  top: 50%;
  transform: translateY(-50%);
  width: 204px;
}

.recruit-info::before {
  -webkit-transform: translateY(50%);
  background-image: url(../../assets/images/recruit/wave.png);
  background-size: cover;
  bottom: 50%;
  content: '';
  height: 134px;
  left: calc((100% / 12) * -1.8);
  position: absolute;
  transform: translateY(50%);
  width: 201px;
}

.recruit-info__title .shape {
  text-align: center;
}

.recruit-info__title .heading {
  color: #e09000;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.75;
  position: relative;
  text-align: center;
}

.recruit-info__title .heading::before {
  background-image: url(../../assets/images/recruit/shape.png);
  background-size: cover;
  content: '';
  display: block;
  display: block;
  height: 77px;
  margin: 0 auto 20px auto;
  width: 97px;
}

.recruit-info__contents {
  color: #e09000;
  line-height: 1.75;
  margin-top: 40px;
  text-align: center;
}

.voice-list {
  position: relative;
}

.voice-list.gutter-top {
  margin-top: 90px;
}

.voice-list::before {
  background-color: #fff343;
  border-radius: 50%;
  content: '';
  height: 367px;
  position: absolute;
  width: 367px;
}

.voice-list.list01::before {
  bottom: -50px;
  content: '';
  right: -150px;
}

.voice-list.list02::before {
  content: '';
  left: -80px;
  top: -100px;
}

.voice-list.list03::before {
  bottom: -300px;
  content: '';
  left: -40px;
  z-index: 1;
}

.voice-list.list04::before {
  bottom: -200px;
  content: '';
  right: 40px;
}

.voice-list__item {
  background-color: #fff;
  padding: 24px;
  position: relative;
  z-index: 1;
}

.voice-list__item.list01 {
  margin-left: calc((100% / 12) * 2);
  width: calc((100% / 12) * 9);
}

.voice-list__item.list02 {
  margin-left: calc((100% / 12) * 1);
  width: calc((100% / 12) * 9);
}

.voice-list__img {
  position: absolute;
  width: 493px;
}

.voice-list__img.list01 {
  left: -90px;
  top: -80px;
}

.voice-list__img.list02 {
  right: -120px;
  top: 40px;
}

.voice-list__img.list03 {
  left: -120px;
  top: -20px;
}

.voice-list__img.list04 {
  right: -120px;
  top: -20px;
}

.voice-list__title {
  color: #e09000;
  font-size: 3.2rem;
  font-weight: 500;
  letter-spacing: 1.5px;
  line-height: 1.5;
  margin-bottom: 16px;
}

.voice-list__txt {
  font-size: 1.8rem;
  line-height: 2;
}

.recruitment-container {
  background-color: #ececec;
  margin-top: 240px;
  padding-bottom: 40px;
  width: 100%;
}

.recruitment-container__info {
  margin: -40px auto 0 auto;
  position: relative;
  width: calc((100% / 12) * 10);
  z-index: 1;
}

.recruitment-container__box {
  background-color: #fff;
}

.recruitment-container__box.transparent {
  background-color: rgba(255,255,255,.8);
}

.recruitment-container__box.padding-layout {
  padding: 50px;
}

.recruitment-container__box.gutter-top {
  margin-top: 30px;
}

.recruitment-container__box.gutter-more-top {
  margin-top: 96px;
}

.recruitment-container__box .info-contents01 {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.recruitment-container__box .info-contents01__item.-img-area {
  width: 28%;
}

.recruitment-container__box .info-contents01__item.-txt-area {
  width: 70%;
}

.recruitment-container__box .info-contents01__item.-txt-area .title {
  color: #e09000;
  font-size: 4rem;
  font-weight: 700;
}

.recruitment-container__box .info-contents01__item.-txt-area .txt {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.75;
  margin-top: 16px;
}

.recruitment-container__box .info-contents02 .point-title {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
}

.recruitment-container__box .info-contents02 .point-title__item.-point {
  color: #e09000;
  font-family: Jost,sans-serif;
  font-size: 5.5rem;
  font-style: normal;
  font-weight: 600;
  padding-right: 30px;
  position: relative;
}

.recruitment-container__box .info-contents02 .point-title__item.-title {
  color: #e09000;
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: -.8px;
  line-height: 1.5;
  padding-left: 40px;
  position: relative;
}

.recruitment-container__box .info-contents02 .point-title__item.-title::before {
  -webkit-transform: translateY(-50%);
  background-color: #e09000;
  content: '';
  height: 90%;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
}

.recruitment-container__box .info-contents02 .detail {
  letter-spacing: .15em;
  line-height: 1.75;
  margin-top: 40px;
}

.recruitment-container__box .info-contents02 .detail span {
  display: inline-block;
  font-weight: 500;
  margin-right: 2rem;
}

.recruitment-container__box .info-contents03__item.-main-area .title {
  color: #e09000;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}

.recruitment-container__box .info-contents03__item.-main-area .txt {
  font-size: 2rem;
  font-weight: 500;
  line-height: 2;
  margin-top: 40px;
}

.recruitment-container__box .info-contents03__item.-main-area .txt.center {
  text-align: center;
}

.recruitment-container__box .info-contents03__item.-sub-area {
  margin-top: 80px;
}

.recruitment-container__box .info-contents03__item.-sub-area .title {
  color: #e09000;
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
}

.recruitment-container__box .info-contents03__item.-sub-area .txt {
  font-size: 2rem;
  line-height: 1.75;
  margin-top: 32px;
}

.recruitment-container__panel {
  margin-top: 24px;
  position: relative;
}

.recruitment-container__panel.csr-top {
  padding-bottom: 120px;
}

.recruitment-container__panel .card-list {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.recruitment-container__panel .card-list__item {
  margin-top: 40px;
  width: 48%;
}

.recruitment-container__panel .card-list__item.align-bottom {
  display: flex;
  flex-direction: column;
}

.recruitment-container__panel .card-list__title {
  background-color: #e09000;
  color: #fff;
  font-size: 2.5rem;
  line-height: 1.5;
  padding: 10px 0 10px 16px;
}

.recruitment-container__panel .card-list__title span {
  display: none;
}

.recruitment-container__panel .card-list__details {
  padding-top: 16px;
  position: relative;
}

.recruitment-container__panel .card-list__details .txt-area {
  margin-bottom: 24px;
}

.recruitment-container__panel .card-list__details .txt-area .title {
  color: #004c88;
  font-size: 1.8rem;
  font-weight: 700;
}

.recruitment-container__panel .card-list__details .txt-area .txt {
  line-height: 1.75;
  margin-top: 8px;
}

.recruitment-container__panel .card-list__details .img-area {
  display: none;
}

.recruitment-container__panel .card-list__img {
  margin-top: auto;
}

.recruitment-container__csr-img {
  bottom: 0;
  left: -16px;
  position: absolute;
  width: 583px;
}

.recruitment-container__other {
  display: flex;
  flex-flow: wrap;
  margin: 40px auto 0 auto;
  width: calc((100% / 12) * 9.5);
}

.recruitment-container__other li {
  line-height: 2.2;
  width: 50%;
}

.apply-btn {
  background-color: #e09000;
  border-radius: 70px;
  margin-top: 40px;
  width: 100%;
  width: 100%;
}

.apply-btn a {
  color: #fff;
  display: block;
  font-size: 4rem;
  font-weight: 700;
  padding: 40px 0;
  position: relative;
  text-align: center;
}

.apply-btn a::after {
  -webkit-transform: translateY(-50%);
  content: url(../../assets/images/recruit/recruitment/arrow.png);
  position: absolute;
  right: 40px;
  top: 38%;
  transform: translateY(-50%);
  z-index: 1;
}

.sdgs-page {
  margin-bottom: 64px;
  overflow: hidden;
}

.sdgs-top-container {
  background-color: #ececec;
  padding: 120px 0 24px 0;
  width: 100%;
}

.sdgs-info {
  margin: 0 auto;
  padding: 80px 0 200px 0;
  width: calc((100% / 12) * 10);
}

.sdgs-info__title .shape {
  text-align: center;
}

.sdgs-info__title .heading {
  color: #008d3d;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.75;
  position: relative;
  text-align: center;
}

.sdgs-info__title .heading::before {
  background-image: url(../../assets/images/sdgs/shape.png);
  background-size: cover;
  content: '';
  display: block;
  display: block;
  height: 75px;
  margin: 0 auto 20px auto;
  width: 46px;
}

.sdgs-info__contents {
  color: #008d3d;
  line-height: 2.2;
  margin-top: 40px;
  text-align: center;
}

.sdgs-info__img-title {
  margin-top: 60px;
  position: relative;
  text-align: center;
}

.sdgs-info__img-title::before {
  -webkit-transform: translateY(-50%);
  background-image: url(../../assets/images/sdgs/info/title_deco-left.png);
  background-size: cover;
  content: '';
  height: 128px;
  left: calc((100% / 12) * -.75);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 128px;
}

.sdgs-info__img-title::after {
  -webkit-transform: translateY(-50%);
  background-image: url(../../assets/images/sdgs/info/title_deco-right.png);
  background-size: cover;
  content: '';
  height: 192px;
  position: absolute;
  right: calc((100% / 12) * -1);
  top: 50%;
  transform: translateY(-50%);
  width: 192px;
}

.sdgs-info__img-title span {
  display: block;
  margin: 0 auto;
  width: 300px;
}

.sdgs-info__concept {
  margin-top: 80px;
}

.efforts__container {
  background-color: #fff;
  margin: -80px auto 0 auto;
  padding: 80px 0 0 0;
  position: relative;
  width: calc((100% / 12) * 10);
  z-index: 1;
}

.efforts__heading {
  color: #008d3d;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}

.efforts__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.efforts__items {
  display: flex;
  flex-direction: column;
  margin-top: 80px;
  width: 48%;
}

.efforts__title {
  align-items: center;
  color: #008d3d;
  display: flex;
  flex-flow: nowrap;
}

.efforts__title .number {
  font-family: Jost,sans-serif;
  font-size: 10rem;
  font-style: normal;
  font-style: italic;
  font-weight: 300;
}

.efforts__title .detail {
  font-size: 2.7rem;
  line-height: 1.5;
  margin-left: 24px;
}

.efforts__contents {
  font-size: 2rem;
  line-height: 1.75;
  margin: 0 0 24px 0;
}

.efforts__sdgs-list {
  display: flex;
  flex-flow: nowrap;
  justify-content: center;
  margin-top: auto;
}

.efforts__sdgs-list span {
  padding: 0 5px;
  width: 30%;
}

.efforts__sdgs-list span img {
  width: 120px;
}

.efforts__hand {
  margin-top: 80px;
}

.efforts__hand img {
  display: block;
  margin: 0 auto;
  width: 785px;
}

.csr-container {
  background-color: #ececec;
  padding-bottom: 40px;
  width: 100%;
}

.csr-container.gutter-top {
  margin-top: 120px;
}

.csr-container__info {
  margin: -40px auto 0 auto;
  position: relative;
  width: calc((100% / 12) * 10);
  z-index: 1;
}

.csr-container__box {
  background-color: #fff;
}

.csr-container__box.transparent {
  background-color: rgba(255,255,255,.8);
}

.csr-container__box.padding-layout {
  padding: 50px;
}

.csr-container__box.gutter-top {
  margin-top: 30px;
}

.csr-container__box.gutter-more-top {
  margin-top: 96px;
}

.csr-container__box .info-contents01 {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.csr-container__box .info-contents01__item.-img-area {
  width: 28%;
}

.csr-container__box .info-contents01__item.-txt-area {
  width: 70%;
}

.csr-container__box .info-contents01__item.-txt-area .title {
  color: #008d3d;
  font-size: 4rem;
  font-weight: 700;
}

.csr-container__box .info-contents01__item.-txt-area .txt {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.75;
  margin-top: 16px;
}

.csr-container__box .info-contents02 .point-title {
  align-items: center;
  display: flex;
  flex-flow: wrap;
}

.csr-container__box .info-contents02 .point-title__item.-point {
  color: #008d3d;
  font-family: Jost,sans-serif;
  font-size: 5.5rem;
  font-style: normal;
  font-weight: 600;
  padding-right: 40px;
  position: relative;
}

.csr-container__box .info-contents02 .point-title__item.-title {
  color: #008d3d;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  padding-left: 40px;
  position: relative;
}

.csr-container__box .info-contents02 .point-title__item.-title::before {
  -webkit-transform: translateY(-50%);
  background-color: #008d3d;
  content: '';
  height: 90%;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
}

.csr-container__box .info-contents02 .detail {
  letter-spacing: .15em;
  line-height: 1.75;
  margin-top: 16px;
}

.csr-container__box .info-contents03__item.-main-area .title {
  color: #008d3d;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}

.csr-container__box .info-contents03__item.-main-area .txt {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.75;
  margin-top: 40px;
}

.csr-container__box .info-contents03__item.-main-area .txt.center {
  text-align: center;
}

.csr-container__box .info-contents03__item.-sub-area {
  margin-top: 80px;
}

.csr-container__box .info-contents03__item.-sub-area .title {
  color: #008d3d;
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
}

.csr-container__box .info-contents03__item.-sub-area .txt {
  font-size: 2rem;
  line-height: 1.75;
  margin-top: 32px;
}

.csr-container__box .column-contents {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.csr-container__box .column-contents__item.-txt-contents {
  padding: 40px 50px;
  width: 70%;
}

.csr-container__box .column-contents__item.-img-contents {
  width: 25%;
}

.csr-container__panel {
  margin-top: 24px;
  position: relative;
}

.csr-container__panel.csr-top {
  padding-bottom: 120px;
}

.csr-container__panel .card-list {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.csr-container__panel .card-list__item {
  margin-bottom: 40px;
  width: 48%;
}

.csr-container__panel .card-list__item.align-bottom {
  display: flex;
  flex-direction: column;
}

.csr-container__panel .card-list__title {
  background-color: #008d3d;
  color: #fff;
  font-size: 2.5rem;
  line-height: 1.5;
  padding: 10px 0 10px 16px;
}

.csr-container__panel .card-list__title span {
  display: none;
}

.csr-container__panel .card-list__details {
  padding-top: 16px;
  position: relative;
}

.csr-container__panel .card-list__details .txt-area {
  font-size: 1.5rem;
  line-height: 1.75;
  margin-bottom: 24px;
}

.csr-container__panel .card-list__details .txt-area.top-gutter-minus {
  margin-top: -470px;
}

.csr-container__panel .card-list__details .img-area {
  display: none;
}

.csr-container__panel .card-list__img {
  margin-top: auto;
}

.csr-container__csr-img {
  bottom: 0;
  left: -16px;
  position: absolute;
  width: 583px;
}

.csr-container__other {
  display: flex;
  flex-flow: wrap;
  margin: 40px auto 0 auto;
  width: calc((100% / 12) * 9.5);
}

.csr-container__other li {
  line-height: 2.2;
  width: 50%;
}

.csr-panel-container {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.csr-panel-container__item {
  width: 48%;
}

.service-page {
  background-color: #ececec;
  margin-bottom: 64px;
  padding: 120px 0 24px 0;
}

.service-top {
  margin: 0 auto;
  padding: 80px 0;
  width: calc((100% / 12) * 10);
}

.service-top__title .shape {
  text-align: center;
}

.service-top__title .heading {
  color: #004c88;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.75;
  position: relative;
  text-align: center;
}

.service-top__title .heading::before {
  background-image: url(../../assets/images/service/shape.png);
  background-size: cover;
  content: '';
  display: block;
  display: block;
  height: 69px;
  margin: 0 auto 20px auto;
  width: 80px;
}

.service-top__contents {
  color: #004c88;
  line-height: 2;
  margin-top: 40px;
}

.service-container {
  padding-bottom: 40px;
  width: 100%;
}

.service-container.gutter-top {
  margin-top: 120px;
}

.service-container__img {
  position: relative;
}

.service-container__img.txt-img::after {
  background-image: url(../../assets/images/service/anniversary.png);
  background-size: cover;
  bottom: 40px;
  content: '';
  height: 153px;
  position: absolute;
  right: 0;
  width: 502px;
}

.service-container__info {
  margin: -40px auto 0 auto;
  position: relative;
  width: calc((100% / 12) * 10);
  z-index: 1;
}

.service-container__box {
  background-color: #fff;
}

.service-container__box.transparent {
  background-color: rgba(255,255,255,.8);
}

.service-container__box.padding-layout {
  padding: 50px;
}

.service-container__box.gutter-top {
  margin-top: 40px;
}

.service-container__box.gutter-more-top {
  margin-top: 40px;
}

.service-container__box .info-contents01 {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.service-container__box .info-contents01__item.-img-area {
  width: 28%;
}

.service-container__box .info-contents01__item.-txt-area {
  width: 70%;
}

.service-container__box .info-contents01__item.-txt-area .title {
  color: #004c88;
  font-size: 4rem;
  font-weight: 700;
}

.service-container__box .info-contents01__item.-txt-area .txt {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.75;
  margin-top: 16px;
}

.service-container__box .info-contents02 .point-title {
  align-items: center;
  display: flex;
  flex-flow: nowrap;
}

.service-container__box .info-contents02 .point-title__item.-point {
  color: #004c88;
  font-family: Jost,sans-serif;
  font-size: 5.5rem;
  font-style: normal;
  font-weight: 600;
  padding-right: 40px;
  position: relative;
}

.service-container__box .info-contents02 .point-title__item.-title {
  color: #004c88;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  padding-left: 40px;
  position: relative;
}

.service-container__box .info-contents02 .point-title__item.-title::before {
  -webkit-transform: translateY(-50%);
  background-color: #004c88;
  content: '';
  height: 90%;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
}

.service-container__box .info-contents02 .detail {
  line-height: 2;
  margin-top: 16px;
}

.service-container__box .info-contents02 .detail .column {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.service-container__box .info-contents02 .detail .column__item.-txt {
  width: 70%;
}

.service-container__box .info-contents02 .detail .column__item.-img {
  width: 30%;
}

.service-container__box .info-contents03__item.-main-area .title {
  color: #004c88;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}

.service-container__box .info-contents03__item.-main-area .txt {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.75;
  margin-top: 40px;
}

.service-container__box .info-contents03__item.-main-area .txt.center {
  text-align: center;
}

.service-container__box .info-contents03__item.-sub-area {
  margin-top: 80px;
}

.service-container__box .info-contents03__item.-sub-area .title {
  color: #004c88;
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
}

.service-container__box .info-contents03__item.-sub-area .txt {
  font-size: 2rem;
  line-height: 1.75;
  margin-top: 32px;
}

.service-container__box .column-contents {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.service-container__box .column-contents__item.-txt-contents {
  padding: 40px 50px;
  width: 70%;
}

.service-container__box .column-contents__item.-img-contents {
  width: 25%;
}

.service-container__panel {
  margin-top: 30px;
}

.service-container__panel .card-list {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
}

.service-container__panel .card-list__item {
  margin-bottom: 40px;
  width: 48.5%;
}

.service-container__panel .card-list__item.align-bottom {
  display: flex;
  flex-direction: column;
}

.service-container__panel .card-list__title {
  background-color: #004c88;
  color: #fff;
  font-size: 2.5rem;
  line-height: 1.5;
  padding: 10px 0 10px 16px;
}

.service-container__panel .card-list__title span {
  display: none;
}

.service-container__panel .card-list__details {
  padding-top: 16px;
  position: relative;
}

.service-container__panel .card-list__details .sub-title {
  color: #004c88;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.75;
  margin-bottom: 16px;
}

.service-container__panel .card-list__details .txt-area {
  font-size: 1.5rem;
  line-height: 1.75;
  margin-bottom: 24px;
}

.service-container__panel .card-list__details .txt-area.top-gutter-minus {
  margin-top: -470px;
}

.service-container__panel .card-list__details .img-area {
  display: none;
}

.service-container__panel .card-list__details .ff {
  display: block;
  float: right;
  margin-top: -30px;
  padding: 10px;
  width: 140px;
}

.service-container__panel .card-list__img {
  margin-top: auto;
}

.service-container__other {
  display: flex;
  flex-flow: wrap;
  margin: 40px auto 0 auto;
  width: calc((100% / 12) * 9.5);
}

.service-container__other li {
  line-height: 2.2;
  width: 50%;
}

.service-flow {
  background-color: #fff;
  padding: 80px 0;
}

.service-flow__item {
  margin: 0 auto;
  width: calc((100% / 12) * 10);
}

.service-flow__title {
  color: #004c88;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}

.service-flow__txt {
  font-size: 2rem;
  font-weight: 700;
  margin-top: 20px;
  text-align: center;
}

.service-flow__img {
  margin-top: 40px;
}

.service-flow__flow-txt {
  font-size: 100%;
  margin-top: 40px;
}

.mv {
  margin-top: 100px;
  overflow: hidden;
  position: relative;
  width: 100%;
}

.mv img {
  -o-object-fit: cover;
  height: calc(100vh - 100px);
  object-fit: cover;
}

.mv .swiper-wrapper {
  transition-timing-function: linear!important;
}

.mv .swiper-slide img {
  border-radius: 10px;
}

.mv__item {
  bottom: 64px;
  left: calc((100% / 12) * 1);
  position: absolute;
  z-index: 1;
}

.mv__items {
  margin-bottom: 8px;
}

.mv__items:last-of-type {
  margin-bottom: 0;
}

.mv__items .txt-contents {
  background-color: #fff;
  display: inline-block;
}

.mv__items .txt-contents.bg {
  position: relative;
}

.mv__items .txt-contents.bg::before {
  background-color: #fff343;
  content: '';
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100px;
  z-index: 1;
}

.mv__items .txt-contents span {
  font-family: Jost,sans-serif;
  font-size: 9.5rem;
  font-style: normal;
  font-weight: 600;
  padding: 16px 20px;
  position: relative;
  z-index: 1;
}

.mv__items .txt-contents span.ja {
  display: inline-block;
  font-family: 'Noto Sans JP',sans-serif;
  font-size: 2rem;
  font-style: normal;
  font-weight: 400;
  font-weight: 700;
  letter-spacing: .1em;
  padding: 16px 20px;
}

.concept {
  background-image: url(../../assets/images/top/concept/concept-bg.jpg);
  background-size: cover;
  height: 100%;
  margin-top: 60px;
  padding: 80px 0;
  width: 100%;
}

.concept__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin: 0 auto;
  width: calc((100% / 12) * 10);
}

.concept__items.-txt {
  width: calc((100% / 10) * 5.2);
}

.concept__items.-img {
  width: calc((100% / 10) * 4);
}

.concept__items .sub-title {
  font-size: 5rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 80px;
}

.concept__items .txt-area {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .1rem;
  line-height: 2;
  margin-top: 50px;
}

.concept__items .txt-area.gutter-bottom {
  margin-bottom: 50px;
}

.concept__btn-mb {
  display: none;
}

.news {
  padding: 80px 0 0 0;
}

.news__item {
  margin-left: calc((100% / 12) * .5);
  margin-top: 60px;
  overflow: hidden;
  width: calc((100% / 12) * 11.5);
}

.news__item a {
  color: #000;
  transition: opacity .3s;
}

.news__item a:hover {
  opacity: .5;
}

.news__item .thumbnail span {
  background-position: center;
  background-size: cover;
  display: block;
  transition: opacity .3s;
}

.news__item .thumbnail span::before {
  content: '';
  display: block;
  padding-top: 100%;
}

.news__item .thumbnail span:hover {
  opacity: .7;
}

.news__item .contents-top {
  align-items: center;
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  margin-top: 8px;
}

.news__item .contents-top .category {
  color: #fff;
  display: inline-block;
  padding: 8px 48px;
  text-align: center;
}

.news__item .contents-top .category.daily {
  background-color: #138046;
}

.news__item .contents-top .category.news {
  background-color: #eea900;
}

.news__item .contents-top .category.topic {
  background-color: #004380;
}

.news__item .contents-top .category.holiday {
  background-color: #929292;
}

.news__item .contents-top .date {
  color: #004380;
  font-family: Jost,sans-serif;
  font-size: 1.5rem;
  font-style: normal;
  font-weight: 600;
}

.news__item .contents-bottom {
  margin-top: 30px;
}

.news__item .contents-bottom .title {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6;
}

.news__item .contents-bottom .txt-area {
  font-size: 1.2rem;
  line-height: 1.75;
  margin-top: 10px;
}

.news__more {
  margin-top: 100px;
  position: relative;
}

.news__more .circle {
  -webkit-transform: translateX(-50%);
  background-color: #ececec;
  border-radius: 50%;
  height: 82px;
  left: 50%;
  position: absolute;
  top: -40px;
  transform: translateX(-50%);
  width: 82px;
}

.news__more .btn {
  -webkit-transform: translateX(-50%);
  background-color: #fff;
  border-radius: 50%;
  display: block;
  height: 72px;
  left: 50%;
  line-height: 80px;
  position: absolute;
  text-align: center;
  top: 5px;
  transform: translateX(-50%);
  width: 72px;
  z-index: 1;
}

.news__more .btn i {
  font-size: 3rem;
}

.news__more .link-txt {
  -webkit-transform: translateX(-50%);
  color: #004380;
  font-family: ttnorms_bold;
  font-weight: 700;
  left: 50%;
  position: absolute;
  text-align: center;
  top: 60px;
  transform: translateX(-50%);
  width: 100%;
}

.news__more .link-txt a {
  color: #004380;
}

.news-slider__pagination {
  margin-top: 60px;
  position: relative;
  text-align: center;
}

.news-slider__pagination.swiper-pagination-progressbar {
  background: rgba(0,0,0,.205);
  height: 5px;
  position: relative;
  width: calc((100% / 12) * 11.5);
}

.news-slider__pagination.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #f5ba13;
  height: 5px;
  width: calc((100% / 12) * 11.5);
}

.company {
  overflow: hidden;
  position: relative;
  width: 100%;
}

.company .swiper-wrapper {
  transition-timing-function: linear!important;
}

.company .swiper-wrapper img {
  display: block;
}

.company__item {
  -webkit-transform: translate(-50%,-50%);
  background-color: #fff;
  left: 50%;
  max-width: 400px;
  padding: 40px 0;
  position: absolute;
  text-align: center;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 100%;
  z-index: 3;
}

.company__item .txt-area {
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.75;
  margin-top: 60px;
}

.company__item .link-area {
  margin-top: 24px;
}

.company__item .link-area img {
  width: 80px;
}

.company__item .link-txt {
  margin-top: 8px;
}

.company__item .link-txt a {
  color: #004380;
  font-family: ttnorms_bold,sans-serif;
  font-style: normal;
  text-align: center;
}

.contents {
  background-color: #cde3ee;
  margin-bottom: 100px;
  margin-top: -70px;
  overflow: hidden;
  padding-bottom: 240px;
}

.contents__logo {
  position: relative;
  z-index: 2;
}

.contents__logo img {
  width: 100%;
}

.contents__item {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  justify-content: flex-end;
  margin-top: 100px;
  position: relative;
  width: 100%;
}

.contents__item.top-gutter {
  margin-top: 80px;
}

.contents__item.reverse {
  justify-content: flex-start;
}

.contents__item.reverse .reverse-container {
  padding-left: calc((100% / 5.25) * .6);
}

.contents__item.reverse .-txt-wrap {
  left: calc((100% / 12) * 6);
}

.contents__items.-txt-wrap {
  bottom: -80px;
  left: calc((100% / 12) * .5);
  position: absolute;
  width: calc((100% / 12) * 5.25);
  z-index: 2;
}

.contents__items.-img-wrap {
  position: relative;
  width: calc((100% / 12) * 6.8);
}

.contents__items.-img-wrap .img-container {
  position: relative;
  z-index: 1;
}

.contents__txt-container {
  background-color: rgba(255,255,255,.747);
  padding-bottom: 40px;
  padding-left: calc((100% / 5.25) * .4);
  padding-right: calc((100% / 5.25) * .8);
  padding-top: 40px;
}

.contents__txt {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.8;
  margin-top: 64px;
}

.contents__btn {
  margin-top: 40px;
}

.contents .service-decoration-wrap-pc01 {
  left: -90px;
  position: absolute;
  top: -180px;
  z-index: -2;
}

.contents .service-decoration-wrap-pc01 img {
  display: block;
  width: 290px;
}

.contents .service-decoration-wrap-mb01 {
  bottom: 0;
  position: absolute;
  right: calc((100% / 12) * -2);
  z-index: 1;
}

.contents .service-decoration-wrap-mb01 img {
  display: block;
  width: 150px;
}

.contents .service-decoration-wrap-pc02 {
  bottom: 0;
  position: absolute;
  right: 0;
  z-index: 1;
}

.contents .service-decoration-wrap-pc02 img {
  display: block;
  margin-left: auto;
  width: 219px;
}

.contents .service-decoration-wrap-mb02 {
  left: -80px;
  position: absolute;
  top: -40px;
  z-index: 0;
}

.contents .service-decoration-wrap-mb02 img {
  display: block;
  margin-left: auto;
  width: 219px;
}

.contents .sdgs-decoration-wrap-pc01 {
  left: 20%;
  position: absolute;
  top: -50%;
  z-index: -1;
}

.contents .sdgs-decoration-wrap-pc01 img {
  display: block;
  width: 252px;
}

.contents .sdgs-decoration-wrap-mb {
  left: 40px;
  position: absolute;
  top: -40px;
  z-index: 0;
}

.contents .sdgs-decoration-wrap-mb img {
  display: block;
  width: 120px;
}

.contents .sdgs-decoration-wrap-pc02 {
  bottom: -40px;
  position: absolute;
  right: calc((100% / 12) * -2);
  z-index: 1;
}

.contents .sdgs-decoration-wrap-pc02 img {
  display: block;
  width: 203px;
}

.contents .recruit-decoration-wrap-pc01 {
  left: 150px;
  position: absolute;
  top: -270px;
  z-index: -1;
}

.contents .recruit-decoration-wrap-pc01 img {
  display: block;
  width: 284px;
}

.contents .recruit-decoration-wrap-pc02 {
  bottom: 0;
  position: absolute;
  right: -100px;
  z-index: 1;
}

.contents .recruit-decoration-wrap-pc02 img {
  display: block;
  width: 174px;
}

.contents .recruit-decoration-wrap-pc03 {
  bottom: -80px;
  position: absolute;
  right: -100px;
  z-index: 1;
}

.contents .recruit-decoration-wrap-pc03 img {
  display: block;
  width: 379px;
}

.contents .recruit-decoration-wrap-mb01 {
  left: -80px;
  position: absolute;
  top: -40px;
  z-index: 0;
}

.contents .recruit-decoration-wrap-mb01 img {
  display: block;
  width: 200px;
}

.contents .recruit-decoration-wrap-mb02 {
  bottom: 0;
  position: absolute;
  right: 0;
  z-index: 2;
}

.contents .recruit-decoration-wrap-mb02 img {
  display: block;
  width: 150px;
}

.contents .recruit-decoration-wrap-mb03 {
  bottom: -80px;
  position: absolute;
  right: -100px;
  z-index: 2;
}

.contents .recruit-decoration-wrap-mb03 img {
  display: block;
  width: 250px;
}

.visibleXs {
  display: none!important;
}

.visibleXs_ls {
  display: none!important;
}

.visibleTablet {
  display: none!important;
}

.hiddenXs {
  display: block;
}

.hiddenXs_ls {
  display: block!important;
}

.hiddenTablet {
  display: block!important;
}

@media screen and (max-width:1280px) {
  .lower-kv {
    background-size: contain;
    height: 70vh;
  }
}

@media screen and (max-width:1200px) {
  body {
    font-size: 1.4rem;
  }

  .l-wrapper {
    width: 90%;
  }

  .lower-kv {
    background-attachment: scroll;
    background-size: cover;
    height: 60vh;
  }

  .lower-kv__heading span {
    font-size: 5rem;
    left: 5%;
  }

  .other-heading__news-bg::after {
    height: 50px;
  }

  .other-heading__item {
    height: 0;
    margin: -29px auto 0 auto;
    width: 90%;
  }

  .other-heading__items .heading-txt {
    font-size: 2.4rem;
    padding: 16px 20px;
  }

  .footer-about {
    width: 90%;
  }

  .footer-magazine {
    padding: 80px 0;
    width: 90%;
  }

  .footer-magazine .magazine-txt {
    font-size: 3.2rem;
  }

  .footer-magazine .magazine-date {
    font-size: 2.4rem;
  }

  .l-footer .footer-wrapper {
    width: 90%;
  }

  .l-footer .footer-items.-contact .tel-area .tel {
    font-size: 3.2rem;
  }

  .l-footer .footer-copy__item .copy-txt {
    font-size: 1rem;
  }

  .l-header nav .gloval-nav {
    display: none;
  }

  .l-header__drower-menu .drower-item {
    margin: 64px auto 0 auto;
    padding: 0 5%;
    width: 100%;
  }

  .l-header__drower-menu .drower-items.-left .item-logo img {
    width: 300px;
  }

  .l-header__drower-menu .drower-items.-left .item-copy .copy-txt {
    font-size: 1rem;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title a {
    font-size: 3rem;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title.ja a {
    font-size: 2.4rem;
  }

  .branch-btn {
    width: calc((100% / 12) * 10.5);
  }

  .branch-btn__items.service-btn:nth-child(2) {
    line-height: 1.5;
  }

  .branch-btn__items a {
    font-size: 1.8rem;
  }

  .ggmap {
    padding-bottom: 60%;
  }

  .top-heading {
    font-size: 4rem;
  }

  .about-top__decoration-circle {
    height: 150px;
    left: -40px;
    width: 150px;
  }

  .about-top__decoration-pumpkin {
    right: -80px;
    width: 280px;
  }

  .about-top__container .txt-img img {
    max-width: 300px;
  }

  .about-top__container .txt-area {
    font-size: 2rem;
    width: 90%;
  }

  .about-top__container .txt-logo {
    margin-top: -120px;
  }

  .about-contents__container .contents01-title {
    -webkit-transform: translateY(-50%);
    left: calc((100% / 12) * 2);
    top: 55%;
    transform: translateY(-50%);
    width: 70px;
  }

  .about-contents__container .contents02-title {
    -webkit-transform: translateY(-50%);
    right: calc((100% / 12) * 2);
    top: 50%;
    transform: translateY(-50%);
    width: 70px;
  }

  .about-link__title {
    font-size: 2.4rem;
  }

  .philosophy__title {
    font-size: 3rem;
  }

  .philosophy__sub-title {
    font-size: 1.6rem;
  }

  .philosophy__main-txt em {
    font-size: 2.4rem;
  }

  .philosophy__main-txt strong {
    font-size: 3rem;
  }

  .top-message__title {
    font-size: 4.5rem;
  }

  .top-message__message-title {
    font-size: 3rem;
  }

  .top-message__name {
    font-size: 1.8rem;
  }

  .company-info__items.-nav-container {
    display: none;
  }

  .company-info__items.-company-container {
    width: 100%;
  }

  .l-contents__items.-title {
    width: 10%;
  }

  .l-contents__items.-container {
    width: 88%;
  }

  .contact-form {
    width: 95%;
  }

  .contact-confirm {
    width: 90%;
  }

  .logo__heading {
    -webkit-transform: translateY(-50%);
    font-size: 5rem;
    left: 5%;
    top: 40%;
    transform: translateY(-50%);
  }

  .logo__top::after {
    height: 150px;
  }

  .logo__top .top-container::before {
    left: -40px;
    width: 220px;
  }

  .logo__top .top-container::after {
    right: -80px;
    width: 280px;
  }

  .logo__top .top-container .logo-img img {
    max-width: 280px;
  }

  .logo__top .top-container .txt-img img {
    max-width: 400px;
  }

  .logo__top .top-container .txt-area {
    font-size: 2rem;
    width: 90%;
  }

  .logo__top .top-container .txt-logo {
    margin-top: -120px;
  }

  .logo__explanation::before {
    left: -40px;
    width: 220px;
  }

  .logo__explanation::after {
    right: -80px;
    width: 280px;
  }

  .logo__explanation .explanation-container {
    margin: 0 auto 80px auto;
    width: 90%;
  }

  .logo__explanation .explanation-container.gutter-top {
    margin-top: 300px;
  }

  .logo__explanation .explanation-container__title span {
    font-size: 2.4rem;
  }

  .logo__explanation .explanation-container__items.-txt {
    font-size: 1.6rem;
  }

  .logo__explanation .explanation-container__items.-btn a {
    font-size: 1.6rem;
  }

  .logo__explanation .explanation-container__items.-btn a::after {
    right: 40px;
  }

  .logo__explanation .explanation-decoration .left-img img {
    max-width: 400px;
  }

  .logo__explanation .explanation-decoration .right-img {
    top: -80px;
  }

  .logo__explanation .explanation-decoration .right-img img {
    max-width: 200px;
  }

  .news-top__news-bg::after {
    height: 50px;
  }

  .news-top__item {
    height: 0;
    margin: -27px auto 0 auto;
    width: 90%;
  }

  .news-top__items .heading-txt {
    font-size: 5rem;
  }

  .news-top__items .breadcrumb-list {
    margin-top: 0;
  }

  .l-news-archive {
    padding: 20px 0 120px 0;
  }

  .l-news-archive__item {
    align-items: flex-start;
    width: 90%;
  }

  .l-news-single__info .news-title {
    font-size: 2.4rem;
  }

  .l-news-single__info .news-data__items.-right .sns-link a {
    font-size: 3rem;
  }

  .l-news-single__contents .heading-txt {
    font-size: 2rem;
  }

  .privacy p {
    font-size: 1.6rem;
  }

  .recruit-info::after {
    height: 100px;
    width: 100px;
  }

  .recruit-info::before {
    height: 51px;
    width: 92px;
  }

  .recruit-info {
    width: 90%;
  }

  .recruit-info__title .heading {
    font-size: 2rem;
  }

  .voice-list::before {
    height: 240px;
    width: 240px;
  }

  .voice-list.list03::before {
    bottom: -80px;
    left: -20px;
  }

  .voice-list.list04::before {
    top: 60%;
  }

  .voice-list__img {
    width: 360px;
  }

  .voice-list__title {
    font-size: 2.8rem;
  }

  .voice-list__txt {
    font-size: 1.6rem;
  }

  .recruitment-container {
    margin-top: 100px;
  }

  .recruitment-container__info {
    width: 90%;
  }

  .recruitment-container__box .info-contents01__item.-txt-area .title {
    font-size: 2.4rem;
  }

  .recruitment-container__box .info-contents01__item.-txt-area .txt {
    font-size: 1.4rem;
  }

  .recruitment-container__box .info-contents02 .point-title__item.-point {
    font-size: 3rem;
    padding-right: 16px;
  }

  .recruitment-container__box .info-contents02 .point-title__item.-title {
    font-size: 2.4rem;
    padding-left: 16px;
  }

  .recruitment-container__box .info-contents03__item.-main-area .title {
    font-size: 2.4rem;
  }

  .recruitment-container__box .info-contents03__item.-main-area .txt {
    font-size: 1.6rem;
  }

  .recruitment-container__box .info-contents03__item.-sub-area {
    margin-top: 32px;
  }

  .recruitment-container__box .info-contents03__item.-sub-area .title {
    font-size: 2rem;
  }

  .recruitment-container__box .info-contents03__item.-sub-area .txt {
    font-size: 1.4rem;
  }

  .recruitment-container__panel .card-list__title {
    font-size: 1.8rem;
  }

  .recruitment-container__panel .card-list__details .txt-area .title {
    font-size: 1.6rem;
  }

  .recruitment-container__csr-img {
    width: 500px;
  }

  .apply-btn a {
    font-size: 3rem;
  }

  .apply-btn a::after {
    right: 40px;
  }

  .sdgs-info {
    width: 90%;
  }

  .sdgs-info__title .heading {
    font-size: 2rem;
  }

  .sdgs-info__img-title::before {
    height: 90px;
    left: calc((100% / 12) * -.5);
    width: 90px;
  }

  .sdgs-info__img-title::after {
    height: 120px;
    width: 120px;
  }

  .sdgs-info__img-title span {
    width: 200px;
  }

  .efforts__container {
    padding: 40px 0 0 0;
    width: 90%;
  }

  .efforts__heading {
    font-size: 2.4rem;
  }

  .efforts__title .number {
    font-size: 6.4rem;
  }

  .efforts__title .detail {
    font-size: 2rem;
  }

  .efforts__contents {
    font-size: 1.6rem;
  }

  .csr-container__info {
    width: 90%;
  }

  .csr-container__box .info-contents01__item.-txt-area .title {
    font-size: 2.4rem;
  }

  .csr-container__box .info-contents01__item.-txt-area .txt {
    font-size: 1.4rem;
  }

  .csr-container__box .info-contents02 .point-title__item.-point {
    font-size: 3rem;
    padding-right: 16px;
  }

  .csr-container__box .info-contents02 .point-title__item.-title {
    font-size: 2.4rem;
    padding-left: 16px;
  }

  .csr-container__box .info-contents03__item.-main-area .title {
    font-size: 2.4rem;
  }

  .csr-container__box .info-contents03__item.-main-area .txt {
    font-size: 1.6rem;
  }

  .csr-container__box .info-contents03__item.-sub-area {
    margin-top: 32px;
  }

  .csr-container__box .info-contents03__item.-sub-area .title {
    font-size: 2rem;
  }

  .csr-container__box .info-contents03__item.-sub-area .txt {
    font-size: 1.4rem;
  }

  .csr-container__panel .card-list__title {
    font-size: 1.8rem;
  }

  .csr-container__csr-img {
    width: 500px;
  }

  .service-top {
    width: 90%;
  }

  .service-top__title .heading {
    font-size: 2rem;
  }

  .service-container__img.txt-img::after {
    height: 89px;
    width: 293px;
  }

  .service-container__info {
    margin: -24px auto 0 auto;
    width: 90%;
  }

  .service-container__box .info-contents01__item.-txt-area .title {
    font-size: 2.4rem;
  }

  .service-container__box .info-contents01__item.-txt-area .txt {
    font-size: 1.4rem;
  }

  .service-container__box .info-contents02 .point-title__item.-point {
    font-size: 3rem;
    padding-right: 16px;
  }

  .service-container__box .info-contents02 .point-title__item.-title {
    font-size: 2.4rem;
    padding-left: 16px;
  }

  .service-container__box .info-contents03__item.-main-area .title {
    font-size: 2.4rem;
  }

  .service-container__box .info-contents03__item.-main-area .txt {
    font-size: 1.6rem;
  }

  .service-container__box .info-contents03__item.-sub-area {
    margin-top: 32px;
  }

  .service-container__box .info-contents03__item.-sub-area .title {
    font-size: 2rem;
  }

  .service-container__box .info-contents03__item.-sub-area .txt {
    font-size: 1.4rem;
  }

  .service-container__panel .card-list__title {
    font-size: 1.8rem;
  }

  .service-flow__title {
    font-size: 2.4rem;
  }

  .service-flow__txt {
    font-size: 1.6rem;
    line-height: 1.75;
    text-align: left;
  }

  .mv__item {
    left: 16px;
  }

  .mv__items .txt-contents span {
    font-size: 8rem;
  }

  .concept__items .sub-title {
    font-size: 3.2rem;
  }

  .concept__items .txt-area {
    font-size: 1.5rem;
  }

  .company__item {
    padding: 30px 0;
  }

  .company__item .txt-area {
    font-size: 2rem;
    margin-top: 34px;
  }

  .company__item .link-area {
    margin-top: 16px;
  }

  .contents {
    margin-top: -20px;
  }

  .contents__item {
    margin-top: 250px;
  }

  .contents__item.reverse {
    margin-top: 250px;
  }

  .contents__item.reverse .-txt-wrap {
    left: calc((100% / 12) * 2.5);
  }

  .contents__items.-txt-wrap {
    bottom: -150px;
    left: calc((100% / 12) * .5);
    width: calc((100% / 12) * 9);
  }

  .contents__items.-img-wrap {
    width: calc((100% / 12) * 9);
  }

  .contents .service-decoration-wrap-pc01 {
    left: -100px;
    top: -120px;
  }

  .contents .service-decoration-wrap-pc01 img {
    width: 180px;
  }

  .contents .sdgs-decoration-wrap-pc01 img {
    width: 200px;
  }

  .contents .sdgs-decoration-wrap-pc02 {
    right: calc((100% / 12) * -.5);
  }

  .contents .sdgs-decoration-wrap-pc02 img {
    width: 150px;
  }

  .contents .recruit-decoration-wrap-pc01 {
    left: 0;
    top: -150px;
  }

  .contents .recruit-decoration-wrap-pc01 img {
    width: 200px;
  }

  .contents .recruit-decoration-wrap-pc02 {
    right: 200px;
  }

  .contents .recruit-decoration-wrap-pc03 img {
    width: 300px;
  }

  .visibleTablet {
    display: block!important;
  }

  .hiddenTablet {
    display: none!important;
  }
}

@media screen and (max-width:896px) {
  .lower-kv.about-kv {
    background-image: none;
    height: auto;
  }

  .lower-kv.service-kv {
    background-image: none;
    height: auto;
  }

  .lower-kv.company-kv {
    background-image: none;
    height: auto;
  }

  .lower-kv.sdgs-kv {
    background-image: none;
    height: auto;
  }

  .lower-kv.recruit-kv {
    background-image: none;
    height: auto;
  }

  .footer-magazine {
    padding: 120px 0;
  }

  .l-header__drower-menu .drower-item {
    margin: 64px auto 0 auto;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title a {
    font-size: 1.6rem;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title.ja a {
    font-size: 1.6rem;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-list__item a {
    line-height: 1.5;
  }

  .top-heading {
    font-size: 3.2rem;
  }

  .about-contents__container .contents01-title {
    -webkit-transform: translateY(-50%);
    left: calc((100% / 12) * 1.5);
    top: 50%;
    transform: translateY(-50%);
    width: 70px;
  }

  .about-contents__container .contents01-deco01 {
    right: calc((100% / 12) * -.5);
    width: 300px;
  }

  .about-contents__container .contents01-deco2 {
    width: 100px;
  }

  .about-contents__container .contents02-title {
    -webkit-transform: translateY(-50%);
    right: calc((100% / 12) * 1.5);
    top: 40%;
    transform: translateY(-50%);
    width: 70px;
  }

  .about-contents__container .contents02-deco01 {
    right: 0;
    top: 0;
    width: 150px;
  }

  .about-contents__container .contents02-deco02 {
    left: 0;
    width: 300px;
  }

  .about-contents__container .contents02-deco03 {
    right: calc((100% / 12) * -.5);
    width: 250px;
  }

  .about-contents__container .txt-area {
    margin-left: calc((100% / 12) * 3.5);
    width: calc((100% / 12) * 8);
  }

  .philosophy {
    padding: 100px 0 100px 0;
  }

  .contact-form .l-form__items.-title {
    width: 35%;
  }

  .contact-form .l-form__items.-contents {
    width: 65%;
  }

  .logo__explanation .explanation-container.gutter-top {
    margin-top: 250px;
  }

  .logo__explanation .explanation-container__items.-btn a::after {
    content: url(../../assets/images/logo/arrow_mb.png);
    right: 8px;
  }

  .voice-list::before {
    height: 200px;
    width: 200px;
  }

  .voice-list.list01::before {
    right: -40px;
  }

  .voice-list__img {
    width: 300px;
  }

  .voice-list__img.list02 {
    right: -80px;
    top: 100px;
  }

  .voice-list__img.list03 {
    left: -80px;
  }

  .voice-list__img.list04 {
    right: -100px;
  }

  .voice-list__title {
    font-size: 2.4rem;
  }

  .recruitment-container__csr-img {
    width: 400px;
  }

  .apply-btn a {
    font-size: 2rem;
  }

  .apply-btn a::after {
    content: url(../../assets/images/recruit/recruitment/arrow_mb.png);
    right: 8px;
    top: 45%;
  }

  .csr-container__csr-img {
    width: 400px;
  }

  .service-container__panel .card-list__details .ff {
    margin-top: -10px;
    width: 100px;
  }

  .mv__items .txt-contents span {
    font-size: 7.5rem;
  }

  .concept__items .sub-title {
    font-size: 3rem;
  }

  .contents__btn {
    margin-top: 24px;
  }

  .visibleXs_ls {
    display: block!important;
  }

  .hiddenXs_ls {
    display: none!important;
  }
}

@media screen and (max-width:480px) {
  .main {
    margin-top: 64px;
  }

  .l-wrapper.news-single {
    width: 90%;
  }

  .lower-kv__heading {
    bottom: -3%;
  }

  .lower-kv__heading span {
    font-size: 3.2rem;
    left: 5%;
  }

  .other-heading__news-bg::before {
    height: 25px;
  }

  .other-heading__news-bg::after {
    height: 40px;
  }

  .other-heading__item {
    height: 0;
    margin: -22px auto 0 auto;
    width: 90%;
  }

  .other-heading__items .heading-txt {
    font-size: 2rem;
    padding: 10px 16px;
  }

  .page-top svg {
    height: 28px;
    width: 39px;
  }

  .footer-about__item .txt-area {
    font-size: 1.8rem;
  }

  .footer-about__item .btn-area {
    margin-top: 24px;
  }

  .footer-magazine {
    padding: 60px 0;
  }

  .footer-magazine .magazine-txt {
    font-size: 2.4rem;
    line-height: 1.5;
  }

  .footer-magazine .magazine-date {
    font-size: 2rem;
  }

  .l-footer .footer-wrapper {
    width: calc((100% / 12) * 9);
  }

  .l-footer .footer-items.-logo {
    width: 100%;
  }

  .l-footer .footer-items.-nav {
    width: 100%;
  }

  .l-footer .footer-items.-nav .footer-nav {
    display: flex;
    flex-flow: wrap;
    justify-content: space-between;
  }

  .l-footer .footer-items.-nav .footer-nav li {
    width: 48%;
  }

  .l-footer .footer-items.-contact {
    width: 100%;
  }

  .l-footer .footer-items.-contact .tel-area .tel {
    font-size: 3rem;
  }

  .l-footer .footer-items.-contact .tel-area .hour {
    font-size: 1.2rem;
  }

  .l-footer .footer-copy__item {
    width: 100%;
  }

  .l-header {
    height: 64px;
    line-height: 64px;
  }

  .l-header__logo {
    left: 8px;
    width: 200px;
  }

  .l-header__menu {
    height: 64px;
    width: 64px;
  }

  .l-header__drower-menu .drower-items.-left {
    margin-bottom: 40px;
    width: 100%;
  }

  .l-header__drower-menu .drower-items.-left .item-logo img {
    width: 240px;
  }

  .l-header__drower-menu .drower-items.-left .item-copy {
    display: none;
  }

  .l-header__drower-menu .drower-items.-right {
    width: 100%;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents.gutter-bottom-hight {
    margin-bottom: 40px;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents.gutter-bottom-low {
    margin-bottom: 24px;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title a {
    font-size: 2rem;
  }

  .l-header__drower-menu .drower-items.-right .drower-nav__items .nav-contents .nav-title.ja a {
    font-size: 2rem;
  }

  .l-header__drower-menu .drower-footer-copy__mb {
    display: block;
    margin-top: 60px;
    width: 100%;
  }

  .l-header__drower-menu .drower-footer-copy__mb .sns-item {
    display: flex;
    flex-flow: wrap;
    justify-content: center;
    text-align: center;
  }

  .l-header__drower-menu .drower-footer-copy__mb .sns-items {
    padding: 0 16px;
  }

  .l-header__drower-menu .drower-footer-copy__mb .sns-items a {
    color: #fff;
  }

  .l-header__drower-menu .drower-footer-copy__mb .sns-items a i {
    font-size: 4rem;
  }

  .l-header__drower-menu .drower-footer-copy__mb .copy-txt {
    color: #fff;
    font-size: 1.2rem;
    margin-top: 20px;
    text-align: center;
  }

  .main-btn.news-btn {
    max-width: 175px;
  }

  .main-btn.gutter-top {
    margin-top: 40px;
  }

  .branch-btn {
    width: calc((100% / 12) * 10.5);
  }

  .branch-btn__items.service-btn:nth-child(1) {
    width: 27.5%;
  }

  .branch-btn__items.service-btn:nth-child(2) {
    width: 45%;
  }

  .branch-btn__items.service-btn:nth-child(2) a {
    line-height: 1.5;
  }

  .branch-btn__items.service-btn:nth-child(3) {
    width: 27.5%;
  }

  .branch-btn__items a {
    font-size: 1.2rem;
    padding: 20px 0;
  }

  .branch-btn__items a span {
    bottom: -8px;
  }

  .branch-btn__items a span svg {
    height: 7px;
    width: 15px;
  }

  .top-heading {
    font-size: 2.8rem;
  }

  .top-heading.center-mb {
    text-align: center;
  }

  .top-heading.center-mb::after {
    -webkit-transform: translateX(-50%);
    left: 50%;
    transform: translateX(-50%);
  }

  .about-page {
    padding: 80px 0 20px 0;
  }

  .about-top__decoration-circle {
    height: 100px;
    top: 70%;
    width: 100px;
  }

  .about-top__decoration-pumpkin {
    right: -60px;
    top: 70%;
    width: 170px;
  }

  .about-top__container .txt-img img {
    max-width: 200px;
  }

  .about-top__container .txt-area {
    font-size: 1.2rem;
    line-height: 2;
  }

  .about-top__container .txt-logo {
    margin-top: -40px;
  }

  .about-contents {
    margin-top: 0;
  }

  .about-contents__container .contents01-title {
    -webkit-transform: translateY(-10%);
    left: calc((100% / 12) * 1);
    top: 30%;
    transform: translateY(-10%);
    width: 54px;
  }

  .about-contents__container .contents01-deco01 {
    right: calc((100% / 12) * -.5);
    top: -90px;
    width: 145px;
  }

  .about-contents__container .contents01-deco2 {
    bottom: -24px;
    left: 0;
    width: 70px;
  }

  .about-contents__container .contents02-title {
    -webkit-transform: translateY(-10%);
    right: calc((100% / 12) * 1);
    top: 30%;
    transform: translateY(-10%);
    width: 54px;
  }

  .about-contents__container .contents02-deco01 {
    right: 8px;
    top: -20px;
    width: 81px;
  }

  .about-contents__container .contents02-deco02 {
    left: 0;
    top: -100px;
    width: 150px;
  }

  .about-contents__container .contents02-deco03 {
    bottom: 80px;
    right: -30px;
    width: 125px;
    z-index: 0;
  }

  .about-contents__container .img-area li.gutter-top {
    margin-top: 30px;
  }

  .about-contents__container .img-area.reverse {
    margin-top: 60px;
  }

  .about-contents__container .txt-area {
    margin-left: calc((100% / 12) * 3.5);
    margin-top: 40px;
    width: calc((100% / 12) * 8);
  }

  .about-contents__container .txt-area__title {
    font-size: 1.6rem;
    line-height: 1.75;
    margin-bottom: 16px;
  }

  .about-contents__container .txt-area__sentence {
    font-size: 1.2rem;
    line-height: 1.75;
  }

  .about-contents__container .txt-area.other-contents {
    margin-left: calc((100% / 12) *.5);
  }

  .about-link {
    margin: 80px auto 0 auto;
    width: calc((100% / 12) * 10);
  }

  .about-link__items {
    margin-bottom: 20px;
    padding-bottom: 10px;
    width: 47%;
  }

  .about-link__title {
    font-size: 1.7rem;
    margin-top: 10px;
  }

  .about-link__link {
    margin: 10px auto 0 auto;
    width: 20px;
  }

  .philosophy {
    padding: 80px 0 64px 0;
  }

  .philosophy__title {
    font-size: 2rem;
  }

  .philosophy__sub-title {
    font-size: 1rem;
  }

  .philosophy__main-txt em {
    font-size: 1.8rem;
  }

  .philosophy__main-txt strong {
    font-size: 1.5rem;
  }

  .philosophy__logo {
    width: 100%;
  }

  .top-message {
    padding-top: 40px;
  }

  .top-message__title {
    font-size: 3rem;
  }

  .top-message__message-title {
    font-size: 1.8rem;
    margin-top: 40px;
  }

  .top-message__name {
    font-size: 1.2rem;
  }

  .top-message__item {
    margin: 24px auto;
  }

  .top-message__items {
    font-size: 1.2rem;
    width: 100%;
  }

  .company-page {
    padding: 40px 0 0 0;
  }

  .company-info {
    margin: 40px auto;
  }

  .company-info {
    margin-left: calc((100% / 12) * 1);
    width: calc((100% / 12) * 11);
  }

  .l-contents__items.-container.company {
    padding: 20px;
  }

  .l-company tr {
    border-bottom: 1px solid #000;
  }

  .l-company tr th {
    border-bottom: none;
    border-top: none;
    display: block;
    font-weight: 700;
    padding: 10px 0 0 0;
    width: 100%;
  }

  .l-company tr td {
    border-bottom: none;
    border-top: none;
    display: block;
    padding: 0 0 10px 0;
    width: 100%;
  }

  .l-company.other tr th {
    font-size: 1.6rem;
    padding: 3px 0 3px 10px;
  }

  .conpany-info__data {
    padding: 16px 10px;
  }

  .conpany-info__data .name {
    font-size: 1.4rem;
    line-height: 1.5;
  }

  .conpany-info__data .adress {
    font-size: 1.2rem;
  }

  .conpany-info__map {
    padding: 5px;
  }

  .contact-page {
    padding: 80px 0 80px 0;
  }

  .contact-form {
    margin: 40px auto 0 auto;
    width: 95%;
  }

  .contact-form__heading {
    font-size: 2rem;
  }

  .contact-form .l-form__item {
    justify-content: space-between;
  }

  .contact-form .l-form__items {
    padding: 12px 16px;
  }

  .contact-form .l-form__items.-title {
    width: 45%;
  }

  .contact-form .l-form__items.-title.title-row-100 {
    width: 100%;
  }

  .contact-form .l-form__items.-title span.badge {
    font-size: 1.2rem;
    margin-right: 8px;
  }

  .contact-form .l-form__items.-title span.txt {
    font-size: 1.2rem;
  }

  .contact-form .l-form__items.-contents {
    width: 55%;
  }

  .contact-form .l-form__items.-contents.contents-row-100 {
    width: 100%;
  }

  .contact-form .l-form__items.-contents .radio-list.user-type {
    justify-content: end;
  }

  .contact-form .l-form__items.-contents .radio-list.list02 p {
    padding-left: 8px;
  }

  .contact-form .l-form__items.-contents .radio-list p {
    margin-right: 0;
  }

  .contact-form .l-form__items.-contents .adress-post-code {
    width: 70%;
  }

  .contact-form .l-form__items .tel-area {
    width: 90%;
  }

  .wpcf7-submit {
    border-radius: 20px;
    font-size: 1.2rem;
    max-width: 175px;
    padding: 16px 0;
  }

  .radio-input+label {
    font-size: 1.1rem;
    margin-right: 10px;
  }

  .radio-input+label::before {
    height: 12px;
    top: 3px;
    width: 12px;
  }

  .radio-input:checked+label::after {
    top: 1px;
  }

  .form-control.txt-area {
    height: 100px;
  }

  .contact-confirm__heading {
    font-size: 2rem;
  }

  .contact-confirm__item {
    margin-bottom: 16px;
  }

  .contact-confirm__items.-title {
    width: 100%;
  }

  .contact-confirm__items.-detail {
    margin-top: 5px;
    width: 100%;
  }

  .thanks {
    font-size: 1.6rem;
    margin: 0 auto;
    padding: 60px 0 0 0;
    width: 90%;
  }

  .faq {
    padding: 40px 0 80px 0;
  }

  .faq__heading {
    font-size: 2rem;
  }

  .faq__item {
    margin: 40px auto 0 auto;
    width: 90%;
  }

  .faq__title {
    font-size: 1.6rem;
  }

  .logo__heading {
    -webkit-transform: translateY(-50%);
    font-size: 3.2rem;
    left: 5%;
    top: 40%;
    transform: translateY(-50%);
  }

  .logo__top {
    padding-top: 20px;
  }

  .logo__top::after {
    background: #ececec;
    height: 50px;
    top: -30px;
  }

  .logo__top .top-container {
    margin-top: 0;
  }

  .logo__top .top-container::before {
    left: -50px;
    top: 70%;
    width: 142px;
  }

  .logo__top .top-container::after {
    right: -60px;
    top: 70%;
    width: 170px;
  }

  .logo__top .top-container .logo-img {
    margin-bottom: 30px;
  }

  .logo__top .top-container .logo-img img {
    max-width: 190px;
  }

  .logo__top .top-container .txt-img img {
    max-width: 205px;
  }

  .logo__top .top-container .txt-area {
    font-size: 1.2rem;
    line-height: 2;
  }

  .logo__top .top-container .txt-logo {
    margin-top: -40px;
  }

  .logo__explanation {
    margin-top: 60px;
  }

  .logo__explanation::before {
    left: -100px;
    top: 80%;
    width: 186px;
  }

  .logo__explanation::after {
    right: -100px;
    top: 80%;
    width: 186px;
  }

  .logo__explanation .explanation-container {
    margin: 0 auto 40px auto;
    width: 90%;
  }

  .logo__explanation .explanation-container.gutter-top {
    margin-top: 140px;
  }

  .logo__explanation .explanation-container__title span {
    font-size: 1.6rem;
    line-height: 1.75;
  }

  .logo__explanation .explanation-container__txt {
    margin-top: 40px;
  }

  .logo__explanation .explanation-container__item {
    margin-top: 40px;
  }

  .logo__explanation .explanation-container__items.-txt {
    font-size: 1.6rem;
    width: 100%;
  }

  .logo__explanation .explanation-container__items.-img {
    margin-top: 24px;
    width: 100%;
  }

  .logo__explanation .explanation-container__items.-btn a {
    font-size: 1.4rem;
    line-height: 1.75;
  }

  .logo__explanation .explanation-decoration .left-img img {
    max-width: 216px;
  }

  .logo__explanation .explanation-decoration .right-img {
    top: -40px;
  }

  .logo__explanation .explanation-decoration .right-img img {
    max-width: 92px;
  }

  .news-top__news-bg::before {
    height: 25px;
  }

  .news-top__news-bg::after {
    height: 40px;
  }

  .news-top__item {
    height: 0;
    margin: -22px auto 0 auto;
    width: 90%;
  }

  .news-top__items .heading-txt {
    font-size: 2rem;
    padding: 10px 16px;
  }

  .news-top__items .breadcrumb-list {
    margin-left: 20px;
    margin-top: 0;
  }

  .news-top__items .breadcrumb-list li {
    font-size: 1.2rem;
  }

  .news-top__items .breadcrumb-list li {
    margin-right: 20px;
  }

  .news-top__items .breadcrumb-list li::after {
    font-size: 1.6rem;
    right: -16px;
  }

  .l-news-archive {
    padding: 5px 0 80px 0;
  }

  .l-news-archive__item {
    border-bottom: 1px solid #fff;
    margin-bottom: 40px;
    padding-bottom: 40px;
    width: 90%;
  }

  .l-news-archive__item::after {
    display: none;
  }

  .l-news-archive__items.-thumbnail {
    padding: 24px;
    width: 100%;
  }

  .l-news-archive__items.-sentence {
    width: 100%;
  }

  .l-news-archive__items.-sentence .archive-info__date {
    font-size: 1.4rem;
  }

  .l-news-archive__items.-sentence .title {
    font-size: 1.6rem;
  }

  .l-news-archive__arrow-link {
    display: none;
  }

  .page-nav {
    margin: 64px 0;
  }

  .page-nav li a {
    font-size: 2rem;
  }

  .l-news-single {
    padding: 40px 0 80px 0;
  }

  .l-news-single__info .news-title {
    font-size: 2rem;
  }

  .l-news-single__info .news-data__items.-left .single-date {
    font-size: 1.4rem;
  }

  .l-news-single__contents .heading-txt {
    font-size: 1.8rem;
    line-height: 1.75;
  }

  .l-news-single__page-feed .single-info__text {
    font-size: 1.4rem;
  }

  .l-news-single__page-feed .single-page-nav li a {
    font-size: 1.6rem;
  }

  .privacy {
    padding: 60px 0 24px 0;
  }

  .privacy p {
    font-size: 1.4rem;
  }

  .recruit-page {
    padding: 60px 0 60px 0;
  }

  .recruit-info::after {
    display: none;
  }

  .recruit-info::before {
    -webkit-transform: translateY(0);
    bottom: 60px;
    height: 55px;
    left: 80%;
    transform: translateY(0);
    width: 92px;
  }

  .recruit-info {
    padding: 40px 0 120px 0;
    width: 90%;
  }

  .recruit-info__title .heading {
    font-size: 1.6rem;
  }

  .recruit-info__title .heading::before {
    height: 50px;
    width: 63px;
  }

  .recruit-info__contents {
    margin-top: 20px;
    text-align: left;
  }

  .voice-list.gutter-top {
    margin-top: 150px;
  }

  .voice-list::before {
    height: 183px;
    right: 60%;
    width: 183px;
  }

  .voice-list.list01::before {
    right: 60%;
  }

  .voice-list.list02::before {
    left: 65%;
    top: 70%;
  }

  .voice-list.list03::before {
    left: -40px;
    top: 70%;
  }

  .voice-list.list04::before {
    left: 65%;
    top: 70%;
  }

  .voice-list__item {
    padding: 16px;
  }

  .voice-list__item.list01 {
    width: calc((100% / 12) * 9.5);
  }

  .voice-list__item.list02 {
    margin-left: calc((100% / 12) * .5);
    width: calc((100% / 12) * 9.5);
  }

  .voice-list__img {
    width: 253px;
  }

  .voice-list__img.list01 {
    left: -45px;
    top: -100px;
  }

  .voice-list__img.list02 {
    right: -70px;
    top: -130px;
  }

  .voice-list__img.list03 {
    left: -40px;
    top: -130px;
  }

  .voice-list__img.list04 {
    right: -70px;
    top: -130px;
  }

  .voice-list__title {
    font-size: 1.5rem;
  }

  .voice-list__txt {
    font-size: 1.2rem;
    line-height: 1.6;
  }

  .recruitment-container__box.padding-layout {
    padding: 20px 16px;
  }

  .recruitment-container__box.gutter-top {
    margin-top: 24px;
  }

  .recruitment-container__box.gutter-more-top {
    margin-top: 40px;
  }

  .recruitment-container__box .info-contents01 {
    flex-direction: column-reverse;
  }

  .recruitment-container__box .info-contents01__item.-img-area {
    margin-top: 16px;
    text-align: center;
    width: 100%;
  }

  .recruitment-container__box .info-contents01__item.-img-area img {
    width: 175px;
  }

  .recruitment-container__box .info-contents01__item.-txt-area {
    width: 100%;
  }

  .recruitment-container__box .info-contents01__item.-txt-area .title {
    font-size: 1.5rem;
    text-align: center;
  }

  .recruitment-container__box .info-contents01__item.-txt-area .txt {
    font-size: 1.2rem;
  }

  .recruitment-container__box .info-contents02 .point-title__item.-point {
    font-size: 1.4rem;
    padding-right: 5px;
  }

  .recruitment-container__box .info-contents02 .point-title__item.-title {
    font-size: 1.3rem;
    padding-left: 8px;
  }

  .recruitment-container__box .info-contents03__item.-main-area .title {
    font-size: 1.5rem;
  }

  .recruitment-container__box .info-contents03__item.-main-area .txt {
    font-size: 1.2rem;
    margin-top: 24px;
  }

  .recruitment-container__box .info-contents03__item.-sub-area {
    margin-top: 40px;
  }

  .recruitment-container__box .info-contents03__item.-sub-area .title {
    font-size: 1.4rem;
  }

  .recruitment-container__box .info-contents03__item.-sub-area .txt {
    font-size: 1.2rem;
    margin-top: 20px;
  }

  .recruitment-container__panel.csr-top {
    padding-bottom: 0;
  }

  .recruitment-container__panel .card-list__item {
    margin-top: 24px;
    width: 100%;
  }

  .recruitment-container__panel .card-list__item.mb-none {
    display: none;
  }

  .recruitment-container__panel .card-list__title {
    font-size: 1.4rem;
    padding: 16px 0 16px 12px;
    position: relative;
  }

  .recruitment-container__panel .card-list__title span {
    -webkit-transform: translateY(-50%);
    display: block;
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
  }

  .recruitment-container__panel .card-list__title span svg {
    height: 10px;
    width: 18px;
  }

  .recruitment-container__panel .card-list__title span svg path {
    fill: #fff;
  }

  .recruitment-container__panel .card-list__details {
    display: none;
  }

  .recruitment-container__panel .card-list__details .txt-area .title {
    font-size: 1.4rem;
  }

  .recruitment-container__panel .card-list__details .img-area {
    display: block;
    margin-top: 16px;
  }

  .recruitment-container__panel .card-list__img {
    display: none;
  }

  .recruitment-container__csr-img {
    bottom: 0;
    display: block;
    left: 0;
    margin: 24px auto 0 auto;
    max-width: 307px;
    position: relative;
  }

  .recruitment-container__other li {
    width: 100%;
  }

  .apply-btn a {
    font-size: 1.4rem;
    line-height: 1.75;
    padding: 24px 0;
  }

  .sdgs-top-container {
    padding: 64px 0 24px 0;
  }

  .sdgs-info {
    padding: 40px 0 120px 0;
    width: 90%;
  }

  .sdgs-info__title .heading {
    font-size: 1.6rem;
  }

  .sdgs-info__title .heading::before {
    height: 75px;
    width: 46px;
  }

  .sdgs-info__contents {
    margin-top: 20px;
    text-align: left;
  }

  .sdgs-info__img-title::before {
    height: 72px;
    left: calc((100% / 12) * -.7);
    width: 72px;
  }

  .sdgs-info__img-title::after {
    height: 64px;
    right: calc((100% / 12) * -1.5);
    width: 64px;
  }

  .sdgs-info__img-title span {
    width: 150px;
  }

  .sdgs-info__concept {
    margin-top: 50px;
  }

  .efforts__heading {
    font-size: 1.5rem;
  }

  .efforts__items {
    margin-top: 40px;
    width: 100%;
  }

  .efforts__title .number {
    font-size: 5rem;
  }

  .efforts__title .detail {
    font-size: 1.5rem;
    font-weight: 700;
  }

  .efforts__contents {
    font-size: 1.2rem;
  }

  .csr-container.gutter-top {
    margin-top: 60px;
  }

  .csr-container__box.padding-layout {
    padding: 20px 16px;
  }

  .csr-container__box.gutter-top {
    margin-top: 24px;
  }

  .csr-container__box.gutter-more-top {
    margin-top: 40px;
  }

  .csr-container__box .info-contents01 {
    flex-direction: column-reverse;
  }

  .csr-container__box .info-contents01__item.-img-area {
    margin-top: 16px;
    text-align: center;
    width: 100%;
  }

  .csr-container__box .info-contents01__item.-img-area img {
    width: 175px;
  }

  .csr-container__box .info-contents01__item.-txt-area {
    width: 100%;
  }

  .csr-container__box .info-contents01__item.-txt-area .title {
    font-size: 1.5rem;
    text-align: center;
  }

  .csr-container__box .info-contents01__item.-txt-area .txt {
    font-size: 1.2rem;
  }

  .csr-container__box .info-contents02 .point-title__item.-point {
    font-size: 2.1rem;
    padding-right: 10px;
  }

  .csr-container__box .info-contents02 .point-title__item.-title {
    font-size: 1.5rem;
    letter-spacing: -.8px;
    padding-left: 10px;
  }

  .csr-container__box .info-contents03__item.-main-area .title {
    font-size: 1.5rem;
  }

  .csr-container__box .info-contents03__item.-main-area .txt {
    font-size: 1.2rem;
    margin-top: 24px;
  }

  .csr-container__box .info-contents03__item.-sub-area {
    margin-top: 40px;
  }

  .csr-container__box .info-contents03__item.-sub-area .title {
    font-size: 1.4rem;
  }

  .csr-container__box .info-contents03__item.-sub-area .txt {
    font-size: 1.2rem;
    margin-top: 20px;
  }

  .csr-container__box .column-contents__item.-txt-contents {
    padding: 10px 16px;
  }

  .csr-container__box .column-contents__item.-txt-contents {
    width: 100%;
  }

  .csr-container__box .column-contents__item.-img-contents {
    margin-top: 16px;
    padding: 10px 16px;
    width: 100%;
  }

  .csr-container__panel.csr-top {
    padding-bottom: 0;
  }

  .csr-container__panel .card-list__item {
    margin-bottom: 24px;
    width: 100%;
  }

  .csr-container__panel .card-list__item.mb-none {
    display: none;
  }

  .csr-container__panel .card-list__title {
    font-size: 1.4rem;
    padding: 16px 0 16px 12px;
    position: relative;
  }

  .csr-container__panel .card-list__title span {
    -webkit-transform: translateY(-50%);
    display: block;
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
  }

  .csr-container__panel .card-list__title span svg {
    height: 10px;
    width: 18px;
  }

  .csr-container__panel .card-list__title span svg path {
    fill: #fff;
  }

  .csr-container__panel .card-list__details {
    display: none;
  }

  .csr-container__panel .card-list__details .txt-area {
    margin-top: 0;
  }

  .csr-container__panel .card-list__details .img-area {
    display: block;
    margin-top: 16px;
  }

  .csr-container__panel .card-list__img {
    display: none;
  }

  .csr-container__csr-img {
    bottom: 0;
    display: block;
    left: 0;
    margin: 24px auto 0 auto;
    max-width: 307px;
    position: relative;
  }

  .csr-container__other li {
    width: 100%;
  }

  .service-page {
    padding: 64px 0 24px 0;
  }

  .service-top {
    padding: 40px 0;
    width: 90%;
  }

  .service-top__title .heading {
    font-size: 1.6rem;
  }

  .service-top__title .heading::before {
    height: 40px;
    width: 46px;
  }

  .service-top__contents {
    margin-top: 20px;
  }

  .service-container.gutter-top {
    margin-top: 60px;
  }

  .service-container__img.txt-img::after {
    bottom: 24px;
    height: 44px;
    width: 146px;
  }

  .service-container__box.padding-layout {
    padding: 20px 16px;
  }

  .service-container__box.gutter-top {
    margin-top: 24px;
  }

  .service-container__box.gutter-more-top {
    margin-top: 24px;
  }

  .service-container__box .info-contents01 {
    flex-direction: column-reverse;
  }

  .service-container__box .info-contents01__item.-img-area {
    margin-top: 16px;
    text-align: center;
    width: 100%;
  }

  .service-container__box .info-contents01__item.-img-area img {
    width: 175px;
  }

  .service-container__box .info-contents01__item.-txt-area {
    width: 100%;
  }

  .service-container__box .info-contents01__item.-txt-area .title {
    font-size: 1.5rem;
    text-align: center;
  }

  .service-container__box .info-contents01__item.-txt-area .txt {
    font-size: 1.2rem;
  }

  .service-container__box .info-contents02 .point-title__item.-point {
    font-size: 2.1rem;
    padding-right: 10px;
  }

  .service-container__box .info-contents02 .point-title__item.-title {
    font-size: 1.5rem;
    letter-spacing: -.8px;
    padding-left: 10px;
  }

  .service-container__box .info-contents02 .detail .column__item.-txt {
    width: 100%;
  }

  .service-container__box .info-contents02 .detail .column__item.-img {
    margin-top: 16px;
    width: 100%;
  }

  .service-container__box .info-contents03__item.-main-area .title {
    font-size: 1.5rem;
  }

  .service-container__box .info-contents03__item.-main-area .txt {
    font-size: 1.2rem;
    margin-top: 24px;
  }

  .service-container__box .info-contents03__item.-sub-area {
    margin-top: 40px;
  }

  .service-container__box .info-contents03__item.-sub-area .title {
    font-size: 1.4rem;
  }

  .service-container__box .info-contents03__item.-sub-area .txt {
    font-size: 1.2rem;
    margin-top: 20px;
  }

  .service-container__box .column-contents__item.-txt-contents {
    padding: 10px 16px;
  }

  .service-container__box .column-contents__item.-txt-contents {
    width: 100%;
  }

  .service-container__box .column-contents__item.-img-contents {
    margin-top: 16px;
    padding: 10px 16px;
    width: 100%;
  }

  .service-container__panel .card-list__item {
    margin-bottom: 24px;
    width: 100%;
  }

  .service-container__panel .card-list__title {
    font-size: 1.6rem;
    letter-spacing: -.8px;
    padding: 16px 20px 16px 12px;
    position: relative;
  }

  .service-container__panel .card-list__title span {
    -webkit-transform: translateY(-50%);
    display: block;
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
  }

  .service-container__panel .card-list__title span svg {
    height: 10px;
    width: 18px;
  }

  .service-container__panel .card-list__title span svg path {
    fill: #fff;
  }

  .service-container__panel .card-list__details {
    display: none;
  }

  .service-container__panel .card-list__details .sub-title {
    font-size: 1.4rem;
  }

  .service-container__panel .card-list__details .txt-area {
    margin-top: 0;
  }

  .service-container__panel .card-list__details .img-area {
    display: block;
    margin-top: 16px;
  }

  .service-container__panel .card-list__details .ff {
    width: 100px;
  }

  .service-container__panel .card-list__img {
    display: none;
  }

  .service-container__other li {
    width: 100%;
  }

  .service-flow__item {
    width: 90%;
  }

  .service-flow__title {
    font-size: 1.8rem;
    line-height: 1.75;
  }

  .service-flow__txt {
    font-size: 1.2rem;
    line-height: 1.75;
    text-align: left;
  }

  .mv {
    margin-top: 64px;
  }

  .mv img {
    height: calc(100vh - 64px);
  }

  .mv__item {
    bottom: 150px;
    left: 8px;
  }

  .mv__items .txt-contents span {
    font-size: 4rem;
  }

  .mv__items .txt-contents span.ja {
    font-size: 1.6rem;
  }

  .concept__item {
    width: 100%;
  }

  .concept__items.-txt {
    width: 100%;
  }

  .concept__items.-img {
    padding: 0 5%;
    width: 100%;
  }

  .concept__items .sub-title {
    font-size: 2.4rem;
    margin-top: 60px;
    text-align: center;
  }

  .concept__items .txt-area {
    font-size: 1.4rem;
    margin-top: 40px;
    text-align: center;
  }

  .concept__btn-mb {
    display: block;
    margin-top: 40px;
    padding: 0 5%;
    position: relative;
    width: 100%;
  }

  .concept__btn-mb::before {
    -webkit-transform: translate(-50%,-50%);
    background-color: #9fa0a0;
    content: '';
    height: 2px;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 90%;
    z-index: 0;
  }

  .concept__btn-mb .mb-btn {
    background-color: #004381;
    border-radius: 50px;
    color: #fff;
    display: block;
    font-family: ttnorms_medium;
    height: 50px;
    line-height: 50px;
    margin: 0 auto;
    position: relative;
    text-align: center;
    width: 200px;
    z-index: 1;
  }

  .news {
    padding: 60px 0 0 0;
  }

  .company__item {
    max-width: 300px;
    padding: 24px 0;
  }

  .company__item .txt-area {
    font-size: 1.8rem;
    margin-top: 40px;
  }

  .company__item .link-area img {
    width: 60px;
  }

  .contents {
    margin-top: -20px;
    padding-bottom: 100px;
  }

  .contents__item {
    flex-direction: column-reverse;
    margin-top: 60px;
  }

  .contents__item.top-gutter {
    margin-top: 50px;
  }

  .contents__item.reverse {
    margin-top: 60px;
  }

  .contents__item.reverse .-txt-wrap {
    left: calc((100% / 12) * 1);
  }

  .contents__item.reverse .-img-wrap {
    margin-left: calc((100% / 12) * -1);
  }

  .contents__items.-txt-wrap {
    bottom: 0;
    left: 0;
    margin-top: -40px;
    position: relative;
    width: calc((100% / 12) * 11);
  }

  .contents__items.-img-wrap {
    margin-left: calc((100% / 12) * 1);
    width: calc((100% / 12) * 11);
  }

  .contents__txt {
    font-size: 1.6rem;
    line-height: 2;
    margin-top: 40px;
  }

  .contents__btn {
    margin-top: 40px;
  }

  .contents .service-decoration-wrap-pc02 img {
    margin-right: auto;
    width: 200px;
  }

  .contents .service-decoration-wrap-mb02 img {
    margin-right: auto;
    width: 200px;
  }

  .contents .sdgs-decoration-wrap-pc02 {
    right: 8px;
  }

  .contents .sdgs-decoration-wrap-pc02 img {
    width: 120px;
  }

  .visibleXs {
    display: block!important;
  }

  .hiddenXs {
    display: none!important;
  }
}

@media screen and (max-width:480px) and (max-width:480px) {
  .about-top__container .txt-area {
    margin: 30px auto;
  }

  .logo__top .top-container .txt-area {
    margin: 30px auto;
  }
}