/* Message page: company lower hero and image-based navigation */
@media (min-width: 1024px) {
  body.page-id-219 .page-article--with-title-banner {
    padding-bottom: 0;
  }

  body.page-id-219 .page-title-banner--about {
    padding: 0 !important;
    background: transparent;
  }

  body.page-id-219 .page-title-banner--about .about-pagehero {
    height: 411px;
    overflow: hidden;
    background: #0079c4;
  }

  body.page-id-219 .page-title-banner--about .about-pagehero__img {
    display: block;
    width: 1967px !important;
    max-width: none !important;
    height: 411px !important;
    margin-left: calc(50% + 580px - 1588px) !important;
    object-fit: fill;
    transform: none !important;
  }

  body.page-id-219 .page-title-banner--about .page-title-banner__inner {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 100px 0;
    background: #dff0f7;
    box-sizing: border-box;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav {
    width: min(calc(100% - 80px), 1160px);
    max-width: 1160px;
    height: 100px;
    margin: 0 auto;
    padding: 0;
    border: 0 !important;
    background: transparent;
    background-image: url("../../img/about/menu3.png") !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: 100% 100% !important;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav ul {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0;
    width: 100%;
    max-width: none;
    height: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav li {
    display: block;
    min-width: 0;
    margin: 0;
    padding: 0;
    border: 0 !important;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav li::before,
  body.page-id-219 .page-title-banner--about .company-nav.quality-nav li::after {
    content: none !important;
    display: none !important;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav a {
    position: relative;
    min-height: 100px;
    padding: 8px 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 0 !important;
    border-radius: 0;
    background: transparent !important;
    background-image: none !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
    font-size: 0 !important;
    font-weight: 900;
    line-height: 0 !important;
    letter-spacing: 0.02em;
    text-align: center;
    text-decoration: none;
    white-space: normal;
    text-indent: -9999px;
    box-sizing: border-box;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav a::before,
  body.page-id-219 .page-title-banner--about .company-nav.quality-nav a::after {
    content: none !important;
    display: none !important;
  }

  body.page-id-219 .page-title-banner--about .company-nav.quality-nav a:hover,
  body.page-id-219 .page-title-banner--about .company-nav.quality-nav a:focus-visible,
  body.page-id-219 .page-title-banner--about .company-nav.quality-nav a.is-current {
    background: transparent !important;
    background-image: none !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
  }
}

/* Message page: legacy block layout */
body.page-id-219 .page-content .message-greeting {
  display: block;
}

body.page-id-219 .page-content .message-greeting__top {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(28px, 3.4vw, 56px);
  align-items: start;
}

body.page-id-219 .page-content .message-greeting__headline {
  margin: 0;
  display: inline-block;
  color: #000;
  font-size: 35pt;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.01em;
  white-space: nowrap;
  word-break: keep-all;
  overflow-wrap: normal;
}

body.page-id-219 .page-content .message-greeting__body p {
  margin: 0;
  color: #0f2239;
  font-size: clamp(15px, 1.24vw, 24px);
  line-height: 1.86;
}

body.page-id-219 .page-content .message-greeting__sign {
  margin-top: clamp(18px, 2.2vw, 34px) !important;
  text-align: right;
  line-height: 1.65;
}

body.page-id-219 .page-content .message-greeting__image {
  margin: clamp(28px, 3.2vw, 48px) 0 0;
}

body.page-id-219 .page-content .message-greeting__image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

body.page-id-219 .page-content .message-shaze-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  gap: 2em;
}

body.page-id-219 .page-content .message-shaze-columns > .wp-block-column {
  margin: 0;
  min-width: 0;
}

body.page-id-219 .page-content .message-shaze-columns__image {
  position: relative;
  min-height: 0;
}

body.page-id-219 .page-content .message-shaze-columns__image .wp-block-image {
  position: absolute;
  inset: 0;
  margin: 0;
}

body.page-id-219 .page-content .message-shaze-columns__image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center top;
  background: #fff;
  border: 1px solid #d6e2f2;
  border-radius: 12px;
  padding: 8px;
}

body.page-id-219 .page-content .message-shaze-columns__image .wp-block-image.size-large,
body.page-id-219 .page-content .message-shaze-columns__image .wp-block-image.size-large img {
  border: 0 !important;
}

body.page-id-219 .page-content .message-shaze-columns__body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
}

body.page-id-219 .page-content .message-shaze-columns__body p {
  margin: 0;
  line-height: 1.95;
  color: #243a56;
}

body.page-id-219 .page-content .message-shaze-columns__body a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border-radius: 999px;
  background: #2f5f9f;
  color: #fff;
  font-weight: 400;
  text-decoration: none;
  width: fit-content;
}

@media (max-width: 980px) {
  body.page-id-219 .page-content {
    --msk-section-gap: 40px;
  }

  body.page-id-219 .page-content .message-shaze-columns {
    grid-template-columns: 1fr;
  }

  body.page-id-219 .page-content .message-greeting__top {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  body.page-id-219 .page-content .message-greeting__headline {
    font-size: 35pt;
    line-height: 1.4;
  }

  body.page-id-219 .page-content .message-greeting__body p {
    font-size: 16px;
    line-height: 1.8;
  }

  body.page-id-219 .page-content .message-shaze-columns__image .wp-block-image {
    position: static;
  }

  body.page-id-219 .page-content .message-shaze-columns__image img {
    height: auto;
  }
}

/* Message page: legacy MSRT side labels and dividers */
body.page-id-219 .page-content {
  --msk-section-gap: 64px;
}

.page-id-219 .page-content .message-section-divider {
  width: 100%;
  max-width: var(--company-banner-max-width, 1080px);
  padding-left: var(--company-msrt-inset, 84px);
  padding-right: 20px;
  height: 24px;
  margin: 34px auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-id-219 .page-content .message-section-divider::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  transform: translateY(-50%);
  background: linear-gradient(90deg, rgba(74, 120, 180, 0.12) 0%, rgba(74, 120, 180, 0.58) 50%, rgba(74, 120, 180, 0.12) 100%);
}

.page-id-219 .page-content .message-section-divider span {
  position: relative;
  z-index: 1;
  display: block;
  width: 8px;
  height: 8px;
  background: #4a78b4;
  box-shadow: 0 0 0 4px #fff;
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns),
.page-id-219 .page-content .message-shaze-columns,
.page-id-219 .page-content .message-philosophy {
  position: relative;
  overflow: visible;
  max-width: var(--company-banner-max-width, 1080px);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--company-msrt-inset, 84px);
  padding-right: 20px;
  --msk-page-msrt-label: "";
  --msk-page-msrt-color: #4a78b4;
  --msk-page-msrt-left: 0;
  --msk-page-msrt-top: 0;
  --msk-page-msrt-scale: 0.45;
  --msk-page-msrt-width-base: 52px;
  --msk-page-msrt-height-base: 236px;
  --msk-page-msrt-pad-top-base: 14px;
  --msk-page-msrt-pad-bottom-base: 36px;
  --msk-page-msrt-font-base: 42px;
  --msk-page-msrt-font-size: 18px;
  --msrt-page-core-rect-cut-offset: calc(var(--msk-page-msrt-width-base) * var(--msk-page-msrt-scale));
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns) {
  --msk-page-msrt-label: "社長挨拶";
  --msk-page-msrt-height-base: 270px;
}

.page-id-219 .page-content .message-shaze-columns {
  --msk-page-msrt-label: "社是";
}

.page-id-219 .page-content .message-philosophy {
  --msk-page-msrt-label: "経営理念";
  max-width: var(--company-banner-max-width, 1080px);
  margin-left: auto;
  margin-right: auto;
  padding: 0 28px 26px;
  padding-left: calc(var(--company-msrt-inset, 84px) + 28px);
  background: linear-gradient(180deg, #f5f9ff 0%, #edf4ff 100%);
  border: 1px solid #cfdef0;
  border-radius: 14px;
  box-shadow: 0 12px 28px rgba(31, 69, 118, 0.1);
}

.page-id-219 .page-content .message-philosophy p {
  margin: 0 0 14px;
  color: #1f3959;
  line-height: 2;
}

.page-id-219 .page-content .message-philosophy ol {
  margin: 0;
  padding-left: 1.2em;
  display: grid;
  gap: 10px;
}

.page-id-219 .page-content .message-philosophy li {
  color: #2a4466;
  line-height: 1.95;
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns),
.page-id-219 .page-content .message-shaze-columns,
.page-id-219 .page-content .message-philosophy {
  max-width: var(--company-banner-max-width, 1080px);
  margin-left: auto;
  margin-right: auto;
  --msk-page-msrt-width-base: 68px;
  --msk-page-msrt-font-size: 18px;
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns),
.page-id-219 .page-content .message-shaze-columns,
.page-id-219 .page-content .message-philosophy {
  margin-top: 0;
  margin-bottom: 0;
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns):not(:first-child),
.page-id-219 .page-content .message-shaze-columns:not(:first-child),
.page-id-219 .page-content .message-philosophy:not(:first-child) {
  margin-top: var(--msk-section-gap);
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::before,
.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::after,
.page-id-219 .page-content .message-shaze-columns::before,
.page-id-219 .page-content .message-shaze-columns::after,
.page-id-219 .page-content .message-philosophy::before,
.page-id-219 .page-content .message-philosophy::after {
  content: "";
  position: absolute;
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::before,
.page-id-219 .page-content .message-shaze-columns::before,
.page-id-219 .page-content .message-philosophy::before {
  left: var(--msk-page-msrt-left);
  top: var(--msk-page-msrt-top);
  bottom: 0;
  width: 1px;
  background: var(--msk-page-msrt-color);
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::after,
.page-id-219 .page-content .message-shaze-columns::after,
.page-id-219 .page-content .message-philosophy::after {
  content: var(--msk-page-msrt-label);
  left: var(--msk-page-msrt-left);
  top: var(--msk-page-msrt-top);
  width: calc(var(--msk-page-msrt-width-base) * var(--msk-page-msrt-scale));
  min-height: calc(var(--msk-page-msrt-height-base) * var(--msk-page-msrt-scale));
  padding: 0 0 var(--msrt-page-core-rect-cut-offset);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--msk-page-msrt-color);
  color: #fff;
  font-size: var(--msk-page-msrt-font-size);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0;
  writing-mode: vertical-rl;
  text-orientation: upright;
  clip-path: polygon(0 0, 100% 0, 100% 78%, 0 100%);
}

.page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::after,
.page-id-219 .page-content .message-shaze-columns::after,
.page-id-219 .page-content .message-philosophy::after {
  font-size: 18px;
  font-weight: 100;
  padding: 0 0 var(--msrt-page-core-rect-cut-offset);
  align-items: center;
  justify-content: center;
}

@media (max-width: 980px) {
  body.page-id-219 .page-content {
    --msk-section-gap: 40px;
  }

  .page-id-219 .page-content .message-section-divider {
    margin: 26px auto;
  }

  .page-id-219 .page-content .message-philosophy {
    padding: 0 18px 20px;
  }

  .page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns):not(:first-child),
  .page-id-219 .page-content .message-shaze-columns:not(:first-child),
  .page-id-219 .page-content .message-philosophy:not(:first-child) {
    margin-top: var(--msk-section-gap);
  }
}

@media (max-width: 880px) {
  .page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::before,
  .page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns)::after,
  .page-id-219 .page-content .message-shaze-columns::before,
  .page-id-219 .page-content .message-shaze-columns::after,
  .page-id-219 .page-content .message-philosophy::before,
  .page-id-219 .page-content .message-philosophy::after {
    display: none;
  }

  .page-id-219 .page-content .wp-block-columns:not(.message-shaze-columns),
  .page-id-219 .page-content .message-shaze-columns,
  .page-id-219 .page-content .message-section-divider {
    padding-left: 20px;
    padding-right: 20px;
  }
}

/* Message page: current block layout */
body.page-id-219 .page-content .message-block {
  max-width: 1080px;
  margin: 0 auto 70px;
}

.message-bartitle {
  background: #0079c4;
  color: #ffffff;
  text-align: center;
  font-size: clamp(16px, 1.5vw, 20px);
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 12px 16px;
  margin: 0 0 36px;
}

.message-greeting__inner {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 44px;
  align-items: start;
}

.message-greeting__catch {
  font-size: clamp(23px, 2.5vw, 33px);
  font-weight: 700;
  line-height: 1.5;
  color: #1f2d3d;
  margin: 0 0 26px;
}

.message-greeting__name {
  text-align: right;
  font-weight: 700;
  color: #1f2d3d;
  margin: 0 0 22px;
}

.message-greeting__text {
  line-height: 2.05;
  font-size: 15px;
}

.message-greeting__photo {
  margin: 0;
  border-radius: 4px;
  overflow: hidden;
}

.message-greeting__photo img {
  display: block;
  width: 100%;
  height: auto;
}

.message-shaze__inner {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 44px;
  align-items: start;
}

.message-shaze__image {
  margin: 0;
}

.message-shaze__image img {
  display: block;
  width: 100%;
  height: auto;
}

.message-shaze__text {
  line-height: 2;
  font-size: 14px;
  margin: 0 0 26px;
}

.message-shaze__pdf {
  text-align: right;
  margin: 0;
}

.message-shaze__pdf a {
  display: inline-block;
  background: #0079c4;
  color: #ffffff;
  text-decoration: none;
  font-weight: 700;
  padding: 11px 30px;
  border-radius: 2px;
}

.message-shaze__pdf a::after {
  content: " →";
}

.message-business__list {
  margin: 0;
}

.message-business__row {
  display: grid;
  grid-template-columns: 230px 1fr;
  gap: 32px;
  padding: 22px 0;
  border-bottom: 1px solid #d4dbe5;
  align-items: start;
}

.message-business__row:first-child {
  border-top: 1px solid #d4dbe5;
}

.message-business__row dt {
  font-weight: 700;
  color: #122946;
  line-height: 1.6;
}

.message-business__row dd {
  margin: 0;
  line-height: 1.9;
  font-size: 14px;
  color: rgba(31, 45, 61, 0.85);
}

.message-philosophy2__lead {
  text-align: center;
  max-width: 880px;
  margin: 0 auto 38px;
  line-height: 1.95;
  font-size: 15px;
}

.message-philosophy2__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 30px;
}

.message-philosophy2__item {
  padding-top: 8px;
}

.message-philosophy2__num {
  display: block;
  font-size: 40px;
  font-weight: 700;
  color: #0079c4;
  line-height: 1;
  margin-bottom: 14px;
  text-align: center;
}

.message-philosophy2__item p {
  font-size: 13px;
  line-height: 1.9;
  margin: 0 0 16px;
  color: rgba(31, 45, 61, 0.85);
}

.message-philosophy2__photos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 30px;
  margin: 38px 0 0;
}

.message-philosophy2__photos figure {
  margin: 0;
  border-radius: 0;
  overflow: hidden;
}

.message-philosophy2__photos img {
  display: block;
  width: 100%;
  aspect-ratio: 984 / 594;
  object-fit: cover;
}

.message-philosophy2__item figure {
  margin: 0;
  border-radius: 4px;
  overflow: hidden;
}

.message-philosophy2__item img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

@media (max-width: 860px) {
  .message-greeting__inner,
  .message-shaze__inner {
    grid-template-columns: 1fr;
  }

  .message-business__row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .message-philosophy2__grid {
    grid-template-columns: 1fr;
  }

  .message-philosophy2__photos {
    grid-template-columns: 1fr;
  }
}

/* Message page: desktop company-lower layout */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about {
    position: relative;
    padding-top: 90px;
    padding-bottom: 0;
  }

  body.page-id-219 .page-content--about::before {
    content: "";
    position: absolute;
    top: 90px;
    bottom: 100px;
    left: max(40px, calc(50% - 580px));
    z-index: 2;
    width: 4px;
    background: #0079c4;
    pointer-events: none;
  }

  body.page-id-219 .page-content--about::after {
    content: "社長あいさつ・社是・理念";
    position: absolute;
    top: 90px;
    left: max(40px, calc(50% - 580px - 50px));
    z-index: 2;
    color: #0079c4;
    font-size: 34px;
    font-weight: 900;
    line-height: 1.08;
    letter-spacing: 0.04em;
    writing-mode: vertical-rl;
    text-orientation: upright;
    pointer-events: none;
  }

  body.page-id-219 .about-sidetitle {
    display: none !important;
  }

  body.page-id-219 .message-block {
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    box-sizing: border-box;
  }

  body.page-id-219 .page-content--about .message-block {
    width: 100% !important;
    max-width: none !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-bottom: 0 !important;
    box-sizing: border-box;
  }

  body.page-id-219 .message-bartitle {
    width: min(calc(100vw - 180px), 1060px);
    max-width: 1060px;
    min-height: 44px;
    margin: 0 auto 80px;
    padding: 8px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateX(50px);
    background: #0079c4;
    color: #ffffff;
    font-size: 21px;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-align: center;
    box-sizing: border-box;
  }

  body.page-id-219 .message-greeting {
    padding: 0;
  }

  body.page-id-219 .message-greeting__inner,
  body.page-id-219 .message-shaze__inner,
  body.page-id-219 .message-business__list,
  body.page-id-219 .message-philosophy2__lead,
  body.page-id-219 .message-philosophy2__grid,
  body.page-id-219 .message-philosophy2__photos {
    width: min(calc(100vw - 180px), 1060px);
    max-width: 1060px;
    margin-left: auto;
    margin-right: auto;
    transform: translateX(50px);
    box-sizing: border-box;
  }

  body.page-id-219 .message-greeting__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 260px;
    gap: 80px;
    align-items: start;
  }

  body.page-id-219 .message-greeting__catch {
    margin: 0 0 44px;
    color: #000000;
    font-size: 35px;
    font-weight: 900;
    line-height: 1.5;
    letter-spacing: 0.01em;
  }

  body.page-id-219 .message-greeting__name {
    margin: 0 0 34px;
    color: #000000;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.7;
    text-align: right;
  }

  body.page-id-219 .message-greeting__text {
    margin: 0;
    color: #000000;
    font-size: 15px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.04em;
  }

  body.page-id-219 .message-greeting__photo {
    margin: 0;
    border-radius: 0;
    overflow: hidden;
  }

  body.page-id-219 .message-greeting__photo img {
    display: block;
    width: 100%;
    height: auto;
    border: 0;
  }

  body.page-id-219 .message-shaze {
    margin-top: 90px;
    padding: 90px 0;
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: #dff0f7;
  }

  body.page-id-219 .page-content--about .message-block.message-shaze {
    margin-top: 90px !important;
  }

  body.page-id-219 .message-shaze__inner {
    display: grid;
    grid-template-columns: 270px minmax(0, 1fr);
    gap: 120px;
    align-items: start;
  }

  body.page-id-219 .message-shaze__body {
    min-height: 373px;
    display: flex;
    flex-direction: column;
  }

  body.page-id-219 .message-shaze__image {
    margin: 0;
  }

  body.page-id-219 .message-shaze__image img {
    display: block;
    width: 100%;
    height: auto;
    border: 0;
  }

  body.page-id-219 .message-shaze__text {
    margin: 0;
    color: #000000;
    font-size: 15px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.04em;
  }

  body.page-id-219 .message-shaze__pdf {
    margin: auto 0 0;
    text-align: right;
  }

  body.page-id-219 .message-shaze__pdf a {
    min-width: 220px;
    min-height: 45px;
    padding: 8px 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0;
    background: #0079c4;
    color: #ffffff;
    font-size: 17px;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: 0.04em;
    text-decoration: none;
    box-sizing: border-box;
  }

  body.page-id-219 .message-business {
    padding: 90px 0;
  }

  body.page-id-219 .message-business__list {
    display: grid;
    gap: 28px;
  }

  body.page-id-219 .message-business__row {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 56px;
    padding: 0;
    border: 0;
  }

  body.page-id-219 .message-business__row:first-child {
    border-top: 0;
  }

  body.page-id-219 .message-business__row dt {
    position: relative;
    margin: 0;
    padding-left: 0px;
    color: #000000;
    font-size: 18px;
    font-weight: 900;
    line-height: 1.55;
  }

  body.page-id-219 .message-business__row dt::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.2em;
    width: 6px;
    height: 52px;
    background: #0079c4;
  }

  body.page-id-219 .message-business__row dd {
    margin: 0;
    color: #000000;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.95;
    letter-spacing: 0.03em;
  }

  body.page-id-219 .message-philosophy2 {
    padding: 90px 0 100px;
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: #dff0f7;
  }

  body.page-id-219 .message-philosophy2__lead {
    margin-top: 0;
    margin-bottom: 70px;
    color: #000000;
    font-size: 15px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.04em;
    text-align: left;
  }

  body.page-id-219 .message-philosophy2__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 54px;
  }

  body.page-id-219 .message-philosophy2__item {
    padding-top: 0;
  }

  body.page-id-219 .message-philosophy2__num {
    display: block;
    margin: 0 0 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid #000000;
    color: #0079c4;
    font-size: 34px;
    font-weight: 500;
    line-height: 1;
    text-align: center;
  }

  body.page-id-219 .message-philosophy2__item p {
    min-height: 120px;
    margin: 0;
    color: #000000;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.85;
    letter-spacing: 0.03em;
  }

  body.page-id-219 .message-philosophy2__photos {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 70px;
    margin-top: 70px;
  }

  body.page-id-219 .message-philosophy2__photos figure {
    margin: 0;
    border-radius: 0;
    overflow: hidden;
  }

  body.page-id-219 .message-philosophy2__photos img {
    display: block;
    width: 100%;
    aspect-ratio: 984 / 594;
    object-fit: cover;
  }

  body.page-id-219 .message-philosophy2__item figure {
    margin: 0;
    border-radius: 0;
    overflow: hidden;
  }

  body.page-id-219 .message-philosophy2__item img {
    display: block;
    width: 100%;
    aspect-ratio: 1.75 / 1;
    object-fit: cover;
  }

  body.page-id-219 .page-content--about .message-bartitle {
    background: #0079c4 !important;
    background-image: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
  }

  body.page-id-219 .message-greeting__catch {
    font-size: 33px !important;
    line-height: 1.46 !important;
    letter-spacing: 0 !important;
  }

  body.page-id-219 .message-greeting__name {
    margin-bottom: 30px !important;
    color: #000000 !important;
    font-size: 14.5px !important;
    line-height: 1.55 !important;
    letter-spacing: 0.02em !important;
  }

  body.page-id-219 .message-greeting__text,
  body.page-id-219 .message-shaze__text,
  body.page-id-219 .message-business__row dd,
  body.page-id-219 .message-philosophy2__lead {
    color: #000000 !important;
    font-size: 14.5px !important;
    line-height: 1.68 !important;
    letter-spacing: 0.02em !important;
  }

  body.page-id-219 .message-shaze__text {
    margin-bottom: 46px !important;
  }

  body.page-id-219 .message-business__row dt {
    font-size: 18px !important;
    font-weight: 900 !important;
    line-height: 1.55 !important;
    letter-spacing: 0 !important;
  }

  body.page-id-219 .message-business__row dd {
    line-height: 1.72 !important;
  }

  body.page-id-219 .message-philosophy2__item p {
    min-height: 110px !important;
    font-size: 13.5px !important;
    line-height: 1.7 !important;
    letter-spacing: 0.02em !important;
  }
}

/* Message: creed QR and management philosophy revisions */
body.page-id-219 .message-shaze__title {
  margin: 0 0 24px;
  color: #0079c4;
  font-size: clamp(16px, 1.35vw, 20px);
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.06em;
}

body.page-id-219 .message-shaze__text {
  margin-bottom: 28px;
}

body.page-id-219 .message-shaze__text p {
  margin: 0 0 1.45em;
}

body.page-id-219 .message-shaze__text p:last-child {
  margin-bottom: 0;
}

body.page-id-219 .message-shaze__song-qr {
  width: 170px;
  margin: auto 0 0 auto;
  text-align: center;
}

body.page-id-219 .message-shaze__song-qr img {
  display: block;
  width: 100%;
  height: auto;
}

body.page-id-219 .message-shaze__song-qr figcaption {
  margin-top: 8px;
  color: #000000;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
}

body.page-id-219 .message-philosophy2__lead {
  font-size: clamp(16px, 1.18vw, 18px);
  font-weight: 700;
  line-height: 2;
}

body.page-id-219 .message-philosophy2__lead span {
  display: block;
  margin-bottom: 1em;
}

body.page-id-219 .message-philosophy2__lead span:last-child {
  margin-bottom: 0;
}

body.page-id-219 .message-philosophy2__photos.message-philosophy2__photos--single {
  grid-template-columns: minmax(0, 620px);
  justify-content: center;
}

body.page-id-219 .message-philosophy2__photos.message-philosophy2__photos--single img {
  aspect-ratio: 984 / 594;
  object-fit: cover;
}

@media (max-width: 860px) {
  body.page-id-219 .message-shaze__song-qr {
    margin-left: 0;
  }
}

/* Message page: line break helper moved from quality CSS */
body.page-id-219 .page-content .message-nowrap {
  white-space: nowrap;
}

body.page-id-219 .message-shaze__text--sp-ja {
  display: none !important;
}

/* Header menu hero baseline: match /products/. */
@media (min-width: 1024px) {
  body.page-id-219 .page-title-banner--about {
    position: relative !important;
    height: 385px !important;
    margin-top: var(--header-h, 110px) !important;
    margin-bottom: 300px !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  body.page-id-219 .page-title-banner--about .about-pagehero {
    width: calc(100vw - var(--sbw, 0px)) !important;
    height: 385px !important;
    max-width: none !important;
    margin-left: calc(50% - (50vw - (var(--sbw, 0px) / 2))) !important;
    margin-right: calc(50% - (50vw - (var(--sbw, 0px) / 2))) !important;
    overflow: hidden !important;
  }

  body.page-id-219 .page-title-banner--about .about-pagehero__img {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    height: 100% !important;
    margin-left: 0 !important;
    object-fit: cover !important;
    object-position: center center !important;
  }

  body.page-id-219 .page-title-banner--about .page-title-banner__inner {
    position: absolute !important;
    top: 385px !important;
    left: 0 !important;
    right: 0 !important;
  }
}

/* Message page: archive 2 SVG comp reproduction */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about {
    position: relative !important;
    width: 1920px !important;
    max-width: 1920px !important;
    min-height: 0 !important;
    height: 3373.52px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    overflow: hidden !important;
    font-family: "Noto Sans JP", "Noto Sans CJK JP", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif !important;
    color: #000000 !important;
    background:
      linear-gradient(
        to bottom,
        transparent 0,
        transparent 879.25px,
        rgba(183, 215, 228, 0.5) 879.25px,
        rgba(183, 215, 228, 0.5) 1633.21px,
        transparent 1633.21px,
        transparent 2363.41px,
        rgba(183, 215, 228, 0.5) 2363.41px,
        rgba(183, 215, 228, 0.5) 100%
      ) !important;
  }

  body.page-id-219 .page-content--about::before {
    content: "";
    position: absolute;
    left: 379.89px;
    top: 91.35px;
    width: 0;
    height: 3180.93px;
    border-left: 5.12px solid #0079c4;
    z-index: 1;
  }

  body.page-id-219 .page-content--about .about-sidetitle {
    position: absolute !important;
    left: 341.53px !important;
    top: 91.35px !important;
    margin: 0 !important;
    color: #0079c4 !important;
    font-size: 42px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    writing-mode: vertical-rl !important;
    text-orientation: upright !important;
    white-space: nowrap !important;
    z-index: 2;
  }

  body.page-id-219 .page-content--about .message-block,
  body.page-id-219 .page-content--about .message-greeting__inner,
  body.page-id-219 .page-content--about .message-greeting__body,
  body.page-id-219 .page-content--about .message-shaze__inner,
  body.page-id-219 .page-content--about .message-shaze__body,
  body.page-id-219 .page-content--about .message-business__list,
  body.page-id-219 .page-content--about .message-business__row,
  body.page-id-219 .page-content--about .message-philosophy2__grid,
  body.page-id-219 .page-content--about .message-philosophy2__item,
  body.page-id-219 .page-content--about .message-philosophy2__photos {
    display: contents !important;
  }

  body.page-id-219 .page-content--about .message-bartitle {
    position: absolute !important;
    left: 483.78px !important;
    width: 1056.9px !important;
    height: 50px !important;
    min-height: 50px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #0079c4 !important;
    color: #ffffff !important;
    font-size: 27px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0.08em !important;
    text-align: center !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-greeting .message-bartitle {
    top: 92.35px !important;
  }

  body.page-id-219 .page-content--about .message-shaze .message-bartitle {
    left: 483.65px !important;
    top: 971.07px !important;
    width: 1056.98px !important;
  }

  body.page-id-219 .page-content--about .message-business .message-bartitle {
    left: 483.57px !important;
    top: 1694.39px !important;
    width: 1057.32px !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2 .message-bartitle {
    top: 2455.87px !important;
    width: 1056.99px !important;
  }

  body.page-id-219 .page-content--about .message-greeting__catch {
    position: absolute !important;
    left: 482.78px !important;
    top: 276.7px !important;
    margin: 0 !important;
    transform: translateY(-0.85em);
    color: #000000 !important;
    font-size: 47px !important;
    font-weight: 800 !important;
    line-height: 73px !important;
    letter-spacing: 0.05em !important;
    white-space: nowrap !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-greeting__name {
    position: absolute !important;
    left: 859.19px !important;
    top: 519.23px !important;
    margin: 0 !important;
    transform: translateY(-0.85em);
    color: #000000 !important;
    font-size: 22.96px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0.04em !important;
    white-space: nowrap !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-greeting__text {
    position: absolute !important;
    left: 482.78px !important;
    top: 586.55px !important;
    margin: 0 !important;
    transform: translateY(-0.85em);
    color: #000000 !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 31.5px !important;
    letter-spacing: 0.045em !important;
    white-space: nowrap !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-greeting__photo {
    position: absolute !important;
    left: 1145px !important;
    top: 220.65px !important;
    width: 396.82px !important;
    height: 567.46px !important;
    margin: 0 !important;
    z-index: 2;
  }

  body.page-id-219 .page-content--about .message-greeting__photo img,
  body.page-id-219 .page-content--about .message-shaze__image img,
  body.page-id-219 .page-content--about .message-philosophy2__photos figure img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
  }

  body.page-id-219 .page-content--about .message-shaze__image {
    position: absolute !important;
    left: 536.76px !important;
    top: 1093.79px !important;
    width: 304px !important;
    height: 419px !important;
    margin: 0 !important;
    z-index: 2;
  }

  body.page-id-219 .page-content--about .message-shaze__image img {
    object-fit: contain !important;
    background: #ffffff !important;
  }

  body.page-id-219 .page-content--about .message-shaze__text {
    position: absolute !important;
    left: 913.83px !important;
    top: 1116.63px !important;
    margin: 0 !important;
    transform: translateY(-0.85em);
    color: #000000 !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 31.5px !important;
    letter-spacing: 0.045em !important;
    white-space: nowrap !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-shaze__pdf {
    position: absolute !important;
    left: 1235.33px !important;
    top: 1462.34px !important;
    width: 305.77px !important;
    height: 50.63px !important;
    margin: 0 !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-shaze__pdf-button {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5em !important;
    background: #0079c4 !important;
    color: #ffffff !important;
    font-size: 23.28px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0.04em !important;
    text-decoration: none !important;
    border-radius: 0 !important;
  }

  body.page-id-219 .page-content--about .message-business__row dt,
  body.page-id-219 .page-content--about .message-business__row dd {
    position: absolute !important;
    margin: 0 !important;
    color: #000000 !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-business__row dt {
    left: 519.61px !important;
    transform: translateY(-0.85em);
    font-size: 18px !important;
    font-weight: 900 !important;
    line-height: 1.55 !important;
    letter-spacing: 0 !important;
    white-space: nowrap !important;
  }

  body.page-id-219 .page-content--about .message-business__row dt::before {
    content: "";
    position: absolute;
    left: -37.04px;
    width: 9.42px;
    background: #0079c4;
  }

  body.page-id-219 .page-content--about .message-business__row dd {
    left: 739.27px !important;
    transform: translateY(-0.85em);
    font-size: 17px !important;
    font-weight: 400 !important;
    line-height: 30px !important;
    letter-spacing: 0.045em !important;
    white-space: nowrap !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(1) dt {
    top: 1871.64px !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(1) dt::before {
    top: -27.7px;
    height: 111.3px;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(1) dd {
    left: 735.77px !important;
    top: 1841.86px !important;
    width: 804.33px !important;
    white-space: normal !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(2) dt {
    top: 2013.88px !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(2) dt::before {
    top: -10.5px;
    height: 191.32px;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(2) dd {
    top: 2001.44px !important;
    width: 800.83px !important;
    white-space: normal !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(3) dt {
    top: 2114.26px !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(3) dt::before {
    content: none;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(3) dd {
    top: 2107.26px !important;
    width: 800.83px !important;
    white-space: normal !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(4) dt {
    top: 2263.5px !important;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(4) dt::before {
    top: -20.7px;
    height: 57.3px;
  }

  body.page-id-219 .page-content--about .message-business__row:nth-child(4) dd {
    top: 2243.02px !important;
    width: 800.83px !important;
    white-space: normal !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__lead {
    position: absolute !important;
    left: 474.28px !important;
    top: 2603.28px !important;
    margin: 0 !important;
    transform: translateY(-0.85em);
    color: #000000 !important;
    font-size: 17px !important;
    font-weight: 400 !important;
    line-height: 30px !important;
    letter-spacing: 0.045em !important;
    white-space: nowrap !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__copy {
    position: absolute !important;
    margin: 0 !important;
    color: #000000 !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num {
    top: 2722.53px !important;
    width: 319.35px !important;
    transform: translateY(-0.85em);
    color: #0079c4 !important;
    font-family: "DIN Alternate", "DINNextLTPro", "Arial Narrow", sans-serif !important;
    font-size: 53px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0.04em !important;
    text-align: center !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 63px;
    border-top: 1px solid #000000;
  }

  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(1) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(1) .message-philosophy2__copy {
    left: 482.64px !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(2) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(2) .message-philosophy2__copy {
    left: 851.58px !important;
    width: 320px !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(3) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(3) .message-philosophy2__copy {
    left: 1221.23px !important;
    width: 320px !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__copy {
    top: 2782.05px !important;
    transform: translateY(-0.85em);
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 30px !important;
    letter-spacing: 0.045em !important;
    white-space: nowrap !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos figure {
    position: absolute !important;
    top: 2960.58px !important;
    width: 491.52px !important;
    height: 296.35px !important;
    margin: 0 !important;
    z-index: 2;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos figure:first-child {
    left: 482.65px !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos figure:last-child {
    left: 1050.44px !important;
    top: 2962.02px !important;
  }
}

/* Message page: CSS recreation of the company page navigation tabs. */
@media (min-width: 1024px) {
  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav {
    width: min(calc(100% - 80px), 1160.82px) !important;
    max-width: 1160.82px !important;
    height: 100px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    background-image: none !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav ul {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    list-style: none !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav li {
    display: block !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav a {
    position: relative !important;
    isolation: isolate !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100px !important;
    min-height: 100px !important;
    margin: 0 !important;
    padding: 0 14px !important;
    overflow: hidden !important;
    border: 2px solid #0079c4 !important;
    border-left-width: 0 !important;
    border-radius: 0 !important;
    background:
      linear-gradient(126deg, transparent 0 66%, rgba(183, 215, 228, 0.4) 66% 100%),
      #ffffff !important;
    color: #0079c4 !important;
    -webkit-text-fill-color: #0079c4 !important;
    font-family: "Noto Sans CJK JP", "Noto Sans JP", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif !important;
    font-size: 27px !important;
    font-weight: 700 !important;
    font-variation-settings: "wght" 700 !important;
    line-height: 34px !important;
    letter-spacing: 0.08em !important;
    text-align: center !important;
    text-decoration: none !important;
    text-indent: 0 !important;
    white-space: normal !important;
    box-sizing: border-box !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav li:first-child a {
    border-left-width: 2px !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav a:hover,
  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav a:focus-visible {
    background:
      linear-gradient(126deg, transparent 0 66%, rgba(183, 215, 228, 0.4) 66% 100%),
      #ffffff !important;
    color: #0079c4 !important;
    -webkit-text-fill-color: #0079c4 !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav a.is-current {
    background: #0079c4 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
  }

  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav a::before,
  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav a::after,
  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav li::before,
  body.page-id-219 .page-title-banner--about nav.company-nav[aria-label="会社概要ページナビ"].quality-nav li::after {
    content: none !important;
    display: none !important;
  }
}

/* Message page: align the artboard to /cannon/ history content width. */
@media (min-width: 1300px) {
  body.page-id-219 .page-content--about {
    position: relative !important;
    left: 50% !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
    transform-origin: center top !important;
  }
}

/* Message page: align each blue section heading with the body column. */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about {
    --message-content-left: 482.78px;
    --message-content-width: 1057.32px;
  }

  body.page-id-219 .page-content--about .message-bartitle,
  body.page-id-219 .page-content--about .message-shaze .message-bartitle,
  body.page-id-219 .page-content--about .message-business .message-bartitle,
  body.page-id-219 .page-content--about .message-philosophy2 .message-bartitle {
    left: var(--message-content-left) !important;
    width: var(--message-content-width) !important;
    transform: none !important;
  }

  body.page-id-219 .page-content--about .message-business__row dt::before {
    left: -36.83px !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__lead {
    left: var(--message-content-left) !important;
    width: var(--message-content-width) !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(1) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(1) .message-philosophy2__copy,
  body.page-id-219 .page-content--about .message-philosophy2__photos figure:first-child {
    left: var(--message-content-left) !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num {
    border-bottom: 0 !important;
    padding-bottom: 0 !important;
  }
}

/* Message page: creed title, paragraph breaks, and company song QR. */
body.page-id-219 .message-shaze__title {
  color: #d84558 !important;
  font-weight: 400 !important;
}

body.page-id-219 .message-shaze__text p {
  margin: 0 0 1em !important;
}

body.page-id-219 .message-shaze__text p:last-child {
  margin-bottom: 0 !important;
}

body.page-id-219 .message-shaze__song-qr {
  width: 161px;
}

body.page-id-219 .message-shaze__song-qr figcaption {
  color: #000000 !important;
}

@media (min-width: 1024px) {
  body.page-id-219 .page-content--about .message-shaze__title {
    position: absolute !important;
    left: 808px !important;
    top: 1055px !important;
    width: 640px !important;
    margin: 0 !important;
    color: #d84558 !important;
    font-size: 26px !important;
    font-weight: 400 !important;
    line-height: 1.35 !important;
    letter-spacing: 0.06em !important;
    text-align: left !important;
    white-space: nowrap !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-shaze__text {
    top: 1132px !important;
  }

  body.page-id-219 .page-content--about .message-shaze__text p {
    margin: 0 0 31.5px !important;
  }

  body.page-id-219 .page-content--about .message-shaze__text p:last-child {
    margin-bottom: 0 !important;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr {
    position: absolute !important;
    left: 1235.33px !important;
    top: 1487px !important;
    width: 151px !important;
    margin: 0 !important;
    text-align: center !important;
    z-index: 3;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: none !important;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr figcaption {
    margin-top: 8px !important;
    color: #000000 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    letter-spacing: 0.04em !important;
    white-space: nowrap !important;
  }
}

/* Message page: management philosophy lead revision. */
body.page-id-219 .message-philosophy2__lead {
  font-size: 18px !important;
  font-weight: 700 !important;
}

@media (min-width: 1024px) {
  body.page-id-219 .page-content--about .message-philosophy2__lead {
    font-size: 20px !important;
    font-weight: 700 !important;
    line-height: 38px !important;
    letter-spacing: 0.04em !important;
  }
}

/* Message page: match the creed title style to the business section labels. */
body.page-id-219 .message-shaze__title {
  margin: 50px 0 !important;
  color: #000000 !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  line-height: 33px !important;
  letter-spacing: 0.04em !important;
}

@media (min-width: 1024px) {
  body.page-id-219 .page-content--about .message-shaze__title {
    top: 1021px !important;
    margin: 50px 0 !important;
    color: #000000 !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    line-height: 33px !important;
    letter-spacing: 0.04em !important;
  }

  body.page-id-219 .page-content--about .message-shaze__text {
    top: 1154px !important;
    transform: none !important;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr {
    top: 1504px !important;
  }
}

/* Message page: make only the creed section a one-column heading plus two-column body. */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about .message-block.message-shaze {
    position: absolute !important;
    left: var(--message-content-left) !important;
    top: 971.07px !important;
    display: block !important;
    width: var(--message-content-width) !important;
    max-width: var(--message-content-width) !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    background: transparent !important;
    z-index: 3 !important;
  }

  body.page-id-219 .page-content--about .message-shaze .message-bartitle {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: 50px !important;
    min-height: 50px !important;
    margin: 0 !important;
    padding: 0 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transform: none !important;
  }

  body.page-id-219 .page-content--about .message-shaze__inner {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 0 0 54px !important;
    transform: none !important;
    box-sizing: border-box !important;
  }

  body.page-id-219 .page-content--about .message-shaze__columns {
    display: grid !important;
    grid-template-columns: 304px minmax(0, 1fr) !important;
    column-gap: 73px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
  }

  body.page-id-219 .page-content--about .message-shaze__body {
    display: flex !important;
    min-height: 0 !important;
    flex-direction: column !important;
  }

  body.page-id-219 .page-content--about .message-shaze__image,
  body.page-id-219 .page-content--about .message-shaze__title,
  body.page-id-219 .page-content--about .message-shaze__text,
  body.page-id-219 .page-content--about .message-shaze__song-qr {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
    margin-left: 0 !important;
    transform: none !important;
    z-index: auto !important;
  }

  body.page-id-219 .page-content--about .message-shaze__image {
    width: 304px !important;
    margin: 0 !important;
  }

  body.page-id-219 .page-content--about .message-shaze__image img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: none !important;
    object-fit: contain !important;
    background: #ffffff !important;
  }

  body.page-id-219 .page-content--about .message-shaze__title {
    width: 100% !important;
    margin: 50px 0 !important;
    color: #000000 !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    line-height: 33px !important;
    letter-spacing: 0.04em !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  body.page-id-219 .page-content--about .message-shaze__text {
    margin: 0 !important;
    color: #000000 !important;
    font-size: 17px !important;
    font-weight: 400 !important;
    line-height: 30px !important;
    letter-spacing: 0.045em !important;
    white-space: nowrap !important;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr {
    width: 151px !important;
    margin: 18px 0 0 auto !important;
    text-align: center !important;
  }
}

@media (max-width: 1023px) {
  body.page-id-219 .message-shaze__inner {
    display: block !important;
  }

  body.page-id-219 .message-shaze__columns {
    display: grid !important;
    grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) !important;
    gap: 32px !important;
    align-items: start !important;
  }
}

@media (max-width: 860px) {
  body.page-id-219 .message-shaze__columns {
    grid-template-columns: 1fr !important;
  }
}

/* Message page: place the song QR at the requested position. */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about .message-shaze__body {
    position: relative !important;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr {
    position: absolute !important;
    right: 0px !important;
    bottom: -119px !important;
    width: 100px !important;
    margin: 0 !important;
  }

  body.page-id-219 .page-content--about .message-shaze__song-qr figcaption {
    display: block !important;
    width: max-content !important;
    margin-top: 6px !important;
    position: relative !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    color: #000000 !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    letter-spacing: 0.02em !important;
    white-space: nowrap !important;
    text-align: center !important;
  }
}

/* Message page: keep creed text inside its column. */
body.page-id-219 .message-shaze__body,
body.page-id-219 .message-shaze__text,
body.page-id-219 .message-shaze__text p {
  margin: 0 !important;
  min-width: 0 !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

body.page-id-219 .message-shaze__text > p {
  margin: 0 !important;
}

body.page-id-219 .page-content--about .message-shaze__text > p,
body.page-id-219 .page-content--about .message-shaze__text p,
body.page-id-219 .page-content--about .message-shaze__text p:last-child {
  margin: 0 !important;
}

/* Message page: make the philosophy section a one-column lead plus three-column body. */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about .message-block.message-philosophy2 {
    position: absolute !important;
    left: var(--message-content-left) !important;
    top: 2455.87px !important;
    display: block !important;
    width: var(--message-content-width) !important;
    max-width: var(--message-content-width) !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    background: transparent !important;
    z-index: 3 !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2 .message-bartitle {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: 50px !important;
    min-height: 50px !important;
    margin: 0 0 58px !important;
    padding: 0 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transform: none !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__lead {
    position: static !important;
    left: auto !important;
    top: auto !important;
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 58px !important;
    padding: 0 !important;
    transform: none !important;
    color: #000000 !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    line-height: 38px !important;
    letter-spacing: 0.04em !important;
    text-align: center !important;
    white-space: normal !important;
    z-index: auto !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 48px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    box-sizing: border-box !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__item {
    display: block !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__copy,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(1) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(1) .message-philosophy2__copy,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(2) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(2) .message-philosophy2__copy,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(3) .message-philosophy2__num,
  body.page-id-219 .page-content--about .message-philosophy2__item:nth-child(3) .message-philosophy2__copy {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
    transform: none !important;
    white-space: normal !important;
    z-index: auto !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: center !important;
    min-height: 64px !important;
    margin: 0 0 24px !important;
    padding: 0 0 18px !important;
    border-bottom: 1px solid #000000 !important;
    color: #0079c4 !important;
    font-family: "DIN Alternate", "DINNextLTPro", "Arial Narrow", sans-serif !important;
    font-size: 48px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0.04em !important;
    text-align: center !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__num::after {
    content: none !important;
    display: none !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__copy {
    margin: 0 !important;
    color: #000000 !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 30px !important;
    letter-spacing: 0.045em !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 52px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 58px 0 0 !important;
    padding: 0 !important;
    transform: none !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos figure,
  body.page-id-219 .page-content--about .message-philosophy2__photos figure:first-child,
  body.page-id-219 .page-content--about .message-philosophy2__photos figure:last-child {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    z-index: auto !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos figure img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: none !important;
    aspect-ratio: 984 / 594 !important;
    object-fit: cover !important;
  }
}

/* Message page: extend the left vertical rule to the bottom of philosophy photos. */
@media (min-width: 1024px) {
  body.page-id-219 .page-content--about::before {
    height: 3212px !important;
  }
}

body:not(.language-page-body).page-id-219 .page-content--about .message-philosophy2__photos,
body.language-page-body--en.page-id-219 .page-content--about .message-philosophy2__photos {
  margin-bottom: 50px !important;
}

/* SP message page refinements. */
@media (max-width: 880px) {
  body.page-id-219 .page-content--about .message-block {
    margin-bottom: 46px !important;
  }

  body.page-id-219 .page-content--about .message-greeting__name {
    margin-bottom: 20px !important;
  }

  body.page-id-219 .page-content--about .message-greeting__text,
  body.page-id-219 .page-content--about .message-shaze__text,
  body.page-id-219 .page-content--about .message-shaze__text p {
    font-size: 15px !important;
    line-height: 1.82 !important;
    letter-spacing: 0.02em !important;
    text-align: left !important;
  }

  body.page-id-219 .page-content--about .message-greeting__text br,
  body.page-id-219 .page-content--about .message-shaze__text br {
    display: none !important;
  }

  body.page-id-219 .page-content--about .message-greeting__sp-paragraph {
    display: block;
    margin-top: 1.35em;
  }

  body.page-id-219 .page-content--about .message-shaze__title {
    white-space: nowrap !important;
    font-size: clamp(18px, 5.2vw, 20px) !important;
    line-height: 1.45 !important;
    letter-spacing: 0.02em !important;
    text-align: center !important;
  }

  body.page-id-219 .page-content--about .message-shaze__text p {
    display: inline !important;
    margin: 0 !important;
  }

  body:not(.language-page-body).page-id-219 .page-content--about .message-shaze__text--default {
    display: none !important;
  }

  body:not(.language-page-body).page-id-219 .page-content--about .message-shaze__text--sp-ja {
    display: block !important;
  }

  body:not(.language-page-body).page-id-219 .page-content--about .message-shaze__text--sp-ja p {
    display: block !important;
    margin: 0 0 1.35em !important;
  }

  body:not(.language-page-body).page-id-219 .page-content--about .message-shaze__text--sp-ja p:last-child {
    margin-bottom: 0 !important;
  }

  body:not(.language-page-body).page-id-219 .page-content--about .message-shaze__text--sp-ja br {
    display: block !important;
  }

  body.page-id-219 .page-content--about .message-business__row dt {
    white-space: nowrap !important;
    font-size: 17px !important;
    line-height: 1.45 !important;
  }

  body.page-id-219 .page-content--about .message-business__row dt br,
  body.page-id-219 .page-content--about .message-philosophy2__lead br,
  body.page-id-219 .page-content--about .message-philosophy2__copy br {
    display: none !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__lead {
    margin-bottom: 34px !important;
    font-size: 15px !important;
    line-height: 1.82 !important;
    text-align: left !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__copy {
    min-height: 0 !important;
    text-align: center !important;
  }

  body.page-id-219 .page-content--about .message-philosophy2__photos,
  body:not(.language-page-body).page-id-219 .page-content--about .message-philosophy2__photos,
  body.language-page-body--en.page-id-219 .page-content--about .message-philosophy2__photos {
    margin-top: 32px !important;
    margin-bottom: 18px !important;
  }
}

/* JP SP company pages: unified content heading layout. */
@media (max-width: 880px) {
  body:not(.language-page-body).page-id-219 .page-content--about > .about-sidetitle {
    position: static !important;
    display: block !important;
    width: min(calc(100vw - 72px), 720px) !important;
    max-width: calc(100% - 32px) !important;
    margin: 38px auto 38px !important;
    padding: 0 0 10px !important;
    border: 0 !important;
    border-bottom: 3px solid #0079c4 !important;
    color: #0079c4 !important;
    font-family: "Noto Sans CJK JP", "Noto Sans JP", sans-serif !important;
    font-size: 22px !important;
    font-weight: 900 !important;
    line-height: 1.12 !important;
    letter-spacing: 0.08em !important;
    writing-mode: horizontal-tb !important;
    text-orientation: mixed !important;
    text-align: left !important;
    -webkit-text-fill-color: #0079c4 !important;
    box-sizing: border-box !important;
    white-space: normal !important;
  }
}

/* JP narrow message page: keep bar titles readable on the blue bands. */
@media (max-width: 1023px) {
  body:not(.language-page-body):not(.language-page-body--en):not(.language-page-body--zh).page-id-219 .page-content--about .message-bartitle {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
  }
}

/* JP SP only: match the company overview hero image with /aboutus/. */
@media (max-width: 880px) {
  body:not(.language-page-body):not(.language-page-body--en):not(.language-page-body--zh).page-id-219 .page-title-banner--about .about-pagehero {
    height: 170px !important;
    min-height: 170px !important;
    background: url("../../img/about/about-hero-sp-20260623.jpg") center center / cover no-repeat !important;
  }

  body:not(.language-page-body):not(.language-page-body--en):not(.language-page-body--zh).page-id-219 .page-title-banner--about .about-pagehero__img {
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    opacity: 0 !important;
  }
}
