@charset "UTF-8";
body.page-philosophy {
  position: relative;
}
body.page-philosophy .guidebox {
  background: url("../images/guide/東光商会webサイト_理念ページ_PC版.jpg") no-repeat top 0px center;
  height: 7663rem;
}
@media screen and (max-width: 700px) {
  body.page-philosophy .guidebox {
    background: url("../images/guide/東光商会webサイト_理念ページ_スマホ版.jpg") no-repeat top center;
    height: 11386rem;
    background-position: top -38rem center;
    background-size: 100% auto;
  }
}

/* ==========================================================================
   Philosophy (企業理念)
   ========================================================================== */
/* Page Header */
.page_header {
  padding: 238px 0 0;
}
@media screen and (max-width: 700px) {
  .page_header {
    padding: 135rem 0 0;
  }
}
.page_header .page_title {
  padding-left: 50px;
}
@media screen and (max-width: 700px) {
  .page_header .page_title {
    padding-left: 20rem;
  }
}
.page_header .page_title .en {
  font-family: Roboto, sans-serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 0.1em;
  color: #1f1f1f;
  display: block;
  margin-bottom: 14px;
  text-transform: capitalize;
}
@media screen and (max-width: 700px) {
  .page_header .page_title .en {
    font-size: 24rem;
    margin-bottom: 26rem;
  }
}
.page_header .page_title .ja {
  font-family: shippori-mincho, serif;
  font-weight: normal;
  font-size: 42px;
  letter-spacing: 0.15em;
  line-height: 72px;
  color: #1f1f1f;
  display: block;
}
@media screen and (max-width: 700px) {
  .page_header .page_title .ja {
    line-height: 72rem;
  }
}
@media screen and (max-width: 700px) {
  .page_header .page_title .ja {
    font-size: 48rem;
    letter-spacing: 0.2em;
    line-height: 72rem;
  }
}

/* Philosophy Intro */
.philosophy_intro {
  padding-bottom: 0;
}
.philosophy_intro .intro_text {
  margin-top: 88px;
  margin-left: 50px;
  margin-bottom: 86px;
}
@media screen and (max-width: 700px) {
  .philosophy_intro .intro_text {
    margin-top: 78rem;
    margin-left: 20rem;
    margin-bottom: 113rem;
    margin-right: 17rem;
  }
}
.philosophy_intro .intro_text p {
  font-size: 14px;
  letter-spacing: 0.08em;
  line-height: 28px;
  text-align: left;
  color: #1f1f1f;
}
@media screen and (max-width: 700px) {
  .philosophy_intro .intro_text p {
    font-size: 26rem;
    line-height: 52rem;
    letter-spacing: 0.075em;
  }
}
.philosophy_intro .intro_image {
  width: 100%;
  max-width: 100vw;
  margin: 0 auto;
  height: 540px;
  overflow: hidden;
  background: url("../images/philosophy_main.jpg") no-repeat center/cover;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 700px) {
  .philosophy_intro .intro_image {
    height: 360rem;
  }
}

/* Philosophy Sections */
.philosophy_section {
  padding: 120px 0 0;
}
@media screen and (max-width: 700px) {
  .philosophy_section {
    padding: 85rem 0 0;
  }
}
.philosophy_section .inner {
  display: flex;
  justify-content: flex-start;
}
.philosophy_section .section_label {
  width: 140px;
  flex-shrink: 0;
  position: relative;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_label {
    width: 70rem;
    margin-bottom: 0;
  }
}
.philosophy_section .section_label .en {
  font-family: Roboto, sans-serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 0.1em;
  color: #1f1f1f;
  display: block;
  margin-left: 10px;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_label .en {
    font-size: 20rem;
    margin-left: 0;
  }
}
.philosophy_section .section_label::after {
  content: "";
  position: absolute;
  top: 52px;
  left: 30px;
  width: 1px;
  height: calc(100% - 52px);
  background-color: #707070;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_label::after {
    display: block;
    top: 71rem;
    left: 10rem;
    height: calc(100% - 71rem);
  }
}
.philosophy_section .section_content {
  flex: 1;
  padding-top: 44px;
  padding-bottom: 117px;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content {
    margin-left: 0;
    padding: 92rem 0 100rem 0;
  }
}
.philosophy_section .section_content .section_subtitle {
  font-family: shippori-mincho, serif;
  font-weight: normal;
  font-size: 24px;
  letter-spacing: 0.08em;
  line-height: 42px;
  color: #1f1f1f;
  margin-bottom: 34px;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content .section_subtitle {
    font-size: 28rem;
    line-height: 54rem;
    letter-spacing: 0.075em;
    margin-bottom: 28rem;
  }
}
.philosophy_section .section_content .section_title {
  font-family: shippori-mincho, serif;
  font-weight: normal;
  font-size: 42px;
  letter-spacing: 0.15em;
  line-height: 72px;
  color: #1f1f1f;
  margin-bottom: 62px;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content .section_title {
    font-size: 48rem;
    line-height: 84rem;
    letter-spacing: 0.15em;
    margin-bottom: 52rem;
  }
}
.philosophy_section .section_content .section_image {
  width: 840px;
  height: 360px;
  margin-bottom: 46px;
  overflow: hidden;
}
.philosophy_section .section_content .section_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content .section_image {
    width: 100%;
    height: 231rem;
    margin-bottom: 44rem;
  }
}
.philosophy_section .section_content .mission_images {
  display: flex;
  gap: 20px;
  margin-bottom: 49px;
}
.philosophy_section .section_content .mission_images .mission_image {
  width: 460px;
  height: 460px;
  overflow: hidden;
}
.philosophy_section .section_content .mission_images .mission_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content .mission_images {
    gap: 10rem;
    margin-bottom: 44rem;
  }
  .philosophy_section .section_content .mission_images .mission_image {
    width: 260rem;
    height: 260rem;
  }
}
.philosophy_section .section_content .section_body p {
  font-size: 16px;
  letter-spacing: 0.2em;
  line-height: 32px;
  color: #1f1f1f;
}
.philosophy_section .section_content .section_body p:not(:last-child) {
  margin-bottom: 2em;
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content .section_body p:not(:last-child) {
    margin-bottom: 36rem;
  }
}
@media screen and (max-width: 700px) {
  .philosophy_section .section_content .section_body p {
    font-size: 26rem;
    line-height: 52rem;
    letter-spacing: 0.2em;
  }
}

/* Philosophy Vision Specific */
/* Middle Banner Section */
.philosophy_middle_banner {
  width: 100%;
  margin: 0 auto;
}
.philosophy_middle_banner .banner_image {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  height: 540px;
  overflow: hidden;
}
@media screen and (max-width: 700px) {
  .philosophy_middle_banner .banner_image {
    height: 360rem;
  }
}
.philosophy_middle_banner .banner_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Philosophy Purpose Specific */
.philosophy_purpose {
  background-color: rgba(236, 239, 241, 0.5);
  position: relative;
}
.philosophy_purpose .section_title {
  margin-bottom: 58px !important;
}
@media screen and (max-width: 700px) {
  .philosophy_purpose .section_title {
    margin-bottom: 54rem;
  }
}
.philosophy_purpose .section_side_image {
  position: absolute;
  right: 0;
  top: 0;
  width: 320px;
  height: 100%;
  overflow: hidden;
}

/* Philosophy Mission Specific */
.philosophy_mission .section_content .section_title {
  margin-bottom: 56px !important;
}
@media screen and (max-width: 700px) {
  .philosophy_mission .section_content .section_title {
    margin-bottom: 54rem;
  }
}

.fix_logo {
  width: 320px;
  height: 320px;
  position: fixed;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  left: calc(50% + 330px);
  top: 200px;
  z-index: 1;
}
@media screen and (max-width: 700px) {
  .fix_logo {
    display: none;
  }
}

/* Philosophy Standard Specific */
.philosophy_standard {
  background-color: rgba(236, 239, 241, 0.5);
}
.philosophy_standard .section_content {
  padding-top: 50px;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content {
    padding-top: 96rem;
  }
}
.philosophy_standard .section_content .standard_list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 46px;
  margin-top: 97px;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list {
    gap: 82rem;
    margin-top: 82rem;
  }
}
.philosophy_standard .section_content .standard_list .standard_item {
  display: flex;
  justify-content: flex-start;
  border-top: 1px solid #dfdfe0;
  padding-top: 13px;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list .standard_item {
    flex-direction: column;
    gap: 0;
    padding-top: 20rem;
  }
}
.philosophy_standard .section_content .standard_list .standard_item .item_meta {
  width: 300px;
  flex-shrink: 0;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list .standard_item .item_meta {
    width: 100%;
    margin-bottom: 59rem;
  }
}
.philosophy_standard .section_content .standard_list .standard_item .item_meta .tag {
  font-family: Roboto, sans-serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 0.1em;
  color: #1f1f1f;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list .standard_item .item_meta .tag {
    font-size: 20rem;
  }
}
.philosophy_standard .section_content .standard_list .standard_item .item_body {
  flex: 1;
}
@media screen and (min-width: 701px) {
  .philosophy_standard .section_content .standard_list .standard_item .item_body {
    margin-top: 33px;
  }
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list .standard_item .item_body {
    margin-left: 50rem;
  }
}
.philosophy_standard .section_content .standard_list .standard_item .item_body .item_title {
  font-family: shippori-mincho, serif;
  font-weight: normal;
  font-size: 32px;
  letter-spacing: 0.15em;
  color: #1f1f1f;
  margin-bottom: 18px;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list .standard_item .item_body .item_title {
    font-size: 36rem;
    margin-bottom: 20rem;
  }
}
.philosophy_standard .section_content .standard_list .standard_item .item_body .item_desc {
  font-size: 16px;
  letter-spacing: 0.2em;
  line-height: 32px;
  color: #1f1f1f;
}
@media screen and (max-width: 700px) {
  .philosophy_standard .section_content .standard_list .standard_item .item_body .item_desc {
    font-size: 26rem;
    line-height: 52rem;
  }
}

/* Footer Contact Background */
.footer-contact::before {
  background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url("../images/footer_contact_bg_philosophy.jpg");
}
@media screen and (max-width: 700px) {
  .footer-contact::before {
    background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url("../images/footer_contact_bg_philosophy_sp.jpg");
  }
}