@charset "UTF-8";
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    row-gap: 2.5rem;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list > li {
    width: 48%;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index .about-index-list > li + li {
    margin-top: 3.75rem;
  }
}
.section.about-index .about-index-list a {
  display: block;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list a {
    height: 100%;
    -webkit-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .section.about-index .about-index-list a:hover {
    opacity: 0.7;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index .about-index-list a {
    border-radius: 0.25rem;
    overflow: hidden;
  }
}
.section.about-index .about-index-list a > figure {
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list a > figure {
    border-radius: 0.25rem;
    margin-left: auto;
    width: 96.0416666667%;
  }
}
.section.about-index .about-index-list a > figure img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .section.about-index * + .about-index-list {
    margin-top: 5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index * + .about-index-list {
    margin-top: 3.75rem;
  }
}
.section.about-index .about-index-list-txt,
.section.about-index .about-index-list-overlay {
  left: 0;
  position: absolute;
  top: 0;
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list-txt,
  .section.about-index .about-index-list-overlay {
    width: 83.5416666667%;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index .about-index-list-txt,
  .section.about-index .about-index-list-overlay {
    width: 100%;
  }
}
.section.about-index .about-index-list-txt {
  color: #FFF;
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list-txt {
    padding: 1rem 1.5rem 0.625rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index .about-index-list-txt {
    padding: 1.125rem;
  }
}
.section.about-index .about-index-list-txt h2 {
  font-weight: 700;
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list-txt h2 {
    font-size: 1.875rem;
    line-height: 1.5;
    margin-bottom: 0.75rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index .about-index-list-txt h2 {
    font-size: 1.5rem;
    line-height: 1.4166666667;
    margin-bottom: 0.625rem;
  }
}
.section.about-index .about-index-list-txt p {
  font-weight: 500;
}
@media print, screen and (min-width: 768px) {
  .section.about-index .about-index-list-txt p {
    font-size: 1.25rem;
    line-height: 1.6;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-index .about-index-list-txt p {
    font-size: 1.0625rem;
    line-height: 1.7647058824;
  }
}
.section.about-index .about-index-list-overlay {
  background: #005F67;
  mix-blend-mode: multiply;
  pointer-events: none;
}

.section.about-link {
  background: #F8FAFA;
}
@media print, screen and (min-width: 768px) {
  .section.about-link .grid-list.-service-list .grid-list-item-inn {
    padding-left: 1.875rem;
    padding-right: 1.875rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-link .grid-list.-service-list .grid-list-item-inn {
    padding-left: 0.9375rem;
    padding-right: 0.9375rem;
  }
}
.section.about-link .grid-list.-service-list .grid-list-item-inn .service-list-index {
  width: 100%;
}

@media print, screen and (min-width: 768px) {
  .section.about-message .section-inn {
    max-width: 57.8125rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-message .about-message-mv {
    margin-left: -0.3125rem;
    max-width: none;
    width: calc(100% + 0.625rem);
  }
}
.section.about-message .about-message-mv img {
  max-width: none;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .section.about-message .about-message-txt {
    font-size: 1rem;
    line-height: 1.75;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-message .about-message-txt {
    font-size: 0.875rem;
    line-height: 1.8571428571;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-message .about-message-txt {
    margin: 0 auto;
    max-width: 51.875rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-message .about-message-txt {
    font-size: 1.0625rem;
    line-height: 1.7647058824;
  }
}
.section.about-message .about-message-txt .-name {
  text-align: right;
}
@media print, screen and (min-width: 768px) {
  .section.about-message .about-message-txt * + .-name {
    margin-top: 3.75rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-message .about-message-txt * + .-name {
    margin-top: 1.875rem;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-message * + .about-message-txt {
    margin-top: 5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-message * + .about-message-txt {
    margin-top: 1.875rem;
  }
}

.section.about-philosophy .about-philosophy-mv {
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .section.about-philosophy .about-philosophy-mv h2 {
    margin-bottom: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-philosophy .about-philosophy-mv h2 {
    margin-bottom: 1.875rem;
  }
}
.section.about-philosophy .about-philosophy-mv h2 img {
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  .section.about-philosophy .about-philosophy-mv p {
    font-size: 1.25rem;
    line-height: 1.6;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-philosophy .about-philosophy-mv p {
    font-size: 1.0625rem;
    line-height: 1.7647058824;
  }
}
.section.about-philosophy .about-philosophy-challenge h2 picture img {
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  .section.about-philosophy .about-philosophy-challenge .number-box-list {
    row-gap: 0;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-philosophy .about-philosophy-challenge .number-box-list > li + li {
    margin-top: 0;
  }
}

@media print, screen and (min-width: 768px) {
  .section.about-company {
    padding-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company {
    padding-top: 1.875rem;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 1.25rem 2%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-link li {
    width: 32%;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company .about-company-link li {
    margin: 0 auto;
    max-width: 20rem;
  }
  .section.about-company .about-company-link li + li {
    margin-top: 1.875rem;
  }
}
.section.about-company .about-company-link a {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 0.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  overflow: hidden;
  padding: 2.125rem 1.25rem 1.25rem;
  position: relative;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-link a {
    height: 100%;
  }
  .section.about-company .about-company-link a:hover figure:after {
    opacity: 0.7;
  }
}
.section.about-company .about-company-link figure {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.section.about-company .about-company-link figure img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
.section.about-company .about-company-link figure:after {
  background-color: #005F67;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  mix-blend-mode: multiply;
  opacity: 0.5;
  position: absolute;
  top: 0;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-link figure:after {
    -webkit-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
}
.section.about-company .about-company-link h3 {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-size: 1.125rem;
  font-weight: 700;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  line-height: 1.3333333333;
  position: relative;
}
.section.about-company .about-company-link .about-company-link-btn {
  margin-top: 1.25rem;
  max-width: 14.375rem;
  position: relative;
  width: 100%;
}
.section.about-company .about-company-link .about-company-link-btn:before {
  background-color: #FFF;
  border: 0.125rem solid #3A9EA3;
  border-radius: 62.4375rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.section.about-company .about-company-link .about-company-link-btn .btn.-border {
  font-size: 1rem;
  line-height: 1.5;
  padding: 0.625rem 0;
  position: relative;
  width: 100%;
}
.section.about-company .about-company-link .about-company-link-btn .btn.-border:after {
  border-width: 0.125rem;
}
@media print, screen and (min-width: 768px) {
  .section.about-company * + .about-company-link {
    margin-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company * + .about-company-link {
    margin-top: 1.875rem;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-company .table col:nth-of-type(1) {
    width: 19%;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company .table col:nth-of-type(1) {
    width: 34.2028985507%;
  }
}
.section.about-company .about-company-table-btn {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #F8FAFA;
  border: 0.0625rem solid #9FDCC4;
  border-radius: 0.3125rem;
  color: #058D84;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  font-family: "Jost", "Noto Sans JP", sans-serif;
  font-size: 0.625rem;
  font-weight: 600;
  height: 1.1875rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  line-height: 1;
  margin: 0 0.25rem;
  padding: 0.0625rem 0.25rem;
  text-align: center;
  text-decoration: none;
  vertical-align: text-bottom;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-table-btn {
    -webkit-transition: background-color 0.2s ease-out, border-color 0.2s ease-out, color 0.2s ease-out;
    transition: background-color 0.2s ease-out, border-color 0.2s ease-out, color 0.2s ease-out;
  }
  .section.about-company .about-company-table-btn:hover {
    background-color: #058D84;
    border-color: #058D84;
    color: #FFF;
  }
}
.section.about-company .about-company-table-list > li {
  margin-left: 0;
  padding-left: 0.75em;
  position: relative;
  text-indent: 0;
}
.section.about-company .about-company-table-list > li:before {
  content: "-";
  left: 0;
  position: absolute;
  top: 0;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-table-col {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-column-gap: 1.25rem;
       -moz-column-gap: 1.25rem;
            column-gap: 1.25rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .section.about-company .about-company-table-col > * {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
.section.about-company .about-company-table-col ul > li {
  margin-left: 0;
  text-indent: 0;
}
.section.about-company .about-company-table-col ul > li:before {
  display: none;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-access + .about-company-access {
    margin-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company .about-company-access + .about-company-access {
    margin-top: 1.875rem;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-access {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 1.25rem;
       -moz-column-gap: 1.25rem;
            column-gap: 1.25rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.section.about-company .about-company-access iframe {
  display: block;
  height: 11.25rem;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-access iframe {
    width: 18.75rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company .about-company-access iframe {
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-access .about-company-access-detail {
    font-size: 1rem;
    line-height: 1.75;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company .about-company-access .about-company-access-detail {
    font-size: 0.875rem;
    line-height: 1.8571428571;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-access .about-company-access-detail {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-company .about-company-access .about-company-access-detail {
    margin-top: 0.9375rem;
  }
}
.section.about-company .about-company-access .about-company-access-detail h3 {
  font-weight: 400;
}
.section.about-company .about-company-access .about-company-access-detail h3:before {
  content: "【";
}
.section.about-company .about-company-access .about-company-access-detail h3:after {
  content: "】";
}
.section.about-company .about-company-access .about-company-access-detail p.-railway {
  color: #058D84;
}
@media print, screen and (min-width: 768px) {
  .section.about-company .about-company-access .about-company-access-detail * + p.-railway {
    margin-top: 1.75em;
  }
}

@media print, screen and (min-width: 768px) {
  .section.about-history ul li {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-history ul li + li {
    margin-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-history ul li + li {
    margin-top: 1.875rem;
  }
}
.section.about-history ul time {
  color: #017E68;
  font-weight: 500;
}
@media print, screen and (min-width: 768px) {
  .section.about-history ul time {
    font-size: 1.125rem;
    line-height: 1.6666666667;
    width: 9.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-history ul time {
    font-size: 0.875rem;
    line-height: 1.4285714286;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-history ul p {
    font-size: 1rem;
    line-height: 1.75;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-history ul p {
    font-size: 0.875rem;
    line-height: 1.8571428571;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-history ul p {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-top: 0.125rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-history ul p {
    margin-top: 0.9375rem;
  }
}

.section.about-policy .about-policy-name {
  text-align: right;
}
.section.about-policy .about-policy-img img {
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .section.about-policy .about-policy-img img {
    width: 7.5rem;
  }
}
.section.about-policy .about-policy-contact h2 {
  font-weight: 700;
}
@media print, screen and (min-width: 768px) {
  .section.about-policy * + .list,
  .section.about-policy .list > li + li,
  .section.about-policy .list + *,
  .section.about-policy * + .about-policy-name,
  .section.about-policy .about-policy-name + *,
  .section.about-policy .about-policy-img + *,
  .section.about-policy * + .about-policy-contact {
    margin-top: 1.75em;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-policy * + .list,
  .section.about-policy .list > li + li,
  .section.about-policy .list + *,
  .section.about-policy * + .about-policy-name,
  .section.about-policy .about-policy-name + *,
  .section.about-policy .about-policy-img + *,
  .section.about-policy * + .about-policy-contact {
    margin-top: 1.8571428571em;
  }
}
@media print, screen and (min-width: 768px) {
  .section.about-policy * + .about-policy-img {
    margin-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-policy * + .about-policy-img {
    margin-top: 1.875rem;
  }
}

@media print, screen and (min-width: 768px) {
  .section.about-privacy .section-inn > figure {
    margin: 2.5rem 0;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-privacy .section-inn > figure {
    margin: 1.875rem 0;
  }
}
.section.about-privacy .section-inn > figure img {
  margin: 0 auto;
}
.section.about-privacy h4,
.section.about-privacy h5,
.section.about-privacy h6 {
  font-weight: 700;
}
.section.about-privacy .table tr > th, .section.about-privacy .table tr > td {
  vertical-align: middle;
}
@media only screen and (max-width: 767px) {
  .section.about-privacy .table tr > th, .section.about-privacy .table tr > td {
    font-size: 0.8125rem;
    padding: 0.5rem;
  }
}
.section.about-policy .section-inn .about-policy-box,
.section.about-privacy .section-inn .about-policy-box  {
  background: #fff;
  border: 0.125rem solid #d5fbe9;
}

@media print, screen and (min-width: 768px) {
  .section.about-policy .section-inn .about-policy-box,
  .section.about-privacy .section-inn .about-policy-box {
    border-radius: 0.9375rem;
    margin-top: 4rem;
    padding: 2.375rem;
  }
}
@media only screen and (max-width: 767px) {
  .section.about-policy .section-inn .about-policy-box,
  .section.about-privacy .section-inn .about-policy-box  {
    border-radius: 0.625rem;
    margin-top: 3rem;
    padding: 0.8125rem;
  }
}
@media print, screen and (min-width: 768px) {
  .page-ttl .page-ttl-inn .min {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .page-ttl .page-ttl-inn .min {
    font-size: 1.2rem;
  }
}

/*# sourceMappingURL=about.css.map */
