.company_scrollto_item_link {
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  .company_scrollto_item_link {
    font-size: 1.5rem;
  }
}

.message_item_sign_name {
  font-size: 1.5rem;
}
@media only screen and (min-width: 768px) {
  .message_item_sign_name {
    font-size: 1.8rem;
  }
}

.story_more .btn {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .story_more .btn {
    font-size: clamp(
        1.6rem,
        calc(1.6rem + 0.0048076923 * (100vw - 768px)),
        2rem
    );
  }
}

.address_item_title {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .address_item_title {
    font-size: clamp(
        2rem,
        calc(2rem + 0.0048076923 * (100vw - 768px)),
        2.4rem
    );
  }
}

.company_scrollto {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .company_scrollto {
    margin-top: 80px;
  }
}
.company_scrollto_lists {
  display: flex;
  gap: 12px 20px;
  flex-wrap: wrap;
}
@media only screen and (min-width: 768px) {
  .company_scrollto_lists {
    gap: 56px;
    justify-content: center;
  }
}
.company_scrollto_item {
  width: calc(50% - 10px);
}
@media only screen and (min-width: 768px) {
  .company_scrollto_item {
    width: auto;
  }
}
.company_scrollto_item_link {
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.03em;
  width: 100%;
  position: relative;
  border-bottom: 1px solid #bbcbc0;
  padding-bottom: 16px;
  display: inline-flex;
  padding-left: 11px;
  padding-bottom: 10px;
}
@media only screen and (min-width: 768px) {
  .company_scrollto_item_link {
    min-width: 160px;
  }
}
.company_scrollto_item_link::after {
  content: "";
  width: 8px;
  height: 8px;
  position: absolute;
  top: 50%;
  right: 11px;
  rotate: 45deg;
  translate: 0 -130%;
  border: 0;
  border-right: 3px solid #00780e;
  border-bottom: 3px solid #00780e;
}

.message {
  margin-top: 40px;
}
@media only screen and (min-width: 768px) {
  .message {
    margin-top: 80px;
  }
}
.message_grid {
  display: flex;
  gap: 40px;
  flex-direction: column;
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .message_grid {
    flex-direction: row;
    margin-top: 60px;
  }
}
@media only screen and (min-width: 768px) {
  .message_grid_content {
    width: 46.6379310345%;
    margin-top: -5px;
  }
}
@media only screen and (min-width: 768px) {
  .message_grid_photo {
    width: calc(53.4482758621% - 40px);
  }
}
.message_item_txt {
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.01em;
}
.message_item_txt:not(:first-child) {
  margin-top: 16px;
}
@media only screen and (min-width: 768px) {
  .message_item_txt:not(:first-child) {
    margin-top: 32px;
  }
}
.message_item_sign {
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.01em;
  text-align: right;
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  .message_item_sign {
    margin-top: 32px;
  }
}
.message_item_sign_name {
  font-weight: 500;
  line-height: 1.7777777778;
  letter-spacing: 0.01em;
  text-align: right;
}
.profile {
  margin-top: 60px;
}
@media only screen and (min-width: 768px) {
  .profile {
    margin-top: 120px;
  }
}
.profile_info {
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .profile_info {
    margin-top: 60px;
  }
}
.profile_info_data {
  display: flex;
  gap: 0px 40px;
  flex-direction: column;
  border-bottom: 1px solid #bbcbc0;
}
@media only screen and (min-width: 768px) {
  .profile_info_data {
    flex-direction: row;
    border-bottom: 1px solid rgba(255, 255, 255, 0);
  }
}
.profile_info_title {
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.01em;
  color: #00780e;
  padding-top: 16px;
}
@media only screen and (min-width: 768px) {
  .profile_info_title {
    width: 260px;
    border-bottom: 1px solid #dee3bc;
    padding-top: 32px;
    padding-bottom: 32px;
  }
}
.profile_info_detail {
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.01em;
  padding-bottom: 16px;
}
@media only screen and (min-width: 768px) {
  .profile_info_detail {
    width: calc(100% - 260px - 40px);
    border-bottom: 1px solid #bbcbc0;
    padding-top: 32px;
    padding-bottom: 32px;
  }
}
.profile_info a {
  color: #00780e;
  display: inline-flex;
  align-items: center;
}
.profile_info a .icon {
  --sw: 14px;
  --sh: 11px;
  background-color: rgba(255, 255, 255, 0);
  top: 1px;
}

.address {
  margin-top: 60px;
}
@media only screen and (min-width: 768px) {
  .address {
    margin-top: 120px;
  }
}
.address_lists {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .address_lists {
    gap: 20px 40px;
    margin-top: 60px;
  }
}
.address_item {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .address_item {
    width: calc(33.33% - 26.6666666667px);
  }
}
.address_item_title {
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.03em;
  color: #00780e;
}
.address_item_ggmap {
  aspect-ratio: 1.0682492582;
  margin-top: 10px;
}
@media only screen and (min-width: 768px) {
  .address_item_ggmap {
    margin-top: 16px;
  }
}
.address_item_ggmap img,
.address_item_ggmap iframe {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.address_item_txt {
  line-height: 2;
  letter-spacing: 0.01em;
  margin-top: 8px;
}
@media only screen and (min-width: 768px) {
  .address_item_txt {
    margin-top: 12px;
  }
}

.story {
  position: relative;
  margin-top: 60px;
}
@media only screen and (min-width: 768px) {
  .story {
    margin-top: 120px;
  }
}
.story_cover {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.story_cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.story_inner {
  padding: 40px 20px;
}
@media only screen and (min-width: 768px) {
  .story_inner {
    max-width: 777px;
    padding: 91px 98px 100px;
  }
}
.story_txt {
  font-weight: 700;
  line-height: 2.25;
  letter-spacing: 0.01em;
  color: #fff;
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .story_txt {
    margin-top: 39px;
    padding-left: 4px;
  }
}
.story_more {
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .story_more {
    max-width: 442px;
    margin-top: 47px;
  }
}
@media only screen and (min-width: 768px) {
  .story_more .btn {
    --btn-w: 100%;
    opacity: 1;
    transition: 150ms linear;
  }
  .story_more .btn:hover {
    filter: brightness(0.9);
  }
}
.story_more .icon {
  border: 1px solid #adcb00;
}

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