@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,100..900&family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200");
/*==================================================================================================
	流用parts
==================================================================================================*/
/*---------------------------------------------------------------------
背景
---------------------------------------------------------------------*/
.-bgGray {
  background-color: #eef2f4;
}

/*---------------------------------------------------------------------
見出し
---------------------------------------------------------------------*/
/*h1.wp-block-heading,
h1.has-background {
  font-size: clamp(1.5em, 2vw, 150%);
  padding: 0.5em;
}
h2.wp-block-heading,
h2.has-background {
  font-size: clamp(1.4em, 1.9vw, 140%);
  padding: 0.5em 1em;
  color: var.$main;
  border-radius: 0.5em;
}
h3.wp-block-heading,
h3.has-background {
  font-size: clamp(1.3em, 1.8vw, 130%);
  padding: 0.5em;
}
h4.wp-block-heading,
h4.has-background {
  font-size: clamp(1.2em, 1.7vw, 120%);
  padding: 0.5em;
}

h5.wp-block-heading,
h5.has-background {
  font-size: clamp(1.1em, 1.6vw, 110%);
  padding: 0.5em;
}
h6.wp-block-heading,
h6.has-background {
  font-size: clamp(1em, 1.5vw, 100%);
  padding: 0.5em;
}
  */
.balloonLabel {
  margin: 2em auto 1em auto;
  font-size: 1.2em;
  background-color: #000;
  color: #fff;
  padding: 0.5em;
  text-align: center;
  line-height: 1.5;
  position: relative;
}
.balloonLabel::before {
  content: "";
  border: solid rgba(0, 0, 0, 0);
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  border-width: 10px;
  margin-left: -10px;
  border-top-color: #000;
  top: 100%;
  left: 50%;
}
.balloonLabel.-gray {
  background-color: #ccc;
}
.balloonLabel.-gray::before {
  border-top-color: #ccc;
}

.lineLabel {
  font-size: clamp(1.3em, 2vw, 250%);
  font-weight: 600;
  margin: 2em auto 1.5em auto;
  padding: 0.5em 0;
  line-height: 1.5;
  position: relative;
}
.lineLabel::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 1em;
  height: 2px;
  background-color: #0080cb;
}
.lineLabel:first-child {
  margin-top: 0;
}
.lineLabel.center {
  text-align: center;
}
.lineLabel.center::before {
  left: 50%;
  transform: translateX(-50%);
}

.enLabel, .enLabelMain4, .enLabelMain3, .enLabelMain2, .enLabelMain, .enLabelWhite {
  font-size: clamp(1.2em, 1.2vw, 130%);
  padding: 0;
  margin: 0 auto;
  line-height: 1.3;
  font-weight: 700;
  letter-spacing: 0.05;
  margin: 0 auto 2em auto;
}
.enLabel span, .enLabelMain4 span, .enLabelMain3 span, .enLabelMain2 span, .enLabelMain span, .enLabelWhite span {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: clamp(2em, 5vw, 300%);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0;
  margin-bottom: 0.2em;
}
.enLabelWhite {
  color: #fff;
}
.enLabelMain {
  color: #0080cb;
}
.enLabelMain2 {
  color: #00a63c;
}
.enLabelMain3 {
  color: #f7eada;
}
.enLabelMain4 {
  color: #aaa;
}

.iconLabel {
  font-size: 1.1em;
  margin: 1em 0;
}
.iconLabel i {
  display: inline-block;
  width: 2.5em;
  height: 2.5em;
  line-height: 2.5;
  border: 1px solid;
  position: relative;
  border-radius: 100px;
  text-align: center;
  margin-right: 0.5em;
}

.centerLabel, .centerLabelWhite, .centerLabelMain2, .centerLabelMain {
  text-align: center;
  font-size: clamp(1.2em, 2.3vw, 240%);
  font-weight: 600;
  letter-spacing: 0.07em;
  color: #0080cb;
  margin: 1em auto 1em auto;
}
.centerLabelMain {
  color: #0080cb;
}
.centerLabelMain2 {
  color: #00a63c;
}
.centerLabelWhite {
  color: #fff;
}

.gradientLabel {
  line-height: 1.7;
  font-size: 1.5em;
}
@media screen and (max-width: 1080px) {
  .gradientLabel {
    font-size: 1.7em;
  }
}
.gradientLabel span {
  padding: 0 0.2em;
  line-height: 1.5;
  color: #fff;
  display: inline-block;
  background: #0080cb;
  background: linear-gradient(90deg, #0080cb 40%, #0080cb 100%);
}

.diagonalLabel, .diagonalLabelWhite {
  font-weight: 600;
  margin: 2em auto 1em auto !important;
  font-size: 1.2em;
  padding-left: 1.5em !important;
  line-height: 1.5 !important;
  position: relative !important;
}
.diagonalLabel span, .diagonalLabelWhite span {
  font-weight: 400 !important;
  font-size: 0.6em !important;
  margin-bottom: 0.7em !important;
  display: block !important;
}
.diagonalLabel::before, .diagonalLabelWhite::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  transform: rotate(20deg);
  width: 1px;
  height: 100%;
  background-color: #000;
}
.diagonalLabelWhite {
  color: #fff;
}
.diagonalLabelWhite::before {
  background-color: #fff;
}

/*---------------------------------------------------------------------
ボタン
---------------------------------------------------------------------*/
.btnWrap {
  margin: 2em auto;
}
@media screen and (max-width: 1080px) {
  .btnWrap {
    text-align: center;
    margin: 1.5em auto;
  }
}
.btnWrap.center a {
  width: 300px;
  max-width: 100%;
}

.btn, body .wp-block-button__link, .btnMain4, .btnMain3, .btnMain2, .btnMain, .btnGray, .btnWhite {
  position: relative;
  font-weight: bold;
  padding: 1em 2.5em;
  display: inline-block;
  border: 1px solid;
  line-height: 1;
  border-radius: 200px;
  min-width: 15em;
  text-align: center;
}
.btnWhite {
  color: #fff;
}
.btnWhite::before, .btnWhite::after {
  background-color: #fff;
}
.btnGray {
  color: #ccc;
}
.btnGray::before, .btnGray::after {
  background-color: #ccc;
}
.btnMain {
  color: #0080cb;
}
.btnMain::before, .btnMain::after {
  background-color: #0080cb;
}
.btnMain2 {
  color: #00a63c;
}
.btnMain2::before, .btnMain2::after {
  background-color: #00a63c;
}
.btnMain3 {
  color: #f7eada;
}
.btnMain3::before, .btnMain3::after {
  background-color: #f7eada;
}
.btnMain4 {
  color: #aaa;
}
.btnMain4::before, .btnMain4::after {
  background-color: #aaa;
}

.btnL, .btnLwhite2, .btnLwhite, .btnLgray, .btnLgrayL, .btnLmain4, .btnLmain3, .btnLmain2, .btnLmain {
  display: inline-block;
  background-color: #fff;
  color: #ccc;
  padding: 1em 2em;
  text-align: center;
  font-weight: bold;
  width: 100%;
  box-shadow: 0 0 1em rgba(0, 0, 0, 0.05);
  overflow: hidden;
  border-radius: 200px;
}
.btnLmain {
  color: #fff;
  background-color: #0080cb;
}
.btnLmain::before, .btnLmain::after {
  content: "";
  display: inline-block;
  color: #fff !important;
}
.btnLmain2 {
  color: #fff;
  background-color: #00a63c;
}
.btnLmain2::before, .btnLmain2::after {
  color: #fff !important;
}
.btnLmain3 {
  color: #fff;
  background-color: #f7eada;
}
.btnLmain3::before, .btnLmain3::after {
  color: #fff !important;
}
.btnLmain4 {
  color: #fff;
  background-color: #aaa;
}
.btnLmain4::before, .btnLmain4::after {
  color: #fff !important;
}
.btnLgrayL {
  color: #000;
  background-color: #eef2f4;
}
.btnLgrayL::before, .btnLgrayL::after {
  color: #000 !important;
}
.btnLgray {
  color: #fff;
  background-color: #ccc;
}
.btnLgray::before, .btnLgray::after {
  color: #fff !important;
}
.btnLwhite {
  color: #0080cb;
  background-color: #fff;
}
.btnLwhite::before, .btnLwhite::after {
  color: #0080cb !important;
}
.btnLwhite2 {
  color: #00a63c;
  background-color: #fff;
}
.btnLwhite2::before, .btnLwhite2::after {
  color: #00a63c !important;
}
.btnL.arrow, .arrow.btnLmain, .arrow.btnLmain2, .arrow.btnLmain3, .arrow.btnLmain4, .arrow.btnLgrayL, .arrow.btnLgray, .arrow.btnLwhite, .arrow.btnLwhite2 {
  position: relative;
  padding: 1em 4em 1em 2em;
}
.btnL.arrow::before, .arrow.btnLmain::before, .arrow.btnLmain2::before, .arrow.btnLmain3::before, .arrow.btnLmain4::before, .arrow.btnLgrayL::before, .arrow.btnLgray::before, .arrow.btnLwhite::before, .arrow.btnLwhite2::before {
  content: "\f061";
  margin-right: 0.2em;
  vertical-align: middle;
  font-family: "Material Symbols Sharp", "Material Symbols Outlined", "Material Symbols Rounded";
  color: #fff;
  position: absolute;
  right: 1.4em;
  top: 50%;
  transform: translateY(-50%);
}
.btnL.arrow::after, .arrow.btnLmain::after, .arrow.btnLmain2::after, .arrow.btnLmain3::after, .arrow.btnLmain4::after, .arrow.btnLgrayL::after, .arrow.btnLgray::after, .arrow.btnLwhite::after, .arrow.btnLwhite2::after {
  content: "";
  display: inline-block;
  width: 2em;
  height: 2em;
  border: 1px solid;
  border-radius: 100px;
  color: #fff;
  position: absolute;
  right: 1em;
  top: 50%;
  transform: translateY(-50%);
}
.btnL.mail::before, .mail.btnLmain::before, .mail.btnLmain2::before, .mail.btnLmain3::before, .mail.btnLmain4::before, .mail.btnLgrayL::before, .mail.btnLgray::before, .mail.btnLwhite::before, .mail.btnLwhite2::before {
  /*content: '\f0e0';
  content: '\e158';*/
  width: 1em;
  height: 1em;
  margin-right: 0.75em;
  background-image: url(../img/common/icon_mail.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}
.btnL.tel, .tel.btnLmain, .tel.btnLmain2, .tel.btnLmain3, .tel.btnLmain4, .tel.btnLgrayL, .tel.btnLgray, .tel.btnLwhite, .tel.btnLwhite2 {
  /*&::before {
    margin-right: 0.5em;
    content: '\f879';
    content: '\e0b0';
  }*/
}
.btnL.search, .search.btnLmain, .search.btnLmain2, .search.btnLmain3, .search.btnLmain4, .search.btnLgrayL, .search.btnLgray, .search.btnLwhite, .search.btnLwhite2 {
  /*&::before {
    margin-right: 0.5em;
    content: '\f002';
    content: '\e8b6';
  }*/
}

/*---------------------------------------------------------------------
リスト
---------------------------------------------------------------------*/
ol {
  list-style-type: decimal;
  margin-left: 2em;
}
ol li {
  margin-bottom: 1em;
}

ul.simpleList {
  list-style: none;
}
ul.simpleList li {
  position: relative;
  line-height: 1.5;
  margin-bottom: 0.75em;
  padding-left: 1.2em;
}
ul.simpleList li::before {
  content: "●";
  display: inline-block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #0080cb;
}
ul.simpleList li:last-child {
  margin-bottom: 0;
}

ul.diamondList li {
  position: relative;
  padding-left: 1.5em;
  line-height: 1.75;
  margin-bottom: 0.5em;
}
ul.diamondList li::before {
  content: "◆";
  position: absolute;
  left: 0;
  top: 0;
}
ul.diamondList li:last-child {
  margin-bottom: 0;
}
ul.diamondList li span {
  color: #0080cb;
}

ul.asteriskList li {
  position: relative;
  line-height: 1.5;
  margin-bottom: 0.75em;
  padding-left: 1.2em;
}
ul.asteriskList li::before {
  content: "※";
  display: inline-block;
  position: absolute;
  left: 0;
  top: 0;
}

ul.timeline {
  list-style: none;
  margin: 2em auto;
}
ul.timeline > li {
  display: flex;
  margin-bottom: 2em;
  line-height: 1.75;
  gap: 1em;
  position: relative;
}
ul.timeline .timeline-date {
  width: 20%;
}
ul.timeline .timeline-content {
  position: relative;
  width: 80%;
}
ul.timeline .timeline-content::before {
  content: "";
  width: 12px;
  height: 12px;
  background: #6fc173;
  position: absolute;
  left: 0;
  top: 0;
  border-radius: 100%;
}
ul.timeline .timeline-content::after {
  content: "";
  position: absolute;
  top: 0;
  left: -2em;
  width: 1px;
  height: calc(100% + 2em);
  border: 1px solid #eee;
  z-index: 2;
}

/*---------------------------------------------------------------------
テーブル
---------------------------------------------------------------------*/
table,
.wp-block-table {
  width: 100%;
  max-width: 100%;
  margin: 1em auto;
  line-height: 1.5;
}
table p,
.wp-block-table p {
  margin-bottom: 0;
}
table tr,
.wp-block-table tr {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
table tr:not(:last-child),
.wp-block-table tr:not(:last-child) {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
table td,
table th,
.wp-block-table td,
.wp-block-table th {
  text-align: left;
  vertical-align: middle !important;
  padding: 1.5em 2em;
  border: none !important;
}
@media screen and (max-width: 1080px) {
  table td,
  table th,
  .wp-block-table td,
  .wp-block-table th {
    padding: 1em;
  }
}
table th,
.wp-block-table th {
  width: 30%;
  white-space: nowrap;
  font-weight: 600;
}
@media screen and (max-width: 1080px) {
  table th,
  .wp-block-table th {
    width: auto;
  }
}
table td,
.wp-block-table td {
  width: 70%;
}
@media screen and (max-width: 1080px) {
  table td,
  .wp-block-table td {
    width: auto;
  }
}

/*---------------------------------------------------------------------
スライダー
---------------------------------------------------------------------*/
.slick-slider {
  position: relative;
}
.slick-slider .slick-dots {
  bottom: -2.5em;
}
.slick-slider .slick-dots li button {
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
}
.slick-slider .slick-dots li button::before {
  position: initial;
  font-size: 1rem;
  width: auto;
  height: auto;
  line-height: 1;
  opacity: 1;
  color: rgba(0, 0, 0, 0.2);
}
.slick-slider .slick-dots li.slick-active button::before {
  color: #fff;
}
.slick-slider .slide-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  margin: auto;
  width: 4em;
  height: 4em;
  z-index: 100;
}
@media screen and (max-width: 1080px) {
  .slick-slider .slide-arrow {
    width: 1.5em;
    height: 1.5em;
  }
}
.slick-slider .slide-arrow:hover {
  opacity: 0.8;
}
.slick-slider .slide-arrow.prev-arrow {
  left: 1em;
}
.slick-slider .slide-arrow.next-arrow {
  right: 1em;
}
.slick-slider button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  padding: 0;
}
.slick-slider .slick-slide {
  overflow: hidden;
}
.slick-slider .slick-slide img {
  width: 100%;
}
@keyframes zoomUp {
  0% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
.slick-slider .add-animation {
  animation: zoomUp 10s linear 0s normal both;
}

/*---------------------------------------------------------------------
タブ
---------------------------------------------------------------------*/
.tab-group {
  list-style: none;
}
.tab-group .tab-button {
  display: flex;
  justify-content: space-between;
  list-style: none;
  cursor: pointer;
}
.tab-group .tab-button .tab {
  flex: 1;
  width: 100%;
  padding: 1em;
  line-height: 1.5;
  background-color: #eef2f4;
  color: #0080cb;
}
.tab-group .tab-button .tab.is-active {
  background-color: #0080cb;
  color: #fff;
}
.tab-group .tab-contents .content {
  display: none;
}
.tab-group .tab-contents .content.is-display {
  display: block;
}

/*---------------------------------------------------------------------
アコーディオン
---------------------------------------------------------------------*/
.accordionBox details, .qaBox details,
.accordionBox summary,
.qaBox summary {
  position: relative;
  list-style: none;
  display: block;
  list-style: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  box-shadow: none;
  outline: none;
}
.accordionBox details, .qaBox details {
  margin: 0 0 1em 0;
  box-shadow: 0 0 5px rgba(0, 128, 203, 0.2);
}
.accordionBox details > div, .qaBox details > div {
  padding: 2em;
  background-color: #fff;
}
@media screen and (max-width: 1080px) {
  .accordionBox details > div, .qaBox details > div {
    padding: 1.5em;
  }
}
.accordionBox details > div p, .qaBox details > div p {
  line-height: 1.75;
  margin-bottom: 1em;
}
.accordionBox details > div p:last-child, .qaBox details > div p:last-child {
  margin-bottom: 0;
}
.accordionBox details summary, .qaBox details summary {
  cursor: pointer;
  background-color: rgba(0, 128, 203, 0.1);
  color: #0080cb;
  font-size: 1.1em;
  padding: 1em 2em 1em 1em;
  line-height: 1.5;
}
.accordionBox details summary::-webkit-details-marker, .qaBox details summary::-webkit-details-marker, .accordionBox details summary::marker, .qaBox details summary::marker {
  display: none;
}
.accordionBox details::after, .qaBox details::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 1.5em;
  line-height: 1;
  width: 1em;
  height: 1em;
  display: inline-block;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(../img/common/icon_open.svg);
  pointer-events: none;
}
.accordionBox details[open]::after, .qaBox details[open]::after {
  background-image: url(../img/common/icon_close.svg);
}

/*FAQ,Q&A*/
.qaBox details {
  margin-bottom: 1.5em;
}
.qaBox details summary {
  padding-left: 3em;
  text-align: left;
}
.qaBox .qaA {
  position: relative;
  padding: 1em;
  border-radius: 0.5em;
  margin: 1em 0 0 2em;
  color: #0080cb;
  background-color: #eef2f4;
}
.qaBox summary::before,
.qaBox .qaA::before {
  content: "Q";
  position: absolute;
  left: 0.5em;
  top: 0.5em;
  width: 1em;
  height: 1em;
  text-align: center;
  line-height: 1;
  font-family: "Inter", sans-serif;
  font-size: 2.5rem;
  pointer-events: none;
}
@media screen and (max-width: 1080px) {
  .qaBox summary::before,
  .qaBox .qaA::before {
    font-size: 2rem;
  }
}
.qaBox .qaA::before {
  content: none;
  /*
  content: 'A';
  top: 1.5em;
  color: var.$main;
  @include mixin.max-screen(var.$screen-lg) {
    top: 1em;
  }
    */
}

/*==================================================================================================
	Wordpress用 scss
==================================================================================================*/
/*---------------- ページタイトル ----------------*/
.sec-pagettl {
  width: 100%;
  position: relative;
  background-color: #fff;
}
.sec-pagettl .pagettl__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  filter: brightness(85%);
  aspect-ratio: 5/1;
}
@media screen and (max-width: 1080px) {
  .sec-pagettl .pagettl__img img {
    aspect-ratio: 3/1;
  }
}
.sec-pagettl .pagettl__txt {
  width: 100%;
  padding: 5em 0 3em 0;
  z-index: 2;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1080px) {
  .sec-pagettl .pagettl__txt {
    flex-wrap: wrap;
    padding: 2em 0;
  }
}
.sec-pagettl .pagettl__txt_ttl {
  display: block;
  padding: 0;
  margin: 0;
  font-size: clamp(1.5em, 2.8vw, 280%);
  line-height: 2;
  font-weight: 600;
}
.sec-pagettl .pagettl__txt_en {
  text-transform: capitalize;
  font-weight: 600;
  line-height: 1.2;
  display: block;
  font-size: 0.4em;
  margin-bottom: 0.5em;
  font-family: "Inter", sans-serif;
  position: relative;
  color: #0080cb;
}
.sec-pagettl .pagettl__txt_en::before {
  content: "";
  display: inline-block;
  width: 0.5em;
  height: 0.5em;
  border-radius: 100%;
  font-weight: bold;
  border: 2px solid #0080cb;
  vertical-align: middle;
  margin-right: 0.5em;
}
.sec-pagettl .pagettl__txt_excerpt {
  display: block;
  font-size: clamp(0.8em, 1.2vw, 90%);
  line-height: 1.8;
  margin-top: 1em;
  margin-left: auto;
  max-width: 60%;
  word-break: auto-phrase;
}
@media screen and (max-width: 1080px) {
  .sec-pagettl .pagettl__txt_excerpt {
    width: 100%;
    max-width: 100%;
  }
}

/*---------------- パンくずリスト ----------------*/
.sec-breadcrumb {
  width: 100%;
}
.sec-breadcrumb .breadCrumb,
.sec-breadcrumb .p-breadcrumb,
.sec-breadcrumb #breadcrumb {
  padding-left: 5vw;
  padding-right: 5vw;
}
@media screen and (max-width: 1200px) {
  .sec-breadcrumb .breadCrumb,
  .sec-breadcrumb .p-breadcrumb,
  .sec-breadcrumb #breadcrumb {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}
@media screen and (max-width: 860px) {
  .sec-breadcrumb .breadCrumb,
  .sec-breadcrumb .p-breadcrumb,
  .sec-breadcrumb #breadcrumb {
    padding-left: 7vw;
    padding-right: 7vw;
  }
}
.sec-breadcrumb .breadCrumb,
.sec-breadcrumb .p-breadcrumb,
.sec-breadcrumb #breadcrumb {
  width: initial;
  text-align: left;
  font-size: 0.8em;
  margin: 1em 0 2em 0;
  color: #ccc;
}
@media screen and (max-width: 1080px) {
  .sec-breadcrumb .breadCrumb,
  .sec-breadcrumb .p-breadcrumb,
  .sec-breadcrumb #breadcrumb {
    display: none;
  }
}
.sec-breadcrumb .breadCrumb ul,
.sec-breadcrumb .p-breadcrumb ul,
.sec-breadcrumb #breadcrumb ul {
  display: flex;
  gap: 1em;
}
.sec-breadcrumb .breadCrumb ul li a::after,
.sec-breadcrumb .p-breadcrumb ul li a::after,
.sec-breadcrumb #breadcrumb ul li a::after {
  content: "";
  display: inline-block;
  width: 0.4em;
  height: 0.4em;
  margin: 0 0 0.1em 0.8em;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
  transform: rotate(45deg);
  pointer-events: none;
}
.sec-breadcrumb .breadCrumb a,
.sec-breadcrumb .p-breadcrumb a,
.sec-breadcrumb #breadcrumb a {
  color: #000;
}

/*---------------------------------------------------------------------
投稿・アーカイブ関連
---------------------------------------------------------------------*/
.sec-archive {
  width: 100%;
}

.no-posts {
  width: 100%;
  display: block;
  text-align: center;
}

.sec-taxonomy {
  width: 100%;
}
.sec-taxonomy .termLabel {
  font-size: clamp(1.3em, 2.2vw, 130%);
  color: #000;
  border-left: 0.2em solid #0080cb;
  padding-left: 0.5em;
}

/*ページナビゲーション*/
.sec-pagenavi {
  width: 100%;
  margin-bottom: 4em;
}
.sec-pagenavi .pagenavi,
.sec-pagenavi .wp-pagenavi {
  text-align: center;
  clear: both;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.sec-pagenavi .pagenavi a,
.sec-pagenavi .pagenavi span,
.sec-pagenavi .wp-pagenavi a,
.sec-pagenavi .wp-pagenavi span {
  color: #000;
  border: 1px solid #000 !important;
  display: inline-block;
  line-height: 1;
  padding: 1em 1.25em;
  margin: 0.25em;
  text-decoration: none;
}
.sec-pagenavi .pagenavi span[aria-current~=page],
.sec-pagenavi .pagenavi .current,
.sec-pagenavi .pagenavi a:hover,
.sec-pagenavi .pagenavi span:hover,
.sec-pagenavi .wp-pagenavi span[aria-current~=page],
.sec-pagenavi .wp-pagenavi .current,
.sec-pagenavi .wp-pagenavi a:hover,
.sec-pagenavi .wp-pagenavi span:hover {
  color: #fff;
  background-color: #000;
}
.sec-pagenavi .pagenavi .pages:hover,
.sec-pagenavi .wp-pagenavi .pages:hover {
  color: #000;
  background-color: #eef2f4;
}
.sec-pagenavi .pagenavi span.current,
.sec-pagenavi .wp-pagenavi span.current {
  font-weight: bold;
}

/*前へ・次へ・一覧に戻るボタン*/
.sec-article-btn {
  text-align: center;
}
.sec-article-btn a {
  text-decoration: none;
}

.sidebar__wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 4em;
}
@media screen and (max-width: 1080px) {
  .sidebar__wrap {
    gap: 0;
  }
}
.sidebar__right {
  width: calc(80% - 2em);
}
@media screen and (max-width: 1080px) {
  .sidebar__right {
    width: 100%;
    order: 1;
  }
}
.sidebar__right .termTtl {
  font-weight: bold;
}
.sidebar__left {
  width: calc(20% - 2em);
}
@media screen and (max-width: 1080px) {
  .sidebar__left {
    width: 100%;
    order: 2;
  }
}
.sidebar__left .sideTtl {
  font-family: "Inter", sans-serif;
  font-size: 1.2em;
  font-weight: 700;
  margin: 0 0 1em 0;
  padding: 0;
  letter-spacing: 0;
}
.sidebar__left .sideList {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}
@media screen and (max-width: 1080px) {
  .sidebar__left .sideList {
    gap: 0.5em;
  }
}
.sidebar__left .sideList li {
  width: 100%;
}
@media screen and (max-width: 1080px) {
  .sidebar__left .sideList li {
    width: calc(50% - 0.25em);
  }
}
.sidebar__left .sideList li a {
  text-align: center;
  position: relative;
  width: 100%;
  font-weight: 700;
  border: 1px solid;
  border-radius: 100px;
  padding: 0.5em 1em;
  line-height: 1.2;
}
.sidebar__left .sideList li.current a {
  background-color: #000;
  color: #fff;
}

/*---------------------------------------------------------------------
記事共通
---------------------------------------------------------------------*/
.sec-article {
  width: 100%;
}
.sec-article .inner h1,
.sec-article .inner h2,
.sec-article .inner h3,
.sec-article .inner h4,
.sec-article .inner h5,
.sec-article .inner h6 {
  margin: 1em auto;
  padding: 0;
  letter-spacing: 0.1em;
  font-weight: 600;
}
.sec-article .inner h1.right,
.sec-article .inner h2.right,
.sec-article .inner h3.right,
.sec-article .inner h4.right,
.sec-article .inner h5.right,
.sec-article .inner h6.right {
  text-align: right;
}
.sec-article .inner h1.left,
.sec-article .inner h2.left,
.sec-article .inner h3.left,
.sec-article .inner h4.left,
.sec-article .inner h5.left,
.sec-article .inner h6.left {
  text-align: left;
}
.sec-article .inner h1.center,
.sec-article .inner h2.center,
.sec-article .inner h3.center,
.sec-article .inner h4.center,
.sec-article .inner h5.center,
.sec-article .inner h6.center {
  text-align: center;
}
.sec-article .inner {
  /*
  h1 {
    position: relative;
    font-size: clamp(2rem, 3vw, 200%);
    display: block;
    padding: 0;
  }
  h2 {
    position: relative;
    font-size: clamp(1.8rem, 2.4vw, 180%);
    font-weight: 300;
    background: none;
    padding: 0 0 1em 0;
    &::before {
      content: '';
      width: 15%;
      height: 1px;
      background-color: var.$base;
      position: absolute;
      left: 0;
      bottom: 0;
    }
  }
  h3 {
    font-size: clamp(1.7rem, 2.3vw, 155%);
    font-weight: 300;
    line-height: 1.6;
    color: var.$text;
    background: none;
    border: none;
    //&:before {
    //  content: "◆";
    //  font-size: 0.8em;
    //  margin-right: 0.3em;
    //}
  }

  h4 {
    font-size: clamp(1.6rem, 2.2vw, 140%);
  }
    */
}
.sec-article .inner ul,
.sec-article .inner ol {
  padding: 0 !important;
  margin: initial !important;
}
.sec-article .inner p {
  line-height: 2;
  margin-bottom: 1.5em;
}
.sec-article .inner p a {
  color: #0080cb;
  text-decoration: underline;
}
.sec-article .inner p.right {
  text-align: right;
}
.sec-article .inner p.left {
  text-align: left;
}
.sec-article .inner p.center {
  text-align: center;
}
.sec-article .flexWrap {
  margin-bottom: 5%;
}

/*---------------- 下層ページリンク ----------------*/
.sec-pagelink > .mContainer {
  padding-top: 2em;
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item {
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 1080px) {
  .sec-pagelink ul.pagelink__list.flexWrap .pagelink__item {
    width: 100%;
  }
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item a {
  display: flex;
  align-items: center;
  padding: 3em 2em;
  width: 100%;
}
@media screen and (max-width: 1080px) {
  .sec-pagelink ul.pagelink__list.flexWrap .pagelink__item a {
    padding: 2em;
  }
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item .txt {
  position: relative;
  width: 100%;
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: clamp(1.3rem, 3vw, 2rem);
  color: #fff;
  line-height: 1;
  padding-right: 1.5em;
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item .txt span {
  display: block;
  font-weight: 600;
  font-size: 0.5em;
  margin-top: 1em;
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item .txt::before {
  content: "";
  display: inline-block;
  position: absolute;
  right: 0;
  top: 0;
  width: 1.5em;
  height: 1.5em;
  background-image: url(../img/common/arrow_main.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item .img {
  z-index: -1;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}
.sec-pagelink ul.pagelink__list.flexWrap .pagelink__item .img img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
}

/*==================================================================================================
	Wordpressブロックエディタ・テーマ上書き用 scss
==================================================================================================*/
/*---------------------------------------------------------------------
ブロックエディタ上書き
---------------------------------------------------------------------*/
body .wp-block-columns {
  --wp-column-gap: 3% !important;
  gap: 3% !important;
  margin-bottom: 5% !important;
}
body .is-style-card.wp-block-media-text {
  box-shadow: none !important;
}
body .wp-block-media-text__content {
  padding: 2em;
}
@media (max-width: 600px) {
  body .wp-block-media-text__content {
    padding: 2em 0;
  }
}
body .lum-lightbox-inner img {
  max-height: 100%;
  max-width: initial;
  height: auto;
  width: auto;
}
@media (max-width: 460px) {
  body .lum-lightbox-inner img {
    max-width: 100% !important;
  }
}
body .alignwide {
  width: 100%;
  left: initial;
}
body .alignfull .inner {
  padding: 0;
}
@media (max-width: 1200px) {
  body .alignfull .inner {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}
@media (max-width: 600px) {
  body .alignfull .inner {
    padding-left: 7vw;
    padding-right: 7vw;
  }
}
body .wp-block-gallery img {
  border-radius: 0;
}
body .wp-block-button {
  display: block;
}
body .wp-block-button__link {
  margin: 1em auto;
  width: 100%;
  display: block;
  max-width: 100%;
}

/*==================================================================================================
	Wordpress カスタム投稿基本スタイル（お知らせ関連）
==================================================================================================*/
/*---------------------------------------------------------------------
一覧ページ
---------------------------------------------------------------------*/
.-news-archive {
  background-color: #eef2f4;
}

/* お知らせリスト */
.news__list {
  margin: 2em auto;
}
.news__item {
  border-top: 1px solid #e3e3e3;
}
.news__item:last-child {
  border-bottom: 1px solid #e3e3e3;
}
.news__item a {
  position: relative;
  display: block;
  padding: 1em 0;
}
.news__item .ttl {
  display: block;
  line-height: 1.5;
  width: 100%;
}

.newscard__list {
  margin: 2em auto;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5em;
}
@media screen and (max-width: 1080px) {
  .newscard__list {
    gap: 1em;
  }
}
.newscard__item {
  width: calc(33.3% - 1em);
  border-top: 1px solid #eef2f4;
  margin: 0 0 1em 0;
}
@media screen and (max-width: 1080px) {
  .newscard__item {
    width: calc(50% - 0.5em);
  }
}
.newscard__item > a, .newscard__item > div {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  overflow: hidden;
  background-color: #fff;
}
.newscard__item > a:hover {
  opacity: 0.8;
}
.newscard__item .imgWrap {
  width: 100%;
}
.newscard__item .imgWrap img {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 16/9;
}
.newscard__item .txtWrap {
  position: relative;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  padding: 1em;
  line-height: 1.5;
}
@media screen and (max-width: 1080px) {
  .newscard__item .txtWrap {
    padding: 1em 3em 1em 1em;
    font-size: 0.9em;
  }
}
.newscard__item .txtWrap .ttl {
  display: block;
  line-height: 1.5;
  width: 100%;
  margin-top: 0.5em;
}

/* カテゴリー・日付 */
.cateList {
  display: inline-block;
}

.cate {
  display: inline-block;
  background-color: #000;
  color: #fff;
  line-height: 1;
  min-width: 10em;
  padding: 0.5em 1.5em;
  border-radius: 100px;
  font-size: 0.8em;
  margin-bottom: 1em;
  text-align: center;
}

.date {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 0.8em;
  margin-left: 0.5em;
}

/*---------------------------------------------------------------------
詳細ページ
---------------------------------------------------------------------*/
.sec-single {
  width: 100%;
}
.sec-single > .mContainer:first-child {
  padding-top: 0;
}

/*記事タイトル等*/
.sec-article-info {
  border-bottom: 1px solid #ccc;
  padding: 0 0 1.5em 0;
  margin: 0 0 1.5em 0;
}
.sec-article-info .ttl {
  width: 100%;
  display: block;
  line-height: 1.5;
  font-size: clamp(1.3em, 4vw, 1.6em);
  margin-top: 0.5em;
  font-weight: 700;
}

/*サムネイル画像*/
.sec-information-article .thumbnail {
  margin-bottom: 2em;
}
.sec-information-article .thumbnail img {
  text-align: center;
  height: min(70vh, 500px);
  width: auto;
  margin: auto 3em auto auto;
}
@media screen and (max-width: 1080px) {
  .sec-information-article .thumbnail img {
    height: auto;
    width: 100%;
  }
}
.sec-information-article p {
  margin-bottom: 1em;
  line-height: 2.1;
}
.sec-information-article p a {
  text-decoration: underline;
}

/*==================================================================================================
	トップページ
==================================================================================================*/
.sec-top-mainview {
  padding: 10vh 0;
  height: 60vw;
  background-image: url(../img/top/mv_pc.webp);
  background-position: bottom right;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 1080px) {
  .sec-top-mainview {
    padding: 10vw 0;
    height: 180vw;
    background-image: url(../img/top/mv_sp.webp);
  }
}
.sec-top-mainview .inner {
  max-width: 1600px;
}
.sec-top-mainview .copy {
  font-size: clamp(1.5em, 3vw, 200%);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.07em;
}
.sec-top-mainview .en {
  font-size: clamp(1em, 1.2vw, 130%);
  font-family: "Inter", sans-serif;
  font-weight: 600;
  margin: 1em 0 2em 0;
  letter-spacing: 0;
  line-height: 1.4;
}
@media screen and (max-width: 1080px) {
  .sec-top-mainview .txt {
    font-size: 0.9em;
    line-height: 1.75;
  }
}

.sec-top-about {
  padding: 0;
}
.sec-top-about .inner {
  display: flex;
  flex-wrap: nowrap;
  gap: 7%;
}
@media screen and (max-width: 1080px) {
  .sec-top-about .inner {
    flex-wrap: wrap;
    gap: 0;
  }
}
.sec-top-about .imgWrap {
  width: 65vw;
  margin: 0 0 0 calc(50% - 50vw);
}
@media screen and (max-width: 1080px) {
  .sec-top-about .imgWrap {
    width: calc(100% + 7vw);
    margin: 0 0 0 -7vw;
    order: 2;
  }
}
.sec-top-about .txtWrap {
  width: 50%;
  padding-top: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-top-about .txtWrap {
    width: 100%;
    order: 1;
    margin-bottom: 2.5em;
    padding: 0;
  }
}
.sec-top-about .txtWrap .btnWrap {
  margin: 2em auto;
}
@media screen and (max-width: 1080px) {
  .sec-top-about .txtWrap .btnWrap {
    text-align: center;
    margin: 1.5em auto;
  }
}

.sec-top-service {
  position: relative;
  margin-top: -3vw;
  color: #fff;
}
@media screen and (max-width: 1080px) {
  .sec-top-service {
    margin-top: 3em;
  }
}
.sec-top-service::before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  display: block;
  width: 98%;
  height: 100%;
  z-index: -1;
  border-radius: 0.75em 0 0 0.75em;
  background: #0080cb;
  background: linear-gradient(90deg, #0080cb 0%, #0095cb 100%);
}
@media screen and (max-width: 1080px) {
  .sec-top-service::before {
    width: 100%;
  }
}
.sec-top-service .inner {
  display: flex;
  gap: 10%;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .inner {
    gap: 0;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 1080px) {
  .sec-top-service .enLabel {
    text-align: center;
  }
}
@media screen and (max-width: 1080px) {
  .sec-top-service .labelWrap {
    width: 100%;
  }
}
.sec-top-service .btnWrap {
  display: flex;
  flex-direction: column;
}
.sec-top-service .btnWrap a {
  display: block;
  margin-top: 1em;
}
.sec-top-service .service__item {
  display: flex;
  border-top: 0.7px solid;
  gap: 2em;
  padding: 2em 0;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .service__item {
    padding: 1.5em 0;
    gap: 1em;
  }
}
.sec-top-service .service__item .imgWrap {
  width: 7%;
  flex-shrink: 0;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .service__item .imgWrap {
    width: 15%;
  }
}
.sec-top-service .service__item .title {
  font-size: 1.1em;
  font-weight: 600;
}
.sec-top-service .service__item .txt {
  margin-top: 1em;
  font-weight: normal;
  line-height: 1.75;
}
.sec-top-service .service__item.last {
  gap: 0;
}
.sec-top-service .service__item.last > div {
  position: relative;
  width: 50%;
  padding: 1em 0;
}
.sec-top-service .service__item.last > div:first-child {
  padding-right: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .service__item.last > div:first-child {
    padding-right: 1em;
  }
}
.sec-top-service .service__item.last > div:first-child::before {
  content: "";
  display: inline-block;
  width: 0.7px;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background-color: #fff;
}
.sec-top-service .service__item.last > div:last-child {
  padding-left: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .service__item.last > div:last-child {
    padding-left: 1em;
  }
}
.sec-top-service .service__item.last > div .imgWrap {
  width: 100%;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .service__item.last > div .imgWrap {
    display: block;
    text-align: center;
  }
}
.sec-top-service .service__item.last > div .imgWrap img {
  width: 15%;
  margin-right: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-top-service .service__item.last > div .imgWrap img {
    justify-content: center;
    width: auto;
    height: 2em;
    margin-bottom: 1em;
  }
}

.sec-top-recruit {
  background-image: url(../img/top/recruiting_bg_pc.webp);
  background-position: right top;
  background-repeat: no-repeat;
  background-size: 70%;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit {
    padding-top: 45vw;
    background-image: url(../img/top/recruiting_bg_sp.webp);
    background-size: contain;
  }
}
.sec-top-recruit .link__list {
  display: flex;
  margin: 4em auto;
  gap: 0.5em;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__list {
    gap: 0.2em;
    flex-wrap: wrap;
  }
}
.sec-top-recruit .link__item {
  width: calc(20% - 0.25em);
  height: auto;
  text-align: center;
  color: #fff;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item {
    width: calc(50% - 0.1em);
  }
}
.sec-top-recruit .link__item:nth-child(1) {
  background: #00aeeb;
  background: linear-gradient(90deg, rgb(0, 174, 235) 0%, rgb(70, 184, 133) 70%);
  border-radius: 0.3em 0 0 0.3em;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item:nth-child(1) {
    width: 100%;
    border-radius: 0.3em 0.3em 0 0;
    text-align: left;
  }
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item:nth-child(1) a {
    padding: 1.2em;
  }
  .sec-top-recruit .link__item:nth-child(1) a::before {
    top: 50%;
    transform: translateY(-50%);
    bottom: initial;
    left: initial;
    right: 1em;
  }
  .sec-top-recruit .link__item:nth-child(1) a .name {
    margin: 0;
  }
  .sec-top-recruit .link__item:nth-child(1) a .name::before {
    content: none;
  }
  .sec-top-recruit .link__item:nth-child(1) a .name span {
    display: inline-block;
    margin-left: 1em;
  }
}
.sec-top-recruit .link__item:nth-child(2) {
  background-image: url(../img/top/recruiting_02.webp);
}
.sec-top-recruit .link__item:nth-child(3) {
  background-image: url(../img/top/recruiting_03.webp);
}
.sec-top-recruit .link__item:nth-child(4) {
  background-image: url(../img/top/recruiting_04.webp);
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item:nth-child(4) {
    border-radius: 0 0 0 0.3em;
  }
}
.sec-top-recruit .link__item:nth-child(5) {
  background-image: url(../img/top/recruiting_05.webp);
  border-radius: 0 0.3em 0.3em 0;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item:nth-child(5) {
    border-radius: 0 0 0.3em 0;
  }
}
.sec-top-recruit .link__item a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 3em 1em 60% 1em;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item a {
    padding: 2em 1em 50% 1em;
  }
}
.sec-top-recruit .link__item a::before {
  content: "";
  width: 2em;
  height: 2em;
  display: inline-block;
  vertical-align: middle;
  background-image: url(../img/common/icon_arrow_right_white.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  left: 50%;
  bottom: 20%;
  transform: translateX(-50%);
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .link__item a::before {
    bottom: 15%;
  }
}
.sec-top-recruit .link__item a:hover {
  filter: brightness(0.9);
}
.sec-top-recruit .link__item a .name {
  font-weight: 600;
  position: relative;
  margin-bottom: 1em;
  line-height: 1.75;
}
.sec-top-recruit .link__item a .name::before {
  content: "";
  width: 1.75em;
  height: 1px;
  background-color: #fff;
  position: absolute;
  left: 50%;
  bottom: -1em;
  transform: translateX(-50%);
}
.sec-top-recruit .link__item a .name span {
  display: block;
  font-weight: 700;
  font-family: "Inter", sans-serif;
  font-size: 0.7em;
}
.sec-top-recruit .infographics {
  background-color: #f5f5f2;
}
.sec-top-recruit .infographics a {
  gap: 1em;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .infographics a {
    display: block;
  }
}
.sec-top-recruit .infographics .enLabel {
  font-size: clamp(1.1em, 1.2vw, 120%);
  padding: 1.5em 2em 2em 2em;
  margin: 0;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .infographics .enLabel {
    padding: 1.5em;
  }
}
.sec-top-recruit .infographics .enLabel span {
  color: #00a63c;
}
.sec-top-recruit .infographics .imgWrap {
  width: 50%;
}
@media screen and (max-width: 1080px) {
  .sec-top-recruit .infographics .imgWrap {
    width: 70%;
    margin-left: auto;
  }
}
.sec-top-recruit .infographics .imgWrap img {
  width: 100%;
}

.sec-top-news {
  position: relative;
}
@media screen and (min-width: 1080px) {
  .sec-top-news::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 98%;
    height: 100%;
    background-color: #eef2f4;
    z-index: -1;
    border-radius: 0 0.75em 0.75em 0;
  }
}
.sec-top-news .inner {
  display: flex;
  gap: 3em;
}
@media screen and (max-width: 1080px) {
  .sec-top-news .inner {
    display: block;
    gap: 1em;
  }
}
.sec-top-news .labelWrap {
  white-space: nowrap;
}
.sec-top-news .news__list {
  width: 100%;
  margin-top: 0;
}
@media screen and (max-width: 1080px) {
  .sec-top-news .btnWrap {
    text-align: center;
  }
}

/*==================================================================================================
	ABOUT
==================================================================================================*/
.sec-about-company h2 {
  font-weight: 600;
  margin: 2em auto 1.5em auto;
}
.sec-about-company .timeline__item {
  display: flex;
  align-items: center;
  background-color: #fff;
  padding: 1em;
  border-radius: 0.25em;
  margin-top: 1em;
}
.sec-about-company .timeline__item .date {
  white-space: nowrap;
  margin-right: 2em;
  font-size: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-about-company .timeline__item .date {
    margin-right: 1em;
  }
}

.sec-pagelink .pagelink__list {
  display: flex;
  gap: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-pagelink .pagelink__list {
    gap: 0.5em;
    flex-wrap: wrap;
  }
}
.sec-pagelink .pagelink__item {
  width: calc(33% - 0.5em);
  height: auto;
  text-align: center;
  color: #fff;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 0.5em;
}
@media screen and (max-width: 1080px) {
  .sec-pagelink .pagelink__item {
    width: calc(50% - 0.25em);
  }
}
.sec-pagelink .pagelink__item:nth-child(1) {
  background-image: url(../img/about/pagelink_01.webp);
}
.sec-pagelink .pagelink__item:nth-child(2) {
  background-image: url(../img/about/pagelink_02.webp);
}
.sec-pagelink .pagelink__item:nth-child(3) {
  background-image: url(../img/about/pagelink_03.webp);
}
.sec-pagelink .pagelink__item a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 4em 1em;
  font-weight: 600;
  position: relative;
  margin-bottom: 1em;
  line-height: 1.75;
}
@media screen and (max-width: 1080px) {
  .sec-pagelink .pagelink__item a {
    padding: 2em 1em;
  }
}
.sec-pagelink .pagelink__item a span {
  display: block;
  font-weight: 700;
  font-family: "Inter", sans-serif;
  font-size: 0.7em;
}
.sec-pagelink .pagelink__item a::before {
  content: "";
  width: 2em;
  height: 2em;
  display: inline-block;
  vertical-align: middle;
  background-image: url(../img/common/icon_arrow_right_white.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  right: 1em;
  bottom: 1em;
}
.sec-pagelink .pagelink__item a:hover {
  filter: brightness(0.9);
}

.sec-about-greeting .flexWrap {
  flex-wrap: nowrap;
  gap: 5%;
}
@media screen and (max-width: 1080px) {
  .sec-about-greeting .flexWrap {
    flex-wrap: wrap;
    justify-content: center;
    gap: 2em;
  }
}
.sec-about-greeting .flexWrap .img {
  width: 35%;
}
@media screen and (max-width: 1080px) {
  .sec-about-greeting .flexWrap .img {
    width: 50%;
  }
}
.sec-about-greeting .flexWrap .txt {
  width: 65%;
}
@media screen and (max-width: 1080px) {
  .sec-about-greeting .flexWrap .txt {
    width: 100%;
  }
}
.sec-about-greeting .flexWrap .txt p {
  margin-bottom: 1.5em;
}
.sec-about-greeting .flexWrap .txt .name {
  text-align: right;
  margin-top: 3em;
}
.sec-about-greeting .flexWrap .txt .name img {
  width: auto;
  height: 4em;
  margin-left: auto;
}

.sec-about-plants .illustmap {
  max-width: 60%;
  margin: auto;
  text-align: center;
}
@media screen and (max-width: 1080px) {
  .sec-about-plants .illustmap {
    max-width: 100%;
  }
}
.sec-about-plants .root {
  margin: 2em 0 4em 0;
}
.sec-about-plants .root .ttl {
  padding: 0 0 0 0.5em;
  border-left: 3px solid #ccc;
  margin-bottom: 2em;
}
.sec-about-plants .root .-col2 {
  line-height: 1.5;
  align-items: center;
}
@media screen and (max-width: 1080px) {
  .sec-about-plants .root .-col2 .-col2 {
    gap: 0.5em;
  }
}
.sec-about-plants .root .-col2 p {
  font-size: 0.9em;
  margin-top: 0.5em;
}
.sec-about-plants .root .-col4 {
  margin: 3em 0;
  text-align: center;
  font-size: 0.8em;
  gap: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-about-plants .root .-col4 {
    max-width: 100%;
    gap: 1em;
  }
}
@media screen and (max-width: 1080px) {
  .sec-about-plants .root .-col4 > * {
    width: calc(50% - 0.5em);
  }
}
.sec-about-plants .lineLabel span {
  font-size: 0.5em;
  color: #fff;
  background-color: #0080cb;
  padding: 0.3em 0.5em;
  line-height: 1.2;
  margin-left: 1em;
}
.sec-about-plants .flexWrap {
  gap: 5%;
  flex-wrap: nowrap;
}
@media screen and (max-width: 1080px) {
  .sec-about-plants .flexWrap {
    flex-wrap: wrap;
    gap: 2em;
  }
}
.sec-about-plants .address {
  padding: 0 0 2em 0;
  margin: 0 0 2em 0;
  border-bottom: 1px solid #ccc;
}
.sec-about-plants .access span {
  display: block;
  color: #0080cb;
}

/*==================================================================================================
	recycle
==================================================================================================*/
/* ------------------- 共通 ------------------- */
.-recycle table tbody tr th,
.-recycle table tbody tr td,
.-solidfuel table tbody tr th,
.-solidfuel table tbody tr td {
  padding: 1.5em 0.5em;
}
@media screen and (max-width: 1080px) {
  .-recycle table tbody tr th,
  .-recycle table tbody tr td,
  .-solidfuel table tbody tr th,
  .-solidfuel table tbody tr td {
    width: 100%;
    display: block;
    padding: 1.2em 0;
  }
}
.-recycle table tbody tr th,
.-solidfuel table tbody tr th {
  color: #0080cb;
}
@media screen and (max-width: 1080px) {
  .-recycle table tbody tr th,
  .-solidfuel table tbody tr th {
    padding-bottom: 0.5em;
  }
}
@media screen and (max-width: 1080px) {
  .-recycle table tbody tr td,
  .-solidfuel table tbody tr td {
    padding-top: 0;
  }
}

/* ------------------- 事業トップ ------------------- */
/*地球と企業の未来をつなぐ*/
.sec-recycle-intro .centerLabel {
  margin-bottom: 0.5em;
}
.sec-recycle-intro .centerLabel + p {
  text-align: center;
}
.sec-recycle-intro .recycle__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 2em 0;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-intro .recycle__list {
    gap: 0;
  }
}
.sec-recycle-intro .recycle__item {
  width: 33%;
  text-align: center;
  padding: 1em 2em;
  border-left: 1px solid #ccc;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-intro .recycle__item {
    padding: 1em 0.5em;
    border-left: none;
    border-bottom: 1px solid #ccc;
    width: 50%;
  }
}
.sec-recycle-intro .recycle__item:last-child {
  border-right: 1px solid #ccc;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-intro .recycle__item:last-child {
    border-right: none;
  }
}
.sec-recycle-intro .recycle__item .name {
  color: #0080cb;
  font-weight: bold;
  word-break: auto-phrase;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-intro .recycle__item .name {
    min-height: 3em;
    display: flex;
    align-items: flex-start;
    justify-content: center;
  }
}
.sec-recycle-intro .recycle__item .img {
  margin: 0.5em auto;
}
.sec-recycle-intro .recycle__item .img img {
  width: 50%;
  max-width: 100px;
  margin: auto;
}
.sec-recycle-intro .recycle__item .ttl {
  font-weight: bold;
  margin-bottom: 0.5em;
  line-height: 1.5;
  word-break: auto-phrase;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-intro .recycle__item .ttl {
    min-height: 3em;
    display: flex;
    align-items: flex-start;
    justify-content: center;
  }
}
.sec-recycle-intro .recycle__item .txt {
  text-align: left;
  font-size: 0.9em;
  line-height: 1.75;
}

/*事業内容*/
.sec-recycle-service .service__item {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2em 0;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-service .service__item {
    display: block;
    padding: 0 0 2em 0;
  }
}
.sec-recycle-service .service__item .imgWrap {
  width: 50vw;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-service .service__item .imgWrap {
    width: 100vw;
  }
}
@media screen and (max-width: 1080px) {
  .sec-recycle-service .service__item .imgWrap img {
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 5/2;
  }
}
.sec-recycle-service .service__item .txtWrap {
  width: 50%;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-service .service__item .txtWrap {
    width: 100%;
    margin-top: 0.5em;
  }
}
.sec-recycle-service .service__item .txtWrap .ttl {
  display: flex;
  align-items: center;
}
.sec-recycle-service .service__item .txtWrap .num {
  font-family: "Inter", sans-serif;
  font-weight: bold;
  color: #ccc;
  font-size: 3em;
  margin-right: 0.5em;
}
.sec-recycle-service .service__item .txtWrap .name {
  line-height: 1.3;
  font-weight: bold;
  font-size: 1.3em;
}
.sec-recycle-service .service__item .txtWrap .name span {
  display: block;
  font-size: 0.5em;
  color: #0080cb;
  font-family: "Inter", sans-serif;
  margin-top: 1em;
}
.sec-recycle-service .service__item .txtWrap .txt {
  margin-top: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-recycle-service .service__item .txtWrap .txt {
    margin-top: 0;
  }
}
.sec-recycle-service .service__item:nth-child(odd) .imgWrap {
  padding-left: 2em;
  margin: 0 calc(50% - 50vw) 0 0;
  order: 2;
}
.sec-recycle-service .service__item:nth-child(odd) .imgWrap img {
  border-radius: 1em 0 0 1em;
}
.sec-recycle-service .service__item:nth-child(even) .imgWrap {
  padding-right: 2em;
  margin: 0 0 0 calc(50% - 50vw);
}
.sec-recycle-service .service__item:nth-child(even) .imgWrap img {
  border-radius: 0 1em 1em 0;
}

/* ------------------- 詳細 ------------------- */
/* SDGs */
.sec-service-SDGs .sdgs__list {
  display: flex;
  justify-content: center;
  margin: 1.5em auto;
  flex: 1;
  gap: 1em;
}
.sec-service-SDGs .sdgs__item {
  width: 130px;
}
/* とは？ */
.sec-service-about {
  min-height: 35vw;
  padding: 1em 0 3em 0;
  position: relative;
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 1080px) {
  .sec-service-about .imgWrap img {
    border-radius: 0 0.5em 0.5em 0;
    width: 48vw;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }
}
/* 強み */
.sec-service-strengths .strengths__list {
  display: flex;
  flex-wrap: nowrap;
  flex: 1;
  gap: 0;
}
@media screen and (max-width: 1080px) {
  .sec-service-strengths .strengths__list {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
.sec-service-strengths .strengths__item {
  text-align: center;
  padding: 0 2em;
  border-left: 1px solid #ccc;
}
@media screen and (max-width: 1080px) {
  .sec-service-strengths .strengths__item {
    padding: 1.5em 0.5em;
    border-left: none;
    border-top: 1px solid #ccc;
  }
}
.sec-service-strengths .strengths__item:last-child {
  border-right: 1px solid #ccc;
}
@media screen and (max-width: 1080px) {
  .sec-service-strengths .strengths__item:last-child {
    border-right: none;
  }
}
.sec-service-strengths .strengths__item .ttl {
  color: #0080cb;
  font-weight: bold;
  word-break: auto-phrase;
}
@media screen and (max-width: 1080px) {
  .sec-service-strengths .strengths__item .ttl {
    min-height: 3em;
    display: flex;
    align-items: flex-start;
    justify-content: center;
  }
}
.sec-service-strengths .strengths__item .img {
  margin: 0.5em auto;
}
.sec-service-strengths .strengths__item .img img {
  width: 50%;
  max-width: 100px;
  margin: auto;
}
.sec-service-strengths .strengths__item .txt {
  text-align: left;
  font-size: 0.9em;
  line-height: 1.75;
}

/* 製品・プロセス */
.sec-service-product .process__list {
  margin-bottom: 2em;
  overflow: hidden;
  position: relative;
  display: flex;
  gap: 1.5em;
}
@media screen and (max-width: 1080px) {
  .sec-service-product .process__list {
    flex-wrap: wrap;
  }
}
.sec-service-product .process__item {
  flex: 1;
}
@media screen and (max-width: 1080px) {
  .sec-service-product .process__item {
    width: 100%;
    flex: auto;
  }
}
.sec-service-product .process__item::before {
  content: "";
  display: block;
  position: absolute;
  top: 3em;
  left: 0;
  width: 120%;
  height: 3px;
  background-color: #0080cb;
  z-index: -1;
}
@media screen and (max-width: 1080px) {
  .sec-service-product .process__item::before {
    width: 3px;
    left: 1em;
    height: 100%;
  }
}
.sec-service-product .process__item .ttl {
  text-align: center;
  position: relative;
  padding: 1em 0.5em;
  border-radius: 0.5em;
  border: 1px solid;
  color: #0080cb;
  line-height: 1.5;
  font-weight: bold;
  background-color: #fff;
  min-height: 6em;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 1080px) {
  .sec-service-product .process__item .ttl {
    padding: 1em;
    text-align: left;
    min-height: auto;
    padding: 1em;
  }
}
.sec-service-product .process__item .ttl .num {
  position: absolute;
  left: 0.5em;
  top: 0.5em;
}
@media screen and (max-width: 1080px) {
  .sec-service-product .process__item .ttl .num {
    position: initial;
    margin-right: 1em;
  }
}
.sec-service-product .process__item .txt {
  margin-top: 1em;
  font-size: 0.9em;
  line-height: 1.5;
}
@media screen and (max-width: 1080px) {
  .sec-service-product .process__item .txt {
    margin-left: 2.5em;
  }
}

/* 導入のメリット */
.sec-service-merit .merit__item {
  padding: 1em 1em 1em 3.5em;
  border-radius: 0.5em;
  margin-top: 1em;
  background-image: url(../img/common/icon_check.svg);
  background-repeat: no-repeat;
  background-size: 1.5em;
  background-position: center left 1em;
  background-color: #fff;
}
.sec-service-merit .merit__item .ttl {
  color: #0080cb;
  font-weight: 700;
  font-size: 1.1em;
}
.sec-service-merit .merit__item .txt {
  color: #000;
}

/* 設備・許認可 */
/* 実績・ケーススタディ */
.sec-service-case .lineLabel + p {
  text-align: center;
  color: #0080cb;
  font-size: 1.1em;
  margin-bottom: 2em;
}
.sec-service-case .case__item {
  position: relative;
  text-align: center;
  padding: 2em;
  background-color: #fff;
  box-shadow: 0 0 6px 0.06;
  background-image: url(../img/common/icon_triangle.svg);
  background-position: right 0.5em top 0.5em;
  background-repeat: no-repeat;
  background-size: 1em;
  border-radius: 0.5em;
}
.sec-service-case .case__item .ttl {
  font-size: clamp(1.1em, 1.2vw, 120%);
  font-weight: 600;
  margin: 0 auto 1.5em auto;
  padding: 0 0 1em 0;
  line-height: 1.5;
  color: #0080cb;
  position: relative;
}
.sec-service-case .case__item .ttl::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 2em;
  height: 1px;
  background-color: #000;
}
.sec-service-case .case__item .txt {
  text-align: left;
}

/* SDGs／ESGへの貢献 */
.sec-service-SDGs .SDGs__item {
  padding: 1em 1em 1em 3.5em;
  border-radius: 0.5em;
  margin-top: 1em;
  background-image: url(../img/common/icon_check.svg);
  background-repeat: no-repeat;
  background-size: 1.5em;
  background-position: center left 1em;
  color: #0080cb;
  background-color: #eef2f4;
  font-weight: 600;
}

/* よくあるご質問 */
.sec-service-qa details {
  box-shadow: none !important;
  border-top: 1px solid #ccc;
  margin: 0;
}
.sec-service-qa details:last-child {
  border-bottom: 1px solid #ccc;
}
.sec-service-qa details summary {
  padding-left: 3em;
  text-align: left;
  background: none !important;
  color: #000 !important;
}
.sec-service-qa .qaA {
  position: relative;
  padding: 1em;
  margin: 0 0 2em 2em;
}
.sec-service-qa summary::before,
.sec-service-qa .qaA::before {
  content: "Q";
  position: absolute;
  left: 0.5em;
  top: 0.75em;
  width: 1em;
  height: 1em;
  text-align: center;
  line-height: 1;
  font-family: "Inter", sans-serif;
  font-size: 1.5em;
  pointer-events: none;
  font-weight: bold;
  color: #0080cb;
}
.sec-service-qa .qaA::before {
  content: none;
}

/* Contact Us */
.sec-service-contact {
  margin-bottom: 3em;
  color: #fff;
}
.sec-service-contact .flexWrap {
  gap: 2em;
}
.sec-service-contact .flexWrap > * {
  width: calc(50% - 1em);
}
@media screen and (max-width: 1080px) {
  .sec-service-contact .flexWrap > * {
    width: 100%;
  }
}
.sec-service-contact .mail .btnLwhite::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 0.75em;
  background-image: url(../img/common/icon_mail_color.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}
.sec-service-contact .tel {
  text-align: center;
}
.sec-service-contact .tel .telLink {
  line-height: 1.2;
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.5em;
}
.sec-service-contact .tel .telLink span {
  font-size: 1.75em;
}

/*背景*/
.-bgImg {
  position: relative;
  color: #fff;
  background-color: #0080cb;
  mix-blend-mode: multiply;
}
.-bgImg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  opacity: 0.2;
  background-repeat: no-repeat;
  background-size: cover;
  z-index: -1;
}
.-bgImg.-document::before {
  background-image: url(../img/document/pagettl.webp);
}
.-bgImg.-thermal::before {
  background-image: url(../img/thermal/pagettl.webp);
}
.-bgImg.-transportation::before {
  background-image: url(../img/transportation/pagettl.webp);
}
.-bgImg.-solidfuel::before {
  background-image: url(../img/solidfuel/pagettl.webp);
}
.-bgImg .lineLabel::before {
  background-color: #fff;
}

/*==================================================================================================
	infographics
==================================================================================================*/
.sec-infographics .infographics__list {
  display: flex;
  justify-content: center;
  gap: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-infographics .infographics__list {
    gap: 1em;
  }
}
.sec-infographics .infographics__item {
  text-align: center;
  width: calc(33% - 2em);
  padding: 2em;
  background-color: #fff;
  border-radius: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-infographics .infographics__item {
    width: 100%;
  }
}
.sec-infographics .infographics__item .ttl {
  font-size: clamp(1.1em, 1.5vw, 150%);
  font-weight: 600;
  margin: 0;
  padding: 0.5em 0 0;
  line-height: 1.5;
  position: relative;
}
.sec-infographics .infographics__item .ttl::before {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 1em;
  height: 1px;
  background-color: #000;
}
.sec-infographics .infographics__item .icon {
  margin: 1em auto 0 0;
}
.sec-infographics .infographics__item .icon img {
  width: 30%;
  margin: auto;
}
.sec-infographics .infographics__item .num {
  font-size: 1.5em;
  font-weight: bold;
}
.sec-infographics .infographics__item .num span {
  font-size: 2em;
  margin-right: 0.05em;
  font-family: "Inter", sans-serif;
}
.sec-infographics .infographics__item .txt {
  text-align: left;
}

/*==================================================================================================
	recruit
==================================================================================================*/
.-recruit .sec-pagettl,
.-interview .sec-pagettl {
  text-align: center;
}
.-recruit .sec-pagettl .pagettl__txt,
.-interview .sec-pagettl .pagettl__txt {
  display: block;
  width: auto;
  text-align: center;
  padding: 2em 0 0 0;
}
.-recruit .sec-pagettl .pagettl__txt_ttl,
.-interview .sec-pagettl .pagettl__txt_ttl {
  font-size: clamp(1.1em, 2vw, 250%);
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 1.2em;
}
.-recruit .sec-pagettl .pagettl__txt_en,
.-interview .sec-pagettl .pagettl__txt_en {
  font-size: clamp(2em, 4vw, 400%);
  font-family: "Inter", sans-serif;
  font-weight: 700;
  margin: 0 0 0.2em 0;
  display: inline-block;
  width: auto;
  text-transform: uppercase;
  background: #00aeeb;
  background: linear-gradient(90deg, rgb(0, 174, 235) 0%, rgb(70, 184, 133) 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.-recruit .sec-pagettl .pagettl__txt_en::before,
.-interview .sec-pagettl .pagettl__txt_en::before {
  content: none;
}

/*一緒に未来を創造しませんか？*/
.sec-recruit-contact {
  text-align: center;
  margin-bottom: 2em;
}
.sec-recruit-contact::before {
  background-image: url(../img/recruit/contact_bg.webp);
}
.sec-recruit-contact .label {
  padding-top: 0.5em;
  font-size: clamp(1.5em, 3vw, 300%);
  font-weight: 700;
}
.sec-recruit-contact .txt {
  margin: 2em auto;
  word-break: auto-phrase;
}
.sec-recruit-contact .btnLwhite {
  max-width: 300px;
  color: #000;
}

/* ------------------- 採用情報トップ ------------------- */
/*ページタイトル*/
.-recruit-parent .sec-pagettl {
  position: relative;
}
.-recruit-parent .sec-pagettl .pagettl__img {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  width: 100vw;
  height: 27vw;
  margin: calc(50% - 50vw);
}
@media screen and (max-width: 1080px) {
  .-recruit-parent .sec-pagettl .pagettl__img {
    height: 40vw;
  }
}
.-recruit-parent .sec-pagettl .pagettl__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  padding: 1em;
}
.-recruit-parent .sec-pagettl .pagettl__txt {
  position: relative;
  padding-top: 24vw;
  text-align: left;
  z-index: 2;
}
@media screen and (max-width: 1080px) {
  .-recruit-parent .sec-pagettl .pagettl__txt {
    padding-top: 33vw;
  }
}
.-recruit-parent .sec-pagettl .pagettl__txt_ttl {
  align-items: self-start;
}
.-recruit-parent .sec-pagettl .pagettl__txt_en::before {
  content: none;
}

/*想いを燃やす、資源になる。*/
.sec-recruit-intro .inner {
  margin-top: 2em;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-intro .inner {
    flex-wrap: wrap;
  }
}
.sec-recruit-intro .ttl {
  font-size: clamp(1.3em, 3vw, 300%);
  font-weight: 700;
}
.sec-recruit-intro .txt {
  margin: 3em 0 0 0;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-intro .txt {
    margin: 1em 0;
  }
}
.sec-recruit-intro .btnWrap {
  margin: 0;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-intro .btnWrap {
    margin: 1em auto;
  }
}
.sec-recruit-intro .btnWrap .btnLmain {
  padding: 1em 3em;
  line-height: 1.5;
}

/*ページリンク*/
.sec-recruit-pagelink .pagelink__list {
  display: flex;
  flex-wrap: wrap;
  gap: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-pagelink .pagelink__list {
    gap: 1em;
  }
}
.sec-recruit-pagelink .pagelink__item {
  width: calc(50% - 1em);
  border-radius: 1em;
  overflow: hidden;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-pagelink .pagelink__item {
    width: 100%;
  }
}
.sec-recruit-pagelink .pagelink__item a {
  display: flex;
  color: #fff;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  aspect-ratio: 16/9;
  width: 100%;
  height: 100%;
  padding: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-pagelink .pagelink__item a {
    padding: 1.5em;
    aspect-ratio: 10/4;
  }
}
.sec-recruit-pagelink .pagelink__item a > div {
  margin-top: auto;
}
.sec-recruit-pagelink .pagelink__item .ttl {
  font-size: clamp(1.3em, 2.5vw, 230%);
  font-weight: 700;
  line-height: 1;
  display: inline-block;
  position: relative;
}
.sec-recruit-pagelink .pagelink__item .ttl::after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-image: url(../img/recruit/icon_arrow.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-left: 0.5em;
}
.sec-recruit-pagelink .pagelink__item .en {
  display: block;
}
.sec-recruit-pagelink .pagelink__item .txt {
  margin-top: 0.5em;
  font-size: 0.8em;
}
.sec-recruit-pagelink .pagelink__item.-interview a {
  background-image: url(../img/recruit/recruit_interview.webp);
}
.sec-recruit-pagelink .pagelink__item.-oneday a {
  background-image: url(../img/recruit/recruit_oneday.webp);
}
.sec-recruit-pagelink .pagelink__item.-benefits a {
  background-image: url(../img/recruit/recruit_benefits.webp);
}
.sec-recruit-pagelink .pagelink__item.-outline a {
  background-image: url(../img/recruit/recruit_outline.webp);
}

/*数字で見るレックス*/
.sec-recruit-data .label {
  font-size: clamp(1.5em, 3vw, 300%);
  font-weight: 700;
}
.sec-recruit-data .label span {
  color: #0080cb;
}
.sec-recruit-data .label + p {
  margin-bottom: 2em;
}
.sec-recruit-data .sliderData {
  margin: 0 0 2em 0;
}
.sec-recruit-data .sliderData .slider-item {
  padding: 2em;
  margin: 0.5em;
  border-radius: 1em;
  text-align: center;
  background-color: #eef2f4;
}
.sec-recruit-data .sliderData .ttl {
  font-size: clamp(1em, 1.2vw, 100%);
  font-weight: 600;
  margin: 0 auto 1.5em auto;
  padding: 0 0 1em 0;
  line-height: 1.5;
  position: relative;
}
.sec-recruit-data .sliderData .ttl::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 2em;
  height: 1px;
  background-color: #000;
}
.sec-recruit-data .sliderData .img {
  width: 25%;
  margin: auto;
}
@media screen and (max-width: 1080px) {
  .sec-recruit-data .sliderData .img {
    width: 40%;
  }
}
.sec-recruit-data .sliderData .txt .num {
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 2em;
}

/* ------------------- 先輩社員の声 ------------------- */
.sec-interview .interview__item {
  margin-bottom: 4em;
}
.sec-interview .interview__item .imgWrap {
  display: flex;
  flex-wrap: nowrap;
}
.sec-interview .interview__item .txtWrap {
  position: relative;
  margin: 2em 0;
}
.sec-interview .interview__item .txtWrap .num {
  position: absolute;
  top: -0.4em;
  right: 0;
  opacity: 0.1;
  color: #0080cb;
  font-size: clamp(5em, 10vw, 1000%);
  font-weight: 700;
  font-family: "Inter", sans-serif;
  line-height: 1;
  z-index: -1;
}
@media screen and (max-width: 1080px) {
  .sec-interview .interview__item .txtWrap .num {
    top: -0.6em;
  }
}
.sec-interview .interview__item .txtWrap .ttl {
  font-size: clamp(1.3em, 3vw, 300%);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 0.5em;
}
.sec-interview .interview__item .qa__list {
  display: flex;
}
@media screen and (max-width: 1080px) {
  .sec-interview .interview__item .qa__list {
    display: block;
  }
}
.sec-interview .interview__item .qa__item {
  flex: 1;
  border-left: 1px solid #ccc;
  padding: 0 2em;
}
@media screen and (max-width: 1080px) {
  .sec-interview .interview__item .qa__item {
    border-left: none;
    border-top: 1px solid #ccc;
    padding: 1.5em 0;
  }
}
.sec-interview .interview__item .qa__item:last-child {
  border-right: 1px solid #ccc;
}
@media screen and (max-width: 1080px) {
  .sec-interview .interview__item .qa__item:last-child {
    border-right: none;
  }
}
.sec-interview .interview__item .qa__q {
  text-align: center;
  color: #0080cb;
  font-size: clamp(1.1em, 1.2vw, 120%);
  font-weight: 600;
  margin: 0 auto 1.5em auto;
  line-height: 1.5;
  position: relative;
}
.sec-interview .interview__item .qa__q::before {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 2em;
  height: 1px;
  background-color: #000;
}
.sec-interview .interview__item .qa__q .num {
  display: block;
  margin-bottom: 0.5em;
}
.sec-interview .interview__item .qa__a p:not(:last-child) {
  margin-bottom: 1em;
}
.sec-interview .interview__item:nth-child(even) .txtWrap {
  text-align: right;
}
.sec-interview .interview__item:nth-child(even) .txtWrap .num {
  right: initial;
  left: 0;
}

/* ------------------- 1日の仕事の流れ ------------------- */
.sec-oneday .tab-group .tab-button {
  display: flex;
  justify-content: center;
  gap: 1em;
  font-size: 0.9em;
  margin-bottom: 4em;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .tab-group .tab-button {
    width: 100%;
    gap: 0.5em;
  }
}
.sec-oneday .tab-group .tab-button .tab {
  flex: initial;
  width: auto;
  padding: 1em 1.5em;
  min-width: 200px;
  text-align: center;
  border-radius: 100px;
  background-color: #fff;
  border: 1px solid;
  color: #000;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .tab-group .tab-button .tab {
    min-width: auto;
  }
}
.sec-oneday .tab-group .tab-button .tab.is-active {
  background-color: #0080cb;
  color: #fff;
  position: relative;
}
.sec-oneday .tab-group .tab-button .tab.is-active::before {
  content: "";
  display: inline-block;
  position: absolute;
  left: 50%;
  top: 100%;
  width: 1px;
  height: 1.5em;
  background-color: #0080cb;
}
.sec-oneday .name .ttl {
  font-size: clamp(1.5em, 3.5vw, 200%);
  font-weight: 700;
}
.sec-oneday .name .txt {
  line-height: 1.5;
  margin: 1em 0;
}
.sec-oneday .flexWrap {
  align-items: flex-start;
  margin: 3em auto 4em auto;
  gap: 3em;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap {
    margin: 3em auto 3em auto;
  }
}
.sec-oneday .flexWrap .imgWrap {
  position: relative;
  width: calc(50% - 1.5em);
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap .imgWrap {
    width: 100%;
  }
}
.sec-oneday .flexWrap .imgWrap::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: #00aeeb;
  background: linear-gradient(90deg, rgb(0, 174, 235) 0%, rgb(70, 184, 133) 70%);
  border-radius: 1em;
  transform: skewY(3deg) scale(0.9, 1);
  z-index: -1;
}
.sec-oneday .flexWrap .imgWrap .imgInner {
  overflow: hidden;
  border-radius: 1em;
  transform: skewY(-3deg);
}
.sec-oneday .flexWrap .imgWrap img {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1/1;
  border-radius: 1em;
  transform: skewY(3deg) scale(1.1, 1.1);
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap .imgWrap img {
    aspect-ratio: 3/2;
  }
}
.sec-oneday .flexWrap .txtWrap {
  width: calc(50% - 1.5em);
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap .txtWrap {
    width: 100%;
  }
}
.sec-oneday .flexWrap .schedule__list {
  overflow: hidden;
}
.sec-oneday .flexWrap .schedule__item {
  position: relative;
  display: flex;
  align-items: flex-start;
  flex-wrap: nowrap;
  margin-bottom: 2em;
  gap: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap .schedule__item {
    margin-bottom: 1em;
  }
}
.sec-oneday .flexWrap .schedule__item .time {
  white-space: nowrap;
  display: inline-block;
  padding: 0.5em 2em;
  min-width: 7em;
  text-align: center;
  border-radius: 100px;
  line-height: 1.5;
  border: 1px solid #0080cb;
  color: #0080cb;
  background-color: #fff;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap .schedule__item .time {
    min-width: 6em;
    padding: 0.5em;
  }
}
.sec-oneday .flexWrap .schedule__item:not(:last-child)::before {
  content: "";
  width: 2px;
  height: 200%;
  position: absolute;
  left: 3.5em;
  top: 1em;
  background-color: #0080cb;
  z-index: -1;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .flexWrap .schedule__item:not(:last-child)::before {
    left: 3em;
  }
}
.sec-oneday .flexWrap .schedule__item:first-child .time, .sec-oneday .flexWrap .schedule__item:last-child .time {
  background-color: #0080cb;
  color: #fff;
}
.sec-oneday .flexWrap .schedule__item p {
  margin-top: 0.5em;
  line-height: 1.5;
}
.sec-oneday .point__list {
  display: flex;
  gap: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-oneday .point__list {
    flex-wrap: wrap;
    gap: 2em;
  }
}
.sec-oneday .point__item {
  display: flex;
  align-items: center;
  gap: 1em;
  line-height: 1.5;
}
.sec-oneday .point__item .imgWrap {
  white-space: nowrap;
}
.sec-oneday .point__item .imgWrap img {
  width: 6em;
}
.sec-oneday .point__item .ttl {
  font-weight: 600;
  color: #0080cb;
  font-size: clamp(1.1em, 2vw, 130%);
}
.sec-oneday .point__item .txt {
  font-size: 0.9em;
  margin-top: 0.5em;
}

/* ------------------- 福利厚生 ------------------- */
.sec-benefits .benefits__list {
  gap: 2em;
}
@media screen and (max-width: 1080px) {
  .sec-benefits .benefits__list {
    gap: 1em;
  }
}
.sec-benefits .benefits__item {
  width: calc(33% - 1.5em);
  background-color: #eef2f4;
  border-radius: 1em;
  padding: 2em;
  text-align: center;
}
@media screen and (max-width: 1080px) {
  .sec-benefits .benefits__item {
    width: 100%;
  }
}
.sec-benefits .benefits__item .ttl {
  font-size: clamp(1.1em, 1.2vw, 120%);
  font-weight: 600;
  margin: 0 auto 1.5em auto;
  line-height: 1.5;
  position: relative;
}
.sec-benefits .benefits__item .ttl::before {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 2em;
  height: 1px;
  background-color: #000;
}
.sec-benefits .benefits__item .img {
  margin: auto;
  width: 25%;
}
@media screen and (max-width: 1080px) {
  .sec-benefits .benefits__item .img {
    width: 20%;
  }
}
.sec-benefits .benefits__item ul {
  margin-top: 1.5em;
  line-height: 1.5;
  text-align: left;
}
.sec-benefits .benefits__item ul li {
  margin-top: 0.5em;
}
@media screen and (max-width: 1080px) {
  .sec-benefits .benefits__item ul li {
    text-align: center;
  }
}
.sec-benefits .benefits__item ul li::before {
  content: "";
  display: inline-block;
  background-image: url(../img/recruit/benefits/icon_check_color.svg);
  width: 1em;
  height: 1em;
  margin-right: 0.5em;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

/* ------------------- 募集要項 ------------------- */
.sec-outline .tab-group {
  display: flex;
  align-items: flex-start;
  gap: 5%;
}
@media screen and (max-width: 1080px) {
  .sec-outline .tab-group {
    flex-wrap: wrap;
    gap: 2em;
  }
}
.sec-outline .tab-group .tab-button {
  display: flex;
  flex-direction: column;
  width: 25%;
  gap: 1em;
}
@media screen and (max-width: 1080px) {
  .sec-outline .tab-group .tab-button {
    width: 100%;
    margin-bottom: 2em;
  }
}
.sec-outline .tab-group .tab-button .tab {
  border-radius: 0.5em;
  padding: 1.5em;
}
@media screen and (max-width: 1080px) {
  .sec-outline .tab-group .tab-button .tab {
    padding: 1em;
  }
}
.sec-outline .tab-group .tab-button .tab.is-active {
  background-image: url(../img/common/icon_tab.svg);
  background-position: right 1em center;
  background-repeat: no-repeat;
  background-size: 0.7em;
}
.sec-outline .tab-group .tab-contents {
  width: 70%;
}
@media screen and (max-width: 1080px) {
  .sec-outline .tab-group .tab-contents {
    width: 100%;
  }
}
.sec-outline .about {
  display: flex;
  margin-bottom: 2em;
  gap: 2em;
  flex-wrap: nowrap;
}
@media screen and (max-width: 1080px) {
  .sec-outline .about {
    flex-wrap: wrap;
  }
}
.sec-outline .about .imgWrap {
  width: 40%;
}
@media screen and (max-width: 1080px) {
  .sec-outline .about .imgWrap {
    width: 100%;
  }
}
.sec-outline .about .imgWrap img {
  border-radius: 1em;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 1080px) {
  .sec-outline .about .imgWrap img {
    aspect-ratio: 4/3;
  }
}
.sec-outline .about .txtWrap {
  width: 60%;
}
@media screen and (max-width: 1080px) {
  .sec-outline .about .txtWrap {
    width: 100%;
  }
}
.sec-outline .about .txtWrap p {
  margin-bottom: 1em;
}
.sec-outline .conditions {
  margin: 2em auto;
}
.sec-outline .conditions > div {
  padding: 1em;
  background-color: #eef2f4;
  border-radius: 0.5em;
}
.sec-outline .conditions .ttl {
  color: #0080cb;
  font-size: 0.9em;
  padding-left: 2em;
  background-image: url(../img/recruit/outline/icon_map.svg);
  background-position: left center;
  background-repeat: no-repeat;
  background-size: contain;
  line-height: 1.5;
  margin-bottom: 0.2em;
}
.sec-outline .conditions .ttl.money {
  background-image: url(../img/recruit/outline/icon_money.svg);
}
.sec-outline table tbody tr th,
.sec-outline table tbody tr td {
  padding: 1.5em 0;
}
@media screen and (max-width: 1080px) {
  .sec-outline table tbody tr th,
  .sec-outline table tbody tr td {
    width: 100%;
    display: block;
    padding: 1.2em 0;
  }
}
@media screen and (max-width: 1080px) {
  .sec-outline table tbody tr th {
    padding-bottom: 0.5em;
  }
}
@media screen and (max-width: 1080px) {
  .sec-outline table tbody tr td {
    padding-top: 0;
  }
}

/*==================================================================================================
	お問い合わせ
==================================================================================================*/
.-contact {
  background-color: #eef2f4;
}
.-contact .sec-page {
  padding-top: 2em;
}
.-contact .lineLabel {
  margin-bottom: 1em !important;
}
.-contact .telLink {
  margin-bottom: 0 !important;
  line-height: 1.5 !important;
}
.-contact .telLink a {
  font-weight: 700 !important;
  color: #000 !important;
  text-decoration: none !important;
}
.-contact .telLink a strong {
  font-size: 2em;
  font-family: "Inter", sans-serif;
  font-weight: 700 !important;
}
.-contact .telLink + p {
  font-size: 0.8em;
}/*# sourceMappingURL=page.css.map */