.pc-only {
  display: block;
}

.s .pc-only {
  display: none;
}

.sp-only {
  display: none;
}

.s .sp-only {
  display: block;
}

/* ========== title ========== */
.c-title-main span {
  font-size: clamp(48px, 8vw, 120px) !important;
}

.c-title-sub {
  margin-top: 22px;
}

/* ========== subtitle ========== */

.c-block.philosophy-area {
  margin-top: 49px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.c-content {
  margin-top: 97px;
}

.c-block-title {
  margin-top: 75px;
}

.c-subtitle {
  row-gap: 9px;
}

.philosophy-area .c-lead-red {
  margin-top: 0;
}

.c-lead-lines {
  letter-spacing: -1%;
  padding: 0 !important;
}

.c-lead-line {
  display: block;
  background: #fd0200;
  color: #fff;
  padding: 2px 8px;
}

.c-lead-line-pc + .c-lead-line-pc {
  margin-top: 7px;
}

.c-lead-line-sp + .c-lead-line-sp {
  margin-top: 3px;
}

.c-lead-red {
  background: none !important;
}

.c-lead-line-pc {
  display: inline-block;
  padding: 2px 8px;
  line-height: 1;
}

.c-lead-line-sp {
  display: none;
}

.inner-list {
  margin-top: 33px;
  padding-left: 24px;
}

.inner-list li {
  color: #e60012;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.03em;
  margin-bottom: 24px;
}

.inner-link {
  background: url(../../images/philosophy/bg-bar.webp) center center no-repeat;
  background-size: cover;
  padding: 33px 29px 41px 37px;
  margin-top: 36px;
  margin-bottom: 70px;
}

.inner-link dl dt {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 32px;
  font-weight: 800;
  line-height: 1.5;
}

.inner-link .c-text {
  color: #fff;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 8px;
}

.inner-link dd {
  display: flex;
  align-items: flex-end;
  gap: 85.5px;
}

.inner-link a {
  min-width: 288px;
  height: 60px;
  background: #252525 url(../../images/philosophy/arrow-link.webp) center right 32px no-repeat;
  color: #fff;
  line-height: 60px;
  border-radius: 999px;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
  margin-bottom: -11px;
}

.c-text strong {
  display: block;
  font-weight: 700;
  margin-top: -5px;
  margin-bottom: 20px;
  line-height: 1;
  letter-spacing: -1%;
}

.c-block-title-h4 {
  font-size: 24px;
  font-weight: 700;
  color: #e60012;
  line-height: 1;
  letter-spacing: -1%;
  margin-top: 44px;
  margin-bottom: 30px;
}

.philosophy-izmlist-block li {
  display: block;
  background: #fff;
  border: #f1f1f1 solid 1px;
  margin-bottom: 24px;
}

.philosophy-izmlist dt {
  background: url(../../images/philosophy/icon-plus.webp) center right 30px no-repeat;
  display: block;
  min-height: 36px;
  font-size: 20px;
  font-weight: 700;
  line-height: 36px;
  display: flex;
  align-items: center;
  cursor: pointer;
  padding: 20px 30px;
}

.philosophy-izmlist dt.active {
  background: url(../../images/philosophy/icon-minus.webp) center right 30px no-repeat;
}

.philosophy-izmlist dt span:first-child {
  background: url(../../images/philosophy/icon-list.webp) center left no-repeat;
  padding-left: 26.14px;
}

.philosophy-izmlist dd {
  border-top: #dcdcdc solid 1px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.8;
  padding-top: 20px;
  margin-left: 30px;
  margin-right: 30px;
  overflow: hidden;
  padding: 0;
}

.philosophy-izmlist dd p {
  margin-top: 18px;
  margin-bottom: 20px;
}

.philosophy-oath {
  margin-top: 48px;
  width: 100%;
}

.philosophy-oath dt {
  color: #e60012;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.philosophy-oath dd p {
  display: block;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.8;
  margin-top: 30px;
  text-align: center;
}

.philosophy-oath dd ul {
  text-align: center;
  line-height: 1.5;
  margin-top: 18px;
}

.philosophy-oath dd ul li {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 14px;
}

.philosophy-oath dd ul li:last-child {
  margin-bottom: 0;
}

.philosophy-oath dd ul li span {
  background: url(../../images/philosophy/icon-list.webp) center left no-repeat;
  padding-left: 26.14px;
}

.icon-minus img {
  height: auto;
  width: 100%;
}

.philosophy-img-area {
  margin-top: 32px;
}

.philosophy-img-area ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.philosophy-img-area img {
  object-fit: contain;
  width: 100%;
}

/* ========== sp画面 ========== */
.s .c-page {
  padding-bottom: 60px;
}

.s .c-content {
  margin-top: 70px;
}

.s .c-lead-line-pc {
  display: none;
}
.s .c-lead-line-sp {
  display: inline-block;
}

.s .p-hrd-button {
  width: 178px;
  height: 40px;
  font-size: 10px;
}

.s .c-media-grid-3 {
  grid-template-columns: repeat(2, 1fr);
}

.s .p-hrd-button-icon {
  right: 12px;
  width: 15px;
}

.s .inner-list {
  padding-left: 20px;
  margin-bottom: 24px;
  margin-top: 0;
}

.s .inner-list li {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 14px;
}

.s .inner-link {
  background: url(../../images/philosophy/bg-bar-sp.webp) center center no-repeat;
  background-size: cover;
  padding: 20px;
  margin-top: 30px;
  margin-bottom: 64px;
}

.s .inner-link dl dt {
  font-size: 20px;
}

.s .inner-link dd {
  display: block;
}

.s .inner-link .c-text {
  margin-top: 5px;
}

.s .inner-link a {
  background: #252525 url(../../images/philosophy/arrow-link.webp) center right 19px no-repeat;
  background-size: 10px;
  font-size: 10px;
  display: block;
  min-width: 178px;
  width: 178px;
  height: 40px;
  line-height: 40px;
  margin-left: auto;
  margin-top: 13px;
}

.s .c-block-title.s-block {
  display: block;
  line-height: 1;
  margin-bottom: 32px;
  padding-bottom: 10px;
}

.s .c-block-title.s-block::after {
  content: attr(data-sub);
  display: block;
  margin-top: 8px;
  font-size: 14px;
  font-weight: 700;
}

.s .c-block {
  margin-top: 24px;
}

.s .c-lead {
  margin-bottom: 10px;
}

.s .c-text strong {
  line-height: 1.8;
  margin-top: 32px;
  margin-bottom: 24px;
}

.s .c-block-title-h4 {
  font-size: 18px;
  margin-top: 32px;
  margin-bottom: 22px;
}

.s .philosophy-izmlist li {
  padding: 28px 20px 24px 20px;
  margin-bottom: 20px;
}

.s .philosophy-izmlist dt {
  background: url(../../images/philosophy/icon-plus.webp) center right 20px no-repeat;
  background-size: 34px 34px;
  font-size: 16px;
  line-height: 1.5;
  min-height: 34px;
  padding: 20px 20px;
}

.s .philosophy-izmlist dt.active {
  background: url(../../images/philosophy/icon-minus.webp) center right 20px no-repeat;
  background-size: 34px 34px;
}

.s .icon-minus {
  height: 34px;
  width: 34px;
  min-width: 34px;
  padding-left: 0 !important;
}

.s .philosophy-izmlist dt span {
  padding-left: 18.61px;
  line-height: 1.5;
}

.s .philosophy-izmlist dt span:first-child {
  background-size: 11px;
  width: calc(100% - 34px);
}

.s .philosophy-izmlist .c-text {
  margin-top: 0;
}

.s .philosophy-oath dt {
  font-size: 18px;
}

.s .philosophy-oath dd p {
  font-size: 14px;
  margin-top: 22px;
}

.s .philosophy-oath dd ul li {
  font-size: 16px;
  margin-bottom: 14px;
}

.s .philosophy-oath dd ul li span {
  background: url(../../images/philosophy/icon-list.webp) center left no-repeat;
  background-size: 11px;
  padding-left: 18.61px;
}

.s .philosophy-oath dd ul {
  margin-top: 18px;
}

.s .philosophy-izmlist dd {
  font-size: 14px;
}

.s .philosophy-oath {
  margin-top: 32px;
}

.s .c-block-title {
  margin-top: 60px;
}

.s .c-block.philosophy-area > .c-text {
  margin-bottom: 21px;
}

.s .philosophy-img-area {
  padding-inline: 20px;
}

.s .philosophy-img-area ul {
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
