@charset "UTF-8";
:where(:root[data-key=top]) #news {
  padding-block: 1.6rem;
}
:where(:root[data-key=top]) #news .news-container {
  padding-block: 4.8rem;
}
@media screen and (width <= 480px) {
  :root:where(:root[data-key=top]) #news .news-container {
    padding-block: 3.2rem;
  }
}
:where(:root[data-key=top]) #news .news-container .news-content {
  padding-inline: 3.2rem;
}
@media screen and (width <= 480px) {
  :root:where(:root[data-key=top]) #news .news-container .news-content {
    padding-inline: 1.6rem;
  }
}
:where(:root[data-key=top]) #news .news-container {
  /* Mission / Service と同じ .section-heading（大見出し + ◆ サブ）を横並びで View all を配置 */
}
:where(:root[data-key=top]) #news .news-container .news-heading-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1.6rem 3.2rem;
  margin-bottom: 3.2rem;
}
:where(:root[data-key=top]) #news .news-container .news-heading-strip .section-heading {
  flex: 1 1 auto;
  min-width: min(100%, 12rem);
}
:where(:root[data-key=top]) #news .news-container .news-view-all {
  flex: 0 0 auto;
  font-size: 1.4rem;
  color: #333;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-family: Verdana, "Noto Sans JP", sans-serif;
  transition: color 0.2s ease;
}
@media (hover: hover) {
  :where(:root[data-key=top]) #news .news-container .news-view-all:hover {
    color: #f00;
  }
}
:where(:root[data-key=top]) #news .news-container .news-view-all:focus-visible {
  outline: 2px solid color-mix(in srgb, #f00 70%, transparent);
  outline-offset: 4px;
  border-radius: 4px;
}
:where(:root[data-key=top]) #news .news-container .news-body {
  min-width: 0;
}
:where(:root[data-key=top]) #news .news-container .news-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid color-mix(in srgb, #ddd 80%, transparent);
  border-bottom: 1px solid color-mix(in srgb, #ddd 80%, transparent);
}
:where(:root[data-key=top]) #news .news-container .news-item {
  display: grid;
  grid-template-columns: 10em auto 1fr auto;
  align-items: center;
  gap: 1.6rem;
  padding: 1.6rem 0;
  border-bottom: 1px solid color-mix(in srgb, #ddd 60%, transparent);
  font-size: 1.4rem;
  transition: all 0.3s ease;
  position: relative;
  text-decoration: none;
  color: inherit;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=top]) #news .news-container .news-item {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
}
:where(:root[data-key=top]) #news .news-container .news-item::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0;
  height: 2px;
  background: #f00;
  transition: width 0.4s ease;
}
@media (hover: hover) {
  :where(:root[data-key=top]) #news .news-container .news-item:hover .news-title {
    color: #f00;
  }
  :where(:root[data-key=top]) #news .news-container .news-item:hover .news-arrow {
    transform: translateX(4px);
  }
  :where(:root[data-key=top]) #news .news-container .news-item:hover::before {
    width: 100%;
  }
}
:where(:root[data-key=top]) #news .news-container .news-item:focus-visible {
  outline: 2px solid color-mix(in srgb, #f00 70%, transparent);
  outline-offset: 4px;
  border-radius: 4px;
}
:where(:root[data-key=top]) #news .news-container .news-list .news-item {
  padding-block: 3.2rem;
  column-gap: 3.2rem;
  font-size: 1.6rem;
  border-bottom: none;
}
:where(:root[data-key=top]) #news .news-container .news-list .news-item::before {
  display: none;
}
@media (hover: hover) {
  :where(:root[data-key=top]) #news .news-container .news-list .news-item:hover .news-title {
    color: #f00;
  }
  :where(:root[data-key=top]) #news .news-container .news-list .news-item:hover .news-arrow {
    transform: translateX(4px);
  }
}
:where(:root[data-key=top]) #news .news-container .news-list > li:not(:last-child) .news-item {
  border-bottom: 1px solid color-mix(in srgb, #ddd 80%, transparent);
}
:where(:root[data-key=top]) #news .news-container .news-date {
  color: #666;
  white-space: nowrap;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  font-family: Verdana, "Noto Sans JP", sans-serif;
}
:where(:root[data-key=top]) #news .news-container .news-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4em 0.9em;
  border-radius: 4px;
  background: color-mix(in srgb, #ddd 22%, #fff);
  color: #333;
  font-size: 1.2rem;
  font-weight: 400;
  white-space: nowrap;
  letter-spacing: 0.03em;
  font-family: Verdana, "Noto Sans JP", sans-serif;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=top]) #news .news-container .news-category {
    width: fit-content;
  }
}
:where(:root[data-key=top]) #news .news-container .news-title {
  color: #333;
  line-height: 1.5;
  transition: color 0.3s ease;
  font-size: 1.6rem;
  font-weight: 400;
  font-family: Verdana, "Noto Sans JP", sans-serif;
}
@media screen and (width <= 480px) {
  :root:where(:root[data-key=top]) #news .news-container .news-title {
    font-size: 1.4rem;
  }
}
:where(:root[data-key=top]) #news .news-container .news-arrow {
  color: #666;
  font-size: 1.6rem;
  line-height: 1;
  font-family: Verdana, "Noto Sans JP", sans-serif;
  transition: transform 0.3s ease, color 0.3s ease;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=top]) #news .news-container .news-arrow {
    display: none;
  }
}
:where(:root[data-key=top]) #news .news-container .news-empty {
  color: #666;
  font-size: 1.4rem;
  padding: 3.2rem 0;
  text-align: center;
  font-family: Verdana, "Noto Sans JP", sans-serif;
}

:where(:root[data-key=news]) #mainVisual .mainVisual-container {
  padding-block: 3.2rem 6.4rem;
}
:where(:root[data-key=news]) {
  /* About の本文エリアに近い縦余白（上: MV 下の区切り、下: sections-body と同様 2xl） */
}
:where(:root[data-key=news]) #page-main #news-index.sections-container {
  padding-inline: 3.2rem;
  padding-block: 6.4rem 9.6rem;
}
@media screen and (width <= 480px) {
  :root:where(:root[data-key=news]) #page-main #news-index.sections-container {
    padding-inline: 0;
    padding-block: 4.8rem 9.6rem;
  }
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .sections-content--news {
  display: block;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-archive {
  padding: 0;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-lead {
  margin-bottom: 3.2rem;
  color: #666;
  font-size: 1.4rem;
  line-height: 1.8;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-item {
  display: grid;
  grid-template-columns: 10em auto 1fr auto;
  align-items: center;
  gap: 1.6rem;
  padding: 1.6rem 0;
  border-bottom: 1px solid color-mix(in srgb, #ddd 60%, transparent);
  font-size: 1.4rem;
  transition: all 0.3s ease;
  position: relative;
  text-decoration: none;
  color: inherit;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=news]) #page-main #news-index.sections-container .news-item {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-item::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0;
  height: 2px;
  background: #f00;
  transition: width 0.4s ease;
}
@media (hover: hover) {
  :where(:root[data-key=news]) #page-main #news-index.sections-container .news-item:hover .news-title {
    color: #f00;
  }
  :where(:root[data-key=news]) #page-main #news-index.sections-container .news-item:hover .news-arrow {
    transform: translateX(4px);
  }
  :where(:root[data-key=news]) #page-main #news-index.sections-container .news-item:hover::before {
    width: 100%;
  }
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-item:focus-visible {
  outline: 2px solid color-mix(in srgb, #f00 70%, transparent);
  outline-offset: 4px;
  border-radius: 4px;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-item {
  padding-block: 3.2rem;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-list > li:first-child .news-item {
  border-top: 1px solid color-mix(in srgb, #ddd 60%, transparent);
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-list > li:first-child .news-item::after {
  content: "";
  position: absolute;
  left: 0;
  top: -1px;
  width: 100%;
  height: 1px;
  background: color-mix(in srgb, #ddd 60%, transparent);
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-date {
  color: #666;
  white-space: nowrap;
  font-family: Verdana, sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4em 0.9em;
  border-radius: 4px;
  background: color-mix(in srgb, #ddd 22%, #fff);
  color: #333;
  font-size: 1.2rem;
  font-weight: 400;
  white-space: nowrap;
  letter-spacing: 0.03em;
  font-family: Verdana, "Noto Sans JP", sans-serif;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=news]) #page-main #news-index.sections-container .news-category {
    width: fit-content;
  }
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-title {
  color: #333;
  line-height: 1.5;
  transition: color 0.3s ease;
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-arrow {
  color: #666;
  font-size: 1.6rem;
  line-height: 1;
  font-family: Verdana, sans-serif;
  transition: transform 0.3s ease, color 0.3s ease;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=news]) #page-main #news-index.sections-container .news-arrow {
    display: none;
  }
}
:where(:root[data-key=news]) #page-main #news-index.sections-container .news-empty {
  color: #666;
  font-size: 1.4rem;
  padding: 3.2rem 0;
  text-align: center;
}
:where(:root[data-key=news]) #news-article {
  padding: 3.2rem 3.2rem 9.6rem;
}
@media screen and (width <= 480px) {
  :root:where(:root[data-key=news]) #news-article {
    padding-inline: 1.6rem;
  }
}
:where(:root[data-key=news]) #news-article .content-inner {
  max-width: 900px;
}
:where(:root[data-key=news]) #news-article .news-article-breadcrumb {
  margin-bottom: 1.6rem;
  font-size: 1.2rem;
  color: #666;
}
:where(:root[data-key=news]) #news-article .news-article-breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.15em 0.35em;
  margin: 0;
  padding: 0;
  list-style: none;
}
:where(:root[data-key=news]) #news-article .news-article-breadcrumb-list li {
  display: inline-flex;
  align-items: baseline;
  max-width: 100%;
}
:where(:root[data-key=news]) #news-article .news-article-breadcrumb-list li + li::before {
  content: "›";
  margin-inline-end: 0.35em;
  color: #999;
  font-size: 1em;
  line-height: 1;
}
:where(:root[data-key=news]) #news-article .news-article-breadcrumb-list a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
@media (hover: hover) {
  :where(:root[data-key=news]) #news-article .news-article-breadcrumb-list a:hover {
    text-decoration: none;
  }
}
:where(:root[data-key=news]) #news-article .news-article-breadcrumb-list [aria-current=page] {
  color: #333;
  font-weight: 400;
  line-height: 1.5;
}
:where(:root[data-key=news]) #news-article .news-article-header {
  margin-bottom: 4.8rem;
  padding-bottom: 1.6rem;
  border-bottom: 1px solid color-mix(in srgb, #ddd 70%, transparent);
}
:where(:root[data-key=news]) #news-article .news-article-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.6rem;
  margin-bottom: 1.6rem;
}
:where(:root[data-key=news]) #news-article .news-article-meta .news-date {
  color: #666;
  white-space: nowrap;
  font-family: Verdana, sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
}
:where(:root[data-key=news]) #news-article .news-article-meta .news-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f00;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 9999px;
  white-space: nowrap;
  letter-spacing: 0.05em;
}
@media screen and (width <= 768px) {
  :root:where(:root[data-key=news]) #news-article .news-article-meta .news-category {
    width: fit-content;
  }
}
:where(:root[data-key=news]) #news-article .news-article-title {
  font-size: 3.2rem;
  line-height: 1.5;
  color: #333;
}
:where(:root[data-key=news]) #news-article .news-article-body {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgb(0 0 0 / 0.05);
  padding: 4.8rem;
  font-size: 1.4rem;
  line-height: 1.8;
  color: #333;
}
@media screen and (width <= 480px) {
  :root:where(:root[data-key=news]) #news-article .news-article-body {
    padding: 3.2rem;
  }
}
:where(:root[data-key=news]) #news-article .news-article-body strong {
  font-weight: 700;
  color: #333;
}
:where(:root[data-key=news]) #news-article .news-article-body a:not(:has(img)) {
  text-decoration: underline;
  text-underline-offset: 3px;
}
@media (hover: hover) {
  :where(:root[data-key=news]) #news-article .news-article-body a:not(:has(img)):hover {
    text-decoration: none;
  }
}
:where(:root[data-key=news]) #news-article .news-article-body p + p {
  margin-top: 3.2rem;
}
:where(:root[data-key=news]) #news-article .news-article-body :is(h2, h3) {
  margin-top: 6.4rem;
  margin-bottom: 1.6rem;
  line-height: 1.5;
  font-size: 1.6rem;
  font-weight: 700;
  color: #333;
}
:where(:root[data-key=news]) #news-article .news-article-body p + :is(h2, h3),
:where(:root[data-key=news]) #news-article .news-article-body :is(ul, ol) + :is(h2, h3) {
  margin-top: 6.4rem;
}
:where(:root[data-key=news]) #news-article .news-article-body :is(ul, ol) {
  margin: 3.2rem 0;
  padding-left: 1.5em;
}
:where(:root[data-key=news]) #news-article .news-article-body li + li {
  margin-top: 0.8rem;
}
:where(:root[data-key=news]) #news-article .news-article-back {
  margin-top: 9.6rem;
  text-align: center;
}
