@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Jost:wght@400;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;500;700&display=swap);

*,
::after,
::before {
  box-sizing: inherit
}

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
main,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section {
  display: block
}

html {
  box-sizing: border-box;
  min-height: 100%;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth
}

html.is-useJs {
  overflow-y: hidden;
  touch-action: none
}

@media print,
screen and (min-width: 1024px) {
  html.is-useJs {
    overflow-y: visible
  }
}

html.is-loaded {
  overflow-y: visible;
  touch-action: auto
}

html.is-drawerActive {
  overflow-y: hidden;
  touch-action: none
}

@media print,
screen and (min-width: 1024px) {
  html.is-drawerActive {
    overflow-y: visible
  }
}

body {
  min-height: 100%;
  color: #002153;
  font-family: "Noto Sans JP", sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-overflow-scrolling: touch
}

[lang=en] body {
  font-family: "Noto Sans", sans-serif
}

.is-drawerActive body {
  overflow-y: hidden;
  touch-action: none
}

@media print,
screen and (min-width: 1024px) {
  .is-drawerActive body {
    overflow-y: visible
  }
}

blockquote,
q {
  quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: "";
  content: none
}

hr {
  overflow: visible
}

ol,
ul {
  list-style: none
}

pre {
  font-family: monospace;
  font-size: 1em
}

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects
}

a:active,
a:hover {
  outline-width: 0
}

abbr[title] {
  border-bottom: none;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  text-decoration: underline
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace;
  font-size: 1em
}

dfn {
  font-style: italic
}

mark {
  background-color: #ff0;
  color: #000
}

small {
  font-size: 10px
}

[lang=en] small {
  font-size: 11px
}

@media print,
screen and (min-width: 768px) {
  small {
    font-size: 12px
  }

  [lang=en] small {
    font-size: 13px
  }
}

sub,
sup {
  position: relative;
  font-size: .75em;
  line-height: 0;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

audio,
canvas,
progress,
video {
  display: inline-block
}

audio:not([controls]) {
  display: none;
  height: 0
}

img,
video {
  max-width: 100%;
  height: auto;
  vertical-align: bottom
}

svg:not([fill]) {
  fill: currentColor
}

svg:not(:root) {
  overflow: hidden
}

table {
  border-spacing: 0;
  border-collapse: collapse
}

button,
input,
optgroup,
select,
textarea {
  margin: 0;
  font: inherit
}

button,
select {
  text-transform: none
}

button,
input {
  overflow: visible
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
  -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
  outline: 1px dotted ButtonText
}

legend {
  display: table;
  max-width: 100%;
  color: inherit;
  white-space: normal
}

optgroup {
  font-weight: 700
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto;
  resize: vertical
}

[type=checkbox],
[type=radio] {
  padding: 0
}

[type=search] {
  outline-offset: -2px;
  -webkit-appearance: textfield
}

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button
}

summary {
  display: list-item
}

[hidden],
template {
  display: none
}

[aria-disabled=true],
[disabled] {
  cursor: not-allowed
}

[aria-busy=true] {
  cursor: progress
}

[aria-controls] {
  cursor: pointer
}

[aria-hidden=false][hidden] {
  display: initial
}

[aria-hidden=false][hidden]:not(:focus) {
  position: absolute;
  clip: rect(0, 0, 0, 0)
}

::after:focus:not(:focus-visible),
::before:focus:not(:focus-visible),
:focus:not(:focus-visible) {
  outline: 0
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  height: 100%
}

@media print {
  body {
    zoom: 72%
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  line-height: 1.73;
  color: #002153;
  background-color: #fff;
  overflow-x: hidden;
  position: relative;
  print-color-adjust: exact;
  -webkit-print-color-adjust: exact
}

[lang=en] body {
  font-family: "Noto Sans", sans-serif;
  font-size: 16px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  body {
    font-size: 18px;
    line-height: 2
  }

  [lang=en] body {
    font-size: 19px;
  }
}

body::after {
  background: #000;
  bottom: 0;
  content: "";
  display: block;
  position: fixed;
  opacity: 0;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  width: 100vw;
  z-index: -1;
  transition: opacity .3s ease
}

body.is-showNavChild::after {
  opacity: .2;
  z-index: 99
}

a {
  text-decoration: none
}

sup>a {
  color: #0093d7
}

main .p-productsCategory__column p.link,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]),
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]),
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]),
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]),
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]) {
  color: #0093d7;
  position: relative;
  -webkit-text-decoration: underline #0093d7;
  text-decoration: underline #0093d7;
  text-underline-offset: 20%;
  transition: .2s ease all;
  word-break: break-all
}

main .p-productsCategory__column p.link.icon_blank,
main .p-productsCategory__column p.link.icon_pdf,
main .p-productsCategory__column p.link.icon_xlsx,
main .p-productsCategory__column p.link[target=_blank],
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_pdf,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_xlsx,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank],
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank],
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank],
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank],
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank] {
  padding-right: 10px
}

main .p-productsCategory__column p.link.icon_blank::after,
main .p-productsCategory__column p.link.icon_pdf::after,
main .p-productsCategory__column p.link.icon_xlsx::after,
main .p-productsCategory__column p.link[target=_blank]::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_pdf::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_xlsx::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank]::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  transform: translate(.2em, .3em);
  height: 20px;
  width: 20px
}

[lang=en] main .p-productsCategory__column p.link.icon_blank::after,
[lang=en] main .p-productsCategory__column p.link.icon_pdf::after,
[lang=en] main .p-productsCategory__column p.link.icon_xlsx::after,
[lang=en] main .p-productsCategory__column p.link[target=_blank]::after,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank::after,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_pdf::after,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_xlsx::after,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank]::after,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after {
  transform: translate(.5em, .2em)
}

@media print,
screen and (min-width: 768px) {

  [lang=en] main .p-productsCategory__column p.link.icon_blank::after,
  [lang=en] main .p-productsCategory__column p.link.icon_pdf::after,
  [lang=en] main .p-productsCategory__column p.link.icon_xlsx::after,
  [lang=en] main .p-productsCategory__column p.link[target=_blank]::after,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank::after,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_pdf::after,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_xlsx::after,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank]::after,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]::after {
    height: 23px;
    width: 23px
  }
}

main .p-productsCategory__column p.link.icon_blank::after,
main .p-productsCategory__column p.link[target=_blank]:not([class*=icon_])::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank]:not([class*=icon_])::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after {
  background-image: url(/images/common/icon_blankBlue.svg);
  transform: translate(.2em, .1em);
  height: 16px;
  width: 16px
}

[lang=en] main .p-productsCategory__column p.link.icon_blank::after,
[lang=en] main .p-productsCategory__column p.link[target=_blank]:not([class*=icon_])::after,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank::after,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank]:not([class*=icon_])::after,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after {
  transform: translate(.4em, .1em)
}

@media print,
screen and (min-width: 768px) {

  [lang=en] main .p-productsCategory__column p.link.icon_blank::after,
  [lang=en] main .p-productsCategory__column p.link[target=_blank]:not([class*=icon_])::after,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_blank::after,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button])[target=_blank]:not([class*=icon_])::after,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_blank::after,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"])[target=_blank]:not([class*=icon_])::after {
    height: 18px;
    width: 18px
  }
}

main .p-productsCategory__column p.link.icon_pdf::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_pdf::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_pdf::after {
  background-image: url(/images/common/icon_pdf.svg)
}

main .p-productsCategory__column p.link.icon_xlsx::after,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_xlsx::after,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_xlsx::after {
  background-image: url(/images/common/icon_xlsx.svg)
}

main .p-productsCategory__column p.link.icon_mail,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail {
  align-items: center;
  display: flex;
  margin-left: 26px
}

[lang=en] main .p-productsCategory__column p.link.icon_mail,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail {
  margin-left: 28px
}

@media print,
screen and (min-width: 768px) {

  [lang=en] main .p-productsCategory__column p.link.icon_mail,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail {
    margin-left: 32px
  }
}

main .p-productsCategory__column p.link.icon_mail::before,
main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail::before,
main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before {
  background-image: url(/images/common/icon_mail.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  position: absolute;
  left: -26px;
  height: 20px;
  transform: translate(0, 0);
  width: 20px
}

[lang=en] main .p-productsCategory__column p.link.icon_mail::before,
[lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail::before,
[lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
[lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
[lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
[lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before {
  left: -27px;
  height: 18px;
  width: 18px
}

@media print,
screen and (min-width: 768px) {

  main .p-productsCategory__column p.link.icon_mail::before,
  main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail::before,
  main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
  main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
  main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
  main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before {
    transform: translate(0, 0)
  }

  [lang=en] main .p-productsCategory__column p.link.icon_mail::before,
  [lang=en] main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).icon_mail::before,
  [lang=en] main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
  [lang=en] main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
  [lang=en] main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before,
  [lang=en] main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]).icon_mail::before {
    left: -31px;
    height: 22px;
    width: 22px
  }
}

@media print,
screen and (min-width: 1024px) {

  main .p-productsCategory__column p.link:hover,
  main [class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]):hover,
  main dd>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]):hover,
  main p:not([class*=p-sitemap__childList-title])>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]):hover,
  main td>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]):hover,
  main th>a:not([class*=c-button]):not(.icon_tel):not([href^="tel:"]):hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

a[href^="tel:"] {
  color: #002153 !important
}

@media print,
screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none
  }
}

.icon_tel {
  align-items: center;
  display: inline-flex;
  margin-right: 0
}

.icon_tel::before {
  background-image: url(/images/common/icon_tel.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  margin-right: 6px;
  height: 20px;
  width: 20px
}

.icon_fax {
  align-items: center;
  color: #002153 !important;
  display: inline-flex;
  pointer-events: none;
  text-decoration: none !important
}

.icon_fax::before {
  background-image: url(/images/common/icon_fax.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  margin-right: 6px;
  height: 20px;
  width: 20px
}

.c-list__anchor+[class*=p-column]:not([class*=p-column__item]):not(.-paragraph),
.c-list__anchor+p,
[class*=p-column]:not([class*=p-column__item]):not(.-paragraph)+p,
p+[class*=p-column]:not([class*=p-column__item]):not(.-paragraph) {
  margin-top: 44px
}

@media print,
screen and (min-width: 1024px) {

  .c-list__anchor+[class*=p-column]:not([class*=p-column__item]):not(.-paragraph),
  .c-list__anchor+p,
  [class*=p-column]:not([class*=p-column__item]):not(.-paragraph)+p,
  p+[class*=p-column]:not([class*=p-column__item]):not(.-paragraph) {
    margin-top: 64px
  }
}

.c-list__anchor+.p-table,
.p-table+[class*=c-list],
.p-table+p:not([class*=u-fontSize__S]),
[class*=c-image]+p,
[class*=p-column].-paragraph+p,
[class*=p-column]:not([class*=p-column__item])+[class*=c-list]:not([class*=c-list__anchor]),
[class*=u-fontSize__S]+p,
p+.l-section,
p+.p-table,
p+p {
  margin-top: 14px
}

@media print,
screen and (min-width: 768px) {

  .c-list__anchor+.p-table,
  .p-table+[class*=c-list],
  .p-table+p:not([class*=u-fontSize__S]),
  [class*=c-image]+p,
  [class*=p-column].-paragraph+p,
  [class*=p-column]:not([class*=p-column__item])+[class*=c-list]:not([class*=c-list__anchor]),
  [class*=u-fontSize__S]+p,
  p+.l-section,
  p+.p-table,
  p+p,
  ul+.p-table {
    margin-top: 20px
  }

  .p-sustainabilityAssurance [class*=p-column]:not([class*=p-column__item])+[class*=c-list]:not([class*=c-list__anchor]) {
    margin-top: 40px;
  }
}

[class*=c-list]:not([class*=c-list__anchor])+[class*=c-list]:not([class*=c-list__anchor]),
[class*=c-list]:not([class*=c-list__anchor])+p,
p+[class*=c-list]:not([class*=c-list__anchor]) {
  margin-top: 16px
}

@media print,
screen and (min-width: 768px) {

  [class*=c-list]:not([class*=c-list__anchor])+[class*=c-list]:not([class*=c-list__anchor]),
  [class*=c-list]:not([class*=c-list__anchor])+p,
  p+[class*=c-list]:not([class*=c-list__anchor]) {
    margin-top: 22px
  }
}

.c-list__discLarge+.c-list__note,
.c-list__discLarge+.c-list__numberNote,
.c-list__discLarge+.u-fontSize__S,
.c-list__discLarge+.u-fontSize__SS,
.p-table+.c-list__note,
.p-table+.c-list__numberNote,
.p-table+.u-fontSize__S,
.p-table+.u-fontSize__SS,
.p-thumbnail+.u-fontSize__S,
.p-thumbnail+.u-fontSize__SS,
.u-fontSize__S+.p-table,
.u-fontSize__SS+.p-table,
[class*=c-image] img+.u-fontSize__SS,
[class*=c-image]+.c-list__numberNote,
[class*=c-image]+.u-fontSize__S,
[class*=c-image]+.u-fontSize__SS,
p+.u-fontSize__S,
p+.u-fontSize__SS {
  margin-top: 10px
}

@media print,
screen and (min-width: 768px) {

  .c-list__discLarge+.c-list__note,
  .c-list__discLarge+.c-list__numberNote,
  .c-list__discLarge+.u-fontSize__S,
  .c-list__discLarge+.u-fontSize__SS,
  .p-table+.c-list__note,
  .p-table+.c-list__numberNote,
  .p-table+.u-fontSize__S,
  .p-table+.u-fontSize__SS,
  .p-thumbnail+.u-fontSize__S,
  .p-thumbnail+.u-fontSize__SS,
  .u-fontSize__S+.p-table,
  .u-fontSize__SS+.p-table,
  [class*=c-image] img+.u-fontSize__SS,
  [class*=c-image]+.c-list__numberNote,
  [class*=c-image]+.u-fontSize__S,
  [class*=c-image]+.u-fontSize__SS,
  p+.u-fontSize__S,
  p+.u-fontSize__SS {
    margin-top: 14px
  }
}

@media print {

  .js-fadeIn,
  .js-staggerUp,
  .js-staggerUp__item {
    opacity: 1 !important
  }

  .js-fadeIn {
    visibility: inherit !important
  }

  .js-staggerUp__item {
    translate: none !important;
    rotate: none !important;
    scale: none !important;
    transform: translate(0, 0) !important
  }
}

.l-footer {
  margin-top: 100px;
  padding-top: 17px;
  overflow: hidden;
  position: relative
}

@media print {
  .l-footer {
    display: none
  }
}

.l-footer a,
.l-footer button {
  outline: 0
}

.l-footer::before {
  background: url(/images/common/bg_footer.svg) no-repeat;
  background-position: top center;
  top: 0;
  background-size: contain;
  content: "";
  display: block;
  left: 50%;
  transform: translateX(-50%);
  position: absolute;
  height: 2214px;
  width: 2214px;
  z-index: 0
}

@media print,
screen and (min-width: 768px) {
  .l-footer::before {
    height: 4941px;
    width: 4941px
  }
}

.l-footer__inner {
  padding: 48px 32px 40px;
  position: relative;
  z-index: 1
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__inner {
    margin: 0 auto;
    max-width: 1280px;
    padding: 130px 20px 80px
  }
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__nav {
    display: flex;
    justify-content: center;
  }
}

.l-footer__nav li:not(.l-footer__subListBanner)>a {
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: all .3s ease
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__nav li:not(.l-footer__subListBanner)>a:hover {
    -webkit-text-decoration: underline 1px #fff;
    text-decoration: underline 1px #fff
  }
}

.l-footer__nav li:not(.l-footer__subListBanner)>a:focus-visible {
  outline: 2px solid #fff
}

.l-footer__mainList {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 41px
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__mainList {
    flex-wrap: wrap;
    max-height: 235px;
    gap: 22px 100px;
    width: 400px
  }
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .l-footer__mainList {
    width: 485px
  }
}

.l-footer__mainList li a {
  color: #fff;
  font-weight: 700;
  line-height: 1
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .l-footer__mainList li:nth-child(4) {
    margin-bottom: 5px
  }
}

.l-footer__subList {
  display: flex;
  flex-direction: column;
  gap: 8px;
  white-space: nowrap
}

.l-footer__subList:not(:first-of-type) {
  margin-top: 20px
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__subList:not(:first-of-type) {
    margin-left: 100px;
    margin-top: -5px
  }
}

.l-footer__subList li a {
  color: #fff;
  font-size: 13px
}

/* [lang=en] .l-footer__subList li a {
  font-size: 14px
} */

.l-footer__subListBanner {
  max-width: 280px;
  width: auto
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__subListBanner {
    margin-bottom: 15px;
    margin-top: 15px;
    max-width: none;
    width: 304px
  }
}

.l-footer__subListBanner a {
  border: 2px solid transparent;
  border-radius: 10px;
  display: block;
  transition: border .2s ease
}

.l-footer__subListBanner a img {
  display: block;
  opacity: 1;
  transition: opacity .2s ease
}

@media print,
screen and (min-width: 1024px) {

  .l-footer__subListBanner a:focus-visible img,
  .l-footer__subListBanner a:hover img {
    opacity: .8
  }
}

.l-footer__subListBanner a:focus-visible {
  border: 2px solid #fff
}

.l-footer__info {
  border-top: 1px solid #c8c8c8;
  margin-top: 46px;
  padding-top: 20px
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__info {
    /* align-items: flex-end; */
    border-top: none;
    /* display: flex;
    justify-content: space-between; */
    margin-top: 50px;
    padding-top: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__info .l-footer__subList {
    justify-content: center;
    align-items: center;
    flex-direction: row;
    gap: 20px 40px;
    order: 2
  }
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__info .l-footer__subList li {
    align-items: center;
    display: flex;
    margin-top: 0;
    position: relative
  }
}

.l-footer__info .l-footer__subList li:nth-child(n+2)::before {
  background: #fff;
  content: "";
  display: block;
  position: absolute;
  left: -20px;
  height: 18px;
  width: 1px
}

.l-footer__info .l-footer__subList li:not(.l-footer__subListBanner) a {
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: all .3s ease
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__info .l-footer__subList li:not(.l-footer__subListBanner) a:hover {
    -webkit-text-decoration: underline 1px #fff;
    text-decoration: underline 1px #fff
  }
}

.l-footer__info .l-footer__subList li:not(.l-footer__subListBanner) a:focus-visible {
  outline: 2px solid #fff
}

.l-footer__logoWrap {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-top: 38px
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__logoWrap {
    align-items: flex-end;
    flex-direction: row;
    orphans: 1;
    margin-top: 20px;
  }
}

.l-footer__logo {
  width: 170px
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__logo {
    width: 240px
  }
}

.l-footer__copy {
  color: #fff;
  margin-top: 10px
}

@media print,
screen and (min-width: 1024px) {
  .l-footer__copy {
    margin-left: 24px;
    margin-top: 0
  }
}

.l-header {
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  transition: all .2s
}

@media print,
screen and (min-width: 1024px) {
  .l-header {
    height: 111px
  }

  [lang=en] .l-header {
    height: 128px
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .l-header {
    height: 111px
  }
}

@media print {
  .l-header {
    display: none
  }
}

.l-header a,
.l-header button {
  outline: 0
}

.l-header::before {
  background: #c8c8c8;
  bottom: 0;
  content: "";
  position: absolute;
  height: 1px;
  width: 100%;
  transition: all .2s
}

.l-header__inner {
  display: flex;
  align-items: center;
  height: 64px;
  justify-content: space-between;
  padding: 12px 0 12px 16px
}

@media print,
screen and (min-width: 1024px) {
  .l-header__inner {
    height: 112px;
    padding: 0 40px
  }
}

.l-header__logo {
  flex-shrink: 0;
  width: 88px
}

@media print,
screen and (min-width: 1024px) {
  .l-header__logo {
    width: 133px
  }
}

.l-header__menu {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative
}

@media print,
screen and (min-width: 1024px) {
  .l-header__menu {
    max-width: 1268px
  }
}

@media print,
screen and (min-width: 1024px) {
  body.is-showNavChild .l-header {
    background: #aaa
  }

  body.is-showNavChild .l-header::before {
    background: 0 0
  }
}

.l-inner {
  margin-left: 16px;
  margin-right: 16px;
  width: calc(100% - 32px)
}

@media print,
screen and (min-width: 768px) {
  .l-inner {
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
    max-width: 1440px;
    width: 100%
  }
}

.l-inner__foot {
  margin-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .l-inner__foot {
    margin-top: 48px
  }
}

.l-inner>:first-child {
  margin-top: 0 !important
}

.l-main {
  margin-top: 64px;
  padding-top: 15px
}

@media print {
  .l-main {
    margin-top: 30px;
    padding-top: 0
  }
}

@media print,
screen and (min-width: 768px) {
  .l-main {
    margin-top: 111px;
    padding-top: 32px
  }
}

.l-main__inner {
  margin-left: 16px;
  margin-right: 16px;
  width: calc(100% - 32px)
}

@media print,
screen and (min-width: 768px) {
  .l-main__inner {
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
    max-width: 1440px;
    width: 100%
  }
}

.l-section:not(:first-child) {
  margin-top: 63px
}

[lang=en] .l-section:not(:first-child) {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .l-section:not(:first-child) {
    margin-top: 100px
  }

  [lang=en] .l-section:not(:first-child) {
    margin-top: 100px;
  }
}

@media print {
  .l-section {
    min-height: 251mm;
    page-break-after: always
  }

  .l-section:last-child {
    page-break-after: auto
  }
}

[class*=c-button]:not([class*=c-buttonList]) {
  align-items: center;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #fff;
  border: 1px solid #002153;
  border-radius: 50px;
  color: #002153;
  cursor: pointer;
  display: inline-flex;
  justify-content: space-between;
  height: 100%;
  position: relative;
  text-decoration: none;
  transition: .2s ease all
}

[class*=c-button]:not([class*=c-buttonList])::after {
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/images/common/icon_arrowRight.svg);
  content: "";
  display: inline-block;
  flex-shrink: 0;
  height: 16px;
  width: 18px;
  transition: .2s ease all
}

[class*=c-button]:not([class*=c-buttonList]).icon_blank::after,
[class*=c-button]:not([class*=c-buttonList])[target=_blank]:not([class*=icon_])::after {
  background-image: url(/images/common/icon_blank.svg);
  height: 20px;
  width: 20px
}

@media print,
screen and (min-width: 1024px) {

  [class*=c-button]:not([class*=c-buttonList]).icon_blank:hover::after,
  [class*=c-button]:not([class*=c-buttonList])[target=_blank]:not([class*=icon_]):hover::after {
    background-image: url(/images/common/icon_blankWhite.svg)
  }
}

[class*=c-button]:not([class*=c-buttonList]).icon_arrowLeft {
  padding-left: 43px;
  padding-right: 8px
}

[class*=c-button]:not([class*=c-buttonList]).icon_arrowLeft::after {
  background-image: url(/images/common/icon_arrowLeft.svg);
  left: 18px;
  height: 12px;
  position: absolute;
  width: 15px
}

[class*=c-button]:not([class*=c-buttonList]).icon_pdf::after {
  background-image: url(/images/common/icon_pdf.svg);
  height: 20px;
  width: 20px
}

@media print,
screen and (min-width: 768px) {
  [class*=c-button]:not([class*=c-buttonList]).icon_pdf::after {
    height: 26px;
    width: 26px
  }
}

[class*=c-button]:not([class*=c-buttonList]).icon_xlsx::after {
  background-image: url(/images/common/icon_xlsx.svg);
  height: 20px;
  width: 20px
}

@media print,
screen and (min-width: 768px) {
  [class*=c-button]:not([class*=c-buttonList]).icon_xlsx::after {
    height: 26px;
    width: 26px
  }
}

[class*=c-button]:not([class*=c-buttonList]).icon_mail::after {
  background-image: url(/images/common/icon_mail.svg);
  height: 16px;
  width: 16px
}

@media print,
screen and (min-width: 1024px) {
  [class*=c-button]:not([class*=c-buttonList]).icon_mail:hover::after {
    background-image: url(/images/common/icon_mailWhite.svg)
  }
}

[class*=c-button]:not([class*=c-buttonList]) span {
  padding-right: 10px
}

@media print,
screen and (min-width: 768px) {
  [lang=en] [class*=c-button]:not([class*=c-buttonList]) span {
    padding-right: 15px
  }
}

@media print,
screen and (min-width: 1024px) {
  [class*=c-button]:not([class*=c-buttonList]):hover {
    background: #002153;
    color: #fff
  }
}

@media print,
screen and (min-width: 1024px) {
  [class*=c-button]:not([class*=c-buttonList]):not([class*=icon_]):hover::after {
    background-image: url(/images/common/icon_arrowRightWhite.svg)
  }
}

.c-button {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  min-height: 56px;
  padding: 16px 20px 16px 24px
}

[lang=en] .c-button {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-button {
    min-height: 60px;
    padding-right: 22px
  }

  .p-sustainabilityGroupSustainabilityStory .c-button {
    padding-right: 32px;
    padding-left: 32px;
  }

  .p-sustainabilityAssurance .c-button {
    padding-right: 50px;
    padding-left: 50px;
  }
}

.c-buttonList {
  display: flex;
  flex-wrap: wrap;
  gap: 16px
}

@media print,
screen and (min-width: 1024px) {
  .c-buttonList {
    gap: 16px 32px
  }
}

.c-button__large {
  font-size: 18px;
  font-weight: 700;
  padding-left: 24px;
  padding-right: 24px;
  min-height: 60px;
  min-width: 234px
}

[lang=en] .c-button__large {
  font-size: 19px;
  font-weight: 700;
  line-height: 1.35;
  min-height: 62px;
  padding: 15px 20px 15px 24px
}

@media print,
screen and (min-width: 768px) {
  .c-button__large {
    font-size: 24px;
    min-height: 64px;
    min-width: 240px
  }

  [lang=en] .c-button__large {
    font-size: 26px;
    line-height: 1.35;
    min-height: 67px
  }
}

.c-button__small {
  font-size: 14px;
  font-weight: 400;
  padding-left: 18px;
  padding-right: 18px;
  margin-top: 8px;
  min-height: 40px
}

[lang=en] .c-button__small {
  font-size: 15px;
  line-height: 1.35;
  min-height: 40px;
  padding: 10px 16px 10px 18px
}

@media print,
screen and (min-width: 768px) {
  .c-button__small {
    min-height: 44px
  }

  [lang=en] .c-button__small {
    min-height: 48px;
    padding: 12px 20px 12px 24px
  }
}

[class*=p-]>.c-button__small {
  margin-top: 0 !important
}

.c-cardLink+.c-cardLink {
  margin-top: 40px
}

.c-cardLink__list {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 40px
}

@media print,
screen and (min-width: 768px) {
  .c-cardLink__list {
    flex-direction: row;
    gap: 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-cardLink__list {
    gap: 40px 65px
  }
}

.c-cardLink__item {
  display: flex;
  flex-direction: column
}

@media print,
screen and (min-width: 768px) {
  .c-cardLink__item {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-cardLink__item {
    width: calc((100% - 130px)/ 3)
  }
}

@media print {
  .c-cardLink__item:nth-of-type(4n) {
    page-break-after: always
  }
}

.c-cardLink__image {
  display: block;
  width: 100%
}

.c-cardLink__image img {
  width: 100%
}

.c-cardLink__image.-imgBorder {
  border: 1px solid #0093d7;
  border-bottom: none;
  border-radius: 20px 20px 0 0
}

.c-cardLink__label {
  align-items: center;
  border: 1px solid #0093d7;
  border-radius: 0 0 20px 20px;
  color: #002153;
  display: flex;
  font-size: 16px;
  font-weight: 500;
  justify-content: space-between;
  line-height: 1.45;
  padding: 10px 44px 10px 16px;
  position: relative;
  width: 100%
}

[lang=en] .c-cardLink__label {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-cardLink__label {
    font-size: 18px;
    padding: 11px 48px 11px 20px
  }

  [lang=en] .c-cardLink__label {
    font-size: 19px
  }
}

.c-cardLink__label::after {
  background-image: url(/images/common/icon_arrowRightBlue.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  height: 20px;
  width: 20px;
  position: absolute;
  right: 16px
}

@media print,
screen and (min-width: 768px) {
  .c-cardLink__label::after {
    right: 20px
  }
}

.c-cardLink__caption {
  font-size: 14px !important;
  margin-top: 16px;
  line-height: 1.857 !important
}

[lang=en] .c-cardLink__caption {
  font-size: 15px !important;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .c-cardLink__caption {
    flex: 2;
    height: 100%;
    min-height: 0
  }
}

.c-cardLink__caption>p+.c-list__disc.-narrow {
  margin-top: 0
}

.c-list__anchor+.c-cardLink,
p+.c-cardLink {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {

  .c-list__anchor+.c-cardLink,
  p+.c-cardLink {
    margin-top: 70px
  }
}

.c-cardLink+p {
  margin-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .c-cardLink+p {
    margin-top: 64px
  }
}

.p-column__item>.c-cardLink .c-cardLink__list {
  display: block
}

.p-column__item>.c-cardLink .c-cardLink__list .c-cardLink__item {
  width: 100%
}

.c-date {
  color: #607696;
  font-family: Jost, sans-serif;
  font-size: 16px;
  font-weight: 700
}

[lang=en] .c-date {
  font-size: 17px
}

@media print,
screen and (min-width: 768px) {
  .c-date {
    font-weight: 600
  }
}

@media print {
  .c-fadeUp {
    translate: none !important;
    rotate: none !important;
    scale: none !important;
    opacity: 1 !important;
    visibility: inherit !important;
    transform: translate(0, 0) !important
  }
}

.c-icon {
  width: 48px
}

.c-iconList {
  align-items: center;
  display: flex;
  gap: 8px;
  margin: 8px 0 7px
}

@media print,
screen and (min-width: 1024px) {
  .c-iconList {
    margin: 13px 0
  }
}

[class*=c-image] {
  width: 100%
}

[class*=c-image] img {
  display: block;
  margin: auto
}

.c-image.-scroll {
  overflow-x: auto
}

@media print,
screen and (min-width: 768px) {
  .c-image.-scroll {
    overflow-x: visible
  }
}

.c-image.-scroll img {
  max-width: 200%
}

@media print,
screen and (min-width: 768px) {
  .c-image.-scroll img {
    max-width: 100%
  }
}

.c-image.-left img {
  margin-left: 0;
  margin-right: 0
}

a[class*=c-image] {
  opacity: 1;
  transition: .2s ease opacity
}

@media print,
screen and (min-width: 1024px) {
  a[class*=c-image]:hover {
    opacity: .8
  }
}

[class*=c-imageCenter] {
  width: 100%;
  margin: 24px auto 0;
  display: block
}

@media print,
screen and (min-width: 768px) {
  [class*=c-imageCenter] {
    margin: 64px auto 0
  }
}

.c-imageCenter__L {
  max-width: 1000px
}

@media print {
  .c-imageCenter__L {
    max-width: 100%
  }
}

.c-imageCenter__M {
  max-width: 870px
}

@media print {
  .c-imageCenter__M {
    max-width: 435px
  }
}

.c-imageCenter__S {
  max-width: 640px
}

@media print {
  .c-imageCenter__S {
    max-width: 320px
  }
}

.c-imageCenter__SS {
  max-width: 480px
}

@media print {
  .c-imageCenter__SS {
    max-width: 320px
  }
}

@media print {
  .c-imageCenter__printFull {
    max-width: 100% !important
  }
}

.c-imageLink {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 40px
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink {
    flex-direction: row;
    gap: 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink {
    gap: 48px 65px
  }

  [lang=en] .c-imageLink {
    gap: 24px
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .c-imageLink {
    gap: 48px 65px
  }
}

.c-imageLink li {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 18px;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink li {
    gap: 24px;
    width: calc((100% - 48px)/ 3)
  }

  [lang=en] .c-imageLink li {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink li {
    width: calc((100% - 130px)/ 3)
  }

  [lang=en] .c-imageLink li {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .c-imageLink li {
    width: calc((100% - 130px)/ 3)
  }
}

.c-imageLink__item {
  position: relative;
  display: block;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 358/187
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink__item {
    aspect-ratio: 370/220
  }
}

.c-imageLink__item::before {
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/images/common/icon_arrowRightWhite.svg);
  content: "";
  display: inline-block;
  flex-shrink: 0;
  height: 16px;
  width: 18px;
  margin-left: 12px;
  position: absolute;
  bottom: 20px;
  right: 14px;
  z-index: 10
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink__item::before {
    bottom: 27px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__item::before {
    bottom: 34px
  }
}

.c-imageLink__item::after {
  content: "";
  background: rgba(0, 33, 83, .3);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transition: .2s ease all;
  transition-duration: .3s;
  z-index: 0;
  opacity: 1
}

.c-imageLink__item img {
  transition: .2s ease all;
  transition-duration: .3s;
  width: 100%
}

.c-imageLink__item p {
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 13px 40px 13px 10px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.45;
  color: #fff;
  text-align: right;
  z-index: 10;
  margin-bottom: 3px
}

[lang=en] .c-imageLink__item p {
  font-size: 19px;
  margin-bottom: 2px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink__item p {
    padding: 16px 40px 16px 10px;
    font-size: 18px;
    margin-bottom: 8px
  }

  [lang=en] .c-imageLink__item p {
    font-size: 19px;
    margin-bottom: 5px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__item p {
    padding: 20px 44px 20px 14px;
    font-size: 24px;
    margin-bottom: 6px
  }

  [lang=en] .c-imageLink__item p {
    font-size: 26px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__item:hover {
    opacity: 1 !important
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__item:hover::after {
    opacity: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__item:hover img {
    transform: scale(1.15)
  }
}

.c-imageLink__relevance {
  margin: 0 auto;
  padding: 0 16px
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink__relevance {
    margin: 0;
    padding: 0
  }
}

.c-imageLink__relevance p {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5
}

[lang=en] .c-imageLink__relevance p {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink__relevance p {
    font-size: 20px
  }

  [lang=en] .c-imageLink__relevance p {
    font-size: 21px
  }
}

.c-imageLink__relevance a {
  display: block;
  max-width: 100%;
  margin-top: 16px;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__relevance a {
    max-width: 306px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-imageLink__relevance a:hover {
    opacity: .8
  }
}

.c-imageLink__relevance [class*=c-list] a:hover {
  opacity: 1
}

.c-label__primary {
  align-items: center;
  background: #002153;
  border-radius: 11px;
  color: #fff;
  display: flex;
  font-size: 12px;
  font-weight: 500;
  justify-content: center;
  min-height: 22px;
  padding: 0 12px
}

[lang=en] .c-label__primary {
  font-size: 13px
}

.c-date+.c-label__primary {
  margin-top: 0
}

.c-list__anchor {
  display: flex;
  flex-wrap: wrap;
  font-weight: 500;
  margin-top: 0;
  padding-left: 9px;
  gap: 12px 32px
}

[lang=en] .c-list__anchor {
  gap: 26px 32px
}

@media print,
screen and (min-width: 768px) {
  .c-list__anchor {
    gap: 20px 39px
  }

  [lang=en] .c-list__anchor {
    gap: 30px 40px
  }
}

.c-list__anchor>li a {
  align-items: center;
  color: #0093d7;
  display: flex
}

.c-list__anchor>li a::before {
  background: url(/images/common/icon_arrowDown.svg) no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 14px;
  width: 12px
}

@media print,
screen and (min-width: 768px) {
  .c-list__anchor>li a::before {
    height: 18px;
    width: 15px
  }
}

.c-list__anchor>li a span {
  font-size: 15px;
  margin-left: 8px;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: .2s ease all;
  width: calc(100% - 20px)
}

[lang=en] .c-list__anchor>li a span {
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-list__anchor>li a span {
    font-size: 16px;
    margin-left: 10px;
    width: calc(100% - 25px)
  }

}

@media print {
  .c-list__anchor>li a span {
    width: auto
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-list__anchor>li a:hover span {
    -webkit-text-decoration: underline 1px #0093d7;
    text-decoration: underline 1px #0093d7
  }
}

p+.c-list__anchor {
  margin-top: 34px
}

@media print,
screen and (min-width: 768px) {
  p+.c-list__anchor {
    margin-top: 40px
  }
}

.c-list__alphaLower,
.c-list__alphaUpper,
.c-list__any,
.c-list__disc,
.c-list__discLarge,
.c-list__number {
  display: flex;
  flex-direction: column;
  gap: 9px
}

.c-list__disc>li,
.c-list__discLarge>li {
  padding-left: 20px;
  position: relative
}

[lang=en] .c-list__disc>li,
[lang=en] .c-list__discLarge>li {
  padding-left: 15px
}

.c-list__disc>li::before,
.c-list__discLarge>li::before {
  display: block;
  position: absolute
}

.c-list__disc>li::before {
  content: "・";
  top: 0;
  left: 2px;
  width: 15px
}

[lang=en] .c-list__disc>li::before {
  content: "-"
}

.c-list__discLarge>li {
  display: flex
}

.c-list__discLarge>li::before {
  background: #607696;
  border-radius: 50%;
  content: "";
  top: .65em;
  left: 0;
  height: 8px;
  width: 8px
}

@media print,
screen and (min-width: 768px) {
  .c-list__discLarge>li::before {
    top: .8em
  }

  [lang=en] .c-list__discLarge>li::before {
    top: .55em
  }
}

.c-list__discLarge.u-fontSize__S li::before {
  top: .65em
}

@media print,
screen and (min-width: 768px) {
  .c-list__discLarge.u-fontSize__S li::before {
    top: .7em
  }
}

th>.c-list__discLarge>li::before {
  top: .55em
}

[lang=en] th>.c-list__discLarge>li::before {
  top: .4em
}

@media print,
screen and (min-width: 768px) {
  th>.c-list__discLarge>li::before {
    top: .65em
  }

  [lang=en] th>.c-list__discLarge>li::before {
    top: .45em
  }
}

td>.c-list__discLarge>li::before {
  top: .55em
}

@media print,
screen and (min-width: 768px) {
  td>.c-list__discLarge>li::before {
    top: .8em
  }
}

.c-list__any>div {
  display: flex
}

.c-list__any>div>dt {
  flex-shrink: 0;
  margin-right: .5em;
  white-space: nowrap
}

.c-list__any>div>dd {
  width: auto
}

.c-list__alphaLower>li,
.c-list__alphaUpper>li {
  padding-left: 30px;
  position: relative
}

[lang=en] .c-list__alphaLower>li,
[lang=en] .c-list__alphaUpper>li {
  padding-left: 25px
}

@media print,
screen and (min-width: 768px) {

  [lang=en] .c-list__alphaLower>li,
  [lang=en] .c-list__alphaUpper>li {
    padding-left: 28px
  }
}

.c-list__alphaLower>li::before,
.c-list__alphaUpper>li::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  text-align: right;
  width: 20px
}

.c-list__alphaLower>li .p-box__gray,
.c-list__alphaUpper>li .p-box__gray {
  margin: 32px 0 36px -20px;
  width: calc(100% + 20px)
}

[lang=en] .c-list__alphaLower>li .p-box__gray,
[lang=en] .c-list__alphaUpper>li .p-box__gray {
  margin: 32px 0 12px -25px;
  width: calc(100% + 25px)
}

@media print,
screen and (min-width: 768px) {

  .c-list__alphaLower>li .p-box__gray,
  .c-list__alphaUpper>li .p-box__gray {
    margin-top: 40px
  }

  [lang=en] .c-list__alphaLower>li .p-box__gray,
  [lang=en] .c-list__alphaUpper>li .p-box__gray {
    margin: 40px 0 12px -28px;
    width: calc(100% + 28px)
  }
}

.c-list__alphaUpper {
  counter-reset: alphaUpper
}

.c-list__alphaUpper>li::before {
  counter-increment: alphaUpper 1;
  content: counter(alphaUpper, upper-alpha) "."
}

.c-list__alphaLower {
  counter-reset: alphaLower
}

.c-list__alphaLower>li::before {
  counter-increment: alphaLower 1;
  content: counter(alphaLower, lower-alpha) "."
}

.c-list__number {
  counter-reset: number 0
}

.c-list__number>li {
  padding-left: 30px;
  position: relative
}

[lang=en] .c-list__number>li {
  padding-left: 25px
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .c-list__number>li {
    padding-left: 28px
  }
}

.c-list__number>li::before {
  counter-increment: number 1;
  content: counter(number) ".";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  text-align: right;
  width: 20px
}

.c-list__number>li .p-box__gray {
  margin: 32px 0 36px -20px;
  width: calc(100% + 20px)
}

[lang=en] .c-list__number>li .p-box__gray {
  margin: 32px 0 12px -25px;
  width: calc(100% + 25px)
}

@media print,
screen and (min-width: 768px) {
  .c-list__number>li .p-box__gray {
    margin-top: 40px
  }

  [lang=en] .c-list__number>li .p-box__gray {
    margin: 40px 0 12px -28px;
    width: calc(100% + 28px)
  }
}

.c-list__note,
.c-list__numberNote {
  display: flex;
  flex-direction: column;
  font-size: 13px;
  line-height: 1.85
}

[lang=en] .c-list__note,
[lang=en] .c-list__numberNote {
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {

  .c-list__note,
  .c-list__numberNote {
    font-size: 14px;
    line-height: 1.86
  }

  [lang=en] .c-list__note,
  [lang=en] .c-list__numberNote {}
}

.c-list__note>li,
.c-list__numberNote>li {
  position: relative
}

.c-list__note>li::before,
.c-list__numberNote>li::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0
}

.c-list__numberNote {
  counter-reset: number 0;
  gap: 7px
}

.c-list__numberNote>li {
  padding-left: 34px
}

.c-list__numberNote>li::before {
  counter-increment: number 1;
  content: "※"counter(number) "：";
  width: 36px
}

[lang=en] .c-list__numberNote>li::before {
  content: "*"counter(number) ":"
}

.c-list__note>li {
  padding-left: 14px
}

[lang=en] .c-list__note>li {
  padding-left: 17px
}

.c-list__note>li::before {
  content: "※";
  width: 1em
}

[lang=en] .c-list__note>li::before {
  content: "*"
}

@media print,
screen and (min-width: 1024px) {
  [class*=c-list].-flexPC {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 9px 60px
  }
}

@media print,
screen and (min-width: 1024px) {
  [class*=c-list].-columnPC {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 9px 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  [class*=c-list].-columnPC>li {
    width: calc((100% - 24px)/ 2)
  }
}

[class*=c-list].-narrow {
  gap: 0
}

[class*=c-list].-withSpace {
  gap: 9px
}

[class*=c-list].-withSpace.u-fontSize__SS {
  gap: 7px
}

[class*=c-list].-bold {
  gap: 16px
}

@media print,
screen and (min-width: 768px) {
  [class*=c-list].-bold {
    gap: 22px
  }
}

[class*=c-list].-bold>li {
  font-weight: 700
}

[class*=c-list].-bold>li>* {
  font-weight: 400
}

[class*=c-list].-bold>li>p:first-child {
  margin-top: 9px
}

[class*=c-list].-bold>li>[class*=c-list] {
  margin-top: 14px
}

@media print,
screen and (min-width: 768px) {
  [class*=c-list].-bold>li>[class*=c-list] {
    margin-top: 20px
  }
}

.c-pagetopWrap {
  position: absolute;
  bottom: 116px;
  right: 16px;
  height: 89px;
  width: 89px;
  z-index: 50
}

@media print,
screen and (min-width: 768px) {
  .c-pagetopWrap {
    right: 48px;
    bottom: 200px;
    height: 108px;
    width: 108px
  }
}

.c-pagetop {
  align-items: center;
  background: #002153;
  border-radius: 50%;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-family: Jost, sans-serif;
  font-weight: 400;
  line-height: 1.2;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  bottom: 16px;
  right: 16px;
  height: 89px;
  width: 89px;
  transition: .2s ease opacity;
  z-index: 50
}

@media print,
screen and (min-width: 768px) {
  .c-pagetop {
    font-size: 18px;
    line-height: 1.2;
    right: 48px;
    bottom: 48px;
    height: 108px;
    width: 108px
  }

  [lang=en] .c-pagetop {}
}

.c-pagetop::before {
  background: url(/images/common/icon_arrowTopWhite.svg) no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 14px;
  margin-bottom: 7px;
  width: 16px
}

@media print,
screen and (min-width: 768px) {
  .c-pagetop::before {
    height: 20px;
    margin-bottom: 8px;
    width: 16px
  }
}

.c-pagetop__text {
  text-align: center
}

.c-pagetop__text:nth-child(n+2) {
  margin-top: 6px !important
}

.c-pagetop.is-show {
  opacity: 1;
  pointer-events: all
}

.c-pagetop.is-static {
  position: absolute;
  right: 0;
  bottom: 0
}

@media print,
screen and (min-width: 1024px) {
  .c-pagetop:hover {
    opacity: .8
  }
}

.c-sdgs {
  margin-bottom: 40px;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 60px;
    margin-left: auto;
    margin-right: 0
  }
}

.c-sdgs__card {
  border: 1px solid #0093d7;
  border-radius: 14px;
  overflow: hidden;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__card {
    min-width: 567px;
    width: auto
  }
}

.c-sdgs__head {
  background: #0093d7;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  height: 44px
}

[lang=en] .c-sdgs__head {
  font-size: 19px
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__body {
    display: flex;
    justify-content: space-between
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__bodyLeft {
    flex-grow: 2;
    max-width: 448px
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__bodyLeft {
    width: 31.3vw
  }
}

.c-sdgs__item {
  width: 100%
}

.c-sdgs__item.-esgList {
  align-items: center;
  display: flex;
  padding: 13px 15px 12px
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__item.-esgList {
    padding: 13px 15px 6px
  }
}

.c-sdgs__item.-esgList dt {
  font-size: 15px;
  line-height: 2
}

[lang=en] .c-sdgs__item.-esgList dt {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__item.-esgList dt {
    font-size: 18px
  }

  [lang=en] .c-sdgs__item.-esgList dt {
    font-size: 19px
  }
}

.c-sdgs__item.-esgList dd {
  font-family: Jost, sans-serif;
  font-weight: 700;
  font-size: 28px;
  display: flex;
  gap: 8px;
  line-height: 1;
  margin-left: 6px
}

[lang=en] .c-sdgs__item.-esgList dd {
  font-size: 30px
}

.c-sdgs__item.-esgList dd .esg_E {
  color: #0f8254
}

.c-sdgs__item.-esgList dd .esg_S {
  color: #dc5164
}

.c-sdgs__item.-esgList dd .esg_G {
  color: #2d81e2
}

.c-sdgs__item.-description {
  border-top: 1px solid #0093d7;
  font-size: 15px;
  font-weight: 700;
  line-height: 2;
  padding: 13px 15px 12px
}

[lang=en] .c-sdgs__item.-description {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__item.-description {
    padding: 10px 16px;
    font-size: 16px
  }

  [lang=en] .c-sdgs__item.-description {
    font-size: 17px
  }
}

.c-sdgs__item.-mark {
  border-top: 1px solid #0093d7;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 13px 15px 19px
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__item.-mark {
    align-items: center;
    border-top: none;
    border-left: 1px solid #0093d7;
    padding: 12px 15px;
    height: 100%;
    max-width: 500px;
    width: auto
  }
}

.c-sdgs__item.-mark img {
  display: block;
  height: 75px;
  width: 75px
}

@media print,
screen and (min-width: 1024px) {
  .c-sdgs__item.-mark img {
    height: 87px;
    width: 87px
  }
}

.c-select {
  align-items: center;
  border-radius: 30px;
  display: inline-flex;
  position: relative
}

.c-select select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #fff;
  border: 1px solid #002153;
  border-radius: 50px;
  color: #002153;
  cursor: pointer;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  padding: 22px 52px 22px 24px;
  min-height: 60px;
  outline: 0;
  transition: .2s ease all
}

[lang=en] .c-select select {
  font-size: 17px;
  padding: 18px 52px 18px 24px;
  min-height: 56px
}

.c-select::after {
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/images/common/icon_pulldown.svg);
  content: "";
  display: inline-block;
  pointer-events: none;
  position: absolute;
  right: 24px;
  transition: .2s ease all;
  height: 7px;
  width: 12px
}

@media print,
screen and (min-width: 1024px) {
  .c-select:hover select {
    background: #002153;
    color: #fff
  }
}

@media print,
screen and (min-width: 1024px) {
  .c-select:hover::after {
    background-image: url(/images/common/icon_pulldownWhite.svg)
  }
}

[class*=c-select]+p,
p+[class*=c-select] {
  margin-top: 24px
}

.c-sign {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .c-sign {
    margin-top: 65px
  }
}

.c-sign__text {
  font-size: 13px;
  text-align: right
}

[lang=en] .c-sign__text {
  font-size: 14px
}

@media print,
screen and (min-width: 768px) {
  .c-sign__text {
    font-size: 14px
  }

  [lang=en] .c-sign__text {
    font-size: 15px
  }
}

.c-sign__image {
  margin: 10px 0 0 auto;
  width: 180px
}

@media print,
screen and (min-width: 768px) {
  .c-sign__image {
    margin: 10px 0 0 auto;
    width: 225px
  }
}

.c-splitText {
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)
}

@media print {
  .c-splitText {
    -webkit-clip-path: none;
    clip-path: none;
    opacity: 1
  }
}

.c-splitText .char {
  display: inline-block;
  transform: translateY(100%);
  transition: transfrom .5s
}

@media print {
  .c-splitText .char {
    transform: translateY(0)
  }
}

.c-text__lead {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.44;
  margin-top: 22px
}

[lang=en] .c-text__lead {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-text__lead {
    font-size: 18px;
    line-height: 1.44
  }

  [lang=en] .c-text__lead {
    font-size: 19px
  }
}

.c-text__lead+.c-text__description {
  margin-top: 10px
}

@media print,
screen and (min-width: 768px) {
  .c-text__lead+.c-text__description {
    margin-top: 13px
  }
}

.c-text__description {
  color: #607696;
  font-size: 14px;
  line-height: 1.71
}

[lang=en] .c-text__description {
  font-size: 15px;
  line-height: 1.5
}

.c-text__note {
  color: #77797c;
  font-size: 13px;
  line-height: 1.85
}

[lang=en] .c-text__note {
  font-size: 14px;
  line-height: 1.5
}

.p-table+.c-text__note {
  margin-top: 6px
}

.c-title__01 {
  display: flex;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 24px;
  position: relative
}

[lang=en] .c-title__01 {
  font-size: 26px;
  line-height: 1.35;
  margin-bottom: 40px
}

@media print,
screen and (min-width: 768px) {
  .c-title__01 {
    font-size: 44px;
    line-height: 1.45;
    margin-bottom: 82px
  }

  [lang=en] .c-title__01 {
    font-size: 46px;
    margin-bottom: 90px
  }
}

.c-title__01::before {
  background: #0093d7;
  border-radius: 50%;
  content: "";
  display: block;
  flex-shrink: 0;
  margin-top: 10px;
  height: 16px;
  width: 16px
}

@media print,
screen and (min-width: 768px) {
  .c-title__01::before {
    height: 24px;
    margin-top: 0;
    position: absolute;
    left: -48px;
    top: 24px;
    width: 24px
  }
}

.c-title__01 span {
  flex-shrink: 0;
  margin-left: 16px;
  width: calc(100% - 32px)
}

@media print,
screen and (min-width: 768px) {
  .c-title__01 span {
    margin-left: 0;
    width: 100%
  }
}

.c-title__01.-small,
.c-title__01.is-small {
  font-size: 20px;
  line-height: 1.8;
  margin-bottom: 14px
}

[lang=en] .c-title__01.-small,
[lang=en] .c-title__01.is-small {
  font-size: 21px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {

  .c-title__01.-small,
  .c-title__01.is-small {
    font-size: 32px;
    line-height: 1.5;
    margin-bottom: 40px
  }

  [lang=en] .c-title__01.-small,
  [lang=en] .c-title__01.is-small {
    font-size: 34px
  }
}

@media print,
screen and (min-width: 768px) {

  .c-title__01.-small::before,
  .c-title__01.is-small::before {
    top: 15px
  }
}

.c-title__02 {
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 40px;
  margin-top: 37px;
  margin-top: 63px;
  padding-top: 18px;
  position: relative;
  line-height: 1.6
}

.c-title__02 .is-small {
  font-size: 18px
}

[lang=en] .c-title__02 {
  font-size: 24px;
  line-height: 1.35
}

[lang=en] .c-title__02 .is-small {
  font-size: 20px
}

@media print,
screen and (min-width: 768px) {
  .c-title__02 {
    font-size: 32px;
    line-height: 1.5;
    padding-top: 45px;
    margin-bottom: 64px;
    margin-top: 100px
  }

  .c-title__02 .is-small {
    font-size: 20px
  }

  [lang=en] .c-title__02 {
    font-size: 34px
  }

  [lang=en] .c-title__02 .is-small {
    font-size: 22px
  }
}

.c-title__02::after,
.c-title__02::before {
  background: #0093d7;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0
}

.c-title__02::before {
  height: 1px;
  width: 100%
}

.c-title__02::after {
  height: 3px;
  width: 40px
}

@media print,
screen and (min-width: 768px) {
  .c-title__02::after {
    width: 62px
  }
}

.c-title__02.-withIcon {
  display: flex;
  padding-top: 15px;
  padding-left: 80px;
  padding-bottom: 15px;
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .c-title__02.-withIcon {
    padding-top: 32px;
    padding-left: 144px;
    padding-bottom: 32px;
    margin-top: 82px
  }
}

.c-title__02.-withIcon::before {
  height: 2px
}

.c-title__02.-withIcon::after {
  display: none
}

.c-title__02.-withIcon .icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 64px
}

@media print,
screen and (min-width: 768px) {
  .c-title__02.-withIcon .icon {
    width: 112px
  }
}

.c-title__02.-withIcon.-pink::before {
  background: #dc5164
}

.c-title__02.-withIcon.-purple::before {
  background: #7467a5
}

.c-title__02.-withIcon.-green::before {
  background: #0f8254
}

.c-list__anchor+.c-title__02 {
  margin-top: 36px
}

[lang=en] .c-list__anchor+.c-title__02 {
  margin-top: 50px
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .c-list__anchor+.c-title__02 {
    margin-top: 72px
  }
}

.c-title__03 {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 32px;
  margin-top: 40px;
  padding-top: 16px;
  position: relative;
  line-height: 1.6
}

[lang=en] .c-title__03 {
  font-size: 21px;
  line-height: 1.35;
  margin-bottom: 29px
}

@media print,
screen and (min-width: 768px) {
  .c-title__03 {
    font-size: 28px;
    line-height: 1.57;
    margin-bottom: 48px;
    margin-top: 64px;
    padding-top: 24px
  }

  [lang=en] .c-title__03 {
    font-size: 30px;
    margin-bottom: 52px
  }
}

.c-title__03::before {
  background: #0093d7;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  height: 1px;
  width: 40px
}

@media print,
screen and (min-width: 768px) {
  .c-title__03::before {
    width: 50px
  }
}

.c-title__03.-small {
  font-size: 18px;
  line-height: 1.44;
  margin-bottom: 4px;
  margin-top: 24px !important;
  padding-top: 0
}

[lang=en] .c-title__03.-small {
  font-size: 19px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-title__03.-small {
    font-size: 24px;
    line-height: 1.66;
    margin-top: 25px !important;
    padding-top: 0
  }

  [lang=en] .c-title__03.-small {
    font-size: 26px
  }
}

.c-title__03.-small::before {
  display: none
}

.c-title__03.-withIcon {
  align-items: center;
  display: flex;
  line-height: 1.5;
  padding-top: 0;
  padding-left: 72px;
  position: relative;
  min-height: 56px
}

@media print,
screen and (min-width: 768px) {
  .c-title__03.-withIcon {
    font-size: 21px;
    padding-left: 104px;
    margin-bottom: 63px;
    min-height: 80px
  }

  [lang=en] .c-title__03.-withIcon {
    font-size: 26px;
    line-height: 1.35
  }
}

@media print {
  .c-title__03.-withIcon {
    margin-bottom: 63px;
  }
}

.c-title__03.-withIcon::before {
  display: none
}

.c-title__03.-withIcon .icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 56px
}

@media print,
screen and (min-width: 768px) {
  .c-title__03.-withIcon .icon {
    width: 80px
  }
}

.c-title__04 {
  color: #607696;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom: 18px;
  margin-top: 40px
}

[lang=en] .c-title__04 {
  font-size: 19px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-title__04 {
    font-size: 24px;
    line-height: 1.66;
    margin-bottom: 24px;
    margin-top: 64px
  }

  [lang=en] .c-title__04 {
    font-size: 26px;
    margin-top: 38px
  }
}

.c-title__04.-withLabel span {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px
}

@media print,
screen and (min-width: 768px) {
  .c-title__04.-withLabel span {
    align-items: center;
    flex-direction: row
  }
}

.c-title__04.-withLabel .label {
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  height: 50px;
  min-width: 120px
}

[lang=en] .c-title__04.-withLabel .label {
  font-size: 15px
}

@media print,
screen and (min-width: 768px) {
  .c-title__04.-withLabel .label {
    font-size: 18px;
    height: 56px;
    min-width: 253px
  }

  [lang=en] .c-title__04.-withLabel .label {
    font-size: 19px
  }
}

.c-title__04.-withLabel .label.-orange {
  background: #dda656
}

.c-title__04.-withLabel .label.-green {
  background: #37754f
}

.c-title__04.-withLabel .label.-lightGreen {
  background: #7faa3d
}

.c-title__04.-withLabel .label.-blue {
  background: #3977b3
}

.c-title__04.-withLabel .label.-gray {
  background: #898989
}

.c-title__04 i {
  color: #002153;
  font-style: normal
}

.c-title__05 {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom: 15px;
  margin-top: 26px
}

[lang=en] .c-title__05 {
  font-size: 17px;
  line-height: 1.35;
  margin-bottom: 17px;
  margin-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .c-title__05 {
    font-size: 20px;
    line-height: 1.66;
    margin-bottom: 20px;
    margin-top: 48px
  }

  [lang=en] .c-title__05 {
    font-size: 21px
  }
}

.c-title__05 span {
  display: flex;
  align-items: center
}

.c-title__05 span .label {
  color: #0093d7;
  font-family: Jost, sans-serif;
  font-size: 40px;
  font-weight: 700;
  margin-right: 10px
}

[lang=en] .c-title__05 span .label {
  font-size: 42px
}

.c-title__04+.c-title__05,
.c-title__05+.c-title__06 {
  margin-top: 0
}

.c-title__06 {
  color: #77797c;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.73;
  margin-bottom: 8px;
  margin-top: 16px
}

[lang=en] .c-title__06 {
  font-size: 16px;
  line-height: 1.35;
  margin-bottom: 5px;
  margin-top: 18px
}

@media print,
screen and (min-width: 768px) {
  .c-title__06 {
    font-size: 18px;
    line-height: 1.66;
    margin-bottom: 8px;
    margin-top: 16px
  }

  [lang=en] .c-title__06 {
    font-size: 17px
  }
}

.p-column__wide+.c-title__05 {
  margin-bottom: 16px
}

.c-vision {
  margin-top: 32px;
  margin-bottom: 32px
}

@media print,
screen and (min-width: 768px) {
  .c-vision {
    margin-top: 64px;
    margin-bottom: 64px
  }
}

.c-vision li {
  align-items: center;
  display: flex;
  position: relative;
  min-height: 48px
}

@media print,
screen and (min-width: 768px) {
  .c-vision li {
    min-height: 60px
  }
}

.c-vision li:nth-child(n+2) {
  margin-top: 26px
}

.c-vision li.-high {
  margin-top: 18px
}

@media print,
screen and (min-width: 768px) {
  .c-vision li.-high {
    margin-top: 24px
  }
}

.c-vision__icon {
  position: absolute;
  width: 48px
}

@media print,
screen and (min-width: 768px) {
  .c-vision__icon {
    width: 60px
  }
}

.c-vision__label {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.55;
  padding-left: 64px
}

[lang=en] .c-vision__label {
  font-size: 19px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .c-vision__label {
    font-size: 20px;
    padding-left: 84px
  }

  [lang=en] .c-vision__label {
    font-size: 21px
  }
}

.c-vision__label b {
  color: #dc5164;
  font-size: 20px;
  font-weight: 700
}

[lang=en] .c-vision__label b {
  font-size: 21px
}

@media print,
screen and (min-width: 768px) {
  .c-vision__label b {
    font-size: 22px
  }

  [lang=en] .c-vision__label b {
    font-size: 24px
  }
}

.p-404>h2 {
  text-align: center;
  padding-top: 0;
  margin-bottom: 20px
}

.p-404>h2::after,
.p-404>h2::before {
  display: none
}

@media print,
screen and (min-width: 768px) {
  .p-404>h2 {
    margin-top: 100px !important;
    margin-bottom: 30px
  }
}

.p-404 p {
  text-align: center
}

.p-404 p:last-child {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-404 p:last-child {
    margin-top: 100px
  }
}

@keyframes about-fadeIn {
  0% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

@keyframes about-bgMove {
  0% {
    opacity: 0;
    transform: translateY(-2%)
  }

  100% {
    opacity: 1;
    transform: translateY(0)
  }
}

.p-about .l-main {
  position: relative
}

.p-about__background {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(/images/about/bg_about_01_sp.png);
  background-repeat: no-repeat;
  background-position: center top;
  opacity: 0;
  transform: translateY(0);
  animation: about-bgMove 4s cubic-bezier(.33, 1, .68, 1) 1s 1 forwards
}

@media print,
screen and (min-width: 768px) {
  .p-about__background {
    background-image: url(/images/about/bg_about_01_pc.png)
  }
}

@media print {
  .p-about__background {
    animation: none;
    background-size: 220%;
    opacity: 1;
    transform: translateY(0)
  }
}

.p-about .c-title__01 {
  margin-bottom: 34px
}

@media print,
screen and (min-width: 768px) {
  .p-about .c-title__01 {
    margin-bottom: 77px
  }
}

.p-about__main {
  background: linear-gradient(180deg, rgba(219, 244, 255, 0) 10%, #dbf4ff 100%);
  padding-bottom: 67px;
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .p-about__main {
    background: linear-gradient(180deg, rgba(219, 244, 255, 0) 30%, #dbf4ff 100%);
    padding-bottom: 70px
  }
}

.p-about__title {
  color: #002153;
  font-size: 6.15vw;
  font-weight: 700;
  line-height: 1.6;
  text-align: left;
  opacity: 0;
  animation: about-fadeIn 6s cubic-bezier(.33, 1, .68, 1) 3s 1 forwards
}

[lang=en] .p-about__title {
  line-height: 1.3
}

@media print,
screen and (min-width: 768px) {
  .p-about__title {
    font-size: 32px;
    line-height: 2.03
  }

  [lang=en] .p-about__title {
    font-size: 34px;
    line-height: 1.5
  }
}

@media print {
  .p-about__title {
    animation: none;
    opacity: 1
  }
}

.p-about__title span {
  display: inline-block;
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-about__title span {
    margin-top: 0
  }
}

.p-about__text {
  animation: about-fadeIn 6s cubic-bezier(.33, 1, .68, 1) 4s 1 forwards;
  margin: 126.7vw auto 0;
  max-width: 810px;
  opacity: 0;
  padding-left: 16px;
  padding-right: 16px;
  width: calc(100% - 32px)
}

@media print,
screen and (min-width: 480px) {
  .p-about__text {
    margin: 100vw auto 0
  }
}

@media print,
screen and (min-width: 640px) {
  .p-about__text {
    margin: 70vw auto 0
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__text {
    margin: 330px auto 0;
    padding-left: 50px;
    padding-right: 0
  }
}

@media print {
  .p-about__text {
    animation: none;
    margin: 80px auto 0;
    max-width: 100%;
    opacity: 1
  }
}

.p-about__text p {
  font-weight: 500;
  font-size: 16px;
  line-height: 2.1
}

[lang=en] .p-about__text p {
  font-size: 17px;
  line-height: 1.6
}

@media print,
screen and (min-width: 768px) {
  .p-about__text p {
    font-size: 20px;
    line-height: 2.2
  }

  [lang=en] .p-about__text p {
    font-size: 21px;
    line-height: 1.7
  }
}

.p-about__text p+p {
  margin-top: 34px
}

@media print,
screen and (min-width: 768px) {
  .p-about__text p+p {
    margin-top: 43px
  }
}

.p-about__sectionTitle {
  color: #002256;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.59;
  position: relative;
  text-align: center
}

[lang=en] .p-about__sectionTitle {
  line-height: 1.3
}

@media print,
screen and (min-width: 768px) {
  .p-about__sectionTitle {
    font-size: 32px;
    line-height: 2.03
  }

  [lang=en] .p-about__sectionTitle {
    line-height: 1.6
  }
}

@media screen and (min-width: 1024px) {
  .p-about__sectionTitle {
    white-space: nowrap
  }
}

.p-about__sectionTitle .back {
  color: #dbf4ff;
  font-family: Jost, sans-serif;
  font-size: 48px;
  font-weight: 700;
  line-height: .8;
  letter-spacing: .03em;
  text-align: center
}

@media print,
screen and (min-width: 768px) {
  .p-about__sectionTitle .back {
    letter-spacing: .011em;
    font-size: 72px
  }
}

.p-about__sectionTitle .front {
  display: block;
  position: absolute;
  bottom: 5px;
  text-align: center;
  width: 100%
}

[lang=en] .p-about__sectionTitle .front {
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .p-about__sectionTitle .front {
    bottom: 0
  }
}

.p-about__linkList {
  display: flex;
  gap: 32px;
  flex-direction: column;
  justify-content: center;
  padding-left: 16px;
  padding-right: 16px;
  margin: 40px auto 0;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-about__linkList {
    flex-direction: row;
    margin-top: 140px;
    max-width: 805px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__linkList {
    gap: 64px 4.51vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-about__linkList {
    gap: 64px 65px
  }
}

.p-about__linkItem .image {
  width: 100%
}

.p-about__linkItem .image img {
  display: block;
  width: 100%
}

.p-about__linkItem .text {
  color: #002153;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.73;
  margin-top: 10px
}

[lang=en] .p-about__linkItem .text {
  line-height: 1.3
}

@media print,
screen and (min-width: 768px) {
  .p-about__linkItem .text {
    font-size: 16px;
    margin-top: 5px
  }

  [lang=en] .p-about__linkItem .text {
    line-height: 1.3
  }
}

.p-about__linkItem .text span {
  position: relative
}

.p-about__linkItem .text span::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 15px;
  margin-left: 12px;
  background: url(/images/common/icon_arrowRight.svg) no-repeat left top;
  background-size: contain
}

.p-about__movie {
  padding-left: 16px;
  padding-right: 16px;
  margin: 32px auto 0;
  max-width: 640px;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-about__movie {
    padding-left: 0;
    padding-right: 0;
    margin: 64px auto 0
  }
}

.p-about__movie .text {
  color: #002153;
  color: #002153;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.73;
  margin-top: 10px
}

[lang=en] .p-about__movie .text {
  font-size: 15px;
  line-height: 1.3
}

@media print,
screen and (min-width: 768px) {
  .p-about__movie .text {
    font-size: 16px;
    margin-top: 5px
  }

  [lang=en] .p-about__movie .text {
    font-size: 17px;
    line-height: 1.3
  }
}

@media print and (min-width: 768px) {
  .p-about__movie .text {
    margin-top: 15px;
  }
}


.p-about .iframe-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%
}

.p-about .iframe-wrap iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%
}

@media print {
  .p-about .iframe-wrap iframe {
    max-width: 520px;
    margin: auto;
    right: 0
  }
}

.p-about__anchor {
  padding-right: 6px;
  font-size: 15px;
  line-height: 1.47;
  gap: 25px 32px;
  margin-top: 48px
}

[lang=en] .p-about__anchor {
  font-size: 16px;
  line-height: 1.2
}

@media print,
screen and (min-width: 768px) {
  .p-about__anchor {
    font-size: 16px;
    line-height: 1.12;
    gap: 25px 40px;
    margin-top: 166px
  }

  [lang=en] .p-about__anchor {
    font-size: 17px;
    line-height: 1.2
  }
}

.p-about #identity {
  position: relative;
  margin-bottom: 72px;
  padding-top: 48px;
  padding-bottom: 64px;
  border-radius: 32px 32px 0 0;
  background: linear-gradient(180deg, #fff 32.75%, #dbf4ff 100%)
}

@media print,
screen and (min-width: 768px) {
  .p-about #identity {
    margin-bottom: 180px;
    padding-top: 123px;
    padding-bottom: 0;
    border-radius: 64px 64px 0 0
  }
}

@media print {
  [lang=en] .p-about #identity {
    page-break-before: always
  }
}

.p-about #identity::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100px;
  background-color: #dbf4ff;
  z-index: -10
}

.p-about #identity::after {
  content: none
}

@media print,
screen and (min-width: 768px) {
  .p-about #identity::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    display: block;
    width: 100%;
    height: 100px;
    background-color: #fff
  }
}

.p-about__logo {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto 32px
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo {
    margin: 0 auto 160px
  }
}

.p-about__logo .outline {
  margin-top: 25px
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .outline {
    margin-top: 73px
  }
}

.p-about__logo .outline .image {
  width: 100%;
  max-width: 200px;
  margin: 0 auto
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .outline .image {
    max-width: 300px
  }
}

.p-about__logo .outline .text {
  font-size: 15px;
  line-height: 1.8;
  margin-top: 32px;
  width: 100%
}

[lang=en] .p-about__logo .outline .text {
  font-size: 16px;
  line-height: 1.4
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .outline .text {
    font-size: 18px;
    line-height: 2;
    margin-top: 64px
  }

  [lang=en] .p-about__logo .outline .text {
    font-size: 19px;
    line-height: 1.5
  }
}

.p-about__logo .outline .text p+p {
  margin-top: 26px
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .outline .text p+p {
    margin-top: 40px
  }
}

.p-about__logo .outline .text .link {
  margin-top: 35px
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .outline .text .link {
    margin-top: 24px
  }
}

.p-about__logo .movie {
  width: 100%;
  max-width: 800px;
  margin: 35px auto 0
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .movie {
    margin: 64px auto 0
  }
}

@media print {
  [lang=en] .p-about__logo .movie {
    page-break-before: always
  }
}

.p-about__logo .movie .text {
  margin-top: 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5
}

[lang=en] .p-about__logo .movie .text {
  font-size: 17px;
  line-height: 1.2
}

@media print,
screen and (min-width: 768px) {
  .p-about__logo .movie .text {
    margin-top: 16px;
    font-size: 20px
  }

  [lang=en] .p-about__logo .movie .text {
    font-size: 17px;
    line-height: 1.2
  }
}

.p-about__monument {
  background-color: #fff;
  border: 2px solid #0093d7;
  border-radius: 24px;
  box-sizing: content-box;
  padding: 30px 14px;
  position: relative;
  z-index: 10
}

@media print {
  .p-about__monument {
    padding: 40px 30px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument {
    border-radius: 48px;
    padding: 61px 80px 64px
  }
}

.p-about__monument .title {
  color: #0093d7;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.44;
  padding-left: 16px;
  padding-right: 16px
}

[lang=en] .p-about__monument .title {
  font-size: 19px;
  line-height: 1.2
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .title {
    font-size: 24px;
    line-height: 1.66;
    padding-left: 0;
    padding-right: 0
  }

  [lang=en] .p-about__monument .title {
    font-size: 26px;
    line-height: 1.3
  }
}

.p-about__monument .outline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: column;
  flex-wrap: nowrap;
  padding-left: 16px;
  padding-right: 16px;
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .outline {
    margin-top: 27px;
    padding-left: 0;
    padding-right: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__monument .outline {
    flex-direction: row
  }
}

.p-about__monument .outline .image {
  width: 100%;
  max-width: 220px;
  margin: 0 auto
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .outline .image {
    max-width: 330px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__monument .outline .image {
    width: 27.8810408922%;
    max-width: inherit;
    margin: 0
  }
}

.p-about__monument .outline .text {
  font-size: 15px;
  line-height: 1.8;
  margin-top: 24px;
  width: 100%
}

[lang=en] .p-about__monument .outline .text {
  font-size: 16px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .outline .text {
    font-size: 18px;
    line-height: 2;
    margin-top: 32px
  }

  [lang=en] .p-about__monument .outline .text {
    font-size: 19px;
    line-height: 1.6
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__monument .outline .text {
    width: 68.4014869888%;
    margin-top: 0
  }
}

.p-about__monument .outline .text p+p {
  margin-top: 26px
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .outline .text p+p {
    margin-top: 40px
  }
}

.p-about__monument .movie {
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .movie {
    width: 100%;
    max-width: 640px;
    margin: 71px auto 0
  }
}

.p-about__monument .movie .text {
  margin-top: 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5
}

[lang=en] .p-about__monument .movie .text {
  font-size: 17px;
  line-height: 1.2
}

@media print,
screen and (min-width: 768px) {
  .p-about__monument .movie .text {
    font-size: 20px;
    margin-top: 16px
  }

  [lang=en] .p-about__monument .movie .text {
    font-size: 21px;
    line-height: 1.3
  }
}

.p-about #around {
  position: relative;
  margin-bottom: 128px;
  background-color: #fff
}

@media print,
screen and (min-width: 768px) {
  .p-about #around {
    margin-bottom: 160px
  }
}

@media print {
  [lang=en] .p-about #around {
    page-break-before: always
  }
}

.p-about #around .p-about__sectionTitle .back {
  color: #f0f0f0
}

.p-about #around .p-about__sectionTitle .front {
  bottom: calc(50% - .2em)
}

@media print,
screen and (min-width: 768px) {
  .p-about #around .p-about__sectionTitle .front {
    bottom: -3px;
    transform: translateX(10px)
  }
}

.p-about #around .p-about__sectionTitle+.text {
  margin-top: -26px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.71;
  text-align: left;
  position: relative;
  z-index: 2
}

[lang=en] .p-about #around .p-about__sectionTitle+.text {
  margin-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-about #around .p-about__sectionTitle+.text {
    font-size: 18px;
    line-height: 1.66;
    margin-top: 10px;
    text-align: center;
    transform: translateX(10px)
  }
}

.p-about #around .button {
  margin-top: 32px;
  text-align: center
}

@media print,
screen and (min-width: 768px) {
  .p-about #around .button {
    margin-top: 62px
  }
}

.p-about #around .button .c-button__small {
  margin-top: 0;
  padding: 16px 20px 16px 24px
}

@media print,
screen and (min-width: 768px) {
  .p-about #around .button .c-button__small {
    min-height: 60px
  }
}

.p-about__productList {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  margin-top: 32px;
  gap: 32px;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-about__productList {
    flex-direction: row;
    gap: 64px 4.51vw;
    margin-top: 80px
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-about__productList {
    gap: 64px 65px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__productList:nth-of-type(2) {
    margin-top: 94px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__productItem {
    max-width: 370px;
    width: calc((100% - 4.51vw)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__productItem {
    width: calc((100% - 9.02vw)/ 3)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-about__productItem {
    width: calc((100% - 130px)/ 3)
  }
}

.p-about__productItem .image {
  width: 100%;
  margin: 0;
  padding: 0;
  text-align: center
}

.p-about__productItem .lead {
  margin: 0;
  padding: 0;
  color: #0093d7;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.33;
  text-align: center
}

[lang=en] .p-about__productItem .lead {
  line-height: 1.2;
  padding-left: 8px;
  padding-right: 8px
}

@media print,
screen and (min-width: 768px) {
  .p-about__productItem .lead {
    font-size: 20px;
    line-height: 1.3
  }

  [lang=en] .p-about__productItem .lead {
    line-height: 1.2
  }
}

.p-about__productItem .text {
  margin-top: 23px
}

.p-about__productItem .text dt {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.375
}

[lang=en] .p-about__productItem .text dt {
  line-height: 1.2
}

@media print,
screen and (min-width: 768px) {
  .p-about__productItem .text dt {
    font-size: 18px;
    line-height: 1.44
  }

  [lang=en] .p-about__productItem .text dt {
    line-height: 1.3
  }
}

.p-about__productItem .text dd {
  margin-top: 11px;
  color: #607696;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.71
}

[lang=en] .p-about__productItem .text dd {
  line-height: 1.3
}

.p-about #numbers {
  background-color: rgba(0, 147, 215, .4);
  margin-bottom: 72px;
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers {
    margin-bottom: 145px
  }

}

@media print {
  .p-about__cardList {
    width: 100%;
    padding: 0 30px
  }

  .p-about #numbers .l-inner {
    padding: 0;
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about #numbers {
    background-color: #fff
  }
}

@media screen and (min-width: 1024px) {
  .p-about #numbers .l-inner {
    padding-left: 6.94vw;
    padding-right: 6.94vw
  }
}

@media screen and (min-width: 1320px) {
  .p-about #numbers .l-inner {
    padding-left: 100px;
    padding-right: 100px
  }
}

.p-about #numbers .p-about__sectionTitle {
  line-height: 1.27;
  margin-bottom: 9px;
  position: relative
}

.p-about #numbers .p-about__sectionTitle .back {
  color: #dbf4ff
}

.p-about #numbers .p-about__sectionTitle .front {
  bottom: calc(50% - .1em)
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .p-about__sectionTitle .front {
    bottom: 0
  }
}

.p-about #numbers .p-about__sectionTitle+.date {
  position: relative;
  margin-top: -27px;
  z-index: 2
}

[lang=en] .p-about #numbers .p-about__sectionTitle+.date {
  margin-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .p-about__sectionTitle+.date {
    margin-top: 30px
  }
}

.p-about #numbers .date {
  font-size: 12px;
  line-height: 1;
  margin-left: auto;
  margin-right: auto;
  width: 100%
}

[lang=en] .p-about #numbers .date {
  font-size: 13px;
  line-height: 1.2
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .date {
    font-size: 13px;
    max-width: 1000px;
    width: 69.45vw
  }

  [lang=en] .p-about #numbers .date {
    font-size: 14px;
    line-height: 1.2;
    width: 75vw
  }
}

.p-about #numbers .button-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: row;
  flex-wrap: nowrap
}

.p-about #numbers .button-wrap:nth-of-type(1) {
  margin-top: 16px;
  margin-bottom: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .button-wrap:nth-of-type(1) {
    margin-top: 38px;
    margin-bottom: 65px
  }
}

.p-about #numbers .button-wrap:nth-of-type(2) {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .button-wrap:nth-of-type(2) {
    margin-top: 40px
  }
}

.p-about #numbers .button-wrap .button {
  margin: 0 16px
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .button-wrap .button {
    margin: 0 20px
  }
}

.p-about #numbers .button-wrap .button .c-button__small {
  margin-top: 0;
  padding: 16px 20px 16px 24px
}

@media print,
screen and (min-width: 768px) {
  .p-about #numbers .button-wrap .button .c-button__small {
    min-height: 60px
  }
}

.p-about__numbers {
  background-color: none;
  border-radius: 0;
  padding: 48px 0 38px;
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .p-about__numbers {
    padding: 103px 0 75px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__numbers {
    background-color: rgba(0, 147, 215, .4);
    border-radius: 64px 0 0 64px;
    padding: 103px 0 75px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__numbers::after {
    background-color: rgba(0, 147, 215, .4);
    content: "";
    display: block;
    position: absolute;
    left: 100%;
    top: 0;
    height: 100%;
    width: 50%
  }
}

.p-about__cardList {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 16px;
  margin: 0 auto;
  width: 100%
}

@media print {
  .p-about__cardList {
    gap: 24px;
    flex-direction: row
  }

  .p-about__card--full {
    max-height: 824px;
  }

  .sw_view object {
    height: 590px !important
  }
}

@media screen and (min-width: 768px) {
  .p-about__cardList {
    gap: 24px;
    flex-direction: row;
    width: 69.45vw;
    max-width: 1000px
  }

  [lang=en] .p-about__cardList {
    width: 75vw
  }
}

.p-about__cardList:nth-of-type(1) {
  margin-top: 34px
}

@media screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(1) {
    margin-top: 44px
  }
}

@media screen and (min-width: 768px) {

  .p-about__cardList:nth-of-type(1) .p-about__card:nth-child(3) .title,
  .p-about__cardList:nth-of-type(1) .p-about__card:nth-child(4) .title {
    transform: translateX(8px)
  }
}

.p-about__cardList:nth-of-type(2) {
  margin-top: 23px
}

@media screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(2) .p-about__card:nth-child(1) {
    padding: 22px 24px 21px
  }
}

.p-about__cardList:nth-of-type(2) .p-about__card:nth-child(1) .title {
  margin-bottom: 2px
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(2) .p-about__card:nth-child(1) .title {
    margin-bottom: 4px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(2) .p-about__card:nth-child(1) .text {
    margin-left: 17px
  }
}

.p-about__cardList:nth-of-type(2) .p-about__card:nth-child(1) .p-about__cardBox {
  transform: translateX(-8px)
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(2) .p-about__card:nth-child(2) {
    padding: 30px 24px 50px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(2) .p-about__card:nth-child(2) .title {
    margin-bottom: 10px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardList:nth-of-type(2) .p-about__card:nth-child(2) .p-about__cardBox {
    transform: translateX(-6px)
  }
}

.p-about__card {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  flex-wrap: wrap;
  padding: 24px 24px 23px;
  border: 2px solid #0093d7;
  border-radius: 24px;
  background-color: #fff
}

@media print,
screen and (min-width: 768px) {
  .p-about__card {
    border-radius: 40px;
    padding: 32px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__card {
    flex-direction: row
  }
}

.p-about__card--half {
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-about__card--half {
    max-width: 488px;
    width: calc((100% - 24px)/ 2)
  }
}

@media print {
  [lang=en] .p-about__card--half {
    padding: 30px 32px 22px;
    max-width: 100%;
    width: 100%
  }
}

.p-about__card--full {
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-about__card--full {
    padding: 30px 32px 22px
  }
}

@media print,
screen and (max-width: 767px) {
  .p-about__card--employees .p-about__cardBox {
    flex-wrap: wrap
  }
}

@media print,
screen and (max-width: 1023px) {
  .p-about__card--employees .p-about__cardBox .text {
    align-items: flex-start;
    width: calc(100% - 96px)
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-about__card--employees .p-about__cardBox .text {
    margin-left: 16px
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-about__card--employees .p-about__cardBox .text dt {
    white-space: nowrap
  }
}

.p-about__card .title {
  font-size: 21px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 16px;
  text-align: center;
  width: 100%
}

[lang=en] .p-about__card .title {
  font-size: 22px;
  line-height: 1.3
}

.p-about__cardBox {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: row;
  flex-wrap: nowrap;
  margin: 0
}

.p-about__cardBox--data {
  flex-direction: column
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox--data {
    flex-direction: row
  }
}

.p-about__cardBox+.p-about__cardBox {
  margin-top: 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox+.p-about__cardBox {
    margin-top: 0;
    margin-left: 64px
  }

  [lang=en] .p-about__cardBox+.p-about__cardBox {
    margin-left: 48px
  }
}

.p-about__cardBox .icon {
  height: auto;
  width: 100%
}

.p-about__cardBox .icon--large {
  width: 80px
}

@media print,
screen and (max-width: 359px) {
  .p-about__cardBox .icon--large {
    width: 20.51vw
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .icon--large {
    width: 6.94vw;
    max-width: 100px
  }
}

.p-about__cardBox .icon--middle {
  width: 72px
}

@media print,
screen and (max-width: 359px) {
  .p-about__cardBox .icon--middle {
    width: 18.46vw
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .icon--middle {
    width: 6.52vw;
    max-width: 94px
  }

  [lang=en] .p-about__cardBox .icon--middle {
    margin-left: -24px
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-about__cardBox .icon--middle+.text {
    margin-left: 8px
  }
}

.p-about__cardBox .icon--small {
  width: 64px
}

@media print,
screen and (max-width: 359px) {
  .p-about__cardBox .icon--small {
    width: 16.41vw
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .icon--small {
    width: 5.5vw;
    max-width: 80px
  }
}

.p-about__cardBox .text {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  flex-wrap: nowrap;
  margin-left: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .text {
    margin-left: 32px
  }
}

.p-about__cardBox .text dt {
  display: flex;
  align-items: center;
  font-size: 21px;
  font-weight: 700;
  line-height: 1.14
}

[lang=en] .p-about__cardBox .text dt {
  align-items: flex-start;
  flex-direction: column;
  gap: 6px
}

.p-about__cardBox .text dt span {
  display: inline-block;
  margin-left: 8px;
  color: #607696;
  font-size: 12px;
  line-height: 1.08
}

@media print,
screen and (max-width: 1023px) {
  [lang=en] .p-about__cardBox .text dt span {
    margin-left: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .text dt span {
    font-size: 13px
  }
}

.p-about__cardBox .text dd {
  color: #0093d7;
  font-size: 24px;
  font-weight: 700;
  padding-top: 2px;
  white-space: nowrap
}

[lang=en] .p-about__cardBox .text dd {
  line-height: 1
}

@media screen and (max-width: 359px) {
  .p-about__cardBox .text dd {
    font-size: 6.15vw
  }
}

.p-about__cardBox .text dd em {
  font-style: normal;
  font-family: Jost, sans-serif;
  font-size: 56px;
  font-weight: 400;
  line-height: 1.14
}

@media screen and (max-width: 359px) {
  .p-about__cardBox .text dd em {
    font-size: 14.35vw
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .text dd em {
    font-size: 4.44vw
  }
}

@media screen and (min-width: 1320px) {
  .p-about__cardBox .text dd em {
    font-size: 64px
  }
}

.p-about__cardBox .text--row {
  flex-direction: row;
  margin-left: 16px
}

.p-about__cardBox .text--row dt {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.85
}

[lang=en] .p-about__cardBox .text--row dt {
  line-height: 1.3
}

.p-about__cardBox .text--row dd {
  margin-left: 8px
}

.p-about__cardBox .graph-wrap {
  margin-top: 24px;
  margin-bottom: 24px;
  padding-left: 16px;
  padding-right: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .graph-wrap {
    width: 24.16px;
    max-width: 348px
  }
}

.p-about__cardBox .graph-wrap .graph {
  text-align: center;
  margin: auto;
  max-width: 317px
}

.p-about__cardBox .graph-wrap .graph img {
  width: 100%
}

.p-about__cardBox .graph-wrap .note {
  color: #77797c;
  font-size: 14px;
  line-height: 1.71;
  text-align: center
}

.p-about__cardBox .items {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  flex-wrap: nowrap;
  width: 100%;
  margin-top: 16px;
  margin-left: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-about__cardBox .items {
    width: 400px;
    margin-top: 0;
    margin-left: 35px;
    transform: translateY(-2px)
  }
}

.p-about__cardBox .items .text {
  align-items: center;
  justify-content: space-between;
  margin-top: 7px;
  margin-left: 0;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardBox .items .text {
    align-items: flex-end;
    border-bottom: 1px dashed #d9d9d9;
    margin-top: 15px
  }
}

.p-about__cardBox .items .text:first-child {
  margin-top: 0
}

.p-about__cardBox .items .text dt {
  margin-bottom: -1px;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  background-color: #fff
}

[lang=en] .p-about__cardBox .items .text dt {
  line-height: 1.3
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardBox .items .text dt {
    font-size: 16px
  }
}

.p-about__cardBox .items .text dd {
  margin-bottom: -1px;
  font-size: 18px;
  line-height: 1.11;
  background-color: #fff
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardBox .items .text dd {
    font-size: 20px
  }
}

.p-about__cardBox .items .text dd em {
  font-size: 32px;
  line-height: 1.13
}

@media print,
screen and (min-width: 768px) {
  .p-about__cardBox .items .text dd em {
    font-size: 36px
  }
}

.p-about #advertisement {
  background-color: #fff;
  margin-bottom: 72px;
  position: relative
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement {
    margin-bottom: 160px
  }
}

.p-about #advertisement .p-about__sectionTitle {
  line-height: 1
}

[lang=en] .p-about #advertisement .p-about__sectionTitle {
  line-height: 1.2
}

@media print,
screen and (max-width: 1023px) {
  [lang=en] .p-about #advertisement .p-about__sectionTitle {
    text-align: left
  }
}

.p-about #advertisement .p-about__box--gray {
  padding: 24px;
  margin-top: 14px
}

@media print,
screen and (min-width: 768px) {
  .p-about #advertisement .p-about__box--gray {
    padding: 48px;
    margin-top: 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement .p-about__box--gray {
    padding: 60px;
    margin-top: 34px
  }
}

.p-about #advertisement .p-about__column {
  display: flex;
  flex-direction: column;
  gap: 16px
}

@media print {
  .p-about #advertisement .p-about__column {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement .p-about__column {
    flex-direction: row;
    gap: 48px
  }
}

.p-about #advertisement .p-about__column .image {
  width: 100%
}

@media print {
  .p-about #advertisement .p-about__column .image {
    width: 50%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement .p-about__column .image {
    width: 35.9712230216%
  }
}

.p-about #advertisement .p-about__column .text-block {
  width: 100%
}

@media print {
  .p-about #advertisement .p-about__column .text-block {
    width: 50%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement .p-about__column .text-block {
    width: 59.7122302158%
  }
}

.p-about #advertisement .p-about__column .text-block .lead {
  margin: 0;
  padding: 0;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.73
}

[lang=en] .p-about #advertisement .p-about__column .text-block .lead {
  font-size: 16px;
  line-height: 1.3
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement .p-about__column .text-block .lead {
    font-size: 22px;
    line-height: 1.82
  }

  [lang=en] .p-about #advertisement .p-about__column .text-block .lead {
    font-size: 24px;
    line-height: 1.4
  }
}

.p-about #advertisement .p-about__column .text-block .button {
  margin-top: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-about #advertisement .p-about__column .text-block .button {
    margin-top: 32px
  }
}

.p-about #advertisement .p-about__column .text-block .button .c-button__small {
  margin-top: 0;
  padding: 16px 20px 16px 24px
}

@media print,
screen and (min-width: 768px) {
  .p-about #advertisement .p-about__column .text-block .button .c-button__small {
    min-height: 60px
  }
}

.p-aboutStory {
  overflow-x: clip !important
}

.p-aboutStory #container {
  padding-top: 64px !important
}

@media print,
screen and (min-width: 1024px) {
  .p-aboutStory #container {
    padding-top: 111px !important
  }
}

.p-aboutStory .l-inner {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 16px;
  padding-right: 16px;
  width: 100% !important;
  background: #fff;
  position: relative;
  z-index: 99
}

@media print,
screen and (min-width: 768px) {
  .p-aboutStory .l-inner {
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
    max-width: 100% !important
  }
}

.p-aboutStory .p-breadcrumb {
  margin-bottom: 0 !important;
  padding-bottom: 5px;
  padding-top: 15px
}

@media print,
screen and (min-width: 768px) {
  .p-aboutStory .p-breadcrumb {
    padding-bottom: 22px;
    padding-top: 32px
  }
}

.p-aboutStory .contentsBody {
  position: relative;
  z-index: 2
}

.p-aboutStory .contentsBody section {
  padding-bottom: 30vw
}

.p-aboutStory .productHistory .grid .item .ttl .age {
  color: #0f1010
}

.p-aboutStory .productHistory .grid .item .ttl .leadTxt {
  margin-top: 0
}

.p-aboutStory .productHistory .grid .txtOnly .ttl .leadTxt {
  margin-top: 0
}

.p-aboutStory .iziModal-content h3,
.p-aboutStory .iziModal-content p {
  color: #333
}

.p-aboutStory .iziModal-header-subtitle {
  color: #333
}

.p-aboutStory footer {
  background: 0 0;
  z-index: 10
}

.p-aboutStory .l-footer {
  margin-top: -10vw !important
}

@media print,
screen and (min-width: 768px) {
  .p-aboutStory .l-footer {
    margin-top: -19vw !important
  }
}

.p-accordion .badge {
  height: 43px;
  margin-right: 16px;
  width: 43px
}

@media print,
screen and (min-width: 768px) {
  .p-accordion .badge {
    height: 48px;
    margin-right: 24px;
    width: 48px
  }
}

.p-accordion .badge+.text-block {
  width: calc(100% - 41px)
}

@media print,
screen and (min-width: 768px) {
  .p-accordion .badge+.text-block {
    width: calc(100% - 48px)
  }
}

.p-accordion .badge img {
  width: 100%
}

.p-accordion__area {
  width: 100%
}

.p-accordion__area li:nth-child(n+2) {
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-accordion__area li:nth-child(n+2) {
    margin-top: 48px
  }
}

.p-accordion__button {
  align-items: center;
  background: #f1f1f1;
  border-radius: 24px;
  position: relative;
  cursor: pointer;
  display: flex;
  font-weight: 500;
  line-height: 1.6;
  padding: 16px 36px 16px 16px;
  transition: all .5s ease
}

@media print,
screen and (min-width: 768px) {
  .p-accordion__button {
    line-height: 1.875;
    padding: 15px 48px 15px 24px
  }
}

.p-accordion__button::after,
.p-accordion__button::before {
  content: "";
  background-color: #002153;
  border-radius: 1px;
  height: 2px;
  position: absolute;
  right: 16px;
  top: 48%;
  transition: transform .5s ease;
  width: 18px
}

@media print,
screen and (min-width: 768px) {

  .p-accordion__button::after,
  .p-accordion__button::before {
    right: 24px;
    width: 24px
  }
}

.p-accordion__button::before {
  transform: rotate(0)
}

.p-accordion__button::after {
  transform: rotate(90deg)
}

.p-accordion__button.close::after {
  transform: rotate(0)
}

.p-accordion__box {
  display: none;
  margin: 0 0 0 16px;
  padding-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-accordion__box {
    margin: 0 24px
  }
}

@media print {
  .p-accordion__box {
    display: block
  }
}

.p-accordion__box .inner {
  display: flex
}

.p-accordion__box .inner .badge+.text-block {
  padding-top: 10px
}

.p-accordion.p-accordion__news {
  background: #f1f1f1;
  border-radius: 16px
}

.p-accordion.p-accordion__news .p-accordion__button {
  color: #607696;
  border-radius: 16px;
  font-size: 18px;
  font-weight: 700;
  padding: 24px 44px 24px 24px
}

[lang=en] .p-accordion.p-accordion__news .p-accordion__button {
  font-size: 19px
}

.p-accordion.p-accordion__news .p-accordion__button::after,
.p-accordion.p-accordion__news .p-accordion__button::before {
  right: 24px;
  top: 48%
}

@media print,
screen and (min-width: 768px) {
  .p-accordion.p-accordion__news .p-accordion__button {
    display: none
  }
}

.p-accordion.p-accordion__news .p-accordion__box {
  font-size: 13px;
  line-height: 1.85;
  margin: 0;
  padding: 0 24px 18px;
  transform: translateY(-6px)
}

[lang=en] .p-accordion.p-accordion__news .p-accordion__box {
  font-size: 14px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-accordion.p-accordion__news .p-accordion__box {
    background: #f1f1f1;
    border-radius: 24px;
    display: block;
    padding: 40px
  }
}

.p-accordion.p-accordion__news .p-accordion__box p+p {
  margin-top: 14px
}

.p-biofund {
  background-image: url(/images/biofund/bg_biofund.svg), url(/images/biofund/bg_biofund.svg);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-position: calc(50% + 141px) 339px, calc(50% - 196px) 1448px;
  background-size: 691px 497.34px, 691px 497.34px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund {
    background-position: calc(50% + 481px) 197px, calc(50% - 778px) 987px;
    background-size: 1137px 819px, 1137px 819px
  }
}

.p-biofund__head .p-mainVisual__text {
  max-width: 770px;
  width: 100%;
  line-height: 1.67;
  margin-top: 32px;
  margin-bottom: 62px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__head .p-mainVisual__text {
    line-height: 2.2;
    margin-top: 105px;
    margin-bottom: 142px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-biofund__head .p-mainVisual__text {
    width: 70%
  }
}

.p-biofund__body .p-members {
  background: rgba(255, 255, 255, .85)
}

.p-biofund__body .p-members__text:first-child {
  margin-top: 0
}

.p-biofund__body .p-members .c-sign__text:first-child {
  line-height: 1;
  margin-bottom: 12px
}

.p-biofund__body .p-members .c-sign__image {
  width: 172px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__body .p-members .c-sign__image {
    width: 198px
  }
}

.p-biofund__body .c-imageLink {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__body .c-imageLink {
    margin-top: 100px
  }
}

.p-biofund__body .p-newsList .c-date {
  line-height: 1;
  width: 100px
}

.p-biofund__body .p-newsList__itemTitle {
  margin-top: 0;
  margin-left: 0;
  padding-left: 21px
}

.p-biofund__body .p-news__meta {
  flex-direction: column;
  align-items: flex-start;
  gap: 10px 0
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__body .p-news__meta {
    flex-direction: row;
    align-items: center;
    gap: 0 36px
  }
}

.p-biofund__buttonBox {
  display: flex;
  flex-direction: column;
  gap: 16px 42px;
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__buttonBox {
    flex-direction: row;
    flex-wrap: wrap
  }
}

.p-biofund__guide {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 24px;
  margin-bottom: 32px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__guide {
    flex-direction: row;
    gap: 48px;
    margin-bottom: 65px
  }
}

.p-biofund__guide img {
  max-width: 235px;
  margin: 0 auto
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__guide img {
    max-width: 240px;
    margin: 0
  }
}

.p-biofund__guideText .c-list__disc {
  font-size: 16px;
  gap: 6px
}

.p-biofund__guideText .c-button {
  margin-top: 22px
}

.p-biofund__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofund__foot {
    margin-top: 96px
  }
}

.p-biofundAbout .cell_title {
  width: auto
}

@media print,
screen and (min-width: 1024px) {
  .p-biofundAbout .cell_title {
    width: 170px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-biofundAbout .p-companyProfile__column {
    max-height: 520px
  }
}

.p-biofundAbout .p-box__gray {
  margin-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundAbout .p-box__gray {
    margin-top: 65px
  }
}

.p-biofundAbout .p-box__gray+p {
  margin-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundAbout .p-box__gray+p {
    margin-top: 65px
  }
}

.p-biofundAbout .c-button__large {
  font-size: 16px;
  font-weight: 500;
  padding: 16px 20px 16px 24px
}

[lang=en] .p-biofundAbout .c-button__large {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-biofundAbout .c-button__large {
    min-height: 60px
  }
}

.p-biofundAbout__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundAbout__foot {
    margin-top: 100px
  }
}

.p-biofundBusiness__body .p-table.-blockSP table tr th {
  text-align: left !important
}

@media print,
screen and (min-width: 768px) {
  .p-biofundBusiness__body .p-table.-blockSP table tr th {
    max-width: 350px;
    width: 45%
  }
}

.p-biofundBusiness__body .p-table.-blockSP table tr td p+p {
  margin-top: 16px
}

.p-biofundBusiness__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundBusiness__foot {
    margin-top: 100px
  }
}

.p-biofundImpressions__body {
  text-align: center
}

.p-biofundImpressions__body h2,
.p-biofundImpressions__body p {
  text-align: left
}

.p-biofundImpressions__body .p-members {
  display: inline-block;
  margin-bottom: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .p-members {
    margin-bottom: 60px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .p-members__box {
    gap: 40px;
    padding: 40px
  }
}

.p-biofundImpressions__body .p-members__image {
  max-width: 129px;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .p-members__image {
    margin: 0
  }
}

.p-biofundImpressions__body .p-members__title {
  line-height: 1.4;
  color: #77797c
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .p-members__title {
    font-size: 25px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .p-members__text {
    margin-top: 29px
  }
}

.p-biofundImpressions__body .p-members__text-name {
  font-size: 16px;
  font-weight: 700;
  margin-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .p-members__text-name {
    font-size: 20px
  }
}

.p-biofundImpressions__body .c-imageCenter__S+p {
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__body .c-imageCenter__S+p {
    margin-top: 64px
  }
}

.p-biofundImpressions__foot .p-note {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundImpressions__foot .p-note {
    margin-top: 100px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-biofundMember__body .p-table.-blockSP table th {
    text-align: left !important;
    width: 145px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-biofundMember__body .p-table.-blockSP table .cell_name {
    width: 160px
  }
}

.p-biofundMember__foot {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundMember__foot {
    margin-top: 77px
  }
}

.p-biofundMember__foot .p-note {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundMember__foot .p-note {
    margin-top: 100px
  }
}

.p-biofundRecruit .inner {
  margin-left: 16px;
  margin-right: 16px;
  width: calc(100% - 32px)
}

@media print,
screen and (min-width: 768px) {
  .p-biofundRecruit .inner {
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
    max-width: 1440px;
    width: 100%
  }
}

.p-biofundRecruit__body .p-table table tr th {
  text-align: left !important
}

@media print,
screen and (min-width: 768px) {
  .p-biofundRecruit__body .p-table table tr th {
    width: 200px
  }
}

.p-biofundRecruit__body .p-table table tr td ul+p {
  margin-top: 39px
}

.p-biofundRecruit__body .p-table table tr td .u-text__bold+p {
  margin-top: 8px
}

.p-biofundRecruit__body .p-table table tr td p+.c-list__disc {
  margin-top: 20px
}

.p-biofundRecruit__bgBlue {
  background: #effaff;
  padding-top: 63px;
  padding-bottom: 63px;
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundRecruit__bgBlue {
    padding-top: 80px;
    padding-bottom: 80px;
    margin-top: 100px
  }
}

.p-biofundRecruit__bgBlue .c-title__02 {
  margin-top: 0
}

.p-biofundRecruit__cardList {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  max-width: 1000px;
  margin: 0 auto
}

@media print,
screen and (min-width: 1024px) {
  .p-biofundRecruit__cardList {
    flex-direction: row;
    justify-content: space-between;
    gap: 40px
  }
}

.p-biofundRecruit__cardItem {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background-color: #fff;
  border-radius: 14px;
  padding: 30px;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-biofundRecruit__cardItem {
    gap: 24px;
    padding: 40px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-biofundRecruit__cardItem {
    width: calc(50% - 64px)
  }
}

.p-biofundRecruit__cardItem p {
  font-size: 14px;
  margin-top: 0
}

.p-biofundRecruit__cardItem [class*=c-button] {
  font-size: 14px;
  margin-top: 0;
  min-height: auto;
  padding: 10px 18px
}

.p-biofundRecruit__cardItem [class*=c-button] span {
  padding-right: 6px
}

.p-biofundRecruit__cardArrow {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 32px
}

@media print,
screen and (min-width: 1024px) {
  .p-biofundRecruit__cardArrow {
    width: 32px;
    height: auto
  }
}

.p-biofundRecruit__cardArrow img {
  transform: rotate(90deg)
}

@media print,
screen and (min-width: 1024px) {
  .p-biofundRecruit__cardArrow img {
    transform: none
  }
}

.p-biofundRecruit__foot {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundRecruit__foot {
    margin-top: 64px
  }
}

.p-biofundRecruit__foot .p-note {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-biofundRecruit__foot .p-note {
    margin-top: 100px
  }
}

[class*=p-box] {
  border-radius: 16px;
  display: block;
  margin-top: 26px;
  padding: 24px 22px;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  [class*=p-box] {
    border-radius: 24px;
    margin-top: 39px;
    padding: 40px
  }
}

.p-box__gray {
  background: #f1f1f1
}

.p-box__blue {
  background: #effaff
}

[class*=p-box]>:first-child {
  margin-top: 0 !important
}

[class*=p-box]+* {
  margin-top: 26px
}

@media print,
screen and (min-width: 768px) {
  [class*=p-box]+* {
    margin-top: 39px
  }
}

.p-breadcrumb {
  margin-bottom: 30px
}

[lang=en] .p-breadcrumb {
  margin-bottom: 15px
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .p-breadcrumb {
    margin-bottom: 30px
  }
}

@media print {
  .p-breadcrumb {
    display: none
  }
}

.p-breadcrumb ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  overflow: hidden;
  padding-bottom: 10px
}

[lang=en] .p-breadcrumb ul {
  gap: 8px 12px
}

.p-breadcrumb ul li {
  align-items: center;
  color: #77797c;
  display: flex;
  flex-shrink: 0;
  font-size: 12px;
  line-height: 1.2
}

[lang=en] .p-breadcrumb ul li {
  font-size: 13px;
  line-height: 1
}

.p-breadcrumb ul li:nth-child(n+2)::before {
  background: url(/images/common/icon_arrowBreadcrumb.svg) no-repeat;
  background-position: center;
  background-size: cover;
  content: "";
  display: inline-block;
  flex-shrink: 0;
  margin-right: 12px;
  height: 6px;
  width: 3px
}

.p-breadcrumb ul li span {
  text-overflow: ellipsis;
  overflow: hidden;
  max-width: calc(100vw - 50px);
  white-space: nowrap
}

@media print,
screen and (min-width: 768px) {
  .p-breadcrumb ul li span {
    max-width: 664px
  }
}

.p-breadcrumb ul li a {
  color: #002153;
  -webkit-text-decoration: underline 1px #002153;
  text-decoration: underline 1px #002153;
  text-underline-offset: 20%;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-breadcrumb ul li a:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

[class*=p-column]:not([class*=p-column__item]) {
  margin-top: 24px;
  margin-left: auto;
  margin-right: auto
}

@media print,
screen and (min-width: 1024px) {
  [class*=p-column]:not([class*=p-column__item]) {
    margin-top: 40px
  }
}

[class*=p-column]:not([class*=p-column__item]).-alignCenter {
  align-items: center
}

[class*=p-column]:not([class*=p-column__item]).-spaceBetween {
  justify-content: space-between
}

.p-column__item>:first-child,
.p-column__itemLarge>:first-child,
.p-column__itemSmall>:first-child {
  margin-top: 0 !important
}

.p-column__item.-widthAuto,
.p-column__itemLarge.-widthAuto,
.p-column__itemSmall.-widthAuto {
  max-width: none !important;
  width: auto !important
}

.p-column__S {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-column__S {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__S {
    gap: 48px 3.33vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__S {
    gap: 48px
  }
}

.p-column__S .p-column__item {
  width: 100%
}

@media print {
  .p-column__S .p-column__item {
    width: calc((100% - 72px)/ 4)
  }
}

@media print,
screen and (min-width: 768px) {
  .p-column__S .p-column__item {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__S .p-column__item {
    width: calc((100% - 9.99vw)/ 4)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__S .p-column__item {
    width: calc((100% - 144px)/ 4)
  }
}

.p-column__S.-narrow {
  gap: 32px 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-column__S.-narrow {
    gap: 48px 1.66vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__S.-narrow {
    gap: 48px 24px
  }
}

@media print {
  .p-column__S.-narrow .p-column__item {
    width: calc((100% - 72px)/ 4)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__S.-narrow .p-column__item {
    width: calc((100% - 4.98vw)/ 4)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__S.-narrow .p-column__item {
    width: calc((100% - 72px)/ 4)
  }
}

.p-column__M {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 24px
}

@media print {
  .p-column__M {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__M {
    flex-direction: row;
    gap: 48px 3.33vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__M {
    gap: 48px
  }
}

.p-column__M .p-column__item {
  width: 100%
}

@media print {
  .p-column__M .p-column__item {
    width: calc((100% - 48px)/ 3)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__M .p-column__item {
    width: calc((100% - 6.66vw)/ 3)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__M .p-column__item {
    width: calc((100% - 96px)/ 3)
  }
}

.p-column__M-02 {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 32px
}

@media print {
  .p-column__M-02 {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__M-02 {
    flex-direction: row;
    gap: 36px 4.51vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__M-02 {
    flex-direction: row;
    gap: 36px 65px
  }
}

.p-column__M-02 .p-column__item {
  width: 100%
}

@media print {
  .p-column__M-02 .p-column__item {
    width: calc((100% - 64px)/ 3)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__M-02 .p-column__item {
    width: calc((100% - 9.02vw)/ 3)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__M-02 .p-column__item {
    width: calc((100% - 130px)/ 3)
  }
}

.p-column__L {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 24px
}

@media print {
  .p-column__L {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__L {
    flex-direction: row;
    gap: 64px 72px;
    max-width: 1000px
  }
}

.p-column__L .p-column__item {
  width: 100%
}

@media print {
  .p-column__L .p-column__item {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__L .p-column__item {
    width: calc((100% - 72px)/ 2)
  }
}

.p-column__wide {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 24px
}

@media print {
  .p-column__wide {
    flex-direction: row;
    gap: 24px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-column__wide {
    flex-direction: row;
    gap: 24px 40px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__wide.-gap80 {
    gap: 24px 80px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__wide.-gap80 .p-column__item {
    width: calc((100% - 80px)/ 2)
  }
}

.p-column__wide .p-column__item {
  width: 100%
}

@media print {
  .p-column__wide .p-column__item {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__wide .p-column__item {
    width: calc((100% - 40px)/ 2)
  }
}

@media print {
  .p-column__wide .p-column__itemLarge {
    width: calc(100% - 24px - 240px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__wide .p-column__itemLarge {
    width: calc(100% - 40px - 25vw)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__wide .p-column__itemLarge {
    width: calc(100% - 40px - 360px)
  }
}

@media print {
  .p-column__wide .p-column__itemSmall {
    width: 240px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-column__wide .p-column__itemSmall {
    width: 25vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-column__wide .p-column__itemSmall {
    width: 360px
  }
}

.c-title__05+.p-column__wide {
  margin-top: 0
}

.p-company .inner {
  margin-left: 16px;
  margin-right: 16px;
  padding-top: 63px;
  padding-bottom: 63px;
  width: calc(100% - 34px)
}

@media print,
screen and (min-width: 768px) {
  .p-company .inner {
    margin: 0 auto;
    max-width: 1440px;
    width: 100%;
    padding: 100px
  }
}

.p-company .inner .c-title__02 {
  margin-top: 0
}

.p-company .p-mainVisual__company {
  background: url(/images/company/bg_company_SP.jpg) no-repeat 0 0/cover
}

@media print,
screen and (min-width: 768px) {
  .p-company .p-mainVisual__company {
    background: url(/images/company/bg_company_PC.jpg) no-repeat 0 0/cover
  }
}

.p-company .p-mainVisual .inner {
  padding-top: 0;
  padding-bottom: 0
}

.p-company__body .content01 {
  background: #effaff
}

.p-company__body .content01 .c-imageLink li:nth-child(2) .c-imageLink__item img {
  -o-object-position: 1px -18px;
  object-position: 1px -18px
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content01 .c-imageLink li:nth-child(2) .c-imageLink__item img {
    -o-object-position: 0;
    object-position: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-company__body .content01 .c-imageLink li:nth-child(2) .c-imageLink__item p {
    font-size: 18px;
    margin-bottom: 11px
  }
}

.p-company__body .content01__buttonWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  border-top: 1px solid #c8c8c8;
  gap: 24px;
  padding-top: 40px;
  margin-top: 36px
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content01__buttonWrap {
    gap: 32px;
    padding-top: 47px;
    margin-top: 47px
  }
}

.p-company__body .content01__buttonWrap .c-button {
  min-width: 286px;
  min-height: auto;
  height: 56px
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content01__buttonWrap .c-button {
    min-width: 284px
  }
}

.p-company__body .content02 {
  background: #0093d7
}

.p-company__body .content02 .c-title__02 {
  color: #fff
}

.p-company__body .content02 .c-title__02::after,
.p-company__body .content02 .c-title__02::before {
  background: #fff
}

.p-company__body .content02__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content02__list {
    justify-content: center;
    gap: 32px
  }
}

.p-company__body .content02__list li {
  width: calc(50% - 12px)
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content02__list li {
    width: auto
  }
}

.p-company__body .content02__list li a {
  background-color: #effaff;
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 13px;
  transition: all .3s ease
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content02__list li a {
    width: 200px;
    height: 200px;
    gap: 16px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-company__body .content02__list li a:hover {
    opacity: .8
  }
}

.p-company__body .content02__list li a img {
  width: 56px;
  height: 56px;
  margin-top: 7px
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content02__list li a img {
    width: 68px;
    height: 68px;
    margin-top: 0
  }
}

.p-company__body .content02__list li a span {
  color: #002153;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center
}

[lang=en] .p-company__body .content02__list li a span {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content02__list li a span {
    font-size: 18px;
    line-height: 1;
    margin-bottom: 11px
  }

  [lang=en] .p-company__body .content02__list li a span {
    font-size: 15px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-company__body .content02__list li a:hover {
    opacity: .8
  }
}

.p-company__body .content03 .inner {
  display: flex;
  flex-direction: column;
  padding-bottom: 0
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content03 .inner {
    flex-direction: row;
    gap: 80px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content03__list {
    max-width: 580px;
    width: 100%
  }
}

.p-company__body .content03__list:first-child .c-title__03 {
  margin-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-company__body .content03__list .c-title__03 {
    margin-top: 0
  }
}

.p-company__body .content03__list .c-list__discLarge>li {
  font-size: 16px
}

[lang=en] .p-company__body .content03__list .c-list__discLarge>li {
  font-size: 17px
}

.p-company__body .content03__list .c-list__discLarge>li p a {
  font-size: 16px
}

[lang=en] .p-company__body .content03__list .c-list__discLarge>li p a {
  font-size: 17px
}

.p-company__body .content03__list .c-list__discLarge>li:nth-child(n+2) {
  margin-top: 5px
}

.p-companyAbout__mainVisual {
  margin: 0 -16px 32px;
  width: calc(100% + 32px)
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAbout__mainVisual {
    margin: 0 0 48px;
    width: 100%
  }
}

.p-companyAbout__column {
  display: flex;
  flex-direction: column;
  gap: 48px 0
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAbout__column {
    flex-direction: row;
    gap: 0 64px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAbout__columnLarge {
    width: calc(100% - 260px - 64px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAbout__columnSmall {
    flex-shrink: 1;
    width: 260px
  }
}

.p-companyAbout__lead {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.59;
  margin-bottom: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-companyAbout__lead {
    font-size: 32px;
    line-height: 1.5;
    margin-bottom: 40px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAbout #tab-03 .p-column__itemLarge {
    width: calc(100% - 40px - 240px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAbout #tab-03 .p-column__itemSmall {
    width: 240px
  }
}

.p-companyAccess__column {
  margin-top: 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAccess__column {
    display: flex;
    justify-content: space-between;
    margin-top: 70px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAccess__columnContent {
    width: calc(61.62% - 64px)
  }
}

.p-companyAccess__columnContent .c-title__02 {
  margin-top: 0
}

.p-companyAccess__columnImage {
  margin-top: 32px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyAccess__columnImage {
    margin-top: 0;
    max-width: 476px;
    width: 38.38%
  }
}

.p-companyAccess__infoAddress+.p-companyAccess__infoTel {
  margin-top: 10px
}

.p-companyAccess__infoTel+.p-companyAccess__infoLink {
  margin-top: 20px
}

@media print,
screen and (min-width: 768px) {
  .p-companyAccessMap .c-title__01 {
    margin-bottom: 80px
  }
}

@media print {
  .p-companyAccessMap__head {
    overflow-y: visible;
    overflow-x: visible;
    width: 100%
  }
}

.p-companyAccessMap__head iframe {
  width: 100%;
  height: 100%;
  max-height: 800px;
  aspect-ratio: 3/2
}

@media print {
  .p-companyAccessMap__head iframe {
    height: auto;
    min-height: 300px;
    aspect-ratio: auto;
    overflow-y: visible;
    overflow-x: visible
  }
}

.p-companyAccessMap__headText {
  font-size: 15px;
  line-height: 1.86;
  display: inline-block;
  vertical-align: middle;
  margin-top: 10px
}

[lang=en] .p-companyAccessMap__headText {
  font-size: 16px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-companyAccessMap__headText {
    font-size: 18px;
    line-height: 1.66
  }

  [lang=en] .p-companyAccessMap__headText {
    font-size: 19px
  }
}

.p-companyAccessMap__headText .icon_star {
  width: 25px;
  height: 25px;
  margin: 0 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  position: relative;
  top: -2px
}

.p-companyAccessMap__body {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-companyAccessMap__body {
    margin-top: 97px;
    margin-bottom: 90px
  }
}

.p-companyAccessMap__body .p-table tr th {
  font-size: 13px;
  font-weight: 700;
  color: #607696;
  line-height: 1.44;
  width: 100%;
  display: block;
  padding: 12px 16px 9px;
  text-align: left
}

[lang=en] .p-companyAccessMap__body .p-table tr th {
  font-size: 14px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-companyAccessMap__body .p-table tr th {
    font-size: 16px;
    font-weight: 400;
    color: #002153;
    line-height: 1.66;
    width: 152px;
    display: table-cell;
    vertical-align: top;
    padding: 16px;
    text-align: center
  }

  [lang=en] .p-companyAccessMap__body .p-table tr th {
    font-size: 17px
  }
}

.p-companyAccessMap__body .p-table tr td {
  font-size: 14px;
  line-height: 1.44;
  width: 100%;
  display: block;
  padding: 0 16px 16px
}

[lang=en] .p-companyAccessMap__body .p-table tr td {
  font-size: 15px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-companyAccessMap__body .p-table tr td {
    font-size: 17px;
    line-height: 1.66;
    width: calc(100% - 152px);
    display: revert;
    padding: 16px
  }

  [lang=en] .p-companyAccessMap__body .p-table tr td {
    font-size: 18px
  }
}

.p-companyAccessMap__body .p-table tr td:first-child {
  padding-top: 16px
}

.p-companyGroup .p-table.-blockSP tr th {
  text-align: left !important;
  line-height: 1.8
}

[lang=en] .p-companyGroup .p-table.-blockSP tr th {
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-companyGroup .p-table.-blockSP tr th {
    max-width: 400px;
    width: 35%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyGroup .p-table.-blockSP tr th {
    width: 400px
  }
}

.p-companyGroup .p-table.-blockSP tr td {
  display: block
}

@media print {
  .p-companyGroup .p-table.-blockSP tr td {
    background-color: #fff
  }
}

.p-companyGroup .p-table.-blockSP tr td.cell_office {
  font-weight: 700;
  margin-left: 1em
}

@media print,
screen and (min-width: 1024px) {
  .p-companyGroup .p-table.-blockSP tr td.cell_office {
    width: 350px;
    margin-left: 0
  }
}

.p-companyGroup .p-table.-blockSP tr td.cell_office+td {
  margin-left: 1em;
  padding-top: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-companyGroup .p-table.-blockSP tr td.cell_office+td {
    margin-left: 0
  }
}

.p-companyGroup .p-table.-blockSP tr td:nth-child(n+2) {
  padding-top: 12px
}

@media print,
screen and (min-width: 768px) {
  .p-companyGroup .p-table.-blockSP tr td:nth-child(n+2) {
    padding-top: 16px
  }
}

.p-companyGroup .p-table.-blockSP tr td a {
  margin-top: 8px;
  margin-bottom: 8px
}

.p-companyGroup .p-table.-blockSP tr td ul {
  margin-top: 8px;
  margin-bottom: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px
}

.p-companyProfileHistory__body .p-tab__button li a {
  line-height: 1.6
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfileHistory__body .p-tab__button li a {
    line-height: 1
  }

  [lang=en] .p-companyProfileHistory__body .p-tab__button li a {
    line-height: 1.6
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfileHistory__body .p-tab__button li a span {
    display: inline
  }
}

.p-companyProfileHistory__foot {
  margin-top: 60px
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfileHistory__foot {
    margin-top: 100px;
    margin-bottom: 100px
  }
}

.p-companyProfileHistory__foot .p-box__gray {
  display: flex;
  flex-direction: column;
  justify-content: space-between
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfileHistory__foot .p-box__gray {
    flex-direction: row;
    align-items: center
  }
}

.p-companyProfileHistory__foot-text {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 24px
}

[lang=en] .p-companyProfileHistory__foot-text {
  font-size: 15px
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfileHistory__foot-text {
    margin-right: 24px;
    margin-bottom: 0
  }
}

.p-companyProfileHistory__foot-text p+p {
  margin-top: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfileHistory__foot-text p+p {
    margin-top: 25px
  }
}

.p-companyProfileHistory__foot-text .c-button {
  font-size: 14px;
  min-height: 44px;
  padding-left: 18px;
  padding-right: 14px
}

[lang=en] .p-companyProfileHistory__foot-text .c-button {
  font-size: 15px
}

.p-companyProfileHistory__foot-image {
  max-width: 370px;
  margin: 0 auto;
  transition: all .3s ease
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfileHistory__foot-image {
    width: 370px;
    margin: 0 0 0 auto
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfileHistory__foot-image:hover {
    opacity: .8
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyISO .p-table.-scroll {
    overflow: auto;
    white-space: nowrap
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyISO .p-table.-scroll {
    overflow: hidden;
    white-space: normal
  }
}

@media print {
  .p-companyISO .p-table.-scroll {
    overflow: visible;
    white-space: normal
  }
}

.p-companyISO .p-table table {
  table-layout: fixed;
  min-width: 850px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyISO .p-table table {
    table-layout: inherit
  }
}

@media print {
  .p-companyISO .p-table table {
    min-width: 100%
  }
}

.p-companyISO .p-table table tr td {
  white-space: normal;
  pointer-events: none;
  color: #002153;
  border-bottom: none;
  margin-right: 0
}

.p-companyISO__foot {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-companyISO__foot {
    margin-top: 77px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyOfficer__body .p-table.-blockSP table th {
    text-align: left !important;
    width: 145px
  }
}

@media print,
screen and (min-width: 768px) and (min-width:768px) {
  [lang=en] .p-companyOfficer__body .p-table.-blockSP table th {
    width: 220px
  }
}

@media print,
screen and (min-width: 768px) and (min-width:1024px) {
  [lang=en] .p-companyOfficer__body .p-table.-blockSP table th {
    width: 345px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyOfficer__body .p-table.-blockSP table .cell_name {
    width: 160px
  }
}

.p-companyOfficer__body .c-list__note {
  margin-top: 16px
}

.p-companyOfficer__foot {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-companyOfficer__foot {
    margin-top: 77px
  }
}

.p-companyPhilosophy .c-title__01 {
  margin-bottom: 31px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy .c-title__01 {
    margin-bottom: 78px
  }
}

.p-companyPhilosophy .inner {
  margin-left: 16px;
  margin-right: 16px;
  width: calc(100% - 32px)
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy .inner {
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
    max-width: 1440px;
    width: 100%
  }
}

.p-companyPhilosophy .en {
  font-family: Jost, sans-serif
}

.p-companyPhilosophy__title {
  display: flex;
  align-items: center;
  margin-bottom: 42px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__title {
    margin-bottom: 50px
  }
}

.p-companyPhilosophy__title .en {
  color: #002153;
  font-size: 40px;
  letter-spacing: .03em;
  line-height: 1;
  font-weight: 600;
  margin-left: 0
}

[lang=en] .p-companyPhilosophy__title .en {
  font-size: 42px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__title .en {
    font-size: 64px
  }

  [lang=en] .p-companyPhilosophy__title .en {
    font-size: 66px
  }
}

.p-companyPhilosophy__title span {
  color: #607696;
  font-size: 18px;
  margin-left: 23px
}

[lang=en] .p-companyPhilosophy__title span {
  font-size: 19px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__title span {
    font-size: 24px;
    margin-left: 32px
  }

  [lang=en] .p-companyPhilosophy__title span {
    font-size: 26px
  }
}

.p-companyPhilosophy__leadText {
  color: #0093d7;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.93;
  text-align: center
}

[lang=en] .p-companyPhilosophy__leadText {
  font-size: 21px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__leadText {
    font-size: 30px;
    line-height: 1.6
  }

  [lang=en] .p-companyPhilosophy__leadText {
    font-size: 32px
  }
}

.p-companyPhilosophy__headText {
  position: relative;
  background: #0093d7;
  color: #fff;
  padding-top: 52px;
  padding-bottom: 50px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__headText {
    padding-top: 77px;
    padding-bottom: 75px
  }
}

.p-companyPhilosophy__headText .inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 42px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__headText .inner {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__headText .inner {
    gap: 63px
  }
}

.p-companyPhilosophy__headText .inner .box01 {
  max-width: 612px;
  width: 100%;
  font-size: 16px;
  line-height: 1.9;
  text-align: center
}

[lang=en] .p-companyPhilosophy__headText .inner .box01 {
  font-size: 17px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__headText .inner .box01 {
    text-align: left
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__headText .inner .box01 {
    font-size: 24px
  }

  [lang=en] .p-companyPhilosophy__headText .inner .box01 {
    font-size: 26px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__headText .inner .box01 p+p {
    margin-top: 53px
  }
}

.p-companyPhilosophy__bg {
  display: flex;
  justify-content: center;
  overflow-x: clip;
  overflow-y: hidden;
  position: absolute;
  top: 0;
  height: 100%;
  width: 100vw;
  z-index: 0
}

.p-companyPhilosophy__bgRect {
  background: radial-gradient(50% 50% at 50% 50%, rgba(193, 240, 255, .6) 0, rgba(211, 234, 255, .3) 48.96%, rgba(255, 255, 255, 0) 97.4%);
  position: absolute;
  top: 0;
  transform: translate3d(45%, 125%, 0);
  height: 371px;
  width: 371px;
  z-index: 0
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__bgRect {
    transform: translate3d(73%, -50%, 0);
    height: 523px;
    width: 523px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__bgRect {
    transform: translate3d(133%, -50%, 0)
  }
}

.p-companyPhilosophy__body {
  max-width: 1240px;
  border: 2px solid #fef520;
  border-radius: 14px;
  margin: 40px 16px;
  padding: 48px 19px 19px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body {
    border-radius: 24px;
    margin: 60px 24px;
    padding: 55px 40px 45px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__body {
    margin: 80px;
    padding: 75px 70px 65px
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-companyPhilosophy__body {
    margin: 80px auto
  }
}

.p-companyPhilosophy__body .inner {
  padding-left: 0;
  padding-right: 0;
  margin-left: 0;
  margin-right: 0;
  width: 100%
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__title {
  margin-bottom: 35px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__title {
    margin-bottom: 50px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child {
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 34px;
  line-height: 1
}

[lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child {
  font-size: 36px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child {
    font-size: 48px
  }

  [lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child {
    font-size: 50px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child .ruby {
  color: #607696;
  font-size: 13px;
  line-height: 1;
  margin-bottom: 16px
}

[lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child .ruby {
  font-size: 14px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child .ruby {
    font-size: 16px
  }

  [lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:first-child .ruby {
    font-size: 17px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:last-child {
  color: #607696;
  font-size: 16px;
  line-height: 1.6;
  margin-top: 14px
}

[lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:last-child {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:last-child {
    font-size: 24px;
    margin-top: 18px
  }

  [lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__leadText p:last-child {
    font-size: 26px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__content {
  position: relative;
  max-width: 910px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  margin: 40px auto 0
}

[lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content {
  max-width: 960px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content {
    flex-direction: row;
    padding-bottom: 40px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box {
  border: 1px solid #0093d7;
  border-radius: 14px;
  width: 92%;
  padding: 20px 16px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box {
    width: 455px;
    padding: 30px 38px 40px
  }

  [lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box {
    width: 480px;
    min-height: 260px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title {
  color: #002153;
  font-size: 16px;
  font-weight: 700;
  text-align: center
}

[lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title {
  font-size: 17px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title {
    font-size: 20px
  }

  [lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title {
    font-size: 21px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title span {
  color: #0093d7;
  font-size: 24px
}

[lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title span {
  font-size: 26px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title span {
    font-size: 30px
  }

  [lang=en] .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box .title span {
    font-size: 32px
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box p+p {
  margin-top: 12px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box p+p {
    margin-top: 16px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box01 {
    transform: translate3d(10px, 0, 0)
  }
}

.p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box02 {
  transform: translate3d(9%, -6%, 0)
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content01 .p-companyPhilosophy__content .box02 {
    transform: translate3d(-10px, 40px, 0)
  }
}

.p-companyPhilosophy__body .content02 {
  border-top: 1px solid #c8c8c8;
  margin-top: 26px;
  padding-top: 50px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content02 {
    margin-top: 45px;
    padding-top: 85px
  }
}

.p-companyPhilosophy__body .content02 .p-companyPhilosophy__content {
  margin-top: 20px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content02 .p-companyPhilosophy__content {
    margin-top: 35px
  }
}

.p-companyPhilosophy__body .content03 {
  border-top: 1px solid #c8c8c8;
  margin-top: 35px;
  padding-top: 50px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 {
    margin-top: 70px;
    padding-top: 85px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .c-title__03 {
    margin-bottom: 43px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 {
  display: flex;
  align-items: center;
  margin-top: 33px;
  gap: 14px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 {
    margin-top: 40px;
    gap: 20px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 span {
  width: 37px
}

[lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 span {
  width: auto
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 span {
    width: auto
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 i {
  font-size: 14px;
  font-weight: 500;
  width: calc(100% - 51px)
}

[lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 i {
  font-size: 15px;
  width: auto
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .c-title__04 i {
    width: auto
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item {
  display: flex;
  flex-direction: column;
  gap: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item {
    flex-direction: row
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item {
    gap: 24px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl {
  display: flex;
  flex-direction: column;
  background-color: #effaff;
  border-radius: 14px;
  width: 100%;
  padding: 16px;
  gap: 12px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl {
    padding: 24px;
    gap: 16px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt {
  display: flex;
  gap: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt {
    align-items: flex-start
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt {
    gap: 20px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt img {
  background: #0093d7;
  padding: 4px;
  border-radius: 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt img {
    padding: 9px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title {
  display: flex;
  flex-direction: column;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.6
}

[lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title {
  font-size: 19px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title {
    font-size: 17px;
    word-break: break-all
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title {
    font-size: 20px;
    line-height: 1.4
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title .en {
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  color: #77797c;
  margin-top: 10px
}

[lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title .en {
  font-size: 15px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title .en {
    font-size: 15px
  }

  [lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dt .title .en {
    font-size: 16px
  }
}

.p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dd {
  line-height: 1.83
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dd {
    font-size: 17px;
    line-height: 1.74
  }

  [lang=en] .p-companyPhilosophy__body .content03 .p-companyPhilosophy__content-list .list-item dl dd {
    line-height: 1.5
  }
}

.p-companyPhilosophy__foot {
  margin-top: 60px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__foot {
    margin-top: 98px;
    margin-bottom: 100px
  }
}

.p-companyPhilosophy__foot .p-box__gray {
  display: flex;
  flex-direction: column;
  justify-content: space-between
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__foot .p-box__gray {
    flex-direction: row;
    align-items: center
  }
}

.p-companyPhilosophy__foot-text {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 24px
}

[lang=en] .p-companyPhilosophy__foot-text {
  font-size: 15px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__foot-text {
    margin-right: 24px;
    margin-bottom: 0
  }
}

.p-companyPhilosophy__foot-text p+p {
  margin-top: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__foot-text p+p {
    margin-top: 25px
  }
}

.p-companyPhilosophy__foot-text .c-button {
  font-size: 14px;
  min-height: 44px;
  padding-left: 18px;
  padding-right: 14px
}

[lang=en] .p-companyPhilosophy__foot-text .c-button {
  font-size: 15px
}

.p-companyPhilosophy__foot-image {
  max-width: 370px;
  margin: 0 auto;
  transition: all .3s ease
}

@media print,
screen and (min-width: 768px) {
  .p-companyPhilosophy__foot-image {
    width: 370px;
    margin: 0 0 0 auto
  }

  .p-companyPhilosophy__foot-image:hover {
    opacity: .8
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProc #content02 .c-image {
    margin-left: auto;
    margin-right: auto;
    width: 824px
  }
}

.p-companyProc #content03 .c-image+.c-text__note {
  margin-top: 12px
}

.p-companyProc #content03 .c-text__note+p {
  margin-top: 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProc #content03 .c-text__note+p {
    margin-top: 63px
  }
}

.p-companyProfile__column {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 32px;
  margin-bottom: 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfile__column {
    gap: 40px 64px;
    margin-bottom: 104px;
    max-height: 1018px;
    width: calc(100% - 40px)
  }

  [lang=en] .p-companyProfile__column {
    max-height: 1618px
  }
}

@media print {
  [lang=en] .p-companyProfile__column {
    max-height: 1400px
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .p-companyProfile__column {
    max-height: 1358px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfile__columnImage {
    order: 2;
    width: 32.25%;
    max-width: 400px
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-companyProfile__columnImage {
    width: 400px
  }
}

.p-companyProfile__columnImage .c-image {
  margin: auto;
  max-width: 400px
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfile__columnTable {
    order: 1;
    max-width: 776px;
    width: calc(67.75% - 40px)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-companyProfile__columnTable {
    width: 776px
  }
}

.p-companyProfile__columnTable .p-table {
  width: auto
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfile__columnTable .p-table tr td:first-child {
    width: 160px
  }
}

@media print,
screen and (min-width: 768px) {
  [lang=en] .p-companyProfile__columnTable .p-table tr td .post {
    margin-right: 20px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfile__columnThumbnail {
    order: 3;
    max-width: 400px;
    width: 32.25%
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-companyProfile__columnThumbnail {
    width: 400px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-companyProfile__columnThumbnail .p-thumbnail {
    order: 3;
    margin: auto;
    max-width: 240px;
    width: 60%
  }
}

@media print,
screen and (min-width: 768px) {
  .p-companyProfile .l-footer {
    margin-top: 93px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-compliance .c-title__01 {
    margin-bottom: 18px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-compliance #content01 .c-title__02 {
    margin-top: 68px
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-compliance #content01>.p-column__wide {
    justify-content: space-between
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01>.p-column__wide .p-column__itemSmall {
    max-width: 300px;
    width: 24%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01>.p-column__wide .p-column__itemLarge {
    max-width: 815px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01>.p-column__wide .p-column__itemLarge .c-list__number {
    display: flex;
    gap: 9px 14px;
    flex-direction: column;
    flex-wrap: wrap;
    height: 44em;
    min-width: 580px
  }

  [lang=en] .p-compliance #content01>.p-column__wide .p-column__itemLarge .c-list__number {
    height: 60em
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-compliance #content01>.p-column__wide .p-column__itemLarge .c-list__number {
    height: 42em
  }

  [lang=en] .p-compliance #content01>.p-column__wide .p-column__itemLarge .c-list__number {
    height: 46em
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01>.p-column__wide .p-column__itemLarge .c-list__number>li {
    width: 50%
  }
}

.p-compliance #content01>.p-column__wide .p-column__itemLarge .c-list__number>li:nth-child(n+2) {
  margin-top: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01 .p-box__gray>.p-column__wide {
    gap: 0 56px;
    width: 100%
  }
}

.p-compliance #content01 .p-box__gray>.p-column__wide .p-column__item:nth-child(n+2) {
  margin-top: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01 .p-box__gray>.p-column__wide .p-column__item:nth-child(n+2) {
    margin-top: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content01 .p-box__gray>.p-column__wide .p-column__item {
    width: auto
  }
}

.p-compliance #content02 .c-image.u-onlySP img {
  width: 91%
}

.p-compliance #content02 .c-image.u-onlyPC img {
  margin: auto;
  width: 823px
}

[lang=ja] .p-compliance #content02 .c-title__04 {
  margin-top: 48px
}

@media print,
screen and (min-width: 1024px) {
  [lang=ja] .p-compliance #content02 .c-title__04 {
    margin-top: 70px
  }
}

.p-compliance #content02 .u-onlySP .c-title__05 {
  margin-bottom: 5px
}

[lang=ja] .p-compliance #content02 .c-list__number {
  margin-top: 0
}

.p-compliance #content02 .c-list__number>li:nth-child(n+2) {
  margin-top: 7px
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content02 .c-list__number>li:nth-child(n+2) {
    margin-top: 22px
  }
}

.p-compliance #content02 .p-column__wide {
  margin-bottom: 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content02 .p-column__wide {
    gap: 70px;
    margin-top: 66px;
    margin-bottom: 62px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content02 .p-column__wide .p-column__item {
    width: calc((100% - 70px)/ 2)
  }
}

.p-compliance #content02 .p-table {
  max-width: 700px
}

@media print,
screen and (min-width: 768px) {

  .p-compliance #content02 .p-table.p-compliance__tableNumber table tr td:first-child,
  .p-compliance #content02 .p-table.p-compliance__tableNumber table tr th:first-child {
    width: 118px
  }
}

@media print,
screen and (min-width: 768px) {

  .p-compliance #content02 .p-table.p-compliance__tableNumber table tr td:nth-child(n+2):not(:last-child),
  .p-compliance #content02 .p-table.p-compliance__tableNumber table tr th:nth-child(n+2):not(:last-child) {
    width: 140px
  }
}

@media print,
screen and (min-width: 768px) {

  .p-compliance #content02 .p-table.p-compliance__tableNumber table tr td:last-child,
  .p-compliance #content02 .p-table.p-compliance__tableNumber table tr th:last-child {
    padding-right: 40px
  }
}

.p-compliance #content03 .p-table table thead tr th.cell_initiative {
  width: 22%
}

.p-compliance #content03 .p-table table thead tr th.cell_target {
  width: 39%
}

.p-compliance #content03 .p-table table thead tr th.cell_record {
  width: 39%
}

.p-compliance #content03 .p-table table tbody tr th {
  text-align: left;
  vertical-align: top
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content04 .p-column__wide {
    gap: 0 64px;
    margin-bottom: 62px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content04 .p-column__wide .p-column__itemLarge {
    width: calc(100% - 64px - 424px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-compliance #content04 .p-column__wide .p-column__itemSmall {
    width: 424px
  }
}

.p-compliance .p-box__gray {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-compliance .p-box__gray {
    margin-top: 64px
  }
}

.p-compliance>.p-box__gray {
  margin-top: 64px
}

@media print,
screen and (min-width: 768px) {
  .p-compliance>.p-box__gray {
    margin-top: 78px
  }
}

@media print {
  .p-sustainabilityGroupSustainability {
    overflow-y: hidden
  }
}

.p-sustainabilityGroupSustainability .l-footer {
  background: #effaff;
  margin-top: 0
}

.p-sustainabilityGroupSustainability__foot {
  background: #effaff;
  margin-top: 27px;
  padding-top: 64px;
  padding-bottom: 101px;
  transform: translateY(37px)
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityGroupSustainability__foot {
    margin-top: -10px;
    padding-top: 100px;
    padding-bottom: 210px;
    transform: translateY(110px)
  }
}

.p-sustainabilityGroupSustainability__foot .column {
  display: flex;
  flex-direction: column;
  gap: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityGroupSustainability__foot .column {
    flex-direction: row;
    gap: 48px
  }
}

@media print {
  .p-sustainabilityGroupSustainability__foot .column {
    flex-direction: row;
    gap: 24px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityGroupSustainability__foot .column .text-block {
    width: calc(100% - 34.7vw - 48px)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-sustainabilityGroupSustainability__foot .column .text-block {
    width: calc(100% - 500px - 48px)
  }
}

@media print {
  .p-sustainabilityGroupSustainability__foot .column .text-block {
    width: calc(100% - 240px - 24px)
  }
}

.p-sustainabilityGroupSustainability__foot .column .image-block {
  max-width: 500px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityGroupSustainability__foot .column .image-block {
    flex-grow: 1;
    width: 34.7vw
  }
}

@media print {
  .p-sustainabilityGroupSustainability__foot .column .image-block {
    flex-grow: 1;
    width: 240px
  }
}

.p-hamburger {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  background-color: transparent;
  color: inherit;
  cursor: pointer;
  display: inline-block;
  height: 48px;
  margin: auto;
  outline: 0;
  position: relative;
  text-decoration: none;
  transition: all .3s ease-in-out;
  width: 59px
}

@media print,
screen and (min-width: 1024px) {
  .p-hamburger {
    display: none
  }
}

.p-hamburger[aria-expanded=true] .p-hamburger__line {
  background-color: transparent;
  width: 30px
}

.p-hamburger[aria-expanded=true] .p-hamburger__line::after,
.p-hamburger[aria-expanded=true] .p-hamburger__line::before {
  top: 0;
  background-color: #0093d7
}

.p-hamburger[aria-expanded=true] .p-hamburger__line::before {
  transform: rotate(45deg)
}

.p-hamburger[aria-expanded=true] .p-hamburger__line::after {
  transform: rotate(-45deg)
}

.p-hamburger__line {
  background-color: #0093d7;
  border-radius: 1px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 19px;
  height: 2px;
  transition: inherit
}

.p-hamburger__line::after,
.p-hamburger__line::before {
  background-color: inherit;
  border-radius: 1px;
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  transition: inherit
}

.p-hamburger__line::before {
  top: -6px
}

.p-hamburger__line::after {
  top: 6px
}

.p-irAnnouncement__item {
  display: block
}

@media print,
screen and (min-width: 768px) {
  .p-irAnnouncement__item {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start
  }
}

.p-irAnnouncement__item:nth-child(n+2) {
  margin-top: 29px
}

@media print,
screen and (min-width: 768px) {
  .p-irAnnouncement__item:nth-child(n+2) {
    margin-top: 40px
  }
}

.p-irAnnouncement__title {
  font-weight: 500;
  line-height: 22px;
  margin-top: 10px;
  padding-left: 16px;
  position: relative;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: .2s ease all;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-irAnnouncement__title {
    font-size: 20px;
    line-height: 32px;
    padding-left: 24px;
    margin-top: 0;
    margin-left: 0;
    width: calc(100% - 140px)
  }
}

.p-irAnnouncement__title::before {
  background: url(/images/common/icon_arrowRightSmall.svg) no-repeat;
  background-size: contain;
  background-position: center;
  content: "";
  display: block;
  height: 10px;
  left: 0;
  position: absolute;
  top: 6px;
  width: 6px
}

@media print,
screen and (min-width: 768px) {
  .p-irAnnouncement__title::before {
    height: 14px;
    top: 9px;
    width: 8px
  }
}

.p-irAnnouncement__meta {
  align-items: center;
  display: flex;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-irAnnouncement__meta {
    line-height: 32px;
    width: 140px
  }
}

.p-lang {
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  opacity: 1;
  outline: 0;
  padding-left: 11px;
  padding-right: 11px;
  position: relative;
  transition: .2s ease all;
  z-index: 210
}

[lang=en] .p-lang {
  font-size: 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-lang {
    padding-left: 24px;
    padding-right: 0;
    position: absolute;
    right: 0;
    top: 27px
  }
}

.p-lang.is-hide {
  opacity: 0;
  pointer-events: none
}

.p-lang::after {
  background: #c8c8c8;
  bottom: 0;
  content: "";
  display: inline-block;
  height: 36px;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 1px
}

@media print,
screen and (min-width: 1024px) {
  .p-lang::after {
    right: auto;
    left: 0;
    height: 27px
  }
}

.p-lang__button {
  align-items: center;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
  border: 0;
  color: #77797c;
  cursor: pointer;
  display: flex;
  outline: 0;
  padding: 0;
  text-decoration: none;
  transition: .2s ease all
}

.p-lang__button:hover {
  color: #484a4e
}

@media print,
screen and (min-width: 1024px) {
  .p-lang__button:hover .p-lang__active::after {
    background-image: url(/images/common/icon_langHover.svg)
  }
}

.p-lang__button:focus-visible {
  outline: 2px solid #0093d7
}

.p-lang__active {
  align-items: center;
  display: flex
}

.p-lang__active::after {
  background-image: url(/images/common/icon_lang.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  font-size: 13px;
  margin-left: 8px;
  margin-top: 2px;
  height: 14px;
  width: 14px;
  transition: .2s ease all
}

[lang=en] .p-lang__active::after {
  font-size: 14px
}

.p-lang__select {
  background: #fff;
  border: 1px solid #c8c8c8;
  border-radius: 8px;
  display: none;
  left: 16px;
  opacity: 0;
  padding: 10px 16px;
  pointer-events: none;
  position: absolute;
  top: 26px;
  transition: opacity .3s ease
}

.p-lang__select.is-show {
  display: block;
  pointer-events: all;
  opacity: 1
}

.p-lang__select li:nth-child(n+2) {
  margin-top: 10px
}

.p-lang__select li a {
  align-items: center;
  color: #77797c;
  display: flex;
  outline: 0;
  text-decoration: none;
  transition: .2s ease all
}

.p-lang__select li a::after {
  background-image: url(/images/common/icon_blankGray.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  content: "";
  display: inline-block;
  font-size: 13px;
  margin-left: 8px;
  transition: .2s ease all;
  height: 11px;
  width: 11px
}

[lang=en] .p-lang__select li a::after {
  font-size: 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-lang__select li a:hover {
    color: #484a4e
  }
}

.p-lang__select li a:hover::after {
  background-image: url(/images/common/icon_blankGrayHover.svg)
}

.p-lang__select li a:focus-visible {
  outline: 2px solid #0093d7
}

.p-logo {
  opacity: 1;
  transition: all .2s;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-logo:hover {
    opacity: .8
  }
}

.p-logo:focus-visible {
  outline: 2px solid #0093d7
}

.p-mainVisual {
  color: #fff;
  padding-top: 15px;
  padding-bottom: 133px;
  margin-top: -15px
}

@media print {
  .p-mainVisual {
    padding-top: 32px;
    padding-bottom: 80px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual {
    padding-top: 32px;
    padding-bottom: 200px;
    margin-top: -79px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-mainVisual {
    margin-top: -32px
  }
}

.p-mainVisual__company {
  background: url(/images/company/bg_company_SP.jpg) no-repeat 0 0/cover
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual__company {
    background: url(/images/company/bg_company_PC.jpg) no-repeat 0 0/cover
  }
}

.p-mainVisual .inner {
  margin-left: 16px;
  margin-right: 16px;
  padding-top: 0;
  padding-bottom: 0;
  width: calc(100% - 32px)
}

@media print {
  .p-mainVisual .inner {
    padding: 40px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual .inner {
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
    max-width: 1440px;
    width: 100%
  }
}

.p-mainVisual .p-breadcrumb ul li {
  color: #fff
}

.p-mainVisual .p-breadcrumb ul li a {
  color: #fff;
  -webkit-text-decoration: underline 1px #fff;
  text-decoration: underline 1px #fff
}

@media print,
screen and (min-width: 1024px) {
  .p-mainVisual .p-breadcrumb ul li a:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-mainVisual .p-breadcrumb ul li:nth-child(n+2)::before {
  background: url(/images/common/icon_arrowBreadcrumbWhite.svg) no-repeat;
  height: 8px;
  width: 4px
}

.p-mainVisual .c-title__01::before {
  background: #fff
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual .c-title__01 {
    margin-bottom: 86px
  }
}

.p-mainVisual .c-title__01+p {
  margin-top: 43px
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual .c-title__01+p {
    margin-top: 0
  }
}

.p-mainVisual__text--small {
  font-weight: 700;
  line-height: 2.1;
  margin-top: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual__text--small {
    margin-top: 13px
  }
}

.p-mainVisual__text {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.7;
  margin-top: 15px
}

[lang=en] .p-mainVisual__text {
  font-size: 26px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-mainVisual__text {
    font-size: 32px;
    margin-top: 5px
  }

  [lang=en] .p-mainVisual__text {
    font-size: 34px
  }
}

.p-members__box {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 32px;
  border: 1px solid #0093d7;
  border-radius: 24px;
  padding: 40px 16px
}

@media print,
screen and (min-width: 768px) {
  .p-members__box {
    flex-direction: row;
    padding: 32px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-members__box {
    gap: 48px;
    padding: 63px
  }
}

.p-members__image {
  max-width: 150px;
  width: 100%;
  height: auto;
  margin: 0 auto
}

@media print,
screen and (min-width: 768px) {
  .p-members__image {
    max-width: 180px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-members__image {
    max-width: 215px
  }
}

.p-members__title {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.78
}

[lang=en] .p-members__title {
  font-size: 19px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-members__title {
    font-size: 22px;
    line-height: 1.83
  }

  [lang=en] .p-members__title {
    font-size: 24px
  }
}

.p-members__text {
  margin-top: 25px
}

@media print,
screen and (min-width: 768px) {
  .p-members__text {
    margin-top: 32px
  }
}

.p-members__text+p {
  margin-top: 26px
}

@media print,
screen and (min-width: 768px) {
  .p-members__text+p {
    margin-top: 39px
  }
}

.p-members .c-sign__name {
  margin-top: 10px
}

@media print,
screen and (min-width: 768px) {
  .p-members .c-sign__name {
    margin-top: 0
  }
}

.p-nav {
  background: #fff;
  position: fixed;
  right: -100%;
  top: 64px;
  height: calc(100vh - 64px);
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  transition: right .3s ease;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-nav {
    background: 0 0;
    position: relative;
    top: auto;
    right: 0;
    height: auto;
    overflow-y: visible
  }
}

.p-nav.is-show {
  right: 0
}

.p-nav.is-show .p-nav__child.is-show {
  right: 0
}

.p-nav a,
.p-nav button {
  outline: 0
}

.p-nav__foot {
  border-top: 1px solid #c8c8c8;
  margin-top: 30px;
  padding-top: 32px
}

.p-nav__link {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  align-items: center;
  background: 0 0;
  border: none;
  color: #002153;
  display: flex;
  font-size: 18px;
  font-weight: 700;
  justify-content: space-between;
  outline: 0;
  padding: 0;
  width: 100%
}

[lang=en] .p-nav__link {
  font-size: 19px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__link {
    font-size: 16px
  }

  [lang=en] .p-nav__link {
    font-size: 17px
  }
}

.p-nav__link::after {
  background: url(/images/common/icon_arrowRight.svg) no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 20px;
  width: 20px
}

.p-nav__linkParent {
  background: 0 0;
  font-size: 16px;
  transition: all .2s
}

[lang=en] .p-nav__linkParent {
  font-size: 17px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkParent {
    border-radius: 14px 14px 0 0;
    flex-direction: column;
    font-size: 15px;
    line-height: 1;
    transform: translateY(1px);
    padding: 10px 12px;
    position: relative;
    z-index: 200
  }

  [lang=en] .p-nav__linkParent {
    font-size: 16px;
    text-align: center;
    padding: 10px 12px 11px
  }

  .p-nav__linkParent::after,
  .p-nav__linkParent::before {
    display: none
  }

  .p-nav__linkParent .bgLeft,
  .p-nav__linkParent .bgRight {
    background-repeat: no-repeat;
    background-size: contain;
    opacity: 0;
    position: absolute;
    bottom: -3px;
    height: 16px;
    width: 16px;
    z-index: 200;
    transition: opacity .2s
  }

  .p-nav__linkParent .bgLeft {
    background-image: url(/images/common/bg_navLeft.svg);
    left: -13px
  }

  .p-nav__linkParent .bgRight {
    background-image: url(/images/common/bg_navRight.svg);
    right: -13px
  }

  .p-nav__linkParent>span:not([class]) {
    width: 100%
  }

  .p-nav__linkParent>span:not([class])::after {
    background: 0 0;
    border-radius: 50%;
    content: "";
    display: block;
    margin: 8px auto 0;
    height: 8px;
    width: 8px;
    transition: all .2s
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-nav__linkParent {
    padding: 10px 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkParent.is-active {
    background: #fff
  }

  .p-nav__linkParent.is-active .bgLeft,
  .p-nav__linkParent.is-active .bgRight {
    opacity: 1
  }
}

@media print,
screen and (min-width: 1024px) {

  .p-nav__linkParent.is-active span::after,
  .p-nav__linkParent:focus-visible span::after,
  .p-nav__linkParent:hover span::after {
    background: #0093d7
  }
}

.p-nav__linkChild {
  transition: all .3s ease
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkChild {
    display: inline-flex;
    padding-left: 4px;
    width: auto
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkChild::after {
    margin-left: 14px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkChild:hover {
    opacity: .8
  }
}

.p-nav__linkChild:focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__linkPrimaryBold {
  color: #002153;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.45;
  -webkit-text-decoration: underline 1px #002153;
  text-decoration: underline 1px #002153;
  text-underline-offset: 20%;
  transition: .2s ease all
}

[lang=en] .p-nav__linkPrimaryBold {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkPrimaryBold {
    font-size: 14px
  }

  [lang=en] .p-nav__linkPrimaryBold {
    display: inline-block;
    font-size: 15px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkPrimaryBold:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-nav__linkPrimaryBold:focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__linkPrimary {
  color: #002153;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.45;
  transition: .2s ease all
}

[lang=en] .p-nav__linkPrimary {
  font-size: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkPrimary {
    font-size: 13px
  }

  [lang=en] .p-nav__linkPrimary {
    font-size: 14px
  }
}

.p-nav__linkSecondary {
  color: #77797c;
  font-weight: 500;
  line-height: 1;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkSecondary {
    font-size: 13px
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-nav__linkSecondary {
    font-size: 14px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__linkSecondary:hover {
    color: #484a4e
  }
}

.p-nav__linkSecondary:focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__accordionButton {
  align-items: center;
  color: #77797c;
  cursor: pointer;
  display: flex;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.45;
  justify-content: space-between;
  min-height: 22px;
  position: relative;
  transition: all .5s ease;
  padding-right: 20px
}

[lang=en] .p-nav__accordionButton {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__accordionButton {
    font-size: 14px;
    pointer-events: none;
    min-height: 32px
  }

  [lang=en] .p-nav__accordionButton {
    font-size: 15px;
    min-height: 15px;
    line-height: 1.45
  }

  .p-nav__accordionButton:nth-child(n+2) {
    margin-top: 24px
  }
}

.p-nav__accordionButton::after,
.p-nav__accordionButton::before {
  content: "";
  background-color: #002153;
  border: 1px;
  height: 1px;
  position: absolute;
  right: 2px;
  top: 48%;
  transition: transform .5s ease;
  width: 16px
}

@media print,
screen and (min-width: 1024px) {

  .p-nav__accordionButton::after,
  .p-nav__accordionButton::before {
    display: none
  }
}

.p-nav__accordionButton::before {
  transform: rotate(0)
}

.p-nav__accordionButton::after {
  transform: rotate(90deg)
}

.p-nav__accordionButton.close::after {
  transform: rotate(0)
}

.p-nav__accordionButton>a {
  color: inherit;
  pointer-events: none
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__accordionButton>a {
    color: #002153;
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153;
    text-underline-offset: 20%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__accordionButton>a:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-nav__accordionButton>a:focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__accordionBox {
  display: none;
  font-size: 14px;
  margin-left: 16px;
  padding-top: 24px
}

[lang=en] .p-nav__accordionBox {
  font-size: 15px;
  padding-top: 22px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__accordionBox {
    display: block;
    font-size: 13px;
    line-height: 1.46;
    margin: 0;
    padding-top: 10px
  }

  [lang=en] .p-nav__accordionBox {
    font-size: 14px;
    padding-top: 16px !important
  }
}

.p-nav__buttonBack {
  min-height: 36px
}

[lang=en] .p-nav__buttonBack {
  font-size: 15px;
  height: 38px;
  min-height: 38px;
  padding-right: 4px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__buttonBack {
    display: none !important
  }
}

.p-nav__bannerList {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 16px 0;
  justify-content: center
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__bannerList {
    flex-direction: row;
    gap: 22px;
    justify-content: flex-start;
    margin: auto;
    width: 966px
  }
}

.p-nav__bannerList li {
  max-width: 304px;
  width: 100%
}

.p-nav__bannerList li a {
  border: 2px solid transparent;
  border-radius: 10px;
  display: block;
  transition: all .2s ease
}

@media print,
screen and (min-width: 1024px) {

  .p-nav__bannerList li a:focus-visible,
  .p-nav__bannerList li a:hover {
    opacity: .8
  }
}

.p-nav__bannerList li a:focus-visible {
  border: 2px solid #0093d7
}

.p-nav__menuIcon {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__menuIcon {
    display: block
  }
}

.p-nav__menuIcon img {
  width: 100%
}

.p-nav__parentInner {
  padding: 30px 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__parentInner {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    padding: 19px 0 0;
    height: 111px
  }
}

.p-nav__parentInner>.p-nav__head {
  margin-bottom: 29px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__parentInner>.p-nav__head {
    margin-bottom: 0;
    order: 1
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__parentInner>.p-nav__body {
    margin-top: 5px;
    order: 3;
    width: 100%;
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__parentInner>.p-nav__foot {
    border-top: none;
    margin-left: 24px;
    order: 2;
    margin-top: 0;
    padding-right: 130px;
    padding-top: 0
  }
}

.p-nav__parentMainList,
.p-nav__parentSubList {
  display: flex;
  flex-direction: column
}

@media print,
screen and (min-width: 1024px) {

  .p-nav__parentMainList,
  .p-nav__parentSubList {
    flex-direction: row
  }
}

.p-nav__parentMainList {
  gap: 25px
}

[lang=en] .p-nav__parentMainList {
  gap: 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__parentMainList {
    gap: 0;
    justify-content: flex-end;
  }

  [lang=en] .p-nav__parentMainList {
    align-items: end;
    gap: 0
  }
}

.p-nav__parentSubList {
  gap: 23px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__parentSubList {
    gap: 24px;
    transform: translateY(-4px)
  }
}

.p-nav__child {
  background: #fff;
  position: fixed;
  right: -100%;
  top: 64px;
  height: calc(100vh - 120px);
  overflow-y: scroll;
  transition: right .3s;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  z-index: 200
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__child {
    display: none;
    height: auto;
    right: 0;
    top: 110px;
    opacity: 0;
    overflow-y: visible;
    pointer-events: none;
    transition: opacity .2s;
    z-index: -1
  }

  [lang=en] .p-nav__child {
    top: 123px
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .p-nav__child {
    top: 110px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__child.is-show {
    display: block;
    pointer-events: all;
    opacity: 1
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__child.is-show .p-nav__accordionButton>a {
    pointer-events: auto;
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__child.is-show .p-nav__accordionButton>a:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-nav__child.is-show .p-nav__accordionButton>a:focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__childInner {
  padding: 15px 24px 30px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInner {
    display: flex;
    flex-wrap: wrap;
    padding: 34px 0 40px;
    margin: auto;
    min-width: 1000px;
    width: 100%
  }
}

.p-nav__childInner>.p-nav__head {
  margin-bottom: 36px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInner>.p-nav__head {
    flex-shrink: 0;
    margin-bottom: 0;
    margin-top: 6px;
    width: 128px
  }
}

.p-nav__childInner>.p-nav__body {
  padding-left: 16px;
  padding-right: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInner>.p-nav__body {
    padding-left: 0;
    padding-right: 0;
    margin-left: 44px
  }
}

.p-nav__childInner>.p-nav__foot {
  margin-left: 16px;
  margin-right: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInner>.p-nav__foot {
    margin-left: 0;
    margin-right: 0;
    width: 100%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerCompany {
    max-width: 1000px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerCompany>.p-nav__head {
    margin-left: 42px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerCompany>.p-nav__body {
    width: calc(100% - 218px)
  }
}

@media print,
screen and (min-width: 1024px) {

  .p-nav__childInnerProducts,
  .p-nav__childInnerRecruit {
    max-width: 1000px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerRd {
    max-width: 1000px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerRd>.p-nav__head {
    margin-left: 42px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerRd>.p-nav__body {
    width: calc(100% - 218px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerSustainability {
    max-width: 1000px
  }
}

@media print,
screen and (min-width: 1280px) {
  .p-nav__childInnerSustainability {
    max-width: 1197px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerSustainability>.p-nav__body {
    width: calc(100% - 176px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerIr {
    max-width: 1000px
  }
}

@media print,
screen and (min-width: 1280px) {
  .p-nav__childInnerIr {
    max-width: 1102px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childInnerIr>.p-nav__body {
    width: calc(100% - 176px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListWrap {
    overflow-x: hidden;
    overflow-y: auto;
    padding-bottom: 4px;
    padding-left: 4px;
    max-height: calc(100vh - 420px);
    min-height: 100px;
  }

  .p-nav__childListWrap--high {
    max-height: calc(100vh - 280px)
  }

  .p-nav__childListWrap::-webkit-scrollbar {
    width: 5px;
  }

  .p-nav__childListWrap::-webkit-scrollbar-track {
    background-color: #c8c8c8;
  }

  .p-nav__childListWrap::-webkit-scrollbar-thumb {
    background-color: #0093d7;
    border-radius: 3px
  }

  /* FOR Firefox */
  @-moz-document url-prefix() {
    .p-nav__childListWrap {
      scrollbar-width: thin;
      scrollbar-color: #0093d7 #c8c8c8;
    }
  }
}

.p-nav__childList {
  margin-top: 23px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childList {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 6px 22px;
    margin-top: 17px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childList>li {
    min-width: 163px;
    max-width: 193px
  }

  [lang=en] .p-nav__childList>li {
    max-width: 210px
  }
}

.p-nav__childList>li:nth-child(n+2) {
  margin-top: 28px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childList>li:nth-child(n+2) {
    margin-top: 0
  }
}

.p-nav__childList>li a:not([class*=p-nav__linkPrimaryBold]) {
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childList>li a:not([class*=p-nav__linkPrimaryBold]):hover {
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

.p-nav__childList>li a:not([class*=p-nav__linkPrimaryBold]):focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__childList>li .p-nav__accordionBox ul li:not(:last-child) {
  margin-bottom: 20px
}

[lang=en] .p-nav__childList>li .p-nav__accordionBox ul li:not(:last-child) {
  margin-bottom: 17px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childList>li .p-nav__accordionBox ul li:not(:last-child) {
    margin-bottom: 16px
  }

  [lang=en] .p-nav__childList>li .p-nav__accordionBox ul li:not(:last-child) {
    margin-bottom: 14px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListCompany {
    max-height: 240px
  }

  [lang=en] .p-nav__childListCompany {
    max-height: 265px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListProducts>li {
    max-width: 200px
  }

  [lang=en] .p-nav__childListProducts>li {
    max-width: 310px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListRd {
    margin-top: 15px;
    max-height: 100px;
    flex-direction: row;
    gap: 6px 40px
  }

  [lang=en] .p-nav__childListRd {
    max-height: 100%
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-nav__childListRd li {
    width: 210px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability {
    gap: 6px 24px;
    margin-top: 11px;
    max-height: 690px
  }

  [lang=en] .p-nav__childListSustainability {
    max-height: 810px;
    margin-top: 22px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li {
    width: 185px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:nth-child(1) {
    margin-top: -4px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:nth-child(2) {
    margin-top: -4px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:nth-child(3) {
    margin-top: 24px !important
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:nth-child(3) .p-nav__accordionBox {
    padding-top: 14px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:nth-child(4) {
    margin-top: 24px !important
  }
}

@media print,
screen and (min-width: 1280px) {

  .p-nav__childListSustainability>li:nth-child(5),
  .p-nav__childListSustainability>li:nth-child(6),
  .p-nav__childListSustainability>li:nth-child(7) {
    min-height: 520px
  }

  [lang=en] .p-nav__childListSustainability>li:nth-child(5),
  [lang=en] .p-nav__childListSustainability>li:nth-child(6),
  [lang=en] .p-nav__childListSustainability>li:nth-child(7) {
    min-height: 650px
  }
}

@media print,
screen and (max-width: 1279px) {
  .p-nav__childListSustainability>li:nth-child(6) {
    margin-top: 24px !important
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:nth-child(8) {
    margin-top: 12px
  }
}

@media print,
screen and (min-width: 1280px) {
  .p-nav__childListSustainability>li:nth-child(8) {
    margin-top: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListSustainability>li:last-child {
    margin-top: 12px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListIr {
    margin-top: 15px;
    max-height: 570px
  }
}

@media print,
screen and (min-width: 1280px) {
  .p-nav__childListIr {
    max-height: 400px
  }

  [lang=en] .p-nav__childListIr {
    max-height: 420px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListIr>li {
    width: 163px
  }

  [lang=en] .p-nav__childListIr>li {
    width: 183px
  }
}

@media print,
screen and (max-width: 1279px) {
  .p-nav__childListIr>li:nth-child(2) {
    margin-top: 24px !important
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListIr>li:nth-child(4) {
    height: 450px
  }

  [lang=en] .p-nav__childListIr>li:nth-child(4) {
    height: auto;
    margin-bottom: 25%
  }
}

@media print,
screen and (min-width: 1280px) {
  .p-nav__childListIr>li:nth-child(4) {
    height: auto
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListIr>li:nth-child(5) {
    margin-bottom: 25px
  }
}

@media print,
screen and (min-width: 1024px) {

  .p-nav__childListIr>li:nth-child(5),
  .p-nav__childListIr>li:nth-child(6) {
    width: 163px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListIr>li:nth-child(6) {
    border-top: 1px solid #c8c8c8;
    padding-top: 22px
  }
}

@media print,
screen and (min-width: 1024px) {

  [lang=en] .p-nav__childListIr>li:nth-child(5),
  [lang=en] .p-nav__childListIr>li:nth-child(6),
  [lang=en] .p-nav__childListIr>li:nth-child(7),
  [lang=en] .p-nav__childListIr>li:nth-child(8) {
    line-height: 1;
    border-top: none;
    padding-top: 0;
    margin-bottom: 8px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListIr>li .p-nav__accordionBox {
    padding-top: 10px
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-nav__childListIr>li .p-nav__accordionBox ul li:not(:last-child):first-child {
    margin-bottom: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListRecruit {
    flex-direction: row;
    gap: 6px 40px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListRecruit>li {
    min-width: auto !important
  }
}

.p-nav__closeButton {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__closeButton {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: 0 0;
    border: none;
    color: #002153;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
    opacity: 1;
    padding: 0;
    position: absolute;
    top: 43px;
    right: 95px;
    text-align: center;
    transition: .2s ease opacity;
    height: 40px;
    width: 30px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__closeButton:hover {
    opacity: .8
  }
}

.p-nav__closeButton:focus-visible {
  outline: 2px solid #0093d7
}

.p-nav__closeButton::before {
  background-image: url(/images/common/icon_close.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 18px;
  width: 18px
}

.p-nav__search {
  align-items: center;
  background: #f1f1f1;
  border-radius: 24px;
  display: flex;
  justify-content: space-between;
  line-height: 1;
  margin: auto;
  position: relative;
  width: 263px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__search {
    font-size: 12px;
    width: 184px
  }

  [lang=en] .p-nav__search {
    font-size: 13px
  }
}

.p-nav__search .mf_finder_container {
  width: 100%
}

.p-nav__search .mf_finder_searchBox {
  margin-left: 0;
  margin-right: 0
}

.p-nav__search .mf_finder_searchBox_items {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0
}

.p-nav__search .mf_finder_searchBox_query_input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: 0 0;
  border: 1px solid transparent;
  border-radius: 24px;
  font-size: 15px;
  outline: 0;
  height: 48px;
  padding-left: 24px;
  padding-right: 48px;
  width: 100%
}

[lang=en] .p-nav__search .mf_finder_searchBox_query_input {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__search .mf_finder_searchBox_query_input {
    border-radius: 17px;
    font-size: 12px;
    height: 33px;
    padding-left: 16px;
    padding-right: 33px
  }

  [lang=en] .p-nav__search .mf_finder_searchBox_query_input {
    font-size: 13px
  }
}

.p-nav__search .mf_finder_searchBox_query_input::-moz-placeholder {
  color: #a1a4a8;
  font-size: 15px;
  font-weight: 500
}

.p-nav__search .mf_finder_searchBox_query_input:-ms-input-placeholder {
  color: #a1a4a8;
  font-size: 15px;
  font-weight: 500
}

.p-nav__search .mf_finder_searchBox_query_input::placeholder {
  color: #a1a4a8;
  font-size: 15px;
  font-weight: 500
}

[lang=en] .p-nav__search .mf_finder_searchBox_query_input::-moz-placeholder {
  font-size: 16px
}

[lang=en] .p-nav__search .mf_finder_searchBox_query_input:-ms-input-placeholder {
  font-size: 16px
}

[lang=en] .p-nav__search .mf_finder_searchBox_query_input::placeholder {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__search .mf_finder_searchBox_query_input::-moz-placeholder {
    font-size: 12px
  }

  .p-nav__search .mf_finder_searchBox_query_input:-ms-input-placeholder {
    font-size: 12px
  }

  .p-nav__search .mf_finder_searchBox_query_input::placeholder {
    font-size: 12px
  }

  [lang=en] .p-nav__search .mf_finder_searchBox_query_input::-moz-placeholder {
    font-size: 13px
  }

  [lang=en] .p-nav__search .mf_finder_searchBox_query_input:-ms-input-placeholder {
    font-size: 13px
  }

  [lang=en] .p-nav__search .mf_finder_searchBox_query_input::placeholder {
    font-size: 13px
  }
}

.p-nav__search .mf_finder_searchBox_query_input:focus-visible {
  border: 1px solid #0093d7
}

.p-nav__search .mf_finder_searchBox_submit {
  background: url(/images/common/icon_searchBlue.svg) no-repeat;
  background-position: center;
  background-size: 18px;
  cursor: pointer;
  position: absolute;
  right: 0;
  height: 48px;
  width: 57px
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__search .mf_finder_searchBox_submit {
    background-size: 15px;
    border-radius: 0 17px 17px 0;
    height: 33px;
    width: 35px
  }
}

.p-nav__search .mf_finder_searchBox_submit::before {
  display: none
}

.p-nav__search .mf_finder_searchBox_submit:focus-visible {
  border: 1px solid #0093d7
}

.p-nav__search .mf_finder_searchBox_suggest_items {
  border: none !important;
  box-shadow: none;
  background-color: transparent;
  top: calc(100% + 10px);
  z-index: 100000
}

.p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item {
  border: none !important;
  background-color: #f1f1f1;
  text-align: left;
  overflow: hidden
}

.p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:first-child {
  border-radius: 16px 16px 0 0;
  padding-top: 5px
}

@media print,
screen and (min-width: 768px) {
  .p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:first-child {
    border-radius: 24px 24px 0 0
  }
}

.p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:last-child {
  border-radius: 0 0 16px 16px;
  padding-bottom: 5px
}

@media print,
screen and (min-width: 768px) {
  .p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:last-child {
    border-radius: 0 0 24px 24px
  }
}

.p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a {
  color: #002153;
  padding: 10px 15px;
  font-size: 12px;
  transition: .2s ease all;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__search .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a:hover {
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

[lang=en] .p-nav__br {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-nav__br {
    display: block
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .p-nav__br {
    display: none
  }
}

[lang=en] .p-nav__space {
  display: inline
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-nav__space {
    display: none
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .p-nav__space {
    display: inline
  }
}

.p-nav__parentMainItem:nth-child(1) .p-nav__accordionButton {
  pointer-events: none;
}

.p-nav__parentMainItem:nth-child(1) .p-nav__accordionButton::after,
.p-nav__parentMainItem:nth-child(1) .p-nav__accordionButton::before {
  display: none;
}

.p-news__head {
  margin-bottom: 30px;
  margin-top: 30px
}

@media print,
screen and (min-width: 768px) {
  .p-news__head {
    margin-bottom: 64px
  }
}

.p-news__body .p-tab {
  margin-top: 20px
}

@media print,
screen and (min-width: 768px) {
  .p-news__body .p-tab {
    margin-top: 40px
  }
}

.p-news__info {
  margin-top: 60px
}

@media print,
screen and (min-width: 768px) {
  .p-news__info {
    margin-top: 100px
  }
}

.p-news__foot {
  margin-top: 60px
}

@media print,
screen and (min-width: 768px) {
  .p-news__foot {
    margin-top: 100px
  }
}

.p-news__meta {
  align-items: center;
  display: flex;
  gap: 0 24px
}

.p-news__pdfButton {
  text-align: center
}

@media print,
screen and (min-width: 768px) {
  .p-news__pdfButton {
    text-align: right
  }
}

.p-news__noResult {
  align-items: center;
  display: flex;
  height: 170px;
  justify-content: center;
  text-align: center;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-news__noResult {
    height: 430px
  }
}

.p-newsList__item:nth-child(n+2) {
  margin-top: 29px
}

@media print,
screen and (min-width: 768px) {
  .p-newsList__item:nth-child(n+2) {
    margin-top: 40px
  }
}

.p-newsList__item a {
  color: #0093d7;
  word-break: break-all
}

@media print,
screen and (min-width: 1024px) {
  .p-newsList__item a:hover .p-newsList__itemTitle {
    -webkit-text-decoration: underline 1px #0093d7;
    text-decoration: underline 1px #0093d7
  }
}

.p-newsList__item a[href$=".pdf"] .p-newsList__itemTitle::after {
  background-image: url(/images/common/icon_pdf.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  transform: translate(.1em, .1em);
  height: 1em;
  width: 1em
}

.p-newsList__itemTitle {
  font-weight: 500;
  line-height: 22px;
  margin-top: 10px;
  padding-left: 16px;
  position: relative;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: .2s ease all
}

@media print,
screen and (min-width: 768px) {
  .p-newsList__itemTitle {
    font-size: 20px;
    line-height: 1.6;
    margin-top: 10px;
    margin-left: 84px;
    padding-left: 24px
  }

  [lang=en] .p-newsList__itemTitle {
    font-size: 21px;
    line-height: 1.3;
    margin-left: 105px
  }
}

.p-newsList__itemTitle::before {
  background: url(/images/common/icon_arrowRightSmall.svg) no-repeat;
  background-size: contain;
  background-position: center;
  content: "";
  display: block;
  height: 10px;
  left: 0;
  position: absolute;
  top: 6px;
  width: 6px
}

@media print,
screen and (min-width: 768px) {
  .p-newsList__itemTitle::before {
    height: 14px;
    top: 8px;
    width: 8px
  }
}

.p-newsDetail__head .p-news__pdfButton {
  margin-top: 62px
}

@media print,
screen and (min-width: 768px) {
  .p-newsDetail__head .p-news__pdfButton {
    margin-top: 5px
  }
}

.p-newsDetail__body {
  margin-top: 52px
}

@media print,
screen and (min-width: 768px) {
  .p-newsDetail__body {
    margin-top: 60px
  }
}

.p-note {
  border-top: 1px solid #c8c8c8;
  color: #607696;
  padding-top: 20px
}

@media print,
screen and (min-width: 768px) {
  .p-note {
    display: flex;
    padding-top: 16px
  }
}

.p-note__title {
  font-size: 18px;
  font-weight: 700
}

[lang=en] .p-note__title {
  font-size: 19px
}

@media print,
screen and (min-width: 768px) {
  .p-note__title {
    font-size: 16px;
    width: 120px
  }

  [lang=en] .p-note__title {
    font-size: 17px
  }
}

.p-note__description {
  font-size: 13px;
  line-height: 1.85;
  margin-top: 14px
}

[lang=en] .p-note__description {
  font-size: 14px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-note__description {
    font-size: 14px;
    line-height: 1.86;
    margin-top: 0 !important;
    width: calc(100% - 120px)
  }

  [lang=en] .p-note__description {
    font-size: 15px
  }
}

.p-note.-column {
  flex-direction: column;
  gap: 6px
}

.p-note.-column .p-note__description,
.p-note.-column .p-note__title {
  width: auto
}

.p-products #loading {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, .5);
  z-index: 999999
}

.p-productsForm {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm {
    gap: 32px 24px
  }
}

.p-productsForm__box {
  background-color: #effaff;
  border-radius: 24px;
  padding: 24px;
  width: 100%
}

@media print,
screen and (min-width: 768px) {
  .p-productsForm__box {
    padding: 32px 40px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box:first-child {
    max-width: 400px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box:nth-child(2) {
    width: calc(100% - 424px)
  }
}

.p-productsForm__box:last-child {
  padding: 24px 0 0;
  background-color: #fff;
  border-radius: 0;
  border-top: 1px solid #c8c8c8
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box:last-child {
    padding: 32px 0 0
  }
}

.p-productsForm__box-text form {
  position: relative;
  align-items: center;
  background: #fff;
  border-radius: 24px;
  display: flex;
  justify-content: space-between;
  line-height: 1;
  margin: auto;
  width: 100%;
  font-size: 16px;
  color: #607696
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box-text form {
    border-radius: 16px
  }
}

.p-productsForm__box-text form input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid transparent;
  outline: 0
}

.p-productsForm__box-text form input[type=text] {
  background: 0 0;
  border-radius: 24px;
  height: 48px;
  width: 100%;
  height: 56px;
  padding: 16.5px 48px 16.5px 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box-text form input[type=text] {
    border-radius: 17px;
    height: 33px;
    height: auto;
    padding-top: 16.5px;
    padding-bottom: 16.5px;
    padding-right: 74px
  }
}

.p-productsForm__box-text form input[type=text]::-moz-placeholder {
  color: #607696;
  font-size: 14px;
  font-weight: 700
}

.p-productsForm__box-text form input[type=text]:-ms-input-placeholder {
  color: #607696;
  font-size: 14px;
  font-weight: 700
}

.p-productsForm__box-text form input[type=text]::placeholder {
  color: #607696;
  font-size: 14px;
  font-weight: 700
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box-text form input[type=text]::-moz-placeholder {
    font-size: 16px
  }

  .p-productsForm__box-text form input[type=text]:-ms-input-placeholder {
    font-size: 16px
  }

  .p-productsForm__box-text form input[type=text]::placeholder {
    font-size: 16px
  }
}

.p-productsForm__box-text form input[type=text]:focus {
  border: 1px solid #0093d7
}

.p-productsForm__box-text form input[type=submit] {
  background: url(/images/common/icon_searchBgPrimary.svg) no-repeat;
  background-position: center;
  background-size: 34px;
  cursor: pointer;
  position: absolute;
  right: 0;
  height: 48px;
  width: 58px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box-text form input[type=submit] {
    background-size: 34px;
    height: 59px;
    width: 70px;
    padding: 0 16px
  }
}

.p-productsForm__box .mf_finder_searchBox {
  margin-right: 0;
  margin-left: 0
}

.p-productsForm__box .mf_finder_searchBox_items {
  position: relative;
  padding: 0
}

.p-productsForm__box .mf_finder_searchBox_items>button {
  background: url(/images/common/icon_searchBgPrimary.svg) no-repeat;
  background-position: center;
  background-size: 34px;
  cursor: pointer;
  position: absolute;
  right: 0;
  height: 48px;
  width: 57px;
  top: 50%;
  margin: -24px 0 0
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box .mf_finder_searchBox_items>button {
    background-size: 34px;
    height: 59px;
    width: 70px;
    padding: 0 16px;
    margin: -30px 0 0
  }
}

.p-productsForm__box .mf_finder_searchBox_items>button::before {
  display: none
}

.p-productsForm__box .mf_finder_searchBox_items_wrapper {
  width: 100%
}

.p-productsForm__box .mf_finder_searchBox_suggest_items {
  border: none !important;
  box-shadow: none;
  background-color: transparent;
  top: calc(100% + 10px)
}

.p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item {
  border: none !important;
  background-color: #f1f1f1;
  text-align: left;
  overflow: hidden
}

.p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:first-child {
  border-radius: 16px 16px 0 0;
  padding-top: 5px
}

@media print,
screen and (min-width: 768px) {
  .p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:first-child {
    border-radius: 24px 24px 0 0
  }
}

.p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:last-child {
  border-radius: 0 0 16px 16px;
  padding-bottom: 5px
}

@media print,
screen and (min-width: 768px) {
  .p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:last-child {
    border-radius: 0 0 24px 24px
  }
}

.p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a {
  color: #002153;
  padding: 10px 15px;
  font-size: 16px;
  transition: .2s ease all;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__box .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a:hover {
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

.p-productsForm__accordion {
  background-color: #effaff;
  border-radius: 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordion {
    border-radius: 24px
  }
}

.p-productsForm__accordionButton {
  background-color: #effaff;
  padding: 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionButton {
    padding: 32px 40px
  }
}

.p-productsForm__accordionButton::after,
.p-productsForm__accordionButton::before {
  right: 26px
}

@media print,
screen and (min-width: 1024px) {

  .p-productsForm__accordionButton::after,
  .p-productsForm__accordionButton::before {
    right: 40px
  }
}

.p-productsForm__accordionButton .text-block .c-title__04 {
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  margin-bottom: 0;
  padding-right: 20px
}

[lang=en] .p-productsForm__accordionButton .text-block .c-title__04 {
  padding-right: 25px
}

@media print,
screen and (max-width: 1023px) {
  [lang=en] .p-productsForm__accordionButton .text-block .c-title__04 span {
    margin-right: 10px
  }
}

.p-productsForm__accordionButton .text-block .c-title__04 i {
  margin-top: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionButton .text-block .c-title__04 i {
    margin-left: 38px
  }
}

.p-productsForm__accordionBox {
  position: relative;
  padding: 0 24px 33px;
  margin: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox {
    padding: 0 40px 40px;
    transform: translateY(-10px)
  }
}

.p-productsForm__accordionBox .inner {
  display: flex;
  flex-direction: column;
  gap: 28px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner {
    flex-direction: row;
    gap: 20px
  }
}

.p-productsForm__accordionBox .inner .left,
.p-productsForm__accordionBox .inner .right {
  display: flex;
  flex-direction: column;
  gap: 28px
}

@media print,
screen and (min-width: 1024px) {

  .p-productsForm__accordionBox .inner .left,
  .p-productsForm__accordionBox .inner .right {
    gap: 19px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .left {
    width: 35.41vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-productsForm__accordionBox .inner .left {
    width: 550px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .right {
    width: calc(100% - 35.41vw)
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-productsForm__accordionBox .inner .right {
    width: calc(100% - 550px)
  }
}

.p-productsForm__accordionBox .inner .c-checkboxWrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 24px 16px;
  padding-left: 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .c-checkboxWrap {
    gap: 16px 24px
  }
}

.p-productsForm__accordionBox .inner .c-checkboxWrap#individual {
  gap: 28px 16px;
  padding-left: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .c-checkboxWrap#individual {
    gap: 16px 24px
  }
}

.p-productsForm__accordionBox .inner .c-checkboxWrap#individual .c-checkAll {
  margin-left: 0;
  width: auto
}

.p-productsForm__accordionBox .inner .c-checkboxWrap#individual .c-checkAll::after {
  display: none
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox {
  display: flex;
  align-items: center;
  cursor: pointer
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__icon {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  width: 24px;
  height: 24px;
  border: solid 1px rgba(0, 147, 215, .3);
  background: #f1f1f1;
  border-radius: 4px;
  transition: all .1s
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__icon {
    width: 20px;
    height: 20px
  }
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__icon::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  margin: 0 auto;
  width: 15px;
  height: 15px;
  background: url(/images/common/icon_checkWhite.svg) no-repeat center;
  background-size: contain;
  opacity: 0;
  transition: opacity .1s
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__icon::before {
    width: 11px;
    height: 11px
  }
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__label {
  display: block;
  font-size: 15px;
  line-height: 1.6;
  margin-left: 8px
}

[lang=en] .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__label {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__label {
    font-size: 14px;
    line-height: 1.7
  }

  [lang=en] .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox__label {
    font-size: 15px
  }
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox input[type=checkbox] {
  margin: 0;
  width: 0;
  opacity: 0
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox input[type=checkbox]:checked+.c-checkbox__icon {
  border: solid 1px #0093d7;
  background-color: #0093d7
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox input[type=checkbox]:checked+.c-checkbox__icon::before {
  opacity: 1
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox.c-checkAll {
  margin-left: -24px;
  width: 100%
}

.p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox.c-checkAll .c-checkbox__label {
  font-weight: 700
}

@media print,
screen and (min-width: 1024px) {
  .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox.c-checkAll .c-checkbox__label {
    font-size: 16px
  }

  [lang=en] .p-productsForm__accordionBox .inner .c-checkboxWrap .c-checkbox.c-checkAll .c-checkbox__label {
    font-size: 17px
  }
}

.p-productsResult {
  margin-bottom: 48px;
  margin-top: 48px
}

@media print,
screen and (min-width: 768px) {
  .p-productsResult {
    margin-bottom: 100px;
    margin-top: 64px
  }
}

.p-productsResult__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 32px
}

@media print {
  .p-productsResult__list {
    gap: 30px 10px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsResult__list {
    gap: 40px 30px;
    margin-top: 40px
  }
}

.p-productsResult__item {
  border-radius: 14px;
  overflow: hidden;
  width: calc((100% - 10px)/ 2);
  transition: .1s ease all
}

@media print {
  .p-productsResult__item:nth-of-type(9n) {
    page-break-after: always
  }
}

@media print,
screen and (min-width: 768px) {
  .p-productsResult__item {
    width: calc((100% - 20px)/ 3)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsResult__item {
    width: calc((100% - 120px)/ 5)
  }
}

.p-productsResult__item a {
  opacity: 1;
  position: relative;
  transition: opacity .3s ease;
  z-index: 0
}

.p-productsResult__item.not-displayed,
.p-productsResult__item.not-selected {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  .p-productsResult__item:hover a {
    opacity: .8
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsResult__item:hover a .p-productsResult__image img {
    transform: scale(1.15);
    transform-origin: center
  }
}

@-moz-document url-prefix() {
  @media print {
    .p-productsResult__list {
      display: block;
    }

    .p-productsResult__list:after {
      content: "";
      display: block;
      clear: both;
    }

    .p-productsResult__item {
      margin-bottom: 10px;
      margin-right: 10px;
      float: left;
    }

    .p-productsResult__item:nth-of-type(3n) {
      margin-right: 0;
      float: right;
    }

    .p-productsResult__item:nth-of-type(3n+1) {
      clear: both;
    }
  }
}

.p-productsResult__image {
  border: 1px solid #c8c8c8;
  border-bottom: none;
  border-radius: 14px 14px 0 0;
  overflow: hidden;
  z-index: 0
}

.p-productsResult__image img {
  transition: all .3s ease;
  transition-duration: .3s
}

.p-productsResult__text {
  background-color: #0093d7;
  color: #fff;
  height: 100%;
  padding: 12px 20px 10px;
  position: relative;
  word-break: break-all;
  z-index: 1
}

.p-productsResult__text .tagList {
  border-bottom: 1px solid #fff;
  display: flex;
  flex-wrap: wrap;
  font-size: 12px;
  line-height: 1.4;
  padding-bottom: 6px
}

[lang=en] .p-productsResult__text .tagList {
  font-size: 13px;
  line-height: 1.35;
  word-break: break-word
}

.p-productsResult__text .tagList li:not(:last-child)::after {
  content: "、"
}

[lang=en] .p-productsResult__text .tagList li:not(:last-child)::after {
  content: ",";
  margin-right: .3em
}

.p-productsResult__text .tagList+.title {
  margin-top: 8px
}

.p-productsResult__text .title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.44
}

[lang=en] .p-productsResult__text .title {
  font-size: 17px;
  line-height: 1.35;
  word-break: break-word
}

.p-productsResult__nil {
  display: block;
  margin-bottom: 48px;
  margin-top: 48px;
  text-align: center
}

@media print,
screen and (min-width: 768px) {
  .p-productsResult__nil {
    margin-bottom: 150px;
    margin-top: 150px
  }
}

.p-productsResult__nil.-hide {
  display: none
}

.p-productsResult__item.is-selected {
  display: block
}

.p-productsResult__item.is-hide {
  display: none
}

.p-productsResult.-hide {
  display: none
}



.p-products .c-title__04 {
  display: flex;
  flex-flow: column;
  margin-top: 0;
  margin-bottom: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-products .c-title__04 {
    flex-flow: inherit;
    align-items: center;
    margin-bottom: 24px
  }
}

.p-products .c-title__04 i {
  font-size: 15px;
  font-weight: 400;
  display: block;
  margin-top: 18px
}

[lang=en] .p-products .c-title__04 i {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-products .c-title__04 i {
    font-size: 14px;
    line-height: 1.85;
    display: inline-block;
    margin-top: 0;
    margin-left: 30px
  }

  [lang=en] .p-products .c-title__04 i {
    font-size: 15px;
    line-height: 1.5
  }
}

.p-products__anchor {
  align-items: center;
  background: rgba(0, 0, 0, .8);
  border-radius: 50px;
  color: #fff;
  display: inline-flex;
  flex-direction: inherit;
  justify-content: center;
  align-items: center;
  font-family: Jost, sans-serif;
  font-weight: 400;
  line-height: 1.2;
  opacity: 1;
  position: fixed;
  bottom: 32px;
  left: 16px;
  height: 56px;
  width: calc(100% - 137px);
  transition: .2s ease opacity;
  z-index: 50
}

@media print,
screen and (min-width: 768px) {
  .p-products__anchor {
    left: 100px;
    bottom: 70px;
    width: calc(100% - 270px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-products__anchor {
    display: none
  }
}

.p-products__anchor::after {
  background: url(/images/common/icon_arrowTopWhite.svg) no-repeat;
  background-size: contain;
  transform: rotate(180deg);
  content: "";
  display: block;
  height: 15px;
  width: 17.5px;
  margin-left: auto;
  position: absolute;
  right: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-products__anchor::after {
    width: 16px;
    height: 20px
  }
}

.p-products__anchorText {
  margin-left: 24px;
  margin-right: auto
}

.p-products__anchor.-hide {
  opacity: 0;
  pointer-events: none
}

.p-products__lowerLink {
  display: flex;
  flex-flow: column;
  max-width: 1000px;
  background-color: #fff6e5;
  border-radius: 16px;
  padding: 24px;
  margin: 0 auto
}

@media print,
screen and (min-width: 768px) {
  .p-products__lowerLink {
    flex-flow: inherit;
    border-radius: 24px;
    padding: 48px 54px 30px 48px
  }
}

.p-products__lowerLink .text-block p {
  margin-top: 16px
}

.p-products__lowerLink .image-block {
  margin-top: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-products__lowerLink .image-block {
    max-width: 380px;
    margin-top: 0;
    margin-left: 30px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory #film .c-title__02 {
    margin-top: 0
  }
}

.p-productsCategory__anchor {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 24px auto 65px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__anchor {
    flex-direction: row;
    gap: 24px;
    margin: 34px auto 65px
  }
}

@media print {
  .p-productsCategory__anchor {
    flex-direction: row;
    margin: 34px auto 65px
  }
}

.p-productsCategory__anchor li {
  background: #effaff;
  border-radius: 14px;
  max-width: 326px;
  width: 100%
}

@media print,
screen and (max-width: 1023px) {
  [lang=en] .p-productsCategory__anchor li {
    max-width: 400px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__anchor li {
    max-width: 256px
  }
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-productsCategory__anchor li:last-child {
    max-width: 420px
  }
}

.p-productsCategory__anchor li a {
  color: #002153;
  display: flex;
  align-items: center;
  padding: 12px 40px 12px 20px;
  position: relative
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__anchor li a {
    padding: 20px 45px 20px 20px
  }
}

.p-productsCategory__anchor li a .icon {
  margin-right: 18px;
  height: 35px;
  width: 35px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__anchor li a .icon {
    margin-right: 16px;
    height: 40px;
    width: 40px
  }
}

.p-productsCategory__anchor li a .text {
  font-size: 15px;
  font-weight: 500
}

[lang=en] .p-productsCategory__anchor li a .text {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__anchor li a .text {
    font-size: 16px
  }

  [lang=en] .p-productsCategory__anchor li a .text {
    font-size: 17px
  }
}

.p-productsCategory__anchor li a::after {
  background: url(/images/common/icon_arrowDownBlue.svg) no-repeat;
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
  right: 17px;
  height: 20px;
  width: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__anchor li a::after {
    right: 20px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__column {
    display: flex;
    justify-content: space-between;
    gap: 92px 48px
  }
}

.p-productsCategory__column+.p-productsCategory__column {
  margin-top: 48px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__column+.p-productsCategory__column {
    margin-top: 90px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__columnTitle {
    width: 196px
  }
}

.p-productsCategory__columnTitle>.sub-category {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 28px
}

[lang=en] .p-productsCategory__columnTitle>.sub-category {
  font-size: 21px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__columnTitle>.sub-category {
    font-size: 24px;
    margin-bottom: 0
  }

  [lang=en] .p-productsCategory__columnTitle>.sub-category {
    font-size: 26px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__columnContent {
    width: calc(100% - 196px - 48px)
  }
}

.p-productsCategory__cardList {
  display: flex;
  flex-wrap: wrap;
  gap: 32px 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__cardList {
    gap: 72px 48px
  }
}

.p-productsCategory__cardItem {
  width: calc((100% - 24px)/ 2)
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__cardItem {
    width: calc((100% - 96px)/ 3)
  }
}

.p-productsCategory__cardItem .image {
  border-radius: 14px;
  overflow: hidden
}

.p-productsCategory__cardItem .image img {
  display: block;
  width: 100%
}

.p-productsCategory__cardItem .image.-border {
  border: 1px solid #c8c8c8
}

.p-productsCategory__cardItem .name {
  color: #002153;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.46
}

[lang=en] .p-productsCategory__cardItem .name {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__cardItem .name {
    font-size: 18px;
    line-height: 1.44
  }

  [lang=en] .p-productsCategory__cardItem .name {
    font-size: 19px
  }
}

.p-productsCategory__cardItem .caption {
  color: #607696;
  font-size: 13px;
  line-height: 1.46
}

[lang=en] .p-productsCategory__cardItem .caption {
  font-size: 14px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__cardItem .caption {
    font-size: 14px;
    line-height: 1.43
  }

  [lang=en] .p-productsCategory__cardItem .caption {
    font-size: 15px
  }
}

.p-productsCategory__cardItem .link {
  color: #0093d7;
  font-size: 15px;
  line-height: 1.46;
  -webkit-text-decoration: underline #0093d7;
  text-decoration: underline #0093d7;
  text-underline-offset: 20%;
  transition: .2s ease all
}

[lang=en] .p-productsCategory__cardItem .link {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__cardItem .link {
    font-size: 16px;
    line-height: 1.44
  }

  [lang=en] .p-productsCategory__cardItem .link {
    font-size: 17px
  }
}

.p-productsCategory__cardItem .image+.name {
  margin-top: 15px
}

.p-productsCategory__cardItem .caption+.caption,
.p-productsCategory__cardItem .name+.caption {
  margin-top: 9px
}

.p-productsCategory__cardItem .caption+.link {
  margin-top: 13px
}

.p-productsCategory__cardItem--link .image {
  aspect-ratio: 446/292;
  display: block;
  overflow: hidden;
  perspective: 1000px;
  position: relative
}

.p-productsCategory__cardItem--link .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  opacity: 1;
  transition-duration: .3s
}

@media print,
screen and (min-width: 1024px) {
  .p-productsCategory__cardItem--link:hover .image img {
    opacity: .7;
    transform: scale(1.15);
    transform-origin: center
  }

  .p-productsCategory__cardItem--link:hover .link {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-productsMaterials {
  background-image: url(/images/products/materials/bg_materials_01.png), url(/images/products/materials/bg_materials_01.png), url(/images/products/materials/bg_materials_01.png), url(/images/products/materials/bg_materials_01.png);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-position: calc(50% + 129px) 180px, calc(50% - 137px) 610px, calc(50% + 113.5px) 1220px, calc(50% - 210px) 2180px;
  background-size: 152px 152px, 234px 234px, 195px 195px, 460px 460px
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials {
    background-position: calc(50% + 517px) 259px, calc(50% - 510.5px) 599px, calc(50% + 607.5px) 1012px, calc(50% - 498px) 1777px;
    background-size: 182px 182px, 493px 493px, 413px 413px, 806px 806px
  }
}

.p-productsMaterials__body {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto
}

.p-productsMaterials__lead {
  margin-bottom: 0;
  text-align: center
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__lead {
    margin-bottom: 44px
  }
}

.p-productsMaterials__lead p {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.94
}

[lang=en] .p-productsMaterials__lead p {
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__lead p {
    font-size: 30px;
    line-height: 1.83
  }
}

.p-productsMaterials__lead p+p {
  margin-top: 18px
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__lead p+p {
    margin-top: 0
  }
}

.p-productsMaterials__column {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-direction: column;
  flex-wrap: nowrap;
  padding-top: 48px;
  padding-bottom: 0;
  border-top: none
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__column {
    flex-direction: row;
    padding-top: 56px;
    padding-bottom: 56px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__column-rev {
    flex-direction: row-reverse
  }
}

.p-productsMaterials__column+.p-productsMaterials__column {
  border-top: none
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__column+.p-productsMaterials__column {
    border-top: 1px solid #c8c8c8
  }
}

.p-productsMaterials__image {
  width: calc(100% + 32px);
  margin-left: -16px;
  margin-right: -16px
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__image {
    width: 38.5%;
    margin-left: 0;
    margin-right: 0
  }
}

.p-productsMaterials__image a {
  display: block;
  opacity: 1;
  transition: .2s ease all
}

.p-productsMaterials__image img {
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-productsMaterials__image:hover {
    opacity: .8
  }
}

.p-productsMaterials__content {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-direction: column;
  flex-wrap: nowrap;
  width: 100%;
  padding-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__content {
    width: calc(61.5% - 40px);
    padding-top: 0
  }
}

.p-productsMaterials__text .c-title__04 {
  margin-top: 0
}

.p-productsMaterials__text p {
  margin-top: 18px
}

@media print,
screen and (min-width: 768px) {
  .p-productsMaterials__text p {
    margin-top: 24px
  }
}

.p-productsMaterials__button {
  margin-top: 24px
}

.p-rd .p-mainVisual__rd {
  background: url(/images/rd/bg_rd.jpg) no-repeat 0 0/cover
}

@media print,
screen and (min-width: 768px) {
  .p-rd .p-mainVisual__rd {
    padding-bottom: 208px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rd .p-mainVisual .c-title__01 {
    margin-bottom: 96px
  }
}

.p-rd .p-mainVisual .c-title__01+p {
  line-height: 1.95
}

[lang=en] .p-rd .p-mainVisual .c-title__01+p {
  line-height: 1.5
}

.p-rd .l-inner {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-rd .l-inner {
    margin-top: 83px
  }
}

.p-rd .c-imageLink {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-rd .c-imageLink {
    margin-top: 100px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-rd .p-column__M {
    gap: 63px 67px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rd .p-column__item {
    width: calc((100% - 48px)/ 3)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-rd .p-column__item {
    width: calc((100% - 134px)/ 3)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-rd .p-column__item .c-image+.u-fontSize__SS {
    margin-top: 24px
  }
}

.p-rd .p-column__item .u-text__bold {
  margin-top: 7px;
  line-height: 1.5
}

[lang=en] .p-rd .p-column__item .u-text__bold {
  line-height: 1.35
}

.p-rd__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-rd__foot {
    margin-top: 97px
  }
}

.p-rd__foot .p-box__gray {
  display: flex;
  flex-direction: column;
  justify-content: space-between
}

@media print,
screen and (min-width: 768px) {
  .p-rd__foot .p-box__gray {
    flex-direction: row;
    align-items: center
  }
}

.p-rd__foot .p-rd__foot-text .c-title__05 {
  margin-top: 0 !important
}

.p-rd__foot-text {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 24px
}

[lang=en] .p-rd__foot-text {
  font-size: 15px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-rd__foot-text {
    margin-right: 24px;
    margin-bottom: 0
  }
}

.p-rd__foot-image {
  max-width: 310px;
  margin: 0 auto;
  transition: all .3s ease
}

@media print,
screen and (min-width: 768px) {
  .p-rd__foot-image {
    width: 310px;
    margin: 0 0 0 auto
  }

  .p-rd__foot-image:hover {
    opacity: .8
  }
}

.p-rdAwards .p-table.-blockSP thead {
  display: none
}

@media print,
screen and (min-width: 768px) {
  .p-rdAwards .p-table.-blockSP thead {
    display: revert
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rdAwards .p-table.-blockSP thead tr {
    border-top: none !important
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rdAwards .p-table .cell_year {
    width: 120px
  }

  [lang=en] .p-rdAwards .p-table .cell_year {
    width: 160px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rdAwards .p-table .cell_name {
    width: 250px
  }

  [lang=en] .p-rdAwards .p-table .cell_name {
    width: 280px
  }
}

.p-rdAwards__foot {
  margin-top: 64px
}

@media print,
screen and (min-width: 768px) {
  .p-rdAwards__foot {
    margin-top: 100px
  }
}

.p-rdFields__title {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 24px;
  line-height: 1.3;
  text-align: center
}

@media print,
screen and (min-width: 768px) {
  .p-rdFields__title {
    font-size: 32px;
    margin-bottom: 36px
  }
}

.p-rdFields__body .c-list__number {
  margin-top: 40px;
  margin-bottom: 36px
}

.p-rdFields__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-rdFields__foot {
    margin-top: 100px
  }
}

.p-rdTopics__foot .p-box__gray {
  display: flex;
  flex-direction: column;
  justify-content: space-between
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics__foot .p-box__gray {
    flex-direction: row;
    align-items: center
  }
}

.p-rdTopics__foot .p-rd__foot-text .c-title__05 {
  margin-top: 0 !important
}

.p-rdTopics__foot-text {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 24px
}

[lang=en] .p-rdTopics__foot-text {
  font-size: 15px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics__foot-text {
    margin-right: 24px;
    margin-bottom: 0
  }
}

.p-rdTopics__foot-image {
  max-width: 310px;
  margin: 0 auto;
  transition: all .3s ease
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics__foot-image {
    width: 310px;
    margin: 0 0 0 auto
  }

  .p-rdTopics__foot-image:hover {
    opacity: .8
  }
}

.p-rdIntellectual .p-column__item {
  max-width: 90%;
  margin: 0 auto
}

.p-rdIntellectual .c-list__any {
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-rdIntellectual .c-list__any {
    margin-top: 39px
  }
}

.p-rdIntellectual #content06 p:last-child {
  padding-left: 1em;
  text-indent: -1em
}

.p-rdOrganization__body>.c-title__02:first-child {
  margin-top: 0
}

.p-rdOrganization__body .c-imageCenter__M {
  max-width: 780px
}

.p-rdOrganization__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-rdOrganization__foot {
    margin-top: 100px
  }
}

.p-rdPublic .inner {
  display: flex;
  flex-flow: column;
  padding-bottom: 0
}

@media print,
screen and (min-width: 768px) {
  .p-rdPublic .inner {
    flex-flow: row wrap;
    gap: 0 80px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-rdPublic .inner {
    gap: 70px 80px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rdPublic .content__list {
    max-width: 580px;
    width: calc((100% - 80px)/ 2)
  }
}

.p-rdTopics .inner {
  display: flex;
  flex-flow: column;
  padding-bottom: 0
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics .inner {
    flex-flow: row wrap;
    gap: 70px 80px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics .content__list {
    max-width: 580px;
    width: calc((100% - 80px)/ 2)
  }
}

.p-rdTopics .content__list:first-child .c-title__03 {
  margin-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics .content__list .c-title__03 {
    margin-top: 0
  }
}

.p-rdTopics .content__list .c-title__04 {
  margin-top: 0
}

.p-rdTopics .content__list .c-list__discLarge>li {
  font-size: 16px
}

.p-rdTopics .content__list .c-list__discLarge>li p a {
  font-size: 16px
}

.p-rdTopics .content__list .c-list__discLarge>li:nth-child(n+2) {
  margin-top: 5px
}

.p-rdTopics #content01 .c-title__02 {
  margin-top: 49px
}

@media print,
screen and (min-width: 768px) {
  .p-rdTopics #content01 .c-title__02 {
    margin-top: 65px
  }
}

.p-recruit {
  position: relative;
  overflow-x: clip
}

.p-recruit .l-inner {
  position: relative;
  z-index: 1
}

.p-recruit__bg {
  display: flex;
  justify-content: center;
  overflow-x: clip;
  position: absolute;
  top: 0;
  height: 100vh;
  width: 100vw;
  z-index: 0
}

@media print,
screen and (min-width: 768px) {
  .p-recruit__bg {
    width: 100%
  }
}

.p-recruit__bgRect {
  background: radial-gradient(50% 50% at 50% 50%, #87e2ff 0, rgba(185, 221, 255, .5) 57.26%, rgba(255, 255, 255, 0) 97.4%);
  position: absolute;
  top: 0;
  transform: translateX(30%);
  height: 346px;
  width: 346px;
  z-index: 0
}

@media print,
screen and (min-width: 768px) {
  .p-recruit__bgRect {
    transform: translateX(40%);
    height: 854px;
    width: 854px
  }
}

.p-recruit__head {
  width: 100%
}

.p-recruit__lead {
  font-size: 23px;
  font-weight: 700;
  line-height: 1.72;
  margin-top: 30px;
  text-align: center;
  position: relative;
  z-index: 1
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__lead {
    font-size: 48px;
    line-height: 1.67
  }
}

@media print {
  .p-recruit__lead {
    font-size: 28px
  }
}

.p-recruit__leadSP {
  display: block
}

@media print,
screen and (min-width: 1320px) {
  .p-recruit__leadSP {
    display: none
  }
}

.p-recruit__leadSP .c-splitText {
  display: inline-block
}

.p-recruit__leadSP .c-splitText:last-child {
  margin-top: 1em
}

.p-recruit__leadPC {
  display: none
}

@media print,
screen and (min-width: 1320px) {
  .p-recruit__leadPC {
    display: block
  }
}

.p-recruit__body {
  margin-top: 31px
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__body {
    display: flex;
    margin: 0 auto;
    padding-right: 7vw;
    width: 100%;
    max-width: 1440px
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-recruit__body {
    padding-right: 102px
  }
}

@media print {
  .p-recruit__body {
    display: flex;
    margin: 24px auto 0;
    width: 100%
  }
}

.p-recruit__imageBlock {
  height: 273px;
  position: relative;
  margin: auto;
  max-width: 390px;
  width: 100%;
  z-index: 1
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__imageBlock {
    height: 746px;
    margin-top: 30px;
    max-width: none
  }
}

.p-recruit__image {
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  overflow: hidden;
  will-change: transform
}

.p-recruit__image img {
  display: block;
  opacity: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
  will-change: opacity;
  z-index: 0
}

@media print {
  .p-recruit__image img {
    opacity: 1
  }
}

.p-recruit__image img:nth-of-type(1) {
  animation-delay: 0
}

.p-recruit__image img:nth-of-type(2) {
  animation-delay: 4s
}

.p-recruit__image img:nth-of-type(3) {
  animation-delay: 8s
}

.p-recruit__image img:nth-of-type(4) {
  animation-delay: 12s
}

.p-recruit__image img:nth-of-type(5) {
  animation-delay: 16s
}

.p-recruit__image-01 {
  top: -10px;
  left: -16px;
  height: 220px;
  width: 220px;
  transform: translateY(0);
  animation: moveAnime01 9s infinite
}

@keyframes moveAnime01 {
  0% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(5%)
  }

  100% {
    transform: translateY(0)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__image-01 {
    left: -4.87vw;
    max-height: 510px;
    max-width: 510px;
    height: 35.4vw;
    width: 35.4vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-recruit__image-01 {
    left: -70px
  }
}

@media print {
  .p-recruit__image-01 {
    animation: none;
    left: 0
  }
}

.p-recruit__image-01 img {
  animation: changeImgAnime 24s infinite
}

@media print {
  .p-recruit__image-01 img {
    animation: none
  }
}

.p-recruit__image-01 img:nth-of-type(6) {
  animation-delay: 20s
}

.p-recruit__image-02 {
  bottom: 21px;
  right: 29px;
  height: 154px;
  width: 154px;
  transform: translateY(5%);
  animation: moveAnime02 7s infinite
}

@keyframes moveAnime02 {
  0% {
    transform: translateY(5%)
  }

  50% {
    transform: translateY(0)
  }

  100% {
    transform: translateY(5%)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__image-02 {
    top: 31.7vw;
    bottom: auto;
    right: 2.78vw;
    max-height: 300px;
    max-width: 300px;
    height: 20.8vw;
    width: 20.8vw
  }
}

@media print,
screen and (min-width: 1320px) {
  .p-recruit__image-02 {
    top: 457px;
    right: 40px
  }
}

@media print {
  .p-recruit__image-02 {
    animation: none;
    right: 0
  }
}

.p-recruit__image-02 img {
  animation: changeImgAnime 20s infinite
}

@media print {
  .p-recruit__image-02 img {
    animation: none
  }
}

@keyframes changeImgAnime {
  0% {
    opacity: 1
  }

  50% {
    opacity: 1
  }

  60% {
    opacity: 0;
    z-index: 10
  }

  100% {
    opacity: 0
  }
}

.p-recruit__textBlock {
  margin-left: 16px;
  margin-right: 16px;
  position: relative;
  width: calc(100% - 32px);
  z-index: 1
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__textBlock {
    flex-shrink: 0;
    margin: 118px 0 0;
    max-width: 697px;
    width: 48.4vw
  }
}

.p-recruit__text {
  font-size: 16px;
  font-weight: 500;
  line-height: 2.5
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__text {
    font-size: 22px;
    line-height: 2.3
  }
}

@media print {
  .p-recruit__text {
    line-height: 2
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__text .is-low {
    display: block;
    line-height: 1.45;
    margin-bottom: -32px;
    transform: translateY(10px)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__text+.p-recruit__text {
    margin-top: 48px
  }
}

.p-recruit__foot {
  background: #effaff;
  margin-top: 27px;
  overflow: hidden;
  padding: 40px 16px 77px;
  transform: translateY(37px);
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__foot {
    transform: translateY(110px);
    padding: 80px 40px 210px;
    margin-top: -40px
  }
}

@media print {
  .p-recruit__foot {
    transform: translateY(0);
    padding: 30px 16px
  }
}

.p-recruit__banner {
  position: relative
}

.p-recruit__banner a[target=_blank] .p-recruit__bannerLabel::after {
  background-image: url(/images/common/icon_blankWhite.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  transform: translate(0, 3px);
  margin-left: 10px;
  height: 20px;
  width: 20px
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__banner a[target=_blank] .p-recruit__bannerLabel::after {
    background-image: url(/images/common/icon_blank.svg);
    margin-left: 14px;
    transform: translate(0, 4px);
    height: 22px;
    width: 22px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__banner a:hover .p-recruit__bannerImagePC {
    opacity: .8
  }
}

.p-recruit__bannerImage {
  opacity: 1
}

.p-recruit__bannerImageSP {
  display: block
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__bannerImageSP {
    display: none
  }
}

.p-recruit__bannerImagePC {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__bannerImagePC {
    display: block;
    transition: .4s ease opacity
  }
}

.p-recruit__bannerLabel {
  color: #fff;
  display: flex;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.45;
  position: absolute;
  right: 18px;
  bottom: 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-recruit__bannerLabel {
    color: #002153;
    font-size: 20px;
    position: relative;
    right: auto;
    bottom: 0;
    margin-top: 13px
  }
}

.p-recruit .l-footer {
  background: #effaff;
  margin-top: 0
}

.p-search {
  overflow-x: revert
}

.p-search .sec {
  max-width: 100%
}

.p-search .searchBox .mf_finder_searchBox {
  margin-right: 0;
  margin-left: 0
}

.p-search .searchBox .mf_finder_searchBox_items {
  position: relative;
  background-color: #f1f1f1;
  border-radius: 100px;
  padding: 0
}

.p-search .searchBox .mf_finder_searchBox_items_wrapper {
  margin-top: 32px;
  margin-bottom: 18px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_items_wrapper {
    margin-top: 0;
    margin-bottom: 40px
  }
}

.p-search .searchBox .mf_finder_searchBox_items>div input {
  color: #002153;
  font-weight: 700;
  font-size: 15px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid transparent;
  outline: 0;
  background: 0 0;
  border-radius: 100px;
  height: 48px;
  padding-left: 22px;
  padding-right: 60px;
  width: 100%
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_items>div input {
  font-size: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_items>div input {
    font-size: 18px;
    padding-left: 24px
  }

  [lang=en] .p-search .searchBox .mf_finder_searchBox_items>div input {
    font-size: 19px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchBox .mf_finder_searchBox_items>div input {
    height: 64px;
    padding-left: 40px;
    padding-right: 105px
  }
}

.p-search .searchBox .mf_finder_searchBox_items>div input::-moz-placeholder {
  color: #a1a4a8;
  font-weight: 500
}

.p-search .searchBox .mf_finder_searchBox_items>div input:-ms-input-placeholder {
  color: #a1a4a8;
  font-weight: 500
}

.p-search .searchBox .mf_finder_searchBox_items>div input::placeholder {
  color: #a1a4a8;
  font-weight: 500
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchBox .mf_finder_searchBox_items>div input::-moz-placeholder {
    font-size: 18px
  }

  .p-search .searchBox .mf_finder_searchBox_items>div input:-ms-input-placeholder {
    font-size: 18px
  }

  .p-search .searchBox .mf_finder_searchBox_items>div input::placeholder {
    font-size: 18px
  }

  [lang=en] .p-search .searchBox .mf_finder_searchBox_items>div input::-moz-placeholder {
    font-size: 19px
  }

  [lang=en] .p-search .searchBox .mf_finder_searchBox_items>div input:-ms-input-placeholder {
    font-size: 19px
  }

  [lang=en] .p-search .searchBox .mf_finder_searchBox_items>div input::placeholder {
    font-size: 19px
  }
}

.p-search .searchBox .mf_finder_searchBox_items>div input:focus {
  border: 1px solid #0093d7
}

.p-search .searchBox .mf_finder_searchBox_items>button {
  background: url(/images/common/icon_searchBlue.svg) no-repeat;
  background-position: center;
  background-size: 18px;
  cursor: pointer;
  position: absolute;
  right: 0;
  box-sizing: content-box;
  outline: 0;
  display: inline-block;
  width: 20px;
  height: 48px;
  padding: 0 20px;
  margin: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchBox .mf_finder_searchBox_items>button {
    background-size: 25px;
    width: 25px;
    height: 64px;
    padding: 0 40px
  }
}

.p-search .searchBox .mf_finder_searchBox_items>button::before {
  display: none
}

.p-search .searchBox .mf_finder_searchBox_links {
  display: flex;
  flex-wrap: wrap;
  gap: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_links {
    gap: 24px 38px
  }
}

.p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] {
  align-items: center;
  gap: 9px 7px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] {
    gap: 16px
  }
}

.p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links]:before {
  font-size: 11px;
  line-height: 1;
  letter-spacing: .1em;
  color: #77797c;
  display: inline-block;
  position: static;
  vertical-align: middle;
  white-space: nowrap;
  width: 100%
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links]:before {
  font-size: 12px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links]:before {
    font-size: 13px;
    width: auto
  }

  [lang=en] .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links]:before {
    font-size: 14px
  }
}

.p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] div {
  vertical-align: middle;
  line-height: 1;
  margin: 0
}

.p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] div a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  line-height: 1;
  color: #fff;
  background-color: #77797c;
  border: 1px solid #77797c;
  border-radius: 100px;
  height: 44px;
  padding: 0 17px;
  transition: .2s ease all
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] div a {
  font-size: 15px
}

.p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] div a.mf_finder_searchBox_link_current {
  color: #002153;
  background-color: #fff;
  border: 1px solid #002153
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] div a.mf_finder_searchBox_link_current:hover {
    opacity: 1
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchBox .mf_finder_searchBox_links [class^=mf_finder_searchBox_][class$=_links] div a:hover {
    opacity: .8
  }
}

.p-search .searchBox .mf_finder_searchBox_links .mf_finder_searchBox_category_links:before {
  content: "カテゴリ："
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_links .mf_finder_searchBox_category_links:before {
  content: "Category"
}

.p-search .searchBox .mf_finder_searchBox_links .mf_finder_searchBox_pagemax_links:before {
  content: "表示件数："
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_links .mf_finder_searchBox_pagemax_links:before {
  content: "RESULT PER PAGE:"
}

.p-search .searchBox .mf_finder_searchBox_links .mf_finder_searchBox_imgsize_links:before {
  content: "画像サイズ："
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_links .mf_finder_searchBox_imgsize_links:before {
  content: "THUMBNAIL SIZE:"
}

.p-search .searchBox .mf_finder_searchBox_category {
  width: 100%;
  padding: 0;
  border-bottom: none
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_category {
  display: none
}

.p-search .searchBox .mf_finder_searchBox_category_links {
  padding-left: 0
}

.p-search .searchBox .mf_finder_searchBox_category_links div {
  display: none
}

[lang=ja] .p-search .searchBox .mf_finder_searchBox_category_links div.mf_finder_searchBox_category_link_0,
[lang=ja] .p-search .searchBox .mf_finder_searchBox_category_links div.mf_finder_searchBox_category_link_1,
[lang=ja] .p-search .searchBox .mf_finder_searchBox_category_links div.mf_finder_searchBox_category_link_2,
[lang=ja] .p-search .searchBox .mf_finder_searchBox_category_links div.mf_finder_searchBox_category_link_3,
[lang=ja] .p-search .searchBox .mf_finder_searchBox_category_links div.mf_finder_searchBox_category_link_4 {
  display: inline-block
}

.p-search .searchBox .mf_finder_searchBox_category_links div a {
  font-size: 13px !important;
  letter-spacing: .1em;
  margin-bottom: 0
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_category_links div a {
  font-size: 14px
}

.p-search .searchBox .mf_finder_searchBox_imgsize {
  display: none
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_imgsize {
    display: inline-block
  }
}

.p-search .searchBox .mf_finder_searchBox_imgsize,
.p-search .searchBox .mf_finder_searchBox_pagemax {
  border-bottom: none;
  padding: 0;
  margin-right: 0
}

@media print,
screen and (min-width: 768px) {

  .p-search .searchBox .mf_finder_searchBox_imgsize,
  .p-search .searchBox .mf_finder_searchBox_pagemax {
    display: inline-block
  }
}

.p-search .searchBox .mf_finder_searchBox_imgsize_links,
.p-search .searchBox .mf_finder_searchBox_pagemax_links {
  padding-left: 0
}

.p-search .searchBox .mf_finder_searchBox_imgsize_links div,
.p-search .searchBox .mf_finder_searchBox_pagemax_links div {
  display: inline-block
}

.p-search .searchBox .mf_finder_searchBox_suggest_items {
  border: none !important;
  box-shadow: none;
  background-color: transparent;
  top: calc(100% + 10px)
}

.p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item {
  border: none !important;
  background-color: #f1f1f1;
  text-align: left;
  overflow: hidden
}

.p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:first-child {
  border-radius: 16px 16px 0 0;
  padding-top: 5px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:first-child {
    border-radius: 24px 24px 0 0
  }
}

.p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:last-child {
  border-radius: 0 0 16px 16px;
  padding-bottom: 5px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item:last-child {
    border-radius: 0 0 24px 24px
  }
}

.p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a {
  color: #002153;
  padding: 10px 15px;
  font-size: 15px;
  transition: .2s ease all;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent
}

[lang=en] .p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a {
  font-size: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a {
    padding: 5px 15px;
    font-size: 18px
  }

  [lang=en] .p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a {
    font-size: 19px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchBox .mf_finder_searchBox_suggest_items .mf_finder_searchBox_suggest_item a:hover {
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

.p-search .searchResult {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_imgsize_0 .mf_finder_organic_doc_contents_wrapper {
    margin-left: 0 !important
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk {
  margin: 0 !important
}

.p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk .mf_finder_msk_item {
  font-size: 18px
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk .mf_finder_msk_item {
  font-size: 19px
}

[lang=ja] .p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk .mf_finder_msk_item::after {
  content: "のことでしょうか？"
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk .mf_finder_msk_item::after {
  content: "?"
}

.p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk .mf_finder_msk_item .router-link-active {
  color: #0093d7;
  font-weight: 700;
  -webkit-text-decoration: underline 1px #0093d7;
  text-decoration: underline 1px #0093d7;
  text-underline-offset: 20%;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_msk_wrapper .mf_finder_msk .mf_finder_msk_item .router-link-active:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_header {
  display: flex;
  flex-wrap: wrap;
  line-height: 1.7
}

@media print,
screen and (min-width: 768px) {
  [lang=ja] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header {
    flex-direction: row-reverse;
    flex-wrap: wrap-reverse;
    justify-content: flex-end
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder] span,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::after,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::before {
  font-size: 15px;
  color: #002153
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder] span,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::after,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::before {
  font-size: 16px
}

@media print,
screen and (min-width: 768px) {

  .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder] span,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::after,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::before {
    font-size: 18px
  }

  [lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder] span,
  [lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::after,
  [lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder]::before {
    font-size: 19px
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_header [class*=mf_finder] span {
  font-weight: 700
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_header_wrapper {
  margin-right: 0;
  margin-left: 0;
  margin-bottom: 22px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_header_wrapper {
    margin-bottom: 0
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_nums .mf_finder_organic_range {
  margin-top: 0
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_nums .mf_finder_organic_range_from,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_nums .mf_finder_organic_range_to {
  font-weight: 400 !important
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_nums .mf_finder_organic_total {
  float: none;
  margin-top: 0
}

.p-search .searchResult .mf_finder_organic .mf_finder_query {
  word-break: break-all
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_query {
  margin: 0 !important
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs {
  margin-top: 10px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs {
    margin-top: 20px
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs>div:first-child {
  border-top: 1px solid #0093d7
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs>div:last-child {
  border-bottom: none
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc {
  border-bottom: 1px solid #0093d7;
  padding: 18px 0 28px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc {
    padding: 20px 0 40px
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_zoom {
  display: none
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_img {
  margin-top: 10px;
  margin-bottom: 10px
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_img_wrapper {
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_img_wrapper:hover {
    opacity: .8
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_img_wrapper.mf_gui_img_frame {
  display: none
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_img_wrapper.mf_gui_img_frame {
    display: block
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents {
  display: flex;
  flex-direction: column;
  word-break: break-all;
  word-wrap: break-word
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link {
  font-size: 0;
  text-decoration: none;
  margin: 0
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child {
  order: 1
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child .mf_finder_organic_doc_title {
  display: inline-block;
  font-size: 16px;
  font-weight: 400;
  color: #0093d7;
  margin-bottom: 5px;
  transition: .2s ease all;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child .mf_finder_organic_doc_title {
  font-size: 17px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child .mf_finder_organic_doc_title {
    font-size: 18px;
    margin-top: 8px;
    margin-bottom: 0
  }

  [lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child .mf_finder_organic_doc_title {
    font-size: 19px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child .mf_finder_organic_doc_title {
    text-underline-offset: 20%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:first-child .mf_finder_organic_doc_title:hover {
    -webkit-text-decoration: underline 1px #0093d7;
    text-decoration: underline 1px #0093d7
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child {
  order: 2
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url {
  font-size: 13px;
  font-weight: 400;
  color: #77797c;
  transition: .2s ease all;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  margin-top: 0
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url {
  font-size: 14px
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url {
    font-size: 14px
  }

  [lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url {
    font-size: 15px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url {
    text-underline-offset: 20%
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url::before {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents .mf_finder_link:last-child .mf_finder_organic_doc_url:hover {
    -webkit-text-decoration: underline 1px #77797c;
    text-decoration: underline 1px #77797c
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents div {
  order: 3
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents div .mf_finder_organic_doc_body {
  font-size: 13px;
  line-height: 1.8;
  color: #002153;
  height: auto;
  max-height: 7em;
  letter-spacing: .1em;
  overflow: hidden;
  margin-top: 10px
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents div .mf_finder_organic_doc_body {
  font-size: 14px;
  line-height: 1.5;
  max-height: 6em
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents div .mf_finder_organic_doc_body {
    font-size: 14px;
    max-height: 5em;
    margin-top: 15px
  }

  [lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents div .mf_finder_organic_doc_body {
    font-size: 15px;
    max-height: 4.4em
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents_wrapper {
  margin-left: 0
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_docs .mf_finder_organic_doc_contents_wrapper {
    margin-left: 38px
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_mark {
  background-color: #fff960;
  color: #002153
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager {
  margin-top: 0;
  margin-bottom: 40px
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_items {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: auto;
  width: 100%;
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_items {
    gap: 16px
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_items li {
  font-weight: 400;
  min-width: auto;
  width: 44px;
  height: 44px;
  margin-left: 0;
  margin-right: 0;
  position: relative;
  top: 0;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_items li:hover {
    opacity: .8
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_after_pages a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_before_pages a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_current,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  line-height: 1;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background-color: #77797c;
  border: 1px solid #77797c;
  border-radius: 100px;
  width: 100%;
  height: 44px;
  padding: 0
}

[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_after_pages a,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_before_pages a,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_current,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a,
[lang=en] .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a {
  font-size: 15px
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_current,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a {
  color: #002153;
  background-color: #fff;
  border: 1px solid #002153
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev {
  width: 44px !important
}

@media print,
screen and (min-width: 576px) {

  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev {
    width: 54px !important
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a {
  width: 44px
}

@media print,
screen and (min-width: 576px) {

  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a,
  .p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a {
    width: 54px
  }
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a span,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a span,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a span,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a span {
  position: relative;
  font-size: 0;
  width: 22px;
  height: 15px
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first a span::before,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last a span::before,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next a span::before,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev a span::before {
  content: "";
  background: url(/images/common/icon_arrowPageMost.svg) no-repeat center;
  background-size: contain;
  display: block;
  width: 22px;
  height: 15px;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  margin: 0 auto
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first span,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last span {
  width: 22px
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_first span::before,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last span::before {
  background: url(/images/common/icon_arrowPageMost.svg) no-repeat center
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev {
  position: relative
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next span,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev span {
  width: 18px !important
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_next span::before,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev span::before {
  background: url(/images/common/icon_arrowRight.svg) no-repeat center !important
}

.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_last span::before,
.p-search .searchResult .mf_finder_organic .mf_finder_organic_pager .mf_finder_pager_item_prev span::before {
  transform: scale(-1, 1) translateY(-50%) !important
}

.p-search .searchResult .mf_finder_logo {
  font-size: 0;
  text-align: right
}

.p-search .searchResult .mf_finder_logo a {
  width: 270px;
  height: 24px;
  background-size: 270px 24px;
  margin-bottom: 0;
  background-position: 62px 50%;
  transition: .2s ease all
}

@media print,
screen and (min-width: 768px) {
  .p-search .searchResult .mf_finder_logo a {
    background-position: 50px 50%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-search .searchResult .mf_finder_logo a:hover {
    opacity: .8
  }
}

.p-search__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-search__foot {
    margin-top: 100px
  }
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords {
  padding: 40px;
  background: #f1f1f1
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_head {
  padding: 0;
  margin-bottom: 10px
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_head::before {
  color: #002153;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.44;
  letter-spacing: normal;
  margin-bottom: 15px
}

[lang=en] .p-search__foot.relatedKeyword .mf_finder_relatedkeywords_head::before {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-search__foot.relatedKeyword .mf_finder_relatedkeywords_head::before {
    font-size: 20px;
    margin-bottom: 20px
  }

  [lang=en] .p-search__foot.relatedKeyword .mf_finder_relatedkeywords_head::before {
    font-size: 21px
  }
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 9px 16px;
  margin-left: 0
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li {
  margin-right: 0;
  margin-bottom: 0;
  display: flex
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li a {
  font-size: 16px;
  line-height: 1.875;
  color: #0093d7;
  background: 0 0;
  position: relative;
  -webkit-text-decoration: underline 1px #0093d7;
  text-decoration: underline 1px #0093d7;
  transition: .2s ease all;
  word-break: break-all;
  padding: 0
}

[lang=en] .p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li a {
  font-size: 17px;
  line-height: 1.5
}

@media print,
screen and (min-width: 1024px) {
  .p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li a {
    text-underline-offset: 20%
  }
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li a:hover {
  background: 0 0
}

@media print,
screen and (min-width: 1024px) {
  .p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li a:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-search__foot.relatedKeyword .mf_finder_relatedkeywords_items li a span::before {
  display: none
}

.p-sitemap__body {
  margin-top: 32px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__body {
    margin-top: 0
  }
}

.p-sitemap__foot {
  margin-top: 63px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__foot {
    margin-top: 100px
  }
}

.p-sitemap__innerBiofund .p-sitemap__childList,
.p-sitemap__innerProducts .p-sitemap__childList,
.p-sitemap__innerRd .p-sitemap__childList,
.p-sitemap__innerRecruit .p-sitemap__childList,
.p-sitemap__innerSupport .p-sitemap__childList {
  gap: 22px
}

@media print,
screen and (min-width: 768px) {

  .p-sitemap__innerBiofund .p-sitemap__childList,
  .p-sitemap__innerProducts .p-sitemap__childList,
  .p-sitemap__innerRd .p-sitemap__childList,
  .p-sitemap__innerRecruit .p-sitemap__childList,
  .p-sitemap__innerSupport .p-sitemap__childList {
    gap: 16px 64px
  }
}

.p-sitemap__parentMainItem {
  margin-top: 24px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__parentMainItem {
    margin-top: 64px
  }
}

.p-sitemap__parentMainItem:first-child {
  margin-top: 0
}

.p-sitemap__parentSubList {
  display: flex;
  flex-flow: column wrap;
  gap: 22px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__parentSubList {
    flex-flow: inherit;
    gap: 48px
  }
}

.p-sitemap__parentSubItem {
  font-size: 16px;
  line-height: 1
}

[lang=en] .p-sitemap__parentSubItem {
  font-size: 17px
}

.p-sitemap__parentSubItem a {
  color: #002153;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: .2s ease all
}

@media print,
screen and (min-width: 1024px) {
  .p-sitemap__parentSubItem a:hover {
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

.p-sitemap__menuIcon {
  width: 55px;
  height: 55px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__menuIcon {
    width: 72px;
    height: 72px
  }
}

.p-sitemap__listHead {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid #c8c8c8
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__listHead {
    gap: 24px;
    padding-bottom: 15px
  }
}

.p-sitemap__listBody {
  color: #002153;
  margin-top: 29px;
  margin-left: 19px;
  margin-right: 19px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__listBody {
    margin-top: 43px;
    margin-left: 0;
    margin-right: 0
  }
}

.p-sitemap__childList {
  display: flex;
  flex-flow: column;
  gap: 42px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__childList {
    max-width: 1000px;
    flex-flow: row wrap;
    gap: 58px 64px;
    margin: 0 auto
  }
}

.p-sitemap__childList>li {
  display: flex;
  flex-flow: column;
  gap: 20px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__childList>li {
    width: calc((100% - 192px)/ 4)
  }

  [lang=en] .p-sitemap__childList>li {
    width: calc((100% - 128px)/ 3)
  }
}

.p-sitemap__childList-title {
  font-size: 16px;
  font-weight: 700;
  color: #77797c
}

[lang=en] .p-sitemap__childList-title {
  font-size: 17px
}

.p-sitemap__childList-item ul {
  display: flex;
  flex-flow: column;
  gap: 22px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__childList-item ul {
    gap: 13px
  }
}

.p-sitemap__childList-item ul li {
  font-size: 16px;
  line-height: 1.55
}

[lang=en] .p-sitemap__childList-item ul li {
  font-size: 17px;
  line-height: 1.35
}

.p-sitemap__linkPrimaryBold {
  color: #002153;
  font-size: 16px;
  font-weight: 700;
  -webkit-text-decoration: underline 1px #002153;
  text-decoration: underline 1px #002153;
  text-underline-offset: 20%;
  transition: .2s ease all
}

[lang=en] .p-sitemap__linkPrimaryBold {
  font-size: 17px
}

@media print,
screen and (min-width: 1024px) {
  .p-sitemap__linkPrimaryBold:hover {
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__linkPrimaryBold.-ListTitle {
    display: block;
    margin-bottom: 9px
  }
}

.p-sitemap__linkPrimary {
  color: #002153;
  font-size: 16px;
  line-height: 1.55;
  -webkit-text-decoration: underline 1px transparent;
  text-decoration: underline 1px transparent;
  text-underline-offset: 20%;
  transition: .2s ease all
}

[lang=en] .p-sitemap__linkPrimary {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-sitemap__linkPrimary:hover {
    -webkit-text-decoration: underline 1px #002153;
    text-decoration: underline 1px #002153
  }
}

.p-sitemap__link {
  color: #002153;
  font-size: 18px;
  font-weight: 700;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  align-items: center;
  background: 0 0;
  border: none;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  outline: 0;
  padding-right: 20px;
  width: calc(100% - 71px)
}

[lang=en] .p-sitemap__link {
  font-size: 19px
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__link {
    font-size: 20px;
    justify-content: flex-start;
    width: auto;
    padding-right: 0
  }

  [lang=en] .p-sitemap__link {
    font-size: 21px
  }
}

.p-sitemap__link::after {
  background: url(/images/common/icon_arrowRight.svg) no-repeat;
  background-size: contain;
  content: "";
  height: 16px;
  width: 16px;
  flex-shrink: 0
}

.p-sitemap__link.-noLink::after {
  display: none
}

.p-sitemap .icon_blankPrimary {
  padding-right: 10px
}

.p-sitemap .icon_blankPrimary::after {
  background-image: url(/images/common/icon_blank.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  transform: translate(0, .3em);
  height: 22px;
  width: 22px
}

.p-sustainability .inner {
  margin-left: 16px;
  margin-right: 16px;
  padding-top: 63px;
  padding-bottom: 63px;
  width: calc(100% - 34px)
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .inner {
    margin: 0 auto;
    max-width: 1440px;
    width: 100%;
    padding: 100px
  }
}

.p-sustainability .inner .c-title__02 {
  margin-top: 0
}

.p-sustainability .p-mainVisual {
  background: url(/images/sustainability/bg_sustainability.jpg) no-repeat 0 0/cover
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .p-mainVisual {
    padding-bottom: 165px
  }
}

.p-sustainability .p-mainVisual .inner {
  padding-top: 0;
  padding-bottom: 0
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .p-mainVisual__text--small {
    font-size: 24px
  }

  [lang=en] .p-sustainability .p-mainVisual__text--small {
    font-size: 26px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .p-mainVisual__text {
    margin-top: 10px;
    line-height: 1.9
  }

  [lang=en] .p-sustainability .p-mainVisual__text {
    line-height: 1.5
  }
}

.p-sustainability .c-list__discLarge {
  gap: 6px
}

.p-sustainability .c-list__discLarge li {
  font-size: 16px
}

[lang=en] .p-sustainability .c-list__discLarge li {
  font-size: 17px
}

.p-sustainability .content01 .inner {
  padding-top: 0
}

.p-sustainability .content01 .inner .banner {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content01 .inner .banner {
    margin-top: 80px
  }
}

.p-sustainability .content01 .inner .banner img {
  width: 100%
}

.p-sustainability .content01 .inner .c-imageLink {
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content01 .inner .c-imageLink {
    margin-top: 63px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainability .content01 .inner .c-imageLink {
    gap: 48px 80px;
    margin-top: 100px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content01 .inner .c-imageLink li {
    gap: 24px;
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainability .content01 .inner .c-imageLink li {
    width: calc((100% - 80px)/ 2)
  }
}

.p-sustainability .content01 .inner .c-imageLink__item {
  aspect-ratio: 580/257
}

.p-sustainability .content01 .inner .c-imageLink__relevance li {
  width: 100%
}

.p-sustainability .content01 .inner .c-imageLink__relevance li a {
  max-width: 100%;
  margin-top: 0
}

@media print {
  .p-sustainability .content01 .inner .c-imageLink__relevance {
    margin-top: 100px
  }
}

.p-sustainability .content02 {
  background: #effaff
}

.p-sustainability .content02__list {
  display: flex;
  flex-direction: column;
  gap: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content02__list {
    flex-direction: row;
    flex-wrap: wrap
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainability .content02__list {
    gap: 65px
  }
}

@media print {
  .p-sustainability .content02__list {
    flex-direction: row;
    flex-wrap: wrap
  }
}

.p-sustainability .content02__list li {
  background: #fff;
  border-radius: 14px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content02__list li {
    width: calc((100% - 40px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainability .content02__list li {
    width: calc((100% - 130px)/ 3)
  }
}

.p-sustainability .content02__list li img {
  overflow: hidden;
  border-radius: 14px 14px 0 0;
  width: 100%
}

.p-sustainability .content02__list li ul {
  padding: 32px
}

.p-sustainability .content02__list li ul li {
  width: 100%
}

.p-sustainability .content03 .inner {
  padding-bottom: 0
}

.p-sustainability .content03 .c-buttonList {
  flex-flow: column
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content03 .c-buttonList {
    flex-flow: wrap;
    justify-content: flex-start
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainability .content03 .c-buttonList {
    justify-content: center
  }
}

.p-sustainability .content03 .c-buttonList .c-button__large {
  font-size: 16px;
  font-weight: 500;
  padding: 16px 20px 16px 24px
}

[lang=en] .p-sustainability .content03 .c-buttonList .c-button__large {
  font-size: 17px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-sustainability .content03 .c-buttonList .c-button__large {
    min-height: 60px
  }
}

.p-sustainabilityBusinessIssues__table+.p-sustainabilityBusinessIssues__table {
  margin-top: 10px
}

.p-sustainabilityBusinessIssues__table table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 8px;
}

.p-sustainabilityBusinessIssues__table table thead th {
  margin-bottom: 20px;
  background: #0093d7;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.75;
  padding: 10px 16px;
  text-align: left
}

@media print {
  .p-sustainabilityBusinessIssues__table table thead th {
    display: table-cell;
  }
}

.p-sustainabilityBusinessIssues__table table thead th.blank {
  background: #fff;
}

.p-sustainabilityBusinessIssues__table table tbody th.title {
  border: 1px solid #c8c8c8;
  color: #002153;
}

.p-sustainabilityBusinessIssues__table table tbody td ul li span.highlight {
  color: #008ae0;
}

.mt60 {
  margin-top: 60px !important;
}

@-moz-document url-prefix() {
  .pbb-always {
    page-break-before: always !important;
  }
}

[lang=en] .p-sustainabilityBusinessIssues__table table thead th {
  font-size: 17px;
  line-height: 1.5
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table thead th {
    display: table-cell;
    border-right: 8px solid #fff;
    font-size: 20px;
    line-height: 2;
    text-align: center
  }

  [lang=en] .p-sustainabilityBusinessIssues__table table thead th {
    font-size: 21px;
    line-height: 1.5
  }
}

@media print {
  .p-sustainabilityBusinessIssues__table table thead th {
    text-align: center
  }
}

.p-sustainabilityBusinessIssues__table table thead::after {
  content: "";
  height: 8px;
  width: 100%;
  display: block
}

.p-sustainabilityBusinessIssues__table table tbody tr th {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.6;
  padding: 19px 16px
}

.p-sustainabilityBusinessIssues__table table tbody tr th .cell_inner {
  color: #fff;
}

.p-sustainabilityBusinessIssues__table table tbody tr th span.normal {
  font-weight: 400;
}

@media print {
  .p-sustainabilityBusinessIssues__table table tbody tr th span.normal {
    word-break: break-all !important;
    display: block;
    width: 100px;
    height: 100px;
  }
}

[lang=en] .p-sustainabilityBusinessIssues__table table tbody tr th {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr th {
    display: table-cell;
    font-size: 18px;
    line-height: 1.33;
    text-align: left;
    height: 90px;
    max-width: 15%;
    min-width: 15%;
    width: 15%;
  }

  [lang=en] .p-sustainabilityBusinessIssues__table table tbody tr th {
    font-size: 19px
  }
}

@media print {
  .p-sustainabilityBusinessIssues__table table tbody tr th {
    font-size: 15px;
    max-width: 100px;
    min-width: 100px;
    width: 100px
  }
}

.p-sustainabilityBusinessIssues__table table tbody tr th .cell_inner {
  align-items: center;
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-sustainabilityBusinessIssues__table table tbody tr th .cell_inner {
    padding-right: 14px
  }
}

.p-sustainabilityBusinessIssues__table table tbody tr th .cell_inner::before {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  flex-shrink: 0;
  left: 0;
  height: 30px;
  width: 30px;
  margin: 0 auto;
  margin-bottom: 10px;
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr th .cell_inner::before {
    height: 40px;
    width: 40px;
    margin: 0 auto;
    margin-bottom: 10px;
  }
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_healthcare {
  background: #1479a2
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_healthcare .cell_inner::before {
  background-image: url(/images/sustainability/common/icon_healthcare_path.svg)
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_smartCommunity {
  background: #d7720f
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_smartCommunity .cell_inner::before {
  background-image: url(/images/sustainability/common/icon_smart_community_path.svg)
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_decarbonizedSociety {
  background: #7467a5
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_decarbonizedSociety .cell_inner::before {
  background-image: url(/images/sustainability/common/icon_decarbonized_society_path.svg)
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_goodEnvironment {
  background: #0f8254
}

.p-sustainabilityBusinessIssues__table table tbody tr th.cell_goodEnvironment .cell_inner::before {
  background-image: url(/images/sustainability/common/icon_good_environment_path.svg)
}

.p-sustainabilityBusinessIssues__table table tbody tr td {
  font-size: 15px;
  line-height: 1.73;
  padding: 18px 16px 17px
}

[lang=en] .p-sustainabilityBusinessIssues__table table tbody tr td {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr td {
    display: table-cell;
    font-size: 16px;
    line-height: 1.54;
    padding: 17px 10px;
    max-width: 300px;
  }

  .p-sustainabilityBusinessIssues__table table tbody tr td.-w27per {
    width: 27%;
  }

  .p-sustainabilityBusinessIssues__table table tbody tr td.-w43per {
    width: 43%;
  }

  [lang=en] .p-sustainabilityBusinessIssues__table table tbody tr td {
    font-size: 17px;
    line-height: 1.35
  }
}

@media print {
  .p-sustainabilityBusinessIssues__table table tbody tr td {
    font-size: 15px;
  }

  .p-sustainabilityBusinessIssues__table table tbody tr td.row03 {
    max-width: 250px;
    width: 15.8vw
  }

  .p-sustainabilityBusinessIssues__table table tbody tr td.row04 {
    max-width: 350px;
    width: 25.8vw
  }
}

.p-sustainabilityBusinessIssues__table table tbody tr td.cell_normal {
  line-height: 1.5
}

[lang=en] .p-sustainabilityBusinessIssues__table table tbody tr td.cell_normal {
  line-height: 1.35
}

.p-sustainabilityBusinessIssues__table table tbody tr td:nth-of-type(n+2) {
  border-left: 1px dashed #c8c8c8
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr td:nth-of-type(n+1) {
    border-top: none;
  }
}

.p-sustainabilityBusinessIssues__table table tbody tr td b {
  color: #0093d7;
  font-size: 20px;
  font-weight: 400
}

[lang=en] .p-sustainabilityBusinessIssues__table table tbody tr td b {
  font-size: 21px
}

/* @media print,
screen and (min-width: 1024px) {
	.p-sustainabilityBusinessIssues__table table tbody tr:first-child th {
		border-bottom: 8px solid #fff
	}
} */

/* @media print,
screen and (min-width: 1024px) {
	.p-sustainabilityBusinessIssues__table table tbody tr:nth-child(n+2) th {
		border-top: 8px solid #fff
	}
} */

.p-sustainabilityBusinessIssues__table table tbody tr:nth-child(n+2) td {
  border-top: 1px dashed #c8c8c8
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr:nth-child(n+2) td {
    border-top: 1px dashed #c8c8c8
  }
}

.p-sustainabilityBusinessIssues__table table tbody tr.row_smartCommunity td.cell_normal {
  padding: 20px 16px 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr.row_smartCommunity td.cell_normal {
    padding: 19px 10px 10px
  }
}

#ancr02 ul.subTitle {
  margin: 0 30px;
}

.p-sustainabilityBusinessIssues__table table tbody tr.row_decarbonizedSociety td.cell_normal {
  padding: 20px 16px 23px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table table tbody tr.row_decarbonizedSociety td.cell_normal {
    padding: 5px 10px 10px
  }
}

@media print {
  .p-sustainabilityBusinessIssues__table table tbody tr.row_decarbonizedSociety {
    page-break-before: always
  }
}

.p-sustainabilityBusinessIssues__thumbnail {
  margin: 40px auto 0
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__thumbnail {
    margin: 62px auto 0 0;
    width: 675px
  }
}

.p-sustainabilityBusinessIssues__thumbnail .p-thumbnail {
  max-width: 100% !important;
  width: 100%
}

.p-sustainabilityBusinessIssues__thumbnail .p-thumbnail__image {
  max-width: 500px
}

.p-sustainabilityBusinessIssues #ancr02 .c-list__note {
  margin-top: 10px
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityBusinessIssues #ancr02 .c-imageCenter__L {
    margin-top: 40px
  }

  #ancr02 h3.title {
    color: #0070c0;
  }
}

.p-sustainabilityBusinessIssues #ancr03 .u-fontSize__M+.u-fontSize__S {
  margin-top: 6px
}

/* p-sustainabilityEditorial */

.p-sustainabilityEditorial .cardHeader .inner .content {
  gap: 30px;
}

.p-sustainabilityEditorial .cardHeader .box.-common .image-wrap {
  width: 150px;
}

.p-sustainabilityEditorial .cardHeader .inner .contentsL {
  font-size: 16px;
}

.p-sustainabilityEditorial .image-wrap {
  position: relative;
}

.p-sustainabilityEditorial .comingSoon {
  position: absolute;
  top: 40px;
  left: 16px;
  padding: 0 5px;
  background: #fff;
  border: 1px solid #c8c8c8;
  font-weight: 700;
}

.p-sustainabilityEditorial__figure {
  display: flex;
  position: relative;
  width: 200%
}

.p-sustainabilityEditorial__figure .card {
  display: flex;
  flex-direction: column;
  width: 50%
}

.p-sustainabilityEditorial__figure .card .head {
  background: #0093d7;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 72px;
  padding: 16px;
  text-align: center
}

[lang=en] .p-sustainabilityEditorial__figure .card .head {
  line-height: 1.4;
  min-height: 88px
}

.p-sustainabilityEditorial__figure .card .head .title {
  color: #fff;
  font-size: 20px;
  font-weight: 700
}

.p-sustainabilityEditorial__figure .card .body {
  background: #f6f6f6;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 16px
}

.p-sustainabilityEditorial__figure .sub-title {
  font-size: 18px;
  font-weight: 700
}

.p-sustainabilityEditorial__figure .page-name {
  font-size: 16px;
  font-weight: 700
}

.p-sustainabilityEditorial__figure p+.page-name {
  margin-top: 1em
}

.p-sustainabilityEditorial__figure .box {
  padding: 16px
}

.p-sustainabilityEditorial__figure .headerBox {
  background: #fff;
}

.p-sustainabilityEditorial__figure .box p.underLine {
  padding-bottom: 20px;
  border-bottom: 2px solid #939393;
}

.p-sustainabilityEditorial__figure .box:nth-child(n+2) {
  flex-grow: 1;
  margin-top: 16px
}

.p-sustainabilityEditorial__figure .box.-common {
  position: relative;
  width: 200%;
  text-align: center;
  z-index: 1
}

.p-sustainabilityEditorial__figure .box.-common .image-wrap {
  width: 100px
}

.p-sustainabilityEditorial__figure .box.-common .image-wrap img {
  border: 1px solid #c8c8c8
}

.p-sustainabilityEditorial__figure .box.-common .text-wrap {
  width: 100%;
}

.p-sustainabilityEditorial__figure .box.-common.-hide {
  opacity: 0;
  pointer-events: none
}

@media print,
screen and (min-width:484px) {
  .p-sustainabilityEditorial .cardHeader .inner .content {
    gap: 30px;
  }

  .p-sustainabilityEditorial .cardHeader .box.-common .image-wrap {
    width: 200px;
  }

  .p-sustainabilityEditorial .comingSoon {
    top: 55px;
    left: 35px;
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEditorial .cardHeader .inner .contentsL {
    font-size: 17px;
  }

  .p-sustainabilityEditorial__figure {
    overflow-x: visible;
    width: 100%
  }

  .p-sustainabilityEditorial__figure .card .head {
    min-height: 88px
  }

  [lang=en] .p-sustainabilityEditorial__figure .card .head {
    min-height: 94px
  }

  .p-sustainabilityEditorial__figure .card .head .title {
    font-size: 22px
  }

  .p-sustainabilityEditorial__figure .sub-title {
    font-size: 20px
  }

  .p-sustainabilityEditorial__figure .page-name {
    font-size: 18px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEditorial .cardHeader .inner .content {
    gap: 100px;
  }

  .p-sustainabilityEditorial .cardHeader .box.-common .image-wrap {
    width: 300px;
  }

  .p-sustainabilityEditorial .comingSoon {
    top: 90px;
    left: 85px;
  }

  .p-sustainabilityEditorial__figure .card .head .title {
    white-space: nowrap
  }
}

.cardHeader {
  position: relative;
  width: 200%;
  padding: 16px;
  background: #f6f6f6;
  text-align: center;
  z-index: 1;
}

@media print,
screen and (min-width: 768px) {
  .cardHeader {
    width: 100%;
  }
}

.cardHeader .circleL {
  position: absolute;
  top: 16px;
  left: 30px;
  width: 298px;
  height: 298px;
  background: #fff;
  border: 1px solid #fff;
  border-top-left-radius: 50%;
  border-bottom-left-radius: 50%;
  z-index: -1;
}

.cardHeader .circleR {
  position: absolute;
  top: 16px;
  right: 30px;
  width: 298px;
  height: 298px;
  background: #fff;
  border: 1px solid #fff;
  border-top-right-radius: 50%;
  border-bottom-right-radius: 50%;
  z-index: -1;
}

.cardHeader .sub-title {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 700
}

@media print,
screen and (min-width: 768px) {
  .cardHeader .sub-title {
    font-size: 20px
  }
}

.cardHeader .inner {
  display: inline-block;
  width: 90%;
  min-height: 298px;
  padding: 16px 100px;
  background: #fff;
  border: 1px solid #fff;
  border-radius: 298px;
  text-align: center;
}

.cardHeader .inner .content {
  display: flex;
  gap: 100px;
}

.cardHeader .inner .contentsL {
  width: 400px;
  font-size: 17px;
  text-align: left;
}

.cardHeader .inner .contentsR {
  width: 400px;
}

.cardHeader .box.-common .image-wrap {
  width: 300px;
}

.cardHeader .box.-common .image-wrap img {
  border: 1px solid #c8c8c8
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEnvironment .c-title__02.-purple {
    margin-top: 100px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEnvironment .c-title__02.-green {
    margin-top: 166px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEnvironment .c-title__04 {
    margin-top: 65px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEnvironment .c-vision {
    margin-top: 36px
  }
}

.p-sustainabilityEnvironment .c-vision__label b {
  color: #7467a5
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEnvironment .p-column__M-02+p {
    margin-top: 65px
  }
}

@media print {
  .p-sustainabilityEnvironment .p-column__M-02 {
    flex-direction: row;
    gap: 24px
  }
}

@media print {
  .p-sustainabilityEnvironment .p-column__M-02 .p-column__item {
    width: calc((100% - 24px)/ 2)
  }
}

@media print {
  .p-sustainabilityEnvironment .p-column__M-02 .p-column__item:nth-of-type(4n) {
    page-break-after: always
  }
}

.p-sustainabilityEnvironmentCirculation__mission {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 24px;
  margin: auto;
  max-width: 1000px;
  width: 100%
}

@media print {
  .p-sustainabilityEnvironmentCirculation__mission {
    flex-direction: row;
    gap: 0 12px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__mission {
    flex-direction: row;
    gap: 0 41px
  }
}

.p-sustainabilityEnvironmentCirculation__mission .c-title__05 {
  width: 100%
}

@media print {
  .p-sustainabilityEnvironmentCirculation__mission .item {
    width: calc((100% - 24px)/ 3)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__mission .item {
    max-width: 306px;
    width: calc((100% - 82px)/ 3)
  }
}

.p-sustainabilityEnvironmentCirculation__mission .card {
  align-items: center;
  border: 2px solid #0093d7;
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  font-size: 15px;
  height: 90px;
  justify-content: center;
  line-height: 1;
  width: 100%
}

[lang=en] .p-sustainabilityEnvironmentCirculation__mission .card {
  font-size: 16px;
  line-height: 1.45;
  text-align: center;
  padding: 0 20px
}

@media print {
  .p-sustainabilityEnvironmentCirculation__mission .card {
    padding: 12px;
    line-height: 1.4
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__mission .card {
    font-size: 18px;
    height: 116px
  }

  [lang=en] .p-sustainabilityEnvironmentCirculation__mission .card {
    font-size: 19px
  }
}

.p-sustainabilityEnvironmentCirculation__mission .c-list__note {
  margin-top: 14px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__mission .c-list__note {
    margin-top: 4px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative {
  margin-top: 32px
}

@media print {
  .p-sustainabilityEnvironmentCirculation__initiative {
    display: flex;
    flex-wrap: wrap;
    gap: 12px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative {
    display: flex;
    flex-wrap: wrap;
    gap: 66px;
    margin-top: 64px
  }
}

@media print {
  .p-sustainabilityEnvironmentCirculation__initiative .item-wrap {
    width: calc((100% - 24px)/ 2)
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item-wrap {
    max-width: 587px;
    width: calc((100% - 66px)/ 2)
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item {
  width: 100%
}

@media print {
  .p-sustainabilityEnvironmentCirculation__initiative .item:nth-child(n+2) {
    margin-top: 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item:nth-child(n+2) {
    margin-top: 65px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-orange .parent-head {
  background: #dda656
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-orange .parent-body {
  background: #fcf5ec
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item.-orange .child-inner:nth-child(n+2) {
    border-left-color: #dda656
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-orange .child-head {
  background: #eed4ae
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .item.-orange .child-head {
    min-height: 135px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-green .parent-head {
  background: #37754f
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-green .parent-body {
  background: #f2faf5
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item.-green .child-inner:nth-child(n+2) {
    border-left-color: #37754f
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-green .child-head {
  background: #cee1d5
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .item.-green:nth-of-type(3) .child-head {
    min-height: 135px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-blue .parent-head {
  background: #3977b3
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-blue .parent-body {
  background: #f0f6fc
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item.-blue .child-inner:nth-child(n+2) {
    border-left-color: #3977b3
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-blue .child-head {
  background: #bfd6ed
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-lightGreen .parent-head {
  background: #7faa3d
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-lightGreen .parent-body {
  background: #f6fcee
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item.-lightGreen .child-inner:nth-child(n+2) {
    border-left-color: #7faa3d
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-lightGreen .child-head {
  background: #deebca
}

@media print,
screen and (min-width: 1024px) {
  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .item.-lightGreen .child-head {
    min-height: 135px
  }
}

@media print,
screen and (max-width: 1023px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item.-gray {
    margin-bottom: 12px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-gray .parent-head {
  background: #898989
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-gray .parent-body {
  background: #f4f4f4
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .item.-gray .child-inner:nth-child(n+2) {
    border-left-color: #898989
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .item.-gray .child-head {
  background: #d3d3d3
}

.p-sustainabilityEnvironmentCirculation__initiative .parent-head {
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  padding: 16px;
  text-align: center
}

[lang=en] .p-sustainabilityEnvironmentCirculation__initiative .parent-head {
  font-size: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .parent-head {
    font-size: 20px
  }

  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .parent-head {
    font-size: 17px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .parent-content {
  font-size: 14px;
  padding: 16px 24px
}

[lang=en] .p-sustainabilityEnvironmentCirculation__initiative .parent-content {
  font-size: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .parent-content {
    font-size: 18px
  }

  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .parent-content {
    font-size: 17px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .parent-content h5 {
  font-size: 14px;
  margin-top: 8px
}

[lang=en] .p-sustainabilityEnvironmentCirculation__initiative .parent-content h5 {
  font-size: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .parent-content h5 {
    font-size: 16px;
    margin-top: 10px
  }

  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .parent-content h5 {
    font-size: 17px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .child-wrap.-flex {
    display: flex
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .child-wrap.-flex .child-inner {
    width: 50%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .child-wrap.-flex .child-inner:nth-child(n+2) {
    border-left-style: solid;
    border-left-width: 1px
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .child-head {
  font-size: 14px;
  font-weight: 700;
  padding: 16px;
  text-align: center
}

[lang=en] .p-sustainabilityEnvironmentCirculation__initiative .child-head {
  font-size: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .child-head {
    font-size: 16px
  }

  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .child-head {
    font-size: 17px;
    display: flex;
    justify-content: center;
    align-items: center
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .child-head {
    min-height: auto
  }
}

.p-sustainabilityEnvironmentCirculation__initiative .child-content {
  padding: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentCirculation__initiative .child-content {
    font-size: 14px
  }

  [lang=en] .p-sustainabilityEnvironmentCirculation__initiative .child-content {
    font-size: 15px
  }
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table {
  margin: auto;
  max-width: 1000px;
  width: 100%
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table thead tr th {
  background: #e1e6e8;
  display: block;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  padding: 19px 0
}

[lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table thead tr th {
  font-size: 17px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentProducts__table.-valuationBasis table thead tr th {
    font-size: 20px
  }

  [lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table thead tr th {
    font-size: 21px
  }
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table thead::after {
  content: "";
  height: 8px;
  width: 100%;
  display: block
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody {
    display: flex;
    justify-content: space-between;
    width: 100%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr {
    width: calc((100% - 32px)/ 5);
    max-width: 193px
  }
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr td,
.p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr th {
  display: block
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr th {
  background: #71bf44;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  padding: 21px 0 20px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr th {
    font-size: 18px;
    padding: 18px 0 19px
  }

  [lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr th {
    font-size: 16px;
    min-height: 90px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 21px 5px 20px
  }
}

@media print,
screen and (min-width: 1320px) {
  [lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr th {
    min-height: 75px
  }
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr td {
  font-size: 18px;
  line-height: 1;
  padding: 20px 0;
  text-align: center
}

[lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr td {
  font-size: 19px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr td {
    padding: 16px 0 25px
  }
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr td .number {
  font-size: 32px
}

[lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tbody tr td .number {
  font-size: 34px
}

.p-sustainabilityEnvironmentProducts__table.-valuationBasis table tfoot tr td {
  display: block;
  font-size: 13px;
  line-height: 1.85
}

[lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tfoot tr td {
  font-size: 14px;
  line-height: 1.5
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tfoot tr td {
    display: table-cell;
    font-size: 14px;
    text-align: right
  }

  [lang=en] .p-sustainabilityEnvironmentProducts__table.-valuationBasis table tfoot tr td {
    font-size: 15px
  }
}

.p-sustainabilityEnvironmentProducts .c-title__05 .display_ib {
  display: inline-block;
}

.p-sustainabilityGroupSustainabilityVision__figure01 {
  margin: 32px auto 0;
  max-width: 1000px;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 {
    display: flex;
    align-items: center;
    height: 152px
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .title {
  font-size: 22px;
  font-weight: 700;
  text-align: center
}

[lang=en] .p-sustainabilityGroupSustainabilityVision__figure01 .title {
  font-size: 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .title {
    font-size: 28px
  }

  [lang=en] .p-sustainabilityGroupSustainabilityVision__figure01 .title {
    font-size: 26px
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .text {
  font-size: 15px
}

[lang=en] .p-sustainabilityGroupSustainabilityVision__figure01 .text {
  font-size: 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .text {
    font-size: 18px
  }

  [lang=en] .p-sustainabilityGroupSustainabilityVision__figure01 .text {
    line-height: 1.25
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .after,
.p-sustainabilityGroupSustainabilityVision__figure01 .before,
.p-sustainabilityGroupSustainabilityVision__figure01 .inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center
}

.p-sustainabilityGroupSustainabilityVision__figure01 .before {
  background: #effaff;
  padding: 30px 20px 24px;
  position: relative
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .before {
    padding: 0;
    height: 152px;
    width: 460px
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .before::after {
  border-style: solid;
  border-width: 16px 19.5px 0;
  border-color: #effaff transparent transparent;
  content: "";
  position: absolute;
  bottom: -16px;
  height: 0;
  width: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .before::after {
    border-width: 76px 0 76px 40px;
    border-color: transparent transparent transparent #effaff;
    top: auto;
    right: -40px;
    bottom: auto
  }
}

@media print {
  .p-sustainabilityGroupSustainabilityVision__figure01 .before::after {
    border-width: 78px 0 78px 41px;
    right: -39px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .before .inner {
    transform: translate(20px, -4px)
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .before .text {
  margin-top: 10px;
  text-align: center
}

.p-sustainabilityGroupSustainabilityVision__figure01 .after {
  background: #0093d7;
  padding: 30px 20px 25px 22px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .after {
    padding: 0;
    height: 152px;
    width: 540px
  }

  [lang=en] .p-sustainabilityGroupSustainabilityVision__figure01 .after {
    width: 610px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .after .inner {
    transform: translate(20px, -1px)
  }
}

@media print {
  .p-sustainabilityGroupSustainabilityVision__figure01 .after .inner {
    padding: 0 32px
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .after .text,
.p-sustainabilityGroupSustainabilityVision__figure01 .after .title {
  color: #fff
}

.p-sustainabilityGroupSustainabilityVision__figure01 .after .text {
  margin-top: 10px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .after .text {
    margin-top: 4px
  }
}

.p-sustainabilityGroupSustainabilityVision__figure01 .after .text .c-list__disc {
  line-height: 1.33
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision__figure01 .after .text .c-list__disc {
    font-size: 16px;
    line-height: 1.25
  }

  [lang=en] .p-sustainabilityGroupSustainabilityVision__figure01 .after .text .c-list__disc {
    font-size: 17px
  }
}

.p-sustainabilityGroupSustainabilityVision_column {
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column {
    display: flex
  }
}

.p-sustainabilityGroupSustainabilityVision_column+.p-sustainabilityGroupSustainabilityVision_column {
  margin-top: 8px
}

.p-sustainabilityGroupSustainabilityVision_column .issue {
  display: flex;
  align-items: center;
  padding: 16px 28px 16px 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column .issue {
    justify-content: center;
    padding: 32px 0;
    width: 287px
  }
}

@media print {
  .p-sustainabilityGroupSustainabilityVision_column .issue {
    justify-content: center;
    padding: 32px 0;
    width: 200px
  }
}

.p-sustainabilityGroupSustainabilityVision_column .issue .category {
  color: #fff;
  display: flex;
  align-items: center;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.6;
  padding-left: 46px;
  position: relative
}

[lang=en] .p-sustainabilityGroupSustainabilityVision_column .issue .category {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column .issue .category {
    flex-direction: column;
    justify-content: center;
    font-size: 18px;
    line-height: 1.33;
    padding-left: 0;
    text-align: center
  }

  [lang=en] .p-sustainabilityGroupSustainabilityVision_column .issue .category {
    font-size: 19px
  }
}

@media print {
  .p-sustainabilityGroupSustainabilityVision_column .issue .category {
    flex-direction: column;
    justify-content: center;
    padding-left: 0;
    text-align: center
  }
}

.p-sustainabilityGroupSustainabilityVision_column .issue .category::before {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
  left: 0;
  height: 30px;
  width: 30px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column .issue .category::before {
    position: relative;
    margin-bottom: 16px;
    height: 80px;
    width: 80px
  }
}

@media print {
  .p-sustainabilityGroupSustainabilityVision_column .issue .category::before {
    position: relative;
    margin-bottom: 16px;
    height: 45px;
    width: 45px
  }
}

.p-sustainabilityGroupSustainabilityVision_column .target {
  display: flex;
  justify-content: center;
  flex-direction: column;
  margin-top: 8px;
  padding: 25px 17px 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column .target {
    padding: 32px 32px 32px 35px;
    margin-top: 0;
    margin-left: 8px;
    width: calc(100% - 8px - 287px)
  }
}

@media print {
  .p-sustainabilityGroupSustainabilityVision_column .target {
    padding: 16px;
    margin-top: 0;
    margin-left: 8px;
    width: calc(100% - 8px - 200px)
  }
}

.p-sustainabilityGroupSustainabilityVision_column .target .c-title__05:first-child {
  margin-top: 0
}

.p-sustainabilityGroupSustainabilityVision_column .target .c-list__disc {
  font-size: 15px;
  line-height: 1.86
}

[lang=en] .p-sustainabilityGroupSustainabilityVision_column .target .c-list__disc {
  font-size: 16px;
  line-height: 1.5
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column .target .c-list__disc {
    font-size: 18px;
    line-height: 1.77
  }

  [lang=en] .p-sustainabilityGroupSustainabilityVision_column .target .c-list__disc {
    font-size: 19px
  }
}

.p-sustainabilityGroupSustainabilityVision_column .target .c-list__disc>li:nth-child(n+2) {
  margin-top: 8px
}

.p-sustainabilityGroupSustainabilityVision_column .target b {
  font-weight: 700
}

.p-sustainabilityGroupSustainabilityVision_column.-humanright .issue {
  background: #dc5164;
  position: relative;
  margin-top: 57px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column.-humanright .issue {
    margin-top: 46px
  }
}

.p-sustainabilityGroupSustainabilityVision_column.-humanright .issue>.c-title__05 {
  position: absolute;
  top: -40px;
  left: 0;
  margin: 0;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column.-humanright .issue>.c-title__05 {
    top: -44px
  }
}

.p-sustainabilityGroupSustainabilityVision_column.-humanright .issue .category::before {
  background-image: url(/images/sustainability/common/icon_humanright_path.svg)
}

.p-sustainabilityGroupSustainabilityVision_column.-humanright .target {
  background: #f8dce0;
  position: relative;
  margin-top: 70px
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column.-humanright .target {
    margin-top: 46px
  }
}

.p-sustainabilityGroupSustainabilityVision_column.-humanright .target>.c-title__05 {
  position: absolute;
  top: -42px;
  left: 0;
  margin: 0;
  width: 100%
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityGroupSustainabilityVision_column.-humanright .target>.c-title__05 {
    top: -44px
  }
}

.p-sustainabilityGroupSustainabilityVision_column.-humanright .target b {
  color: #dc5164
}

.p-sustainabilityGroupSustainabilityVision_column.-healthcare .issue {
  background: #1479a2
}

.p-sustainabilityGroupSustainabilityVision_column.-healthcare .issue .category::before {
  background-image: url(/images/sustainability/common/icon_healthcare_path.svg)
}

.p-sustainabilityGroupSustainabilityVision_column.-healthcare .target {
  background: #e8efff
}

.p-sustainabilityGroupSustainabilityVision_column.-healthcare .target b {
  color: #1479a2
}

.p-sustainabilityGroupSustainabilityVision_column.-smartCommunity .issue {
  background: #d7720f
}

.p-sustainabilityGroupSustainabilityVision_column.-smartCommunity .issue .category::before {
  background-image: url(/images/sustainability/common/icon_smart_community_path.svg)
}

.p-sustainabilityGroupSustainabilityVision_column.-smartCommunity .target {
  background: #f8ebdb
}

.p-sustainabilityGroupSustainabilityVision_column.-smartCommunity .target b {
  color: #d7720f
}

.p-sustainabilityGroupSustainabilityVision_column.-decarbonizedSociety .issue {
  background: #7467a5
}

.p-sustainabilityGroupSustainabilityVision_column.-decarbonizedSociety .issue .category::before {
  background-image: url(/images/sustainability/common/icon_decarbonized_society_path.svg)
}

.p-sustainabilityGroupSustainabilityVision_column.-decarbonizedSociety .target {
  background: #ede8fb
}

.p-sustainabilityGroupSustainabilityVision_column.-decarbonizedSociety .target b {
  color: #7467a5
}

.p-sustainabilityGroupSustainabilityVision_column.-goodEnvironment .issue {
  background: #0f8254
}

.p-sustainabilityGroupSustainabilityVision_column.-goodEnvironment .issue .category::before {
  background-image: url(/images/sustainability/common/icon_good_environment_path.svg)
}

.p-sustainabilityGroupSustainabilityVision_column.-goodEnvironment .target {
  background: #e3f5e7
}

.p-sustainabilityGroupSustainabilityVision_column.-goodEnvironment .target b {
  color: #0f8254
}

.c-list__discLarge+.p-sustainabilityGroupSustainabilityVision_column,
.p-sustainabilityGroupSustainabilityVision_column+.c-list__discLarge {
  margin-top: 25px
}

@media print {
  .p-sustainabilityGroupSustainabilityVision .c-imageCenter__M {
    max-width: 870px
  }
}

.p-sustainabilityGroupSustainabilityVision .line {
  width: 100%;
  margin-top: 36px;
  border-bottom: 1px solid #dfdfdf;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M {
  max-width: 1040px !important;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul {
  display: flex;
  align-items: center;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li img {
  max-width: 480px;
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li img {
    max-width: 100%;
  }
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content {
  margin-right: 15px;
  padding: 10px;
  background: #EDF5FC;
  border: 1px solid #EDF5FC;
  border-radius: 10px;
  font-size: 14px;
}

@media (min-width: 768px) and (max-width: 908px) {
  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content {
    font-size: 10px;
  }
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .title {
  padding: 3px 10px;
  background: #0F90BF;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  color: #fff;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content table tr td {
  padding-left: 10px;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content table tr td.pb10 {
  padding-bottom: 10px;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents01 table {
  width: 100%;
  margin-bottom: 10px;
  background: #FFF;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents02 {
  width: 50%;
  margin-right: 10px;
  margin-bottom: 10px;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents03 {
  width: unset;
  margin-bottom: 10px;
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents03 {
    width: 50%;
  }
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents02 table,
.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents03 table {
  background: #FFF;
  width: 100%;
  height: 180px;
}

@media print {

  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents02 table,
  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents03 table {
    height: 210px;
  }
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .contents04 table {
  width: 100%;
  background: #FFF;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content .flex {
  display: flex;
  justify-content: space-between;
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M ul li.content table .circleBlue {
  color: #0F90BF;
}

.p-tab__button {
  display: flex;
  overflow: auto;
  padding-bottom: 10px;
  white-space: nowrap
}

@media print,
screen and (min-width: 768px) {
  .p-tab__button {
    border-bottom: 1px solid #c8c8c8;
    padding-bottom: 0;
    width: 100%
  }
}

.p-tab__button li {
  border-bottom: 1px solid #c8c8c8;
  position: relative
}

@media print,
screen and (min-width: 768px) {
  .p-tab__button li {
    border-bottom: none
  }
}

.p-tab__button li::after {
  background: #0093d7;
  content: "";
  display: block;
  opacity: 0;
  position: absolute;
  bottom: 0;
  height: 3px;
  width: 100%;
  transition: all .3s ease
}

@media print,
screen and (min-width: 768px) {
  .p-tab__button li::after {
    height: 4px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-tab__button li:hover::after {
    opacity: 1
  }
}

.p-tab__button li a {
  color: #002153;
  display: block;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  padding: 14px 12px;
  text-align: center
}

[lang=en] .p-tab__button li a {
  font-size: 15px
}

@media print,
screen and (min-width: 768px) {
  .p-tab__button li a {
    font-size: 16px;
    padding: 16px 24px
  }

  [lang=en] .p-tab__button li a {
    font-size: 17px
  }
}

.p-tab__button li.active::after {
  opacity: 1
}

.p-tab__area {
  display: none;
  opacity: 0;
  background: #fff;
  padding-top: 22px;
  padding-bottom: 4px
}

@media print,
screen and (min-width: 768px) {
  .p-tab__area {
    padding-top: 40px
  }
}

.p-tab__area>:first-child {
  margin-top: 0 !important
}

.p-tab__area.is-active {
  display: block;
  animation-name: displayAnime;
  animation-duration: 2s;
  animation-fill-mode: forwards
}

@keyframes displayAnime {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

.-w5per {
  width: 5%
}

.-w10per {
  width: 10%
}

.-w15per {
  width: 15%
}

.-w20per {
  width: 20%
}

.-w25per {
  width: 25%
}

.-w30per {
  width: 30%
}

.-w35per {
  width: 35%
}

.-w40per {
  width: 40%
}

.-w45per {
  width: 45%
}

.-w50per {
  width: 50%
}

.-w55per {
  width: 55%
}

.-w60per {
  width: 60%
}

.-w65per {
  width: 65%
}

.-w70per {
  width: 70%
}

.-w75per {
  width: 75%
}

.-w80per {
  width: 80%
}

.-w85per {
  width: 85%
}

.-w90per {
  width: 90%
}

.-w95per {
  width: 95%
}

.p-table+.p-table {
  margin-top: 48px
}

@media print,
screen and (min-width: 1024px) {
  .p-table+.p-table {
    margin-top: 72px
  }
}

.p-table table {
  width: 100%
}

.p-table table tr {
  border-bottom: 1px solid #c8c8c8
}

.p-table table tr td,
.p-table table tr th {
  page-break-inside: avoid;
  text-align: left
}

.p-table table tr td.bgGray,
.p-table table tr th.bgGray {
  background: #f1f1f1
}

.p-table table tr th {
  color: #607696;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.45;
  padding: 9px 16px
}

[lang=en] .p-table table tr th {
  font-size: 14px;
  line-height: 1.35;
  white-space: normal;
  word-wrap: break-word
}

@media print,
screen and (min-width: 768px) {
  .p-table table tr th {
    font-size: 16px;
    line-height: 1.8;
    padding: 18px 16px
  }

  [lang=en] .p-table table tr th {
    font-size: 17px;
    padding: 20px 18px
  }
}

.p-table table tr th:not(:last-child) {
  border-right: 1px solid #c8c8c8
}

.p-table table tr td {
  padding: 12px 16px;
  vertical-align: top
}

[lang=en] .p-table table tr td {
  padding: 15px 16px;
  font-size: 15px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-table table tr td {
    padding: 15px 16px
  }

  [lang=en] .p-table table tr td {
    padding: 19px 18px;
    font-size: 18px
  }
}

.p-table table tr td>:first-child {
  margin-top: 0 !important
}

.p-table table tr td:not(:last-child) {
  border-right: 1px solid #c8c8c8;
}

.p-table table tfoot tr {
  border-bottom: none
}

.p-table table tfoot tr td {
  border-left: none !important;
  padding: 24px 0 0 !important
}

@media print,
screen and (min-width: 768px) {
  .p-table table tfoot tr td {
    padding: 38px 0 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-table:not([class*=-narrow]) {
    width: 100%
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessIssues__table:not([class*=-narrow]) {
    width: 100%
  }
}

.p-table:not([class*=-block]):not([class*=is-noBorder]):not([class*=-noBorder]) tbody {
  border-top: 1px solid #c8c8c8
}

@media print,
screen and (min-width: 768px) {
  .p-table:not([class*=-block]):not([class*=is-noBorder]):not([class*=-noBorder]) tr th {
    text-align: center
  }
}

.p-table:not([class*=-block]):not([class*=is-noBorder]):not([class*=-noBorder]) tr td:last-child {
  border-left: 1px solid #c8c8c8
}

.p-table.-scroll {
  overflow: auto;
  padding-bottom: 10px;
  white-space: nowrap
}

.p-sustainabilityBusinessIssues__table.-scroll {
  overflow: auto;
  padding-bottom: 10px;
  white-space: nowrap
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M.-scroll {
  overflow: auto;
  padding-bottom: 10px;
  white-space: nowrap
}

.p-sustainabilityEditorial.-scroll {
  overflow: auto;
  padding-bottom: 60px;
}

@media print,
screen and (min-width: 768px) {
  .p-table.-scroll {
    overflow: hidden;
    white-space: normal
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityBusinessIssues__table.-scroll {
    overflow: hidden;
    white-space: normal
  }

  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M.-scroll {
    overflow: hidden;
    white-space: normal
  }

  .p-sustainabilityEditorial.-scroll {
    overflow: hidden;
    white-space: normal
  }
}

@media print {
  .p-table.-scroll {
    overflow: visible;
    white-space: normal
  }

  .p-sustainabilityBusinessIssues__table.-scroll {
    white-space: normal
  }

  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M.-scroll {
    overflow: hidden;
    white-space: normal
  }
}

@media print {
  .p-sustainabilityIndicator {
    margin-top: 20px
  }
}

.p-table.-scroll::before {
  content: "表はスクロールしてご覧ください";
  background: url(/images/common/icon_scroll.svg) no-repeat;
  position: sticky;
  top: 0;
  left: 0;
  height: 24px;
  display: flex;
  align-items: center;
  color: #77797c;
  font-size: 13px;
  padding-left: 27px;
  margin-bottom: 10px
}

.p-sustainabilityBusinessIssues__table.-scroll::before {
  content: "表はスクロールしてご覧ください";
  background: url(/images/common/icon_scroll.svg) no-repeat;
  position: sticky;
  top: 0;
  left: 0;
  height: 24px;
  display: flex;
  align-items: center;
  color: #77797c;
  font-size: 13px;
  padding-left: 27px;
  margin-bottom: 10px
}

.p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M::before {
  content: "表はスクロールしてご覧ください";
  background: url(/images/common/icon_scroll.svg) no-repeat;
  position: sticky;
  top: 0;
  left: 0;
  height: 24px;
  display: flex;
  align-items: center;
  color: #77797c;
  font-size: 13px;
  padding-left: 27px;
  margin-bottom: 10px
}

[lang=en] .p-table.-scroll::before {
  content: "Please scroll through the table."
}

[lang=en] .p-sustainabilityBusinessIssues__table.-scroll::before {
  content: "Please scroll through the table."
}

[lang=en] .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M.-scroll::before {
  content: "Please scroll through the table."
}

[lang=en] .p-sustainabilityEditorial.-scroll::before {
  content: "Please scroll through the table."
}

@media print,
screen and (min-width: 768px) {
  .p-table.-scroll::before {
    display: none
  }

  .p-sustainabilityBusinessIssues__table.-scroll::before {
    display: none
  }

  .p-sustainabilityGroupSustainabilityMateriality .c-imageCenter__M.-scroll::before {
    display: none
  }

  .p-sustainabilityEditorial.-scroll::before {
    display: none
  }
}

/* p-sustainabilityBusinessStrategy */

.p-sustainabilityBusinessStrategy .flex {
  display: flex;
  flex-wrap: wrap;
}

@media print,
screen and (min-width: 1024px) {
  .p-sustainabilityBusinessStrategy .flex .p-column__wide .p-column__item {
    width: 30%;
  }

  .p-sustainabilityBusinessStrategy .flex {
    flex-wrap: nowrap;
  }
}

/* p-sustainabilityBusinessIssues */

.p-sustainabilityBusinessIssues .productBtn {
  margin-top: 30px;
}

.p-sustainabilityBusinessIssues .flex {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}

.p-sustainabilityBusinessIssues .flex p {
  margin-top: 0;
}

@media print,
screen and (min-width: 1024px) {
  .p-column__wide .p-column__item.double {
    width: 100%;
  }
}

/* arrow */

.p-sustainabilityEditorial .arrow--left {
  position: absolute;
  top: -23px;
  left: -60px;
  width: 0;
  height: 0;
  border-bottom: 40px solid transparent;
  border-top: 40px solid transparent;
  border-right: 40px solid #0093d7;
  border-left: 40px solid transparent;
}

.p-sustainabilityEditorial .arrow--right {
  position: absolute;
  top: -23px;
  right: -60px;
  width: 0;
  height: 0;
  border-bottom: 40px solid transparent;
  border-top: 40px solid transparent;
  border-left: 40px solid #0093d7;
  border-right: 40px solid transparent;
}

.p-sustainabilityEditorial .arrow--content {
  display: flex;
  justify-content: space-between;
  position: relative;
  width: 190%;
  margin: 0 auto;
  margin-top: 60px;
  margin-left: 20px;
  padding: 5px 0;
  background: #0093d7;
  color: #fff;
}

@media print,
screen and (min-width: 768px) {
  .p-sustainabilityEditorial .arrow--content {
    width: 95%;
    margin-left: auto;
    padding: 0;
  }
}

.p-sustainabilityEditorial .arrow--content p {
  margin-top: 0;
}

.p-sustainabilityEditorial .arrow--content p:nth-child(1) {
  margin-left: 60px;
}

.p-sustainabilityEditorial .arrow--content p:nth-child(2) {
  margin-right: 60px;
}

@media print,
screen and (min-width: 768px) {
  .p-table.-narrow {
    margin-left: auto;
    margin-right: auto;
    max-width: 773px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-table.-left {
    margin-left: 0 !important
  }
}

.p-table.-block table tr:nth-child(n+2) th {
  padding-top: 18px
}

[lang=en] .p-table.-block table tr:nth-child(n+2) th {
  padding-top: 20px
}

.p-table.-block table tr td,
.p-table.-block table tr th {
  display: block
}

.p-table.-block table tr td:nth-child(n+2),
.p-table.-block table tr th:nth-child(n+2) {
  padding-top: 0
}

.p-table.-block table tr td:not(:last-child),
.p-table.-block table tr th:not(:last-child) {
  border-right: none
}

.p-table.-block table tr td {
  padding-bottom: 12px
}

.p-table.-block table tr td:nth-child(n+2) {
  padding-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-table.-blockSP:not(.-noBorder) table tr:first-child {
    border-top: 1px solid #c8c8c8
  }
}

.p-table.-blockSP:not(.-noBorder) table tr:nth-child(n+2) th {
  padding-top: 10px
}

@media print,
screen and (min-width: 768px) {
  .p-table.-blockSP:not(.-noBorder) table tr:nth-child(n+2) th {
    padding-top: 18px
  }

  [lang=en] .p-table.-blockSP:not(.-noBorder) table tr:nth-child(n+2) th {
    padding-top: 20px
  }
}

.p-table.-blockSP:not(.-noBorder) table tr th {
  border-bottom: 1px solid #c8c8c8
}

@media print,
screen and (min-width: 768px) {
  .p-table.-blockSP:not(.-noBorder) table tr th {
    padding-top: 18px;
    text-align: center;
    vertical-align: top
  }
}

.p-table.-blockSP:not(.-noBorder) table tr th+td:nth-child(n+2) {
  padding-top: 12px
}

[lang=en] .p-table.-blockSP:not(.-noBorder) table tr th+td:nth-child(n+2) {
  padding-top: 15px
}

@media print,
screen and (min-width: 768px) {
  .p-table.-blockSP:not(.-noBorder) table tr th+td:nth-child(n+2) {
    padding-top: 16px
  }

  [lang=en] .p-table.-blockSP:not(.-noBorder) table tr th+td:nth-child(n+2) {
    padding-top: 19px
  }
}

.p-table.-blockSP:not(.-noBorder) table tr td:nth-child(n+2) {
  padding-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-table.-blockSP:not(.-noBorder) table tr td:nth-child(n+2) {
    padding-top: 16px
  }

  [lang=en] .p-table.-blockSP:not(.-noBorder) table tr td:nth-child(n+2) {
    padding-top: 19px
  }
}

.p-table.-blockSP:not(.-noBorder) table tr td,
.p-table.-blockSP:not(.-noBorder) table tr th {
  display: block
}

@media print,
screen and (min-width: 768px) {

  .p-table.-blockSP:not(.-noBorder) table tr td,
  .p-table.-blockSP:not(.-noBorder) table tr th {
    display: table-cell
  }
}

@media print,
screen and (max-width: 767px) {

  .p-table.-blockSP:not(.-noBorder) table tr td:not(:last-child),
  .p-table.-blockSP:not(.-noBorder) table tr th:not(:last-child) {
    border-right: none
  }
}

@media print,
screen and (max-width: 767px) {

  .p-table.-blockSP:not(.-noBorder) table tr td.empty,
  .p-table.-blockSP:not(.-noBorder) table tr th.empty {
    display: none
  }
}

@media print,
screen and (max-width: 768px) {

  .p-table.-blockSP.-noBorder table td,
  .p-table.-blockSP.-noBorder table th {
    display: block
  }

  .p-table.-blockSP.-noBorder table td {
    padding-top: 8px !important;
    padding-left: 0 !important
  }
}

@media print,
screen and (min-width: 768px) {
  .p-table.-noBorder {
    width: 100%
  }
}

.p-table.-noBorder:not([class*=-block]) tr:first-child td,
.p-table.-noBorder:not([class*=-block]) tr:first-child th {
  padding-top: 0 !important
}

.p-table.-noBorder tr {
  border-bottom: none;
  vertical-align: top
}

.p-table.-noBorder tr td,
.p-table.-noBorder tr th {
  color: #002153;
  font-size: 15px;
  line-height: 1.6
}

[lang=en] .p-table.-noBorder tr td,
[lang=en] .p-table.-noBorder tr th {
  font-size: 16px;
  line-height: 1.3
}

@media print,
screen and (min-width: 768px) {

  .p-table.-noBorder tr td,
  .p-table.-noBorder tr th {
    font-size: 18px;
    line-height: 1.875
  }

  [lang=en] .p-table.-noBorder tr td,
  [lang=en] .p-table.-noBorder tr th {
    font-size: 19px;
    line-height: 1.4
  }
}

.p-table.-noBorder tr td:not(:last-child),
.p-table.-noBorder tr th:not(:last-child) {
  border-right: none
}

.p-table.-noBorder tr th {
  padding: 0 24px 0 0;
  min-width: 84px
}

@media print,
screen and (min-width: 768px) {
  .p-table.-noBorder tr th {
    padding: 16px 0;
    min-width: 120px
  }
}

.p-table.-noBorder tr th:not(:first-child) {
  padding: 16px 0 16px 16px
}

.p-table.-noBorder tr th.-tertiary {
  color: #607696;
  font-weight: 700
}

.p-table.-noBorder tr td {
  padding: 16px 0
}

.p-table.-noBorder tr td:not(:first-child) {
  padding: 16px 0 16px 16px
}

.c-list__any .p-table {
  margin-top: 16px
}

.p-tableInfo table {
  width: 100%
}

.p-tableInfo table tr {
  border-bottom: 1px solid #c8c8c8
}

.p-tableInfo table tr td,
.p-tableInfo table tr th {
  display: block
}

@media print,
screen and (min-width: 1024px) {

  .p-tableInfo table tr td,
  .p-tableInfo table tr th {
    display: table-cell
  }
}

.p-tableInfo table tr .cell_title {
  vertical-align: top
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo table tr .cell_title {
    text-align: left;
    width: 25.8%
  }
}

.p-tableInfo table tr .cell_title .name {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.44;
  text-align: left
}

[lang=en] .p-tableInfo table tr .cell_title .name {
  font-size: 19px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo table tr .cell_title .name {
    font-size: 20px;
    line-height: 1.5
  }

  [lang=en] .p-tableInfo table tr .cell_title .name {
    font-size: 21px
  }
}

.p-tableInfo table tr .cell_title .button {
  margin-top: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo table tr .cell_title .button .c-button {
    width: 196px
  }
}

.p-tableInfo table tr .cell_addressList li {
  margin-top: 20px
}

.p-tableInfo table tr .cell_addressList li:first-child {
  margin-top: 0
}

.p-tableInfo table tr .cell_address .name {
  color: #607696;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.47
}

[lang=en] .p-tableInfo table tr .cell_address .name {
  font-size: 16px;
  line-height: 1.35
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo table tr .cell_address .name {
    font-size: 16px;
    line-height: 1.625
  }

  [lang=en] .p-tableInfo table tr .cell_address .name {
    font-size: 17px
  }
}

.p-tableInfo table tr .cell_address .person,
.p-tableInfo table tr .cell_address .tel,
.p-tableInfo table tr .cell_address .text {
  font-size: 14px;
  line-height: 1.7
}

[lang=en] .p-tableInfo table tr .cell_address .person,
[lang=en] .p-tableInfo table tr .cell_address .tel,
[lang=en] .p-tableInfo table tr .cell_address .text {
  font-size: 15px;
  line-height: 1.5
}

@media print,
screen and (min-width: 1024px) {

  .p-tableInfo table tr .cell_address .person,
  .p-tableInfo table tr .cell_address .tel,
  .p-tableInfo table tr .cell_address .text {
    font-size: 18px;
    line-height: 1.67
  }

  [lang=en] .p-tableInfo table tr .cell_address .person,
  [lang=en] .p-tableInfo table tr .cell_address .tel,
  [lang=en] .p-tableInfo table tr .cell_address .text {
    font-size: 19px
  }
}

.p-tableInfo table tr .cell_address .name+.text {
  margin-top: 10px
}

.p-tableInfo table tr .cell_address .name+.tel {
  margin-top: 9px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo table tr .cell_address .name+.tel {
    margin-top: 8px
  }
}

.p-tableInfo table tr .cell_address .tel+.person,
.p-tableInfo table tr .cell_address .text+.person,
.p-tableInfo table tr .cell_address .text+.tel {
  margin-top: 10px
}

@media print,
screen and (min-width: 1024px) {

  .p-tableInfo table tr .cell_address .tel+.person,
  .p-tableInfo table tr .cell_address .text+.person,
  .p-tableInfo table tr .cell_address .text+.tel {
    margin-top: 8px
  }
}

.p-tableInfo table tr .cell_link {
  padding: 0 16px 15px;
  text-align: right
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo table tr .cell_link {
    padding: 16px;
    min-width: 196px
  }

  [lang=en] .p-tableInfo table tr .cell_link {
    min-width: 220px
  }
}

.p-tableInfo table tr .cell_link .c-button__small {
  margin-top: 0
}

.p-tableInfo__01 {
  border-top: 1px solid #c8c8c8
}

.p-tableInfo__01 .cell_title {
  padding: 16px 16px 10px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo__01 .cell_title {
    padding: 16px
  }
}

.p-tableInfo__01 .cell_address {
  padding: 0 16px 10px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo__01 .cell_address {
    padding: 16px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo__02 {
    border-top: 1px solid #c8c8c8
  }
}

.p-tableInfo__02 .cell_title {
  border-bottom: 1px solid #c8c8c8;
  padding-bottom: 15px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo__02 .cell_title {
    padding: 16px
  }
}

.p-tableInfo__02 .cell_address {
  padding: 16px 16px 10px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo__02 .cell_address {
    padding: 15px 16px
  }
}

.p-tableInfo__02 .cell_address:last-child {
  padding: 16px
}

.p-tableInfo__02+.p-tableInfo__02 {
  margin-top: 65px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo__02+.p-tableInfo__02 {
    border-top: none;
    margin-top: 0
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo+.c-title__02 {
    margin-top: 98px
  }
}

.p-tableInfo+.p-box__gray {
  margin-top: 24px
}

@media print,
screen and (min-width: 1024px) {
  .p-tableInfo+.p-box__gray {
    margin-top: 40px
  }
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory {
    margin-top: 25px
  }
}

.p-tableHistory tr {
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid #c8c8c8;
  padding-bottom: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory tr {
    display: revert;
    border-bottom: none;
    padding-bottom: 0
  }
}

.p-tableHistory tr.rowspan {
  border-bottom: none
}

.p-tableHistory tr:first-child th {
  padding-top: 0
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory tr:first-child th {
    padding-top: 6px
  }
}

.p-tableHistory tr:first-child td {
  padding-top: 0
}

.p-tableHistory td,
.p-tableHistory th {
  display: table-cell;
  vertical-align: top
}

.p-tableHistory th {
  width: 100%;
  padding: 16px 16px 9px;
  text-align: left
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory th {
    width: 82px;
    padding: 31px 0 0
  }
}

.p-tableHistory th .c-title__04 {
  line-height: 1;
  margin: 0
}

.p-tableHistory .cell_date {
  width: 80px;
  padding-left: 16px
}

[lang=en] .p-tableHistory .cell_date {
  width: 95px
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory .cell_date {
    width: 108px;
    padding-left: 0;
    padding-top: 30px
  }

  [lang=en] .p-tableHistory .cell_date {
    width: 100px
  }
}

.p-tableHistory .cell_text {
  padding-left: 16px;
  padding-right: 16px
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory .cell_text {
    padding-left: 0;
    padding-right: 0;
    padding-top: 24px
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-tableHistory .cell_year+.cell_text {
    padding-left: 46px
  }
}

.p-tableHistory .cell_date+.cell_text {
  width: calc(100% - 96px)
}

[lang=en] .p-tableHistory .cell_date+.cell_text {
  width: calc(100% - 95px)
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory .cell_date+.cell_text {
    width: calc(100% - 190px)
  }

  [lang=en] .p-tableHistory .cell_date+.cell_text {
    width: calc(100% - 100px)
  }
}

.p-tableHistory__date {
  font-size: 14px;
  line-height: 1.6
}

[lang=en] .p-tableHistory__date {
  font-size: 15px;
  line-height: 1.35
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory__date {
    line-height: 1.9
  }
}

.p-tableHistory__text {
  font-size: 14px;
  line-height: 1.6
}

[lang=en] .p-tableHistory__text {
  font-size: 15px;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .p-tableHistory__text {
    font-size: 18px;
    line-height: 2
  }

  [lang=en] .p-tableHistory__text {
    font-size: 19px
  }
}

.p-term .access-log-group {
  color: #002153;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom: 15px;
  margin-top: 23px
}

@media print,
screen and (min-width: 1024px) {
  .p-term .access-log-group {
    font-size: 20px;
    line-height: 1.44;
    margin-bottom: 20px
  }
}

.p-term #ot-sdk-btn {
  margin-top: 40px
}

.p-term #ot-sdk-btn.ot-sdk-show-settings {
  white-space: normal;
  word-wrap: break-word;
  align-items: center;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #fff;
  border: 1px solid #002153;
  border-radius: 28px;
  color: #002153;
  cursor: pointer;
  display: inline-flex;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 500;
  justify-content: space-between;
  height: auto;
  min-height: 56px;
  padding: 0;
  padding-left: 24px;
  padding-right: 20px;
  position: relative;
  text-decoration: none;
  transition: .2s ease all
}

.p-term #ot-sdk-btn.ot-sdk-show-settings::after {
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/images/common/icon_arrowRight.svg);
  content: "";
  display: inline-block;
  flex-shrink: 0;
  height: 16px;
  width: 18px;
  transition: .2s ease all;
  margin-left: 10px
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-btn.ot-sdk-show-settings:hover {
    background-color: #002153;
    color: #fff
  }
}

.p-term #ot-sdk-cookie-policy-v2 {
  font-family: inherit;
  font-size: 18px
}

.p-term #ot-sdk-cookie-policy-v2 section {
  margin-bottom: 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 section {
    margin-bottom: 72px
  }
}

.p-term #ot-sdk-cookie-policy-v2 section:last-child {
  margin-bottom: 0
}

.p-term #ot-sdk-cookie-policy-v2 #cookie-policy-description,
.p-term #ot-sdk-cookie-policy-v2 a,
.p-term #ot-sdk-cookie-policy-v2 h4,
.p-term #ot-sdk-cookie-policy-v2 h6,
.p-term #ot-sdk-cookie-policy-v2 li,
.p-term #ot-sdk-cookie-policy-v2 p,
.p-term #ot-sdk-cookie-policy-v2 th {
  color: #002153
}

.p-term #ot-sdk-cookie-policy-v2 #cookie-policy-description,
.p-term #ot-sdk-cookie-policy-v2 .ot-sdk-cookie-policy-group-desc,
.p-term #ot-sdk-cookie-policy-v2 a,
.p-term #ot-sdk-cookie-policy-v2 span,
.p-term #ot-sdk-cookie-policy-v2 td {
  font-size: 15px;
  line-height: 1.875
}

@media print,
screen and (min-width: 1024px) {

  .p-term #ot-sdk-cookie-policy-v2 #cookie-policy-description,
  .p-term #ot-sdk-cookie-policy-v2 .ot-sdk-cookie-policy-group-desc,
  .p-term #ot-sdk-cookie-policy-v2 a,
  .p-term #ot-sdk-cookie-policy-v2 span,
  .p-term #ot-sdk-cookie-policy-v2 td {
    font-size: 18px
  }
}

.p-term #ot-sdk-cookie-policy-v2 #cookie-policy-description {
  margin-bottom: 0;
  margin-top: 26px
}

.p-term #ot-sdk-cookie-policy-v2 .ot-mobile-border {
  display: none
}

.p-term #ot-sdk-cookie-policy-v2 .ot-table-header {
  color: #607696;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.45;
  padding: 9px 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 .ot-table-header {
    text-align: center;
    font-size: 16px;
    padding: 18px 16px
  }
}

.p-term #ot-sdk-cookie-policy-v2 .ot-table-header:not(:last-child) {
  border-right: 1px solid #c8c8c8
}

.p-term #ot-sdk-cookie-policy-v2 .ot-sdk-cookie-policy-group {
  color: #002153;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom: 15px;
  margin-top: 23px
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 .ot-sdk-cookie-policy-group {
    font-size: 20px;
    line-height: 1.44;
    margin-bottom: 20px
  }
}

.p-term #ot-sdk-cookie-policy-v2 table,
.p-term #ot-sdk-cookie-policy-v2 tbody,
.p-term #ot-sdk-cookie-policy-v2 td,
.p-term #ot-sdk-cookie-policy-v2 th,
.p-term #ot-sdk-cookie-policy-v2 thead,
.p-term #ot-sdk-cookie-policy-v2 tr {
  display: block
}

@media print,
screen and (min-width: 1024px) {

  .p-term #ot-sdk-cookie-policy-v2 table,
  .p-term #ot-sdk-cookie-policy-v2 tbody,
  .p-term #ot-sdk-cookie-policy-v2 td,
  .p-term #ot-sdk-cookie-policy-v2 th,
  .p-term #ot-sdk-cookie-policy-v2 thead,
  .p-term #ot-sdk-cookie-policy-v2 tr {
    display: revert
  }
}

.p-term #ot-sdk-cookie-policy-v2 .ot-sdk-cookie-policy-title {
  color: #607696;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom: 18px;
  margin-top: 40px
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 .ot-sdk-cookie-policy-title {
    font-size: 24px;
    line-height: 1.66;
    margin-bottom: 24px;
    margin-top: 40px
  }
}

.p-term #ot-sdk-cookie-policy-v2 a {
  background: 0 0
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 a:hover {
    background: 0 0;
    -webkit-text-decoration: underline 1px transparent;
    text-decoration: underline 1px transparent
  }
}

.p-term #ot-sdk-cookie-policy-v2 table {
  margin: auto;
  margin-top: 40px;
  border-radius: 0;
  border-spacing: 0;
  border-collapse: collapse;
  width: 100%;
  overflow: hidden
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table {
    max-width: 773px;
    margin-left: auto;
    margin-right: auto
  }
}

.p-term #ot-sdk-cookie-policy-v2 table .ot-scrn-rdr {
  display: none
}

.p-term #ot-sdk-cookie-policy-v2 table .ot-host {
  width: auto
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table .ot-host {
    width: 30%
  }
}

.p-term #ot-sdk-cookie-policy-v2 table .ot-cookies {
  width: auto
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table .ot-cookies {
    width: 45%
  }
}

.p-term #ot-sdk-cookie-policy-v2 table .ot-cookies-type {
  width: auto
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table .ot-cookies-type {
    width: 25%
  }
}

.p-term #ot-sdk-cookie-policy-v2 table thead {
  background-color: #fff;
  font-weight: 700
}

.p-term #ot-sdk-cookie-policy-v2 table thead tr {
  position: absolute;
  top: -9999px;
  left: -9999px;
  z-index: -9999
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table thead tr {
    position: static;
    z-index: 1
  }
}

.p-term #ot-sdk-cookie-policy-v2 table tr {
  border-bottom: 0;
  border-right: 0;
  margin: 0
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table tr {
    border: none;
    border-bottom: 1px solid #c8c8c8;
    border-right: 0 solid #c8c8c8
  }
}

.p-term #ot-sdk-cookie-policy-v2 table tr td {
  border: none;
  border-bottom: 1px solid #c8c8c8;
  border-right: 0;
  font-size: 15px;
  line-height: 1.7;
  padding: 12px 16px
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table tr td {
    font-size: 18px;
    word-wrap: break-word;
    padding: 15px 16px
  }

  .p-term #ot-sdk-cookie-policy-v2 table tr td:not(:last-child) {
    border-right: 1px solid #c8c8c8
  }
}

.p-term #ot-sdk-cookie-policy-v2 table tr td:last-child td {
  border-bottom: 1px solid #c8c8c8;
  border-right: 0
}

.p-term #ot-sdk-cookie-policy-v2 table tr td:before {
  height: 100%;
  width: auto;
  padding-right: 15px;
  padding-bottom: 0;
  content: attr(data-label);
  font-size: 13px;
  font-weight: 700;
  color: #607696;
  display: inline-block
}

@media print,
screen and (min-width: 1024px) {
  .p-term #ot-sdk-cookie-policy-v2 table tr td:before {
    display: none
  }
}

.p-term #ot-sdk-cookie-policy-v2 table tr td a,
.p-term #ot-sdk-cookie-policy-v2 table tr td span {
  font-size: inherit;
  word-break: keep-all
}

.p-term #ot-sdk-cookie-policy-v2 table tr td a {
  color: #0093d7;
  display: inline-block;
  position: relative;
  transition: .2s all;
  word-break: break-all;
  -webkit-text-decoration: underline 1px #0093d7;
  text-decoration: underline 1px #0093d7;
  text-underline-offset: 20%;
  margin-right: 10px
}

.p-term #ot-sdk-cookie-policy-v2 table tr td a:last-child {
  margin-right: 0
}

.p-term #ot-sdk-cookie-policy-v2 table tr td:last-child,
.p-term #ot-sdk-cookie-policy-v2 table tr th:last-child {
  border-right: 0
}

.p-term a:not([target=_blank]) {
  margin-right: 0 !important
}

.p-term .c-title__05 span {
  display: inline-block;
  margin-top: 20px
}

.p-thumbnailWrap {
  margin: 40px auto 0
}

.p-thumbnailWrap .p-thumbnail {
  width: 100%
}

.p-thumbnailWrap .p-thumbnail__image {
  max-width: 500px;
  width: auto
}

@media print {
  .p-sustainabilityBusinessIssues .double .flex {
    flex-wrap: nowrap;
  }

  .p-sustainabilityBusinessIssues .double .p-thumbnailWrap .p-thumbnail__image {
    min-width: 100%;
  }
}

.p-sustainabilityAssurance .p-thumbnailWrap .p-thumbnail__image {
  max-width: 400px;
  width: auto
}

.p-thumbnail {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin: auto;
  width: 100%
}

.p-thumbnail__image {
  border: 1px solid #dfdfdf;
  opacity: 1;
  transition: .2s ease opacity;
  max-width: 500px;
  width: auto
}

.p-thumbnail__image img {
  display: block;
  width: 100%
}

.p-thumbnail__image.-small {
  max-width: 235px
}

.p-thumbnail__caption {
  color: #002153;
  font-size: 13px
}

[lang=en] .p-thumbnail__caption {
  font-size: 14px
}

@media print,
screen and (min-width: 768px) {
  .p-thumbnail__caption {
    font-size: 14px
  }

  [lang=en] .p-thumbnail__caption {
    font-size: 15px
  }
}

.p-thumbnail__image+.p-thumbnail__button {
  margin-top: 24px
}

.p-thumbnail__caption+.p-thumbnail__button,
.p-thumbnail__image+.p-thumbnail__caption {
  margin-top: 10px
}

@media print,
screen and (min-width: 1024px) {
  .p-thumbnail:hover .p-thumbnail__image {
    opacity: .8
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-thumbnail:hover .p-thumbnail__button {
    background: #002153;
    color: #fff
  }
}

.p-topMessage__body {
  margin-top: 64px
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage__body {
    margin-top: 104px
  }
}

.p-topMessage__foot {
  margin-top: 64px
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage__foot {
    margin-top: 100px
  }
}

.p-topMessage__foot .p-box__gray .c-list__discLarge {
  margin-top: 8px
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage__foot .p-box__gray .c-list__discLarge {
    margin-top: 11px
  }
}

.c-list__discLarge li.noSymbol::before {
  display: none;
}

.c-list__discLarge li.noSymbol .line {
  width: 300px;
  margin-top: 36px;
  border-bottom: 1px solid #607696;
}

@media print,
screen and (min-width: 1024px) {
  .p-topMessage .p-column__wide {
    gap: 48px;
    width: 100%
  }

  .p-topMessage .p-column__wide2 {
    width: 100%
  }

  .p-topMessage .p-column__wide2::after {
    content: "";
    clear: both;
    display: block
  }
}

.p-topMessage .p-column__wide2 .p-column__itemLarge {
  margin-top: 64px
}

.p-topMessage .p-column__wide2 .p-column__itemSmall {
  margin-bottom: 64px
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage .p-column__wide2 .p-column__itemLarge {
    width: 100%;
    margin-top: 0;
    float: none
  }

  .p-topMessage .p-column__wide2 .p-column__itemSmall {
    width: 100%;
    margin-bottom: 0;
    float: none
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-topMessage .p-column__wide .p-column__itemLarge {
    width: calc(100% - 48px - 280px)
  }

  .p-topMessage .p-column__wide2 .p-column__itemLarge {
    width: calc(100% - 400px);
    float: left
  }
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage .p-column__wide .p-column__itemSmall {
    width: 280px
  }

  .p-topMessage .p-column__wide2 .p-column__itemSmall {
    width: 400px;
    padding-left: 40px;
    float: right
  }
}

.p-topMessage__presidentSign {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  margin-top: 40px
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage__presidentSign {
    margin-top: 65px
  }
}

.p-topMessage__presidentSign img {
  margin: 10px 0 0 auto;
  width: 180px
}

@media print,
screen and (min-width: 768px) {
  .p-topMessage__presidentSign img {
    margin: 10px 0 0 auto;
    width: 225px
  }
}

.u-wbr__noWrap {
  white-space: nowrap !important
}

.u-align__left {
  text-align: left !important
}

.u-align__center {
  text-align: center !important
}

.u-align__right {
  text-align: right !important
}

.u-verAlign__top {
  vertical-align: top !important
}

.u-verAlign__middle {
  vertical-align: middle !important
}

.u-verAlign__bottom {
  vertical-align: bottom !important
}

@media print {
  .u-breakBefore {
    margin-top: 30px;
    page-break-before: always
  }

  .u-breakAfter {
    page-break-after: always
  }

  .u-breakAfter+:not(.c-title__02):not(section) {
    margin-top: 30px
  }
}

.u-color__primary {
  color: #002153 !important
}

.u-color__accent {
  color: #0093d7 !important
}

[class*=c-list]:not(.c-list__anchor)>li>a:not([class*=c-button]).u-color__primary {
  -webkit-text-decoration: underline #002153 !important;
  text-decoration: underline #002153 !important
}

.c-list__anchor>li.u-color__primary a {
  color: #002153 !important
}

.c-list__anchor>li.u-color__primary a:hover span {
  -webkit-text-decoration: underline #002153 !important;
  text-decoration: underline #002153 !important
}

.u-fontSize__SS {
  font-size: 13px !important;
  line-height: 1.85
}

[lang=en] .u-fontSize__SS {
  font-size: 14px !important;
  line-height: 1.65
}

@media print,
screen and (min-width: 768px) {
  .u-fontSize__SS {
    font-size: 14px !important;
    line-height: 1.86
  }

  [lang=en] .u-fontSize__SS {
    font-size: 15px !important;
    line-height: 1.5
  }
}

.u-fontSize__S {
  font-size: 15px !important;
  line-height: 1.5
}

[lang=en] .u-fontSize__S {
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .u-fontSize__S {
    font-size: 16px !important;
    line-height: 1.875 !important
  }

  [lang=en] .u-fontSize__S {}
}

.u-fontSize__M {
  font-size: 16px !important;
  line-height: 1.73 !important
}

[lang=en] .u-fontSize__M {
  font-size: 17px !important;
  line-height: 1.5
}

@media print,
screen and (min-width: 768px) {
  .u-fontSize__M {
    font-size: 18px !important;
    line-height: 1.44 !important
  }

  [lang=en] .u-fontSize__M {
    font-size: 19px !important
  }
}

.u-fontSize__L {
  font-size: 18px !important
}

[lang=en] .u-fontSize__L {
  font-size: 19px !important
}

@media print,
screen and (min-width: 768px) {
  .u-fontSize__L {
    font-size: 20px !important
  }

  [lang=en] .u-fontSize__L {
    font-size: 21px !important
  }
}

span[class*=u-fontSize] {
  display: block
}

.u-indent__S {
  padding-left: 15px
}

[lang=en] .u-indent__S {
  padding-left: 17px
}

@media print,
screen and (min-width: 768px) {
  .u-indent__S {
    padding-left: 40px
  }

  [lang=en] .u-indent__S {
    padding-left: 40px
  }
}

.u-text__normal {
  font-weight: 400 !important
}

.u-text__medium {
  font-weight: 500 !important
}

.u-text__bold {
  font-weight: 700 !important
}

.u-visuallyHidden:not(:focus) {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  border: 0;
  white-space: nowrap;
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%)
}

.u-onlySP {
  display: block
}

@media print,
screen and (min-width: 768px) {
  .u-onlySP {
    display: none
  }
}

.u-onlyTB {
  display: none
}

@media print,
screen and (min-width: 1024px) {
  .u-onlyTB {
    display: block
  }
}

.u-onlyPC {
  display: none
}

@media print,
screen and (min-width: 768px) {
  .u-onlyPC {
    display: block
  }
}


@media print,
screen and (min-width: 768px) {
  .h5_label {
    color: #002153;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.66;
    margin-bottom: 20px;
  }
}

@media print,
screen and (max-width: 767px) {
  .h5_label {
    color: #002153;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.44;
    margin-bottom: 15px;
  }
}

@media print,
screen and (min-width: 768px) {
  .cc_dt dt {
    width: 300px;
  }
}

@media print,
screen and (max-width: 767px) {
  .cc_dt dt {
    width: 180px;
    font-size: 14px;
  }

  .cc_dt dd {
    font-size: 13px;
  }
}

.header_blank::after {
  content: "";
  display: inline-block;
  background-image: url(/images/common/icon_blankBlue.svg);
  transform: translate(0.4em, 0.1em);
  height: 16px;
  width: 16px;
}

@media print,
screen and (min-width: 1024px) {
  .h-blank__Wrap {
    width: 600px;
  }
}


@media print,
screen and (min-width: 1024px) {
  .c-imageLink.col-4 li {
    width: calc((100% - 130px) / 4);
  }

  .c-imageLink.col-4 {
    gap: 48px 43px;
  }
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink.col-4 li {
    width: calc((100% - 48px) / 4);
  }

  .c-imageLink.col-4 {
    gap: 16px;
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListProducts.p-nav__childListLength>li {
    max-width: 300px;
  }

  .p-nav__childListProducts.p-nav__childListLength {
    flex-direction: row;
  }
}

.p-nav__childListText {
  font-weight: 700;
  line-height: 1.45;
  font-size: 15px;
  pointer-events: none;
  color: #002153;
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListText {
    font-size: 14px;
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__childList.length>li {
    width: calc((100% - 192px) / 2);
  }
}

.c-title__03.-withIcon.txt {
  padding-left: 120px;
  margin-bottom: 55px;
}

.c-title__03.-withIcon.txt .icon {
  top: -10px;
  font-size: 11px;
  padding: 11px;
  display: inline-block;
  width: 100px;
  height: 100px;
  color: white;
  background-repeat: no-repeat;
  background-position: 50% 14%;
  background-size: 25px;
  padding-top: 43px;
}

.c-title__03.-withIcon.txt.icon01 .icon {
  background-color: #1479a2;
  background-image: url(/images/sustainability/common/icon_healthcare_path.svg);

}

.c-title__03.-withIcon.txt.icon02 .icon {
  background-color: #d7720f;
  background-image: url(/images/sustainability/common/icon_smart_community_path.svg);
  height: 130px;
}

.c-title__03.-withIcon.txt.icon03 .icon {
  background-color: #7467a5;
  background-image: url(/images/sustainability/common/icon_decarbonized_society_path.svg);
}

.c-title__03.-withIcon.txt.icon04 .icon {
  background-color: #0f8254;
  background-image: url(/images/sustainability/common/icon_good_environment_path.svg);
  height: 130px;
  word-break: break-all;
}

.c-title__03.-withIcon.txt .icon_txt {
  font-size: 20px;
}

@media print,
screen and (min-width: 768px) {
  .c-title__03.-withIcon.txt {
    padding-left: 120px;
  }

  .c-title__03.-withIcon.txt .icon_txt {
    font-size: 28px;
  }
}

@media print,
screen and (min-width: 768px) {
  .c-title__03.-withIcon.txt.icon04 {
    margin-bottom: 85px;
  }
}

@media print,
screen and (max-width: 767px) {
  .c-title__03.-withIcon.txt .icon {
    top: -20px;
  }
}

@media print,
screen and (min-width: 768px) {
  .p-column__wide.logo_wide {
    gap: 50px 40px;
  }
}

@media print {
  .page-break {
    page-break-inside: avoid;
    page-break-after: auto
  }
}

/* header */

@media print,
screen and (min-width: 1024px) {
  .c-imageLink.col-4 li {
    width: calc((100% - 130px) / 4);
  }

  .c-imageLink.col-4 {
    gap: 48px 43px;
  }
}

@media print,
screen and (min-width: 768px) {
  .c-imageLink.col-4 li {
    width: calc((100% - 48px) / 4);
  }

  .c-imageLink.col-4 {
    gap: 16px;
  }
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListProducts.p-nav__childListLength>li {
    max-width: 300px;
  }

  .p-nav__childListProducts.p-nav__childListLength {
    flex-direction: row;
  }
}

.p-nav__childListText {
  font-weight: 700;
  line-height: 1.45;
  font-size: 15px;
  pointer-events: none;
  color: #002153;
}

@media print,
screen and (min-width: 1024px) {
  .p-nav__childListText {
    font-size: 14px;
  }
}

@media print,
screen and (min-width: 768px) {
  .p-sitemap__childList.length>li {
    width: calc((100% - 192px) / 2);
  }
}

@media print {
  .page-break {
    page-break-inside: avoid;
    page-break-after: auto
  }
}

/* accordion environment */

.accordion-content {
  display: none;
}

.accordion-content.open {
  display: block;
}

.accordion-content {
  margin-top: 30px;
}

.accordion-button {
  display: block;
  margin: 20px 0;
  padding: 10px;
  cursor: pointer;
  text-align: center;
  position: relative;
  padding-right: 30px;
}

.accordion-button::after {
  content: '';
  background: url(/images/about/CI/icon_arrowDown_blue.svg);
  background-size: 16px 16px;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 50%;
  margin-left: 5px;
  transform: translateY(-50%);
  transition: transform .3s ease;
}

.accordion-button.open::after {
  transform: translateY(-50%) rotate(180deg);
}