@charset "UTF-8";
html {
  scroll-behavior: smooth;
}

.common-width {
  max-width: 1240px;
  width: 90%;
  margin: 0 auto;
  display: block;
}

#wrap {
  overflow: hidden;
}

.common-ma {
  padding: 100px 0 0 0;
}

.page-title-left h2, .page-title-left h3, .page-title-left h4 {
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.1;
}
.page-title-left h2 span, .page-title-left h3 span, .page-title-left h4 span {
  font-family: "Lato";
  letter-spacing: 0.1rem;
  font-size: 1.7rem;
  font-weight: 600;
  color: #027CCF;
  line-height: 1.1;
}

.page-title-center h2, .page-title-center h3, .page-title-center h4 {
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.1;
  text-align: center;
}
.page-title-center h2 span, .page-title-center h3 span, .page-title-center h4 span {
  font-family: "Lato";
  letter-spacing: 0.1rem;
  font-size: 1.7rem;
  font-weight: 600;
  color: #027CCF;
  line-height: 1.1;
  text-align: center;
}

.sub-title {
  font-size: 2.4rem;
  color: #027CCF;
  font-weight: 600;
  border-bottom: 1px solid #027CCF;
  padding-bottom: 2px;
  margin: 0 0 12px 0;
}

.btn {
  color: #313131;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.7rem;
  font-weight: 600;
  display: block;
  position: relative;
  text-decoration: underline !important;
}
.btn::after {
  content: "";
  background: url(../images/btn-arrow.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 2px;
  bottom: 0;
  margin: auto;
  right: -24px;
}

/*---スクロール時遅れて表示、順番に表示---*/
.fadein {
  opacity: 0;
  transition: all 1.3s;
  transform: translate(0, 45px);
}

/*---TOP遅れて表示---*/
#post {
  opacity: 0;
}

.anchor {
  display: block;
  padding-top: 180px;
  margin-top: -150px !important;
}

.headline {
  animation: SlideIn 1.2s;
}

/* CSSアニメーションの設定 */
@keyframes SlideIn {
  0% {
    opacity: 1; /*初期状態では透明に*/
    transform: translateX(324px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
#global-header {
  position: fixed;
  top: 0;
  width: 100%;
  padding: 0 0 0 3vw;
  width: 100%;
  background: rgba(255, 255, 255, 0.92);
  z-index: 998;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#global-header .logo {
  width: 480px;
}
#global-header .header-right .right-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
}
#global-header .header-right .right-bottom #global-navi ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#global-header .header-right .right-bottom #global-navi ul li {
  display: none;
}
#global-header .header-right .right-bottom #global-navi ul li:last-child {
  display: block;
  margin-right: 62px;
}
#global-header .header-right .right-bottom #global-navi ul li:last-child a {
  width: 70px;
  height: 39px;
  display: grid;
  place-items: center;
  background: #F8B648;
  text-align: center;
  position: relative;
}
#global-header .header-right .right-bottom #global-navi ul li:last-child a p {
  font-size: 1.4rem;
  color: #fff;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 9px;
  margin: auto;
}
#global-header .header-right .right-bottom #global-navi ul li:last-child a::before {
  content: "";
  background: url(../images/mail.svg) no-repeat;
  background-size: contain;
  width: 18px;
  height: 13px;
  position: absolute;
  top: 18px;
  left: 0;
  right: 0;
  margin: auto;
}
#global-header .header-right .right-bottom #global-navi ul li a {
  font-size: 1.6rem;
  color: #202020;
  padding: 12px 0;
  display: block;
}

.key-wrap {
  position: relative;
  z-index: 1;
}
.key-wrap #key-visual {
  height: 380px;
  width: 100%;
  margin: 62px 0 0 auto;
  position: relative;
}
.key-wrap #key-visual .key-txt {
  position: absolute;
  bottom: 24px;
  left: 24px;
  z-index: 1;
  height: -moz-fit-content;
  height: fit-content;
}
.key-wrap #key-visual .sp {
  display: none;
}
.key-wrap #key-visual .slider {
  margin-inline: auto;
  width: 100%;
  position: relative;
}
.key-wrap #key-visual .slider .slide {
  position: relative;
}
.key-wrap #key-visual .slider .slide::before {
  content: "";
  background: rgba(0, 0, 0, 0.4);
  width: 100%;
  height: 100vh;
  position: absolute;
  top: 0;
  z-index: 5;
}
.key-wrap #key-visual .slider .slide .key-bg {
  height: 380px;
  -o-object-fit: cover;
     object-fit: cover;
}
.key-wrap #key-visual .slider .slick-center::before {
  display: none;
}

.grid-key {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
}
.grid-key img {
  height: 380px;
  -o-object-fit: cover;
     object-fit: cover;
}

.top01 .key-txt img {
  max-height: 245px;
  height: 40vw;
  -o-object-fit: contain;
     object-fit: contain;
}

.top02 .key-txt img {
  max-height: 338px;
  height: 40vw;
  -o-object-fit: contain;
     object-fit: contain;
}

.top03 .key-txt img {
  max-height: 103px;
  height: 40vw;
  -o-object-fit: contain;
     object-fit: contain;
}

.cta-banner {
  position: fixed;
  bottom: 0;
  right: 0;
  width: 350px;
  height: 60px;
  z-index: 1;
}
.cta-banner img {
  width: 100%;
}

#subkey-visual {
  width: 100%;
  position: relative;
  width: 100%;
  margin: 2px 0 0 auto;
}
#subkey-visual .title-top {
  height: 20vw;
  max-height: 270px;
  background: linear-gradient(180deg, rgb(49, 156, 229), rgb(2, 124, 207));
  position: relative;
}
#subkey-visual .title-top h1 {
  font-size: 3.6rem;
  font-weight: 600;
  color: #fff;
  position: absolute;
  left: 3vw;
  top: -6px;
  bottom: 0;
  margin: auto;
  line-height: 1;
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
  z-index: 1;
}
#subkey-visual .title-top h1 span {
  font-size: 1.8rem;
  color: #fff;
  font-family: "Lato";
  line-height: 1;
}
#subkey-visual .title-top .pankuzu {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin: 6px 0 0 0;
  position: absolute;
  bottom: 8px;
  right: 0;
}
#subkey-visual .title-top .pankuzu li {
  position: relative;
  padding-right: 36px;
}
#subkey-visual .title-top .pankuzu li::after {
  content: ">";
  font-size: 1.7rem;
  color: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  height: -moz-fit-content;
  height: fit-content;
  margin: auto;
  right: 15px;
}
#subkey-visual .title-top .pankuzu li:last-child::after {
  display: none;
}
#subkey-visual .title-top .pankuzu li a {
  font-size: 1.5rem;
  color: #fff;
}
#subkey-visual .key-img {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
#subkey-visual .key-img img {
  -o-object-fit: cover;
     object-fit: cover;
}

.key-txt-wrap {
  display: flex;
  width: 100%;
}
.key-txt-wrap .txt-list {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  position: absolute;
  top: 50px;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
  left: 310px;
  width: 65%;
}
.key-txt-wrap .txt-list .txt-item {
  font-size: 1.7rem;
  font-weight: 600;
  color: #fff;
  padding: 2px 8px;
  border: 1px solid #fff;
  margin-right: 12px;
  margin-top: 12px;
}
.key-txt-wrap .txt-list .txt-item:last-child {
  border: none;
  padding: 0;
}

.company-bg {
  background: url(../images/company/key-bg.webp) no-repeat center;
  background-size: cover;
}

#top-container {
  padding-bottom: 100px;
}
#top-container #news {
  padding-top: 80px;
}
#top-container #news .news-contents {
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  border: 2px solid #F5F5F5;
  border-radius: 16px;
  display: flex;
  justify-content: space-between;
  padding: 32px;
}
#top-container #news .news-left {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#top-container #news .news-list {
  width: 70%;
}
#top-container #news .news-list li {
  border-bottom: 1px solid #DEDEDE;
}
#top-container #news .news-list li:last-child {
  border-bottom: none;
}
#top-container #news .news-list li a {
  padding: 12px 0 12px 12px;
  display: flex;
  flex-wrap: wrap;
  transition: all ease 0.5s;
}
#top-container #news .news-list li a:hover {
  opacity: 0.7;
}
#top-container #news .news-list li a time {
  width: 90px;
  font-size: 1.4rem;
  font-family: "Lato";
}
#top-container #news .news-list li a span {
  width: 80px;
  font-size: 1.4rem;
  text-align: center;
  padding: 2px 6px;
  margin-right: 28px;
  height: -moz-fit-content;
  height: fit-content;
  display: block;
}
#top-container #news .news-list li a .cat_none {
  background: #DFDFDF;
}
#top-container #news .news-list li a .cat_event {
  background: #AFEA00;
}
#top-container #news .news-list li a .cat_new {
  background: #FFD24D;
}
#top-container #news .news-list li a h3 {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 500;
}
#top-container .bnr {
  display: block;
  max-width: 850px;
  width: 90%;
  margin: 60px auto 0 auto;
}
#top-container #greeting {
  margin-top: 80px;
}
#top-container #greeting .parallax {
  background-image: url(../images/greeting-bg.webp);
  background-size: cover;
  background-attachment: fixed;
  box-sizing: border-box;
  width: 100%;
  padding: 80px 0;
}
#top-container #greeting .contents {
  padding: 40px 60px;
  background: rgba(255, 255, 255, 0.8);
}
#top-container #greeting .contents p {
  font-size: 1.8rem;
  line-height: 1.8;
  margin-top: 16px;
}
#top-container #service .service-list {
  display: grid;
  gap: 24px;
  margin-top: 80px;
}
#top-container #service .service-list .service-box {
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  display: flex;
  justify-content: space-between;
  padding: 28px;
  border-radius: 16px;
  border: 3px solid #F5F5F5;
}
#top-container #service .service-list .service-box .service-txt {
  width: 55%;
}
#top-container #service .service-list .service-box .service-txt p {
  font-size: 1.7rem;
  font-weight: 500;
  margin: 16px 0 24px 0;
}
#top-container #service .service-list .service-box .service-txt .btn-list {
  display: flex;
  flex-wrap: wrap;
}
#top-container #service .service-list .service-box .service-txt .btn-list li {
  margin-right: 68px;
}
#top-container #service .service-list .service-box figure {
  width: 40%;
}
#top-container #service .service-list .service-box figure img {
  -o-object-fit: cover;
     object-fit: cover;
}

#repair-container {
  padding-bottom: 100px;
}
#repair-container .intro {
  font-size: 1.6rem;
  line-height: 1.6;
}
#repair-container h4 {
  font-size: 2.1rem;
  font-weight: 600;
  display: flex;
  align-items: center;
}
#repair-container h4::before {
  content: "●";
  font-size: 2.1rem;
  color: #027CCF;
  line-height: 1;
  display: block;
  right: 6px;
}
#repair-container h5 {
  font-size: 2rem;
  color: #027CCF;
  text-align: center;
  font-weight: 600;
  margin: 8px 0;
}
#repair-container .section {
  margin-bottom: 40px;
}
#repair-container .section .service-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px 16px;
  margin-top: 16px;
}
#repair-container .section .service-list li a.service-wrap {
  display: block;
}
#repair-container .section .service-list li a.service-wrap figure img {
  -o-object-fit: cover;
     object-fit: cover;
}

#reform-container .intro {
  font-size: 1.7rem;
  line-height: 1.6;
}
#reform-container .page-title-center + .sub-title {
  margin-top: 24px;
}
#reform-container .strength .strength-list {
  display: grid;
  gap: 32px;
  margin-top: 24px;
}
#reform-container .strength .strength-list .strength-box {
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  display: flex;
  justify-content: space-between;
  padding: 20px 24px;
  border-radius: 16px;
  border: 3px solid #F5F5F5;
}
#reform-container .strength .strength-list .strength-box .strength-txt {
  width: 58%;
}
#reform-container .strength .strength-list .strength-box .strength-txt .page-title-left {
  border-bottom: 1px solid #C9C9C9;
  padding-bottom: 8px;
  margin-bottom: 12px;
}
#reform-container .strength .strength-list .strength-box .strength-txt .page-title-left h4 {
  font-size: 2.4rem;
}
#reform-container .strength .strength-list .strength-box .strength-txt .page-title-left h4 span {
  font-size: 1.6rem;
}
#reform-container .strength .strength-list .strength-box .strength-txt h5 {
  font-size: 1.7rem;
  font-weight: 600;
}
#reform-container .strength .strength-list .strength-box .strength-txt p {
  font-size: 1.5rem;
  font-weight: 500;
  margin: 8px 0 0 0;
}
#reform-container .strength .strength-list .strength-box figure {
  width: 38%;
}
#reform-container .strength .strength-list .strength-box figure img {
  -o-object-fit: cover;
     object-fit: cover;
}
#reform-container .flow .flow-bg {
  padding: 40px 0;
  background: url(../images/reform/flow-bg.webp) no-repeat;
  background-size: cover;
  margin-top: 24px;
}
#reform-container .flow .flow-bg p {
  font-size: 2.4rem;
  text-align: center;
  font-weight: 600;
  filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.3));
}
#reform-container .flow .flow-list {
  display: grid;
  gap: 32px 24px;
  grid-template-columns: 1fr 1fr;
  margin-top: 60px;
}
#reform-container .flow .flow-list .flow-item .step {
  font-size: 1.7rem;
  text-align: center;
  color: #fff;
  font-family: "Lato";
  padding: 1px 0;
  width: 100px;
  margin: 0 auto;
  background: #027CCF;
}
#reform-container .flow .flow-list .flow-item h4 {
  font-size: 2.1rem;
  font-weight: 600;
  text-align: center;
  margin: 8px 0;
}
#reform-container .flow .flow-list .flow-item figure img {
  -o-object-fit: cover;
     object-fit: cover;
}
#reform-container .flow .flow-list .flow-item h5 {
  font-size: 1.8rem;
  font-weight: 600;
  margin: 12px 0 6px 0;
}
#reform-container .flow .flow-list .flow-item p {
  font-size: 1.6rem;
}
#reform-container .flow .flow-list .flow-item .point {
  border: 1px solid #027CCF;
  padding: 8px;
  background: #F2F2F2;
  margin-top: 12px;
}
#reform-container .flow .flow-list .flow-item .point h6 {
  font-size: 1.7rem;
  font-weight: 600;
  text-align: center;
  color: #027CCF;
}
#reform-container .flow .flow-list .flow-item .point p {
  font-size: 1.5rem;
  text-align: center;
  line-height: 1.4;
}
#reform-container .case {
  background: #F9F9F9;
  padding: 60px 0;
  margin-top: 80px;
}
#reform-container .case .title-wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
#reform-container .case .title-wrap .btn {
  margin-right: 24px;
}
#reform-container .case .case-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  margin-top: 16px;
}
#reform-container .case .case-list .case-item a {
  display: block;
}
#reform-container .case .case-list .case-item a figure img {
  max-height: 248px;
  height: 20vw;
  -o-object-fit: cover;
     object-fit: cover;
}
#reform-container .case .case-list .case-item a .cat {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.4rem;
  color: #fff;
  background: #027CCF;
  padding: 1px 8px;
  margin-top: 12px;
}
#reform-container .case .case-list .case-item a h3 {
  font-size: 1.8rem;
  font-weight: 600;
  margin: 4px 0 2px 0;
  line-height: 1.4;
}
#reform-container .case .case-list .case-item a p {
  font-size: 1.6rem;
}
#reform-container .voice {
  background: #F9F9F9;
  padding: 0 0 120px 0;
}
#reform-container .voice .voice-wrap {
  padding: 24px 40px;
  border-radius: 16px;
  border: 3px solid #F5F5F5;
  background: #fff;
  display: flex;
  justify-content: space-between;
}
#reform-container .voice .voice-wrap .voice-left {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#reform-container .voice .voice-wrap .voice-list {
  width: 68%;
}
#reform-container .voice .voice-wrap .voice-list li {
  border-bottom: 1px solid #DEDEDE;
  padding: 12px 0 12px 12px;
  display: block;
}
#reform-container .voice .voice-wrap .voice-list li:last-child {
  border-bottom: none;
}
#reform-container .voice .voice-wrap .voice-list li .cat {
  font-size: 1.5rem;
  color: #fff;
  padding: 1px 0;
  width: 66px;
  text-align: center;
  background: #027CCF;
  height: -moz-fit-content;
  height: fit-content;
}
#reform-container .voice .voice-wrap .voice-list li h3 {
  font-size: 1.6rem;
  font-weight: 500;
  margin-top: 6px;
}

#case-container {
  max-width: 1600px;
  width: 90%;
  margin: 60px auto 120px auto;
  display: flex;
  justify-content: space-between;
}
#case-container h2 {
  font-size: 2rem;
  color: #fff;
  background: #027CCF;
  padding: 4px 12px;
  font-weight: 600;
}
#case-container .case-side {
  width: 140px;
}
#case-container .case-side h2 {
  text-align: center;
  font-family: "Lato";
}
#case-container .case-side ul li {
  border-bottom: 1px solid #C9C9C9;
}
#case-container .case-side ul li a {
  font-size: 1.4rem;
  padding: 10px;
  display: block;
  position: relative;
  color: #313131;
}
#case-container .case-side ul li a::after {
  content: "";
  background: url(../images/btn-arrow.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 6px;
  margin: auto;
}
#case-container .case-wrap {
  width: calc(100% - 140px - 4%);
}
#case-container .case-wrap .case-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  margin-top: 16px;
}
#case-container .case-wrap .case-list .case-item a {
  display: block;
}
#case-container .case-wrap .case-list .case-item a figure img {
  max-height: 248px;
  height: 16vw;
  -o-object-fit: cover;
     object-fit: cover;
}
#case-container .case-wrap .case-list .case-item a .cat {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.3rem;
  color: #fff;
  background: #027CCF;
  padding: 1px 6px;
  margin-top: 6px;
}
#case-container .case-wrap .case-list .case-item a h3 {
  font-size: 1.7rem;
  font-weight: 600;
  margin: 6px 0 4px 0;
  line-height: 1.4;
}
#case-container .case-wrap .case-list .case-item a p {
  font-size: 1.5rem;
}
#case-container .case-wrap .pagenation ul {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #F9F9F9;
  padding: 18px 40px;
  margin: 40px auto 120px auto;
  position: relative;
}
#case-container .case-wrap .pagenation ul li {
  margin-right: 2%;
  border: none;
}
#case-container .case-wrap .pagenation ul li a {
  font-size: 1.7rem;
  font-family: "Lato";
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  height: 30px;
  font-size: 1.7rem;
  width: 30px;
  background: #027CCF;
  border-radius: 50px;
  padding: 0;
}
#case-container .case-wrap .pagenation ul .page-active {
  font-size: 1.7rem;
  font-family: "Lato";
}
#case-container .case-wrap .pagenation ul .next a, #case-container .case-wrap .pagenation ul .prev a {
  color: #433F37;
  font-size: 1.7rem;
  background: none;
  width: auto;
  font-family: "Lato";
}
#case-container .case-wrap .pagenation ul .next {
  position: absolute;
  right: 2%;
  top: 0;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}
#case-container .case-wrap .pagenation ul .prev {
  position: absolute;
  left: 2%;
  top: 0;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}

#case-container .case-btn {
  width: 240px;
  display: block;
  border: 1px solid #027CCF;
  border-radius: 50px;
  margin: 24px auto;
  text-align: center;
  font-size: 1.7rem;
  color: #027CCF;
  padding: 12px 0;
}
#case-container .case-contents {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 16px;
}
#case-container .case-contents .case-box .case-title {
  font-size: 2.1rem;
  padding: 8px 0 4px 0;
  text-align: center;
  color: #fff;
  font-weight: 600;
  font-family: "Lato";
  line-height: 1;
}
#case-container .case-contents .case-box .title-before {
  background: #C5C5C5;
}
#case-container .case-contents .case-box .title-after {
  background: #F8B648;
}
#case-container .case-contents .case-box figure img {
  max-height: 370px;
  height: 18vw;
  -o-object-fit: cover;
     object-fit: cover;
}
#case-container .case-contents .case-box .case-txt {
  margin-top: 16px;
}
#case-container .case-contents .case-box .case-txt dl dt {
  font-size: 1.8rem;
  font-weight: 600;
  border-bottom: 1px solid #C9C9C9;
  padding-bottom: 4px;
}
#case-container .case-contents .case-box .case-txt dl dd {
  font-size: 1.5rem;
  padding-bottom: 12px;
}
#case-container .case-contents .case-before figure {
  border: 6px solid #C5C5C5;
}
#case-container .case-contents .case-after figure {
  border: 6px solid #F8B648;
}

#voice-container .voice-list {
  max-width: 900px;
  width: 90%;
  margin: 60px auto;
}
#voice-container .voice-list li {
  border-top: 1px solid #DEDEDE;
  padding: 16px 0 16px 16px;
  display: flex;
  justify-content: space-between;
}
#voice-container .voice-list li:last-child {
  border-bottom: none;
}
#voice-container .voice-list li .cat {
  font-size: 1.5rem;
  color: #fff;
  padding: 1px 0;
  width: 66px;
  text-align: center;
  background: #027CCF;
  height: -moz-fit-content;
  height: fit-content;
}
#voice-container .voice-list li h3 {
  font-size: 1.7rem;
  font-weight: 500;
  width: calc(100% - 66px - 3%);
}
#voice-container .pagenation ul {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #F9F9F9;
  padding: 18px 40px;
  margin: 40px auto 120px auto;
  position: relative;
}
#voice-container .pagenation ul li {
  margin-right: 2%;
  border: none;
}
#voice-container .pagenation ul li a {
  font-size: 1.7rem;
  font-family: "Lato";
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  height: 30px;
  font-size: 1.7rem;
  width: 30px;
  background: #027CCF;
  border-radius: 50px;
  padding: 0;
}
#voice-container .pagenation ul .page-active {
  font-size: 1.7rem;
  font-family: "Lato";
}
#voice-container .pagenation ul .next a, #voice-container .pagenation ul .prev a {
  color: #433F37;
  font-size: 1.7rem;
  background: none;
  width: auto;
  font-family: "Lato";
}
#voice-container .pagenation ul .next {
  position: absolute;
  right: 2%;
  top: 0;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}
#voice-container .pagenation ul .prev {
  position: absolute;
  left: 2%;
  top: 0;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}

.wp-pagenavi {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #F9F9F9;
  padding: 24px 40px;
  margin: 60px auto;
  position: relative;
}
.wp-pagenavi span, .wp-pagenavi a {
  font-size: 1.7rem !important;
  color: #000;
  border: none !important;
}
.wp-pagenavi a {
  color: #027CCF;
}
.wp-pagenavi .larger, .wp-pagenavi .smaller {
  background: #027CCF;
  border-radius: 50px;
  color: #fff;
  padding: 2px 10px;
}
.wp-pagenavi .nextpostslink {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}
.wp-pagenavi .previouspostslink {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 16px;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}
.wp-pagenavi .pages, .wp-pagenavi .extend, .wp-pagenavi .first, .wp-pagenavi .last {
  display: none;
}

#recruit-container #interview .interview-list {
  display: grid;
  gap: 24px;
  margin-top: 24px;
}
#recruit-container #interview .interview-list .interview-box {
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  border: 3px solid #F5F5F5;
  border-radius: 16px;
  padding: 28px;
}
#recruit-container #interview .interview-list .interview-box p {
  font-size: 1.6rem;
  line-height: 1.6;
  margin-top: 8px;
}
#recruit-container #interview .interview-list .interview-box h4 {
  font-size: 2.1rem;
  color: #027CCF;
  font-weight: 600;
  padding-bottom: 2px;
  border-bottom: 1px solid #027CCF;
  margin-top: 24px;
}
#recruit-container #interview .interview-list .interview-box .interview-top {
  display: flex;
  justify-content: space-between;
}
#recruit-container #interview .interview-list .interview-box .interview-top figure {
  width: 30%;
}
#recruit-container #interview .interview-list .interview-box .interview-top figure img {
  -o-object-fit: cover;
     object-fit: cover;
}
#recruit-container #interview .interview-list .interview-box .interview-top .interview-txt {
  width: 65%;
}
#recruit-container #interview .interview-list .interview-box .interview-top .interview-txt h3 {
  font-size: 2.4rem;
  font-weight: 600;
  padding-bottom: 4px;
  border-bottom: 1px solid #C9C9C9;
}
#recruit-container #interview .interview-list .interview-box .interview-top .interview-txt h3 span {
  font-size: 1.5rem;
  color: #B2B2B2;
  font-family: "Lato";
}
#recruit-container #movie {
  background: #027CCF;
  margin-top: 100px;
  padding: 60px 0;
}
#recruit-container #movie h2, #recruit-container #movie span {
  color: #fff;
}
#recruit-container #movie .js-modal-btn {
  margin: 0 auto;
  max-width: 600px;
  width: 90%;
  margin-top: 24px;
  cursor: pointer;
  height: -moz-fit-content;
  height: fit-content;
  transition: all ease 0.5s;
}
#recruit-container #movie .js-modal-btn:hover {
  opacity: 0.7;
}
#recruit-container #flow {
  margin-top: 80px;
}
#recruit-container #flow .flow-contents {
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  border: 3px solid #F5F5F5;
  border-radius: 16px;
  padding: 28px;
  margin-top: 16px;
}
#recruit-container #flow .flow-contents .flow-list {
  display: grid;
  gap: 24px;
}
#recruit-container #flow .flow-contents .flow-list .flow-box {
  display: flex;
  justify-content: space-between;
}
#recruit-container #flow .flow-contents .flow-list .flow-box figure {
  width: 25%;
}
#recruit-container #flow .flow-contents .flow-list .flow-box figure img {
  -o-object-fit: cover;
     object-fit: cover;
}
#recruit-container #flow .flow-contents .flow-list .flow-box .flow-txt {
  width: 70%;
}
#recruit-container #flow .flow-contents .flow-list .flow-box .flow-txt h3 {
  font-size: 2.1rem;
  color: #027CCF;
  font-weight: 600;
  padding-bottom: 2px;
  border-bottom: 1px solid #027CCF;
}
#recruit-container #flow .flow-contents .flow-list .flow-box .flow-txt p {
  font-size: 1.6rem;
  line-height: 1.6;
  margin-top: 8px;
}
#recruit-container #flow .flow-contents .flow-list .flow-box .flow-txt h3 + h3 {
  margin-top: 16px;
}
#recruit-container #info table {
  width: 100%;
  margin-top: 16px;
}
#recruit-container #info table tr {
  border: 1px solid #DEDEDE;
}
#recruit-container #info table tr th, #recruit-container #info table tr td {
  font-size: 1.7rem;
  padding: 16px;
}
#recruit-container #info table tr th {
  width: 200px;
  background: #F9F9F9;
  font-weight: 500;
  color: #027CCF;
  text-align: left;
}
#recruit-container #info table tr td {
  width: calc(100% - 200px);
}
#recruit-container #info table tr td a {
  pointer-events: none;
  color: #202020;
}
#recruit-container #entry {
  margin-top: 80px;
}
#recruit-container #entry .entry-wrap {
  background: linear-gradient(180deg, rgb(2, 124, 207), rgb(49, 156, 229));
  padding: 40px 0 80px 0;
  margin-top: 16px;
}
#recruit-container #entry form {
  margin-top: 16px;
  padding: 40px;
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  border: 2px solid #F5F5F5;
  border-radius: 16px;
}
#recruit-container #entry form dl div {
  padding: 12px 0;
}
#recruit-container #entry form dl div dt, #recruit-container #entry form dl div dd {
  color: #2E2E2E;
}
#recruit-container #entry form dl div dt {
  font-size: 1.6rem;
  display: flex;
  align-items: center;
}
#recruit-container #entry form dl div dt span.hissu {
  color: #fff;
  background: #027CCF;
  line-height: 1;
  font-size: 1.4rem;
  padding: 4px 6px;
  margin-right: 6px;
}
#recruit-container #entry form dl div dt br {
  display: none;
}
#recruit-container #entry form dl div dt .fix {
  display: block;
}
#recruit-container #entry form dl div dd {
  margin-top: 6px;
}
#recruit-container #entry form dl div dd input, #recruit-container #entry form dl div dd textarea {
  width: 100%;
  font-size: 1.6rem;
  padding: 16px 16px;
  background: #fff;
  border: 1px solid #D8D8D8;
  box-sizing: border-box;
  width: 100%;
  border-radius: 3px;
}
#recruit-container #entry form dl .title-top {
  align-items: flex-start;
}
#recruit-container #entry form dl .file-wrap dd label {
  color: #656172;
}
#recruit-container #entry form dl .file-wrap dd input {
  background: none;
  border: none;
  padding: 0;
  width: auto;
  font-weight: 400;
  color: #858585;
}
#recruit-container #entry form .check {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 24px;
}
#recruit-container #entry form .check label, #recruit-container #entry form .check input {
  font-weight: 500;
  cursor: pointer;
  margin: 0 0 4px 0;
  font-size: 1.7rem;
}
#recruit-container #entry form .check input {
  width: 16px;
  height: 16px;
  margin-right: 4px;
}
#recruit-container #entry form .tyuui {
  color: #A7A7A7;
  font-size: 1.5rem;
  background: #fff;
  padding: 24px;
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#recruit-container #entry form .tyuui h3 {
  font-size: 2.1rem;
  text-align: center;
  font-weight: 600;
  margin-bottom: 12px;
}
#recruit-container #entry form .tyuui p {
  width: -moz-fit-content;
  width: fit-content;
}
#recruit-container #entry form .btn-group {
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 40px auto 0 auto;
}
#recruit-container #entry form .btn-group input[type=submit] {
  border: none;
  font-size: 1.8rem;
  -webkit-appearance: none;
  padding: 12px 77px;
  background: #027CCF;
  color: #ffffff;
}
#recruit-container #entry .wpcf7-list-item-label {
  margin: 0 24px 8px 0;
}

#news-container .news-list {
  max-width: 900px;
  width: 90%;
  margin: 60px auto 100px auto;
}
#news-container .news-list li {
  border-bottom: 1px solid #DEDEDE;
}
#news-container .news-list li:first-child {
  border-top: 1px solid #DEDEDE;
}
#news-container .news-list li a {
  padding: 16px 24px 16px 16px;
  display: flex;
  position: relative;
}
#news-container .news-list li a::after {
  content: "";
  background: url(../images/btn-arrow.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 6px;
  margin: auto;
}
#news-container .news-list li a time {
  width: 110px;
  font-size: 1.7rem;
  font-family: "Lato";
}
#news-container .news-list li a span {
  width: 80px;
  font-size: 1.4rem;
  text-align: center;
  padding: 2px 6px;
  margin-right: 28px;
  height: -moz-fit-content;
  height: fit-content;
  display: block;
}
#news-container .news-list li a .cat_none {
  background: #DFDFDF;
}
#news-container .news-list li a .cat_event {
  background: #AFEA00;
}
#news-container .news-list li a .cat_new {
  background: #FFD24D;
}
#news-container .news-list li a h3 {
  width: calc(100% - 190px);
  font-size: 1.7rem;
  font-weight: 500;
}
#news-container #news-detail {
  margin-bottom: 100px;
}
#news-container #news-detail time {
  font-size: 1.5rem;
  color: #027CCF;
  font-family: "Lato";
}
#news-container #news-detail h1 {
  font-size: 2.4rem;
  color: #027CCF;
  font-weight: 600;
  color: #027CCF;
  margin-bottom: 16px;
}
#news-container #news-detail h2 {
  font-size: 2.1rem;
  color: #fff;
  font-weight: 600;
  color: #fff;
  background: #027CCF;
  padding: 4px 12px;
  margin-bottom: 16px;
}
#news-container #news-detail h3 {
  font-size: 2.1rem;
  line-height: 1.4;
  color: #027CCF;
  font-weight: 600;
  padding-bottom: 4px;
  border-bottom: 1px solid #027CCF;
  margin-bottom: 12px;
}
#news-container #news-detail h4 {
  font-size: 2rem;
  color: #027CCF;
  font-weight: 600;
}
#news-container #news-detail h5 {
  font-size: 1.8rem;
  font-weight: 600;
}
#news-container #news-detail h6 {
  font-size: 1.7rem;
  font-weight: 500;
}
#news-container #news-detail p {
  font-size: 1.6rem;
}
#news-container #news-detail a {
  color: #027CCF;
  text-decoration: underline;
}
#news-container #news-detail figure {
  margin: 1em 0;
}
#news-container #news-detail img {
  margin: 1em 0;
  max-width: 100%;
  width: auto;
}
#news-container #news-detail .news-btn {
  background: #F9F9F9;
  padding: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #202020;
  margin-top: 32px;
}
#news-container #news-detail .news-btn::before {
  content: "";
  background: url(../images/btn-arrow.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 16px;
  transform: rotate(180deg);
  margin-right: 8px;
}
#news-container .pagenation ul {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #F9F9F9;
  padding: 18px 40px;
  margin: 40px auto;
  position: relative;
}
#news-container .pagenation ul li {
  margin-right: 2%;
  border: none;
}
#news-container .pagenation ul li a {
  font-size: 1.7rem;
  font-family: "Lato";
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  height: 30px;
  font-size: 1.7rem;
  width: 30px;
  background: #027CCF;
  border-radius: 50px;
  padding: 0;
}
#news-container .pagenation ul .page-active {
  font-size: 1.7rem;
  font-family: "Lato";
}
#news-container .pagenation ul .next a, #news-container .pagenation ul .prev a {
  color: #433F37;
  font-size: 1.7rem;
  background: none;
  width: auto;
  font-family: "Lato";
}
#news-container .pagenation ul .next {
  position: absolute;
  right: 2%;
  top: 0;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}
#news-container .pagenation ul .prev {
  position: absolute;
  left: 2%;
  top: 0;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
}

#products-container {
  margin-bottom: 100px;
}
#products-container .products-wrap h2 {
  font-size: 2.4rem;
  color: #027CCF;
  font-weight: 600;
  padding-bottom: 4px;
  border-bottom: 1px solid #027CCF;
  margin-bottom: 16px;
}
#products-container .products-wrap .products-list {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr 1fr;
}
#products-container .products-wrap .products-list .products-item {
  display: contents;
}
#products-container .products-wrap .products-list .products-item a {
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  border: 3px solid #F5F5F5;
  border-radius: 16px;
  padding: 16px;
  display: flex;
  justify-content: space-between;
}
#products-container .products-wrap .products-list .products-item a figure {
  width: 35%;
}
#products-container .products-wrap .products-list .products-item a figure img {
  -o-object-fit: cover;
     object-fit: cover;
}
#products-container .products-wrap .products-list .products-item a .products-txt {
  width: 60%;
}
#products-container .products-wrap .products-list .products-item a .products-txt h3 {
  font-size: 1.8rem;
  color: #027CCF;
  font-weight: 600;
  margin-bottom: 2px;
}
#products-container .products-wrap .products-list .products-item a .products-txt p {
  font-size: 1.5rem;
  line-height: 1.4;
}
#products-container .products-wrap .products-list .products-item a .products-txt p br {
  display: none;
}
#products-container .products-wrap .products-list .products-item a .products-txt .btn {
  margin-top: 12px;
}
#products-container .products-wrap + .products-wrap {
  margin-top: 36px;
}

#company-container {
  margin-bottom: 100px;
}
#company-container #company table {
  width: 100%;
  margin-top: 16px;
}
#company-container #company table tr {
  border: 1px solid #DEDEDE;
}
#company-container #company table tr th, #company-container #company table tr td {
  font-size: 1.7rem;
  padding: 16px;
}
#company-container #company table tr th {
  width: 200px;
  background: #F9F9F9;
  font-weight: 500;
  color: #027CCF;
  text-align: left;
}
#company-container #company table tr td {
  width: calc(100% - 200px);
}
#company-container #company table tr td a {
  pointer-events: none;
  color: #202020;
}
#company-container #access .access-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 16px;
}
#company-container #access .access-wrap .access-map h3 {
  font-size: 2.1rem;
  color: #fff;
  text-align: center;
  font-weight: 600;
  padding: 4px 0;
  background: #027CCF;
}
#company-container #access .access-wrap .access-map iframe {
  width: 100%;
  height: 240px;
}

#contact-container {
  margin-bottom: 100px;
}
#contact-container .contact-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
}
#contact-container .contact-list li {
  background: #F2F2F2;
  height: 60px;
  display: grid;
  place-items: center;
  position: relative;
}
#contact-container .contact-list li h3 {
  font-size: 1.8rem;
  color: #fff;
  font-weight: 500;
  padding: 2px 16px;
  background: #027CCF;
  position: absolute;
  top: -16px;
  left: 0;
  right: 0;
  margin: auto;
  width: -moz-fit-content;
  width: fit-content;
}
#contact-container .contact-list li p {
  color: #027CCF;
  font-family: "Lato";
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  margin-top: 16px;
}
#contact-container .contact-list li:nth-child(1) p, #contact-container .contact-list li:nth-child(2) p {
  font-size: 2.4rem;
}
#contact-container .contact-list li:nth-child(1) a {
  pointer-events: none;
}
#contact-container .contact-list li:nth-child(1) p::before {
  content: "";
  background: url(../images/tel.svg) no-repeat;
  background-size: contain;
  width: 18px;
  height: 18px;
  margin-right: 6px;
  display: block;
}
#contact-container .contact-list li:nth-child(2) p::before {
  content: "";
  background: url(../images/contact/fax.svg) no-repeat;
  background-size: contain;
  width: 21px;
  height: 20px;
  margin-right: 6px;
}
#contact-container .contact-list li:nth-child(3) p {
  font-size: 1.8rem;
}
#contact-container .contact-list li:nth-child(3) p::before {
  content: "";
  background: url(../images/contact/mail.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 11px;
  margin-right: 6px;
}
#contact-container #contact {
  margin-top: 80px;
}
#contact-container #contact form {
  margin-top: 16px;
  padding: 32px;
  background: linear-gradient(90deg, rgb(245, 245, 245), rgb(255, 255, 255));
  border: 3px solid #F5F5F5;
  border-radius: 16px;
}
#contact-container #contact form dl div {
  padding: 12px 0;
  display: flex;
  align-items: center;
}
#contact-container #contact form dl div dt, #contact-container #contact form dl div dd {
  color: #2E2E2E;
}
#contact-container #contact form dl div dt {
  width: 168px;
  font-size: 1.5rem;
  display: flex;
  align-items: self-start;
}
#contact-container #contact form dl div dt span.hissu {
  color: #fff;
  background: #027CCF;
  line-height: 1;
  font-size: 1.4rem;
  padding: 4px 6px;
  margin-right: 6px;
}
#contact-container #contact form dl div dt br {
  display: none;
}
#contact-container #contact form dl div dt .sp {
  display: block;
}
#contact-container #contact form dl div dt .fix {
  display: block;
}
#contact-container #contact form dl div dd {
  width: calc(100% - 168px);
}
#contact-container #contact form dl div dd input, #contact-container #contact form dl div dd textarea {
  width: 100%;
  font-size: 1.6rem;
  padding: 16px 16px;
  background: #fff;
  border: 1px solid #D8D8D8;
  box-sizing: border-box;
  width: 100%;
  border-radius: 3px;
}
#contact-container #contact form dl div .checkbox {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
#contact-container #contact form dl div .checkbox .wpcf7-form-control-wrap {
  margin-bottom: 12px;
  width: 100%;
}
#contact-container #contact form dl div .checkbox .wpcf7-form-control-wrap .first {
  width: 100%;
}
#contact-container #contact form dl div .checkbox .wpcf7-text {
  width: 100%;
}
#contact-container #contact form dl div .checkbox label {
  font-size: 1.6rem;
  margin: 0 24px 8px 0;
  cursor: pointer;
}
#contact-container #contact form dl div .checkbox label:first-child {
  width: 100%;
}
#contact-container #contact form dl div .checkbox label input[type=checkbox] {
  width: -moz-fit-content;
  width: fit-content;
}
#contact-container #contact form dl .title-top {
  align-items: flex-start;
}
#contact-container #contact form dl .file-wrap dd label {
  color: #656172;
}
#contact-container #contact form dl .file-wrap dd input {
  background: none;
  border: none;
  padding: 0;
  width: auto;
  font-weight: 400;
  color: #858585;
}
#contact-container #contact form .check {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 24px;
}
#contact-container #contact form .check label, #contact-container #contact form .check input {
  font-weight: 500;
  cursor: pointer;
  margin: 0 0 4px 0;
  font-size: 1.7rem;
}
#contact-container #contact form .check input {
  width: 16px;
  height: 16px;
  margin-right: 4px;
}
#contact-container #contact form .tyuui {
  color: #A7A7A7;
  font-size: 1.5rem;
  background: #fff;
  padding: 24px;
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#contact-container #contact form .tyuui h3 {
  font-size: 2.1rem;
  text-align: center;
  font-weight: 600;
  margin-bottom: 12px;
}
#contact-container #contact form .tyuui p {
  width: -moz-fit-content;
  width: fit-content;
}
#contact-container #contact form .btn-group {
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 40px auto 0 auto;
}
#contact-container #contact form .btn-group input[type=submit] {
  border: none;
  font-size: 1.8rem;
  -webkit-appearance: none;
  cursor: pointer;
  padding: 12px 77px;
  background: #027CCF;
  color: #ffffff;
}
#contact-container #contact form .btn-group input[type=submit]:hover {
  background: #005C9B;
}
#contact-container #contact .wpcf7-list-item-label {
  margin: 0 24px 8px 0;
}

.wpcf7-not-valid-tip {
  font-size: 1.3rem !important;
}

.wpcf7-response-output {
  font-size: 2.4rem;
  font-weight: 600;
  text-align: center;
  color: red;
}

.wpcf7-spinner {
  position: absolute !important;
}

#privacy-container {
  margin-bottom: 100px;
}
#privacy-container .privacy-list {
  display: grid;
  gap: 32px;
}
#privacy-container .privacy-list .privacy-item h2 {
  font-size: 2.4rem;
  font-weight: 600;
  color: #027CCF;
  padding-bottom: 4px;
  border-bottom: 1px solid #027CCF;
  margin-bottom: 16px;
  font-feature-settings: "palt";
}
#privacy-container .privacy-list .privacy-item p {
  font-size: 1.6rem;
  line-height: 1.6;
}
#privacy-container .privacy-list .privacy-item ol {
  padding-left: 4em;
  margin: 12px 0;
}
#privacy-container .privacy-list .privacy-item ol li {
  list-style: decimal;
  font-size: 1.6rem;
  line-height: 1.6;
}
#privacy-container .privacy-list .privacy-item table {
  width: 100%;
  margin-top: 12px;
}
#privacy-container .privacy-list .privacy-item table tr {
  border: 1px solid #DEDEDE;
}
#privacy-container .privacy-list .privacy-item table tr th, #privacy-container .privacy-list .privacy-item table tr td {
  font-size: 1.6rem;
  padding: 16px;
}
#privacy-container .privacy-list .privacy-item table tr th {
  width: 160px;
  background: #F9F9F9;
  font-weight: 500;
  color: #027CCF;
  text-align: left;
}
#privacy-container .privacy-list .privacy-item table tr td {
  width: calc(100% - 160px);
}
#privacy-container .privacy-list .privacy-item table tr td .sp {
  display: none;
}
#privacy-container .privacy-list .privacy-item table tr td a {
  color: #202020;
  pointer-events: none;
}

#contents-404 h2 {
  font-size: 2.8rem;
  text-align: center;
  font-weight: 600;
}
#contents-404 p {
  font-size: 1.7rem;
  margin: 24px 0 120px 0;
  text-align: center;
}

#global-footer .cta-area {
  width: 100%;
  display: flex;
}
#global-footer .cta-area .cta-img {
  width: 30%;
}
#global-footer .cta-area .cta-img img {
  -o-object-fit: cover;
     object-fit: cover;
}
#global-footer .cta-area .cta-txt {
  width: 40%;
  background: #027CCF;
  padding: 40px 24px;
}
#global-footer .cta-area .cta-txt h2, #global-footer .cta-area .cta-txt span {
  color: #fff;
}
#global-footer .cta-area .cta-txt p {
  font-size: 1.6rem;
  font-weight: 500;
  color: #fff;
  margin: 16px 0;
}
#global-footer .cta-area .cta-txt .cta-btn {
  font-size: 1.6rem;
  font-family: "Lato";
  color: #fff;
  width: 200px;
  border: 1px solid #fff;
  padding: 12px 0;
  position: relative;
  display: block;
  margin: 0 auto;
  text-align: center;
}
#global-footer .cta-area .cta-txt .cta-btn::after {
  content: "";
  background: #fff;
  height: 1px;
  width: 22px;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
#global-footer .footer-bnr {
  background: #fff;
  padding: 40px 0;
}
#global-footer .footer-bnr .bnr-list {
  display: flex;
  align-items: center;
  justify-content: center;
}
#global-footer .footer-bnr .bnr-list li {
  margin: 0.5%;
}
#global-footer .footer-bnr .bnr-list li a {
  display: block;
}
#global-footer .footer-bnr .bnr-list li a img {
  -o-object-fit: contain;
     object-fit: contain;
}
#global-footer .pagetop {
  background: #027CCF;
  font-size: 1.5rem;
  text-align: center;
  color: #fff;
  font-family: "Lato";
  padding: 2px 0;
  position: relative;
  display: block;
}
#global-footer .pagetop::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-left: 14px solid transparent;
  border-right: 14px solid transparent;
  border-bottom: 14px solid #027CCF;
  position: absolute;
  top: -14px;
  left: 0;
  right: 0;
  margin: auto;
}
#global-footer .footer-inner {
  padding: 60px 0 0 0;
  background: #F9F9F9;
}
#global-footer .footer-inner .logo {
  display: block;
  width: 450px;
  margin: 0 auto;
}
#global-footer .footer-inner .info-area {
  display: flex;
  justify-content: center;
  margin: 36px 2%;
}
#global-footer .footer-inner .info-area .info-box {
  background: #F2F2F2;
  padding: 24px;
}
#global-footer .footer-inner .info-area .info-box:first-child {
  margin-right: 2%;
}
#global-footer .footer-inner .info-area .info-box .info-title, #global-footer .footer-inner .info-area .info-box .info-txt {
  font-size: 1.5rem;
  line-height: 1.4;
  text-align: center;
}
#global-footer .footer-inner .info-area .info-box .info-title a, #global-footer .footer-inner .info-area .info-box .info-txt a {
  color: #202020;
  pointer-events: none;
}
#global-footer .footer-inner .info-area .info-box .info-title {
  margin: 0 auto 4px auto;
  width: 84px;
  font-weight: 600;
  color: #fff;
  background: #027CCF;
  padding: 2px 0;
}
#global-footer .footer-inner .info-area .info-box .tel {
  font-size: 2.8rem;
  font-family: "Lato";
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #027CCF;
  pointer-events: none;
}
#global-footer .footer-inner .info-area .info-box .tel::before {
  content: "";
  background: url(../images/tel.svg) no-repeat;
  background-size: contain;
  width: 18px;
  height: 18px;
  display: block;
  margin-right: 6px;
}
#global-footer .footer-inner .info-area .info-box .info-list .info-item {
  display: flex;
}
#global-footer .footer-inner .info-area .info-box .info-list .info-item dt, #global-footer .footer-inner .info-area .info-box .info-list .info-item dd {
  font-size: 1.6rem;
}
#global-footer .footer-inner .info-area .info-box .info-list .info-item dt {
  width: 50px;
  font-weight: 600;
}
#global-footer .footer-inner .info-area .info-box .info-list .info-item dd {
  width: calc(100% - 65px);
}
#global-footer .footer-inner .footer-menu {
  padding: 16px 0;
}
#global-footer .footer-inner .footer-menu .footer-list {
  display: flex;
  justify-content: center;
  margin-top: 16px;
}
#global-footer .footer-inner .footer-menu .footer-list:last-child a {
  color: #ABABAB;
}
#global-footer .footer-inner .footer-menu .footer-list li {
  margin: 0 18px;
}
#global-footer .footer-inner .footer-menu .footer-list li a {
  font-size: 1.5rem;
  color: #202020;
}
#global-footer p.copy_small {
  font-size: 1.2rem;
  text-align: center;
  color: #878787;
  padding: 40px 0 80px 0;
}/*# sourceMappingURL=tb_style.css.map */