main {
 margin-bottom: 0;
}

section {
 position: relative;
 width: 100%;
}
section h2.line2 {
 position: relative;
 line-height: 1.5;
 margin-bottom: 80px;
 color: var(--color);
 font-family: var(--ff_osw);
 font-weight: 300;
 font-size: 24px;
 text-align: center;
 letter-spacing: 0.06em;

 --color: #ffffff;
}
@media screen and (max-width: 1024px) {
 section h2.line2 {
  margin-bottom: 60px;
  font-size: 20px;
 }
}
section h2.line2:after {
 content: "";
 display: block;
 position: absolute;
 bottom: -30px;
 left: 50%;
 width: 100px;
 height: 10px;
 border-right: 1px solid var(--color);
 border-left: 1px solid var(--color);
 background: linear-gradient(to bottom, transparent 0 calc(50% - 0.5px), var(--color) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px));
 translate: -50% 0%;
}
@media screen and (max-width: 1024px) {
 section h2.line2:after {
  bottom: -20px;
  width: 80px;
  height: 7px;
 }
}
section h2.line2.bl {
 --color: var(--c_bl);
}
section.message_area {
 padding: 0;
}
section.message_area .message_mv {
 height: 660px;
 padding: 0 5%;
 background: #e9f0f7;
}
@media screen and (max-width: 600px) {
 section.message_area .message_mv {
  height: auto;
 }
}
section.message_area .message_mv >.inner {
 display: flex;
 position: relative;
 width: 100%;
 max-width: 750px;
 height: 100%;
 justify-content: space-between;
 margin: 0 auto;
}
section.message_area .message_mv >.inner .president {
 width: auto;
 height: 100%;
 padding-top: 50px;
}
@media screen and (max-width: 600px) {
 section.message_area .message_mv >.inner .president {
  width: 35%;
  padding-top: 30px;
 }
}
section.message_area .message_mv >.inner .president img {
 width: auto;
 height: 100%;
}
@media screen and (max-width: 600px) {
 section.message_area .message_mv >.inner .president img {
  width: 100%;
  height: auto;
 }
}
section.message_area .message_mv >.inner h1 {
 align-self: center;
}
@media screen and (max-width: 600px) {
 section.message_area .message_mv >.inner h1 {
  width: 60%;
 }
}
section.message_area .message_detail {
 padding: 110px 5%;
}
@media screen and (max-width: 1024px) {
 section.message_area .message_detail {
  padding-block: 50px;
 }
}
section.message_area .message_detail >.inner {
 width: 100%;
 max-width: 890px;
 margin: 0 auto;
}
section.message_area .message_detail >.inner p {
 line-height: 2;
 font-size: 18px;
 letter-spacing: 0.06em;
}
@media screen and (max-width: 1024px) {
 section.message_area .message_detail >.inner p {
  font-size: 16px;
 }
}
section.message_area .message_detail >.inner p +p {
 margin-top: 2em;
}
section.message_area .message_detail >.inner p.signature {
 display: flex;
 line-height: 1;
 flex-direction: column;
 margin-top: 2.5em;
 font-size: 22px;
 letter-spacing: 0.06em;
}
@media screen and (max-width: 1024px) {
 section.message_area .message_detail >.inner p.signature {
  font-size: 18px;
 }
}
section.message_area .message_detail >.inner p.signature span {
 margin-bottom: 15px;
 font-size: 0.72em;
}
section.vision_area {
 overflow: hidden;
 padding: 80px 5%;
 background-image: linear-gradient(to right, rgb(32, 70, 165) 0%, rgb(47, 96, 166) 25%, rgb(47, 111, 166) 50%, rgb(47, 96, 166) 75%, rgb(32, 70, 165) 100%);
}
@media screen and (max-width: 1024px) {
 section.vision_area {
  padding-block: 40px;
 }
}
section.vision_area .bg {
 position: absolute;
 width: 25%;
 mix-blend-mode: color-dodge;
}
section.vision_area .bg.bg_L {
 top: 0;
 left: 0;
}
section.vision_area .bg.bg_R {
 right: 0;
 bottom: 0;
}
section.vision_area .bg img {
 width: 100%;
}
section.vision_area >.inner {
 text-align: center;
}
section.vision_area >.inner h3 {
 margin-bottom: 35px;
}
@media screen and (max-width: 1024px) {
 section.vision_area >.inner h3 {
  margin-bottom: 20px;
 }
 section.vision_area >.inner h3 img {
  max-width: 70%;
 }
}
section.vision_area >.inner p {
 line-height: 2;
 margin-bottom: 60px;
 color: #ffffff;
 font-size: 18px;
 letter-spacing: 0.06em;
}
@media screen and (max-width: 1024px) {
 section.vision_area >.inner p {
  margin-bottom: 30px;
  font-size: 16px;
 }
}
section.vision_area >.inner .logo img {
 width: 220px;
}
section.mission_area {
 padding: 100px 5%;
 text-align: center;
}
@media screen and (max-width: 1024px) {
 section.mission_area {
  padding-block: 50px;
 }
}
section.mission_area >.inner {
 width: 100%;
 max-width: 1100px;
 margin: 0 auto;
}
section.mission_area >.inner h3 {
 margin-bottom: 60px;
}
@media screen and (max-width: 1024px) {
 section.mission_area >.inner h3 {
  margin-bottom: 30px;
 }
}
section.mission_area >.inner ul {
 display: grid;
 grid-template-columns: repeat(2, 1fr);
 gap: 60px 45px;
}
@media screen and (max-width: 1024px) {
 section.mission_area >.inner ul {
  grid-template-columns: 1fr;
  gap: 30px 25px;
 }
}
section.mission_area >.inner ul li {
 display: flex;
 line-height: 1.8181818182;
 justify-content: center;
 align-items: center;
 padding: 40px 0;
 border-image-source: url(/wp-content/themes/thermotech/message/img/mission_bg.png);
 border-image-slice: 17 fill;
 border-image-width: 17px;
 border-image-repeat: stretch;
 font-size: 22px;
 letter-spacing: 0.06em;
}
@media screen and (max-width: 1024px) {
 section.mission_area >.inner ul li {
  font-size: 18px;

  padding-block: 30px;
 }
}
@media screen and (max-width: 600px) {
 section.mission_area >.inner ul li {
  font-size: 14px;
 }
}
section.value_area {
 margin-bottom: 140px;
 padding: 100px 0;
 background: #f9f9f9;
}
@media screen and (max-width: 1024px) {
 section.value_area {
  margin-bottom: 70px;
  padding: 50px 5%;
 }
}
section.value_area >.inner h3 {
 margin-bottom: 70px;
 text-align: center;
}
section.value_area >.inner .principles_area {
 display: flex;
 position: relative;
 align-items: center;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area {
  flex-direction: column;
  gap: 40px;
 }
}
section.value_area >.inner .principles_area .graph {
 position: relative;
 left: -50px;
 width: 50vw;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .graph {
  position: static;
  width: 100%;
  text-align: center;
  translate: 0;
 }
}
section.value_area >.inner .principles_area .graph img {
 width: 100%;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .graph img {
  width: 80%;
 }
}
section.value_area >.inner .principles_area .txt_area {
 width: 50%;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .txt_area {
  width: 100%;
 }
}
section.value_area >.inner .principles_area .txt_area >.inner {
 width: 100%;
 max-width: 550px;
 text-align: center;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .txt_area >.inner {
  max-width: 100%;
 }
}
section.value_area >.inner .principles_area .txt_area >.inner h4 {
 margin-bottom: 80px;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .txt_area >.inner h4 {
  margin-bottom: 20px;
 }
}
@media screen and (max-width: 600px) {
 section.value_area >.inner .principles_area .txt_area >.inner h4 img {
  width: 300px;
 }
}
section.value_area >.inner .principles_area .txt_area >.inner dl dt {
 display: flex;
 width: 80px;
 line-height: 1;
 justify-content: center;
 align-items: center;
 margin: 0 auto 15px;
 border: 1px solid #2f60a6;
 border-radius: 100px;
 color: var(--c_bl);
 background: #ffffff;
 font-weight: 400;
 font-size: 22px;
 letter-spacing: 0em;

 aspect-ratio: 1;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .txt_area >.inner dl dt {
  width: 70px;
  margin-bottom: 10px;
  font-size: 20px;
 }
}
section.value_area >.inner .principles_area .txt_area >.inner dl dd {
 line-height: 2;
 font-size: 18px;
 letter-spacing: 0.06em;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .txt_area >.inner dl dd {
  font-size: 16px;
 }
}
section.value_area >.inner .principles_area .txt_area >.inner dl dd:not(:last-child) {
 margin-bottom: 45px;
}
@media screen and (max-width: 1024px) {
 section.value_area >.inner .principles_area .txt_area >.inner dl dd:not(:last-child) {
  margin-bottom: 25px;
 }
}
/*# sourceMappingURL=layout.css.map */