@charset "UTF-8";
/* CSS Document */

.webfont {
  transform: rotate(0.001deg);
}

.over {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.aspect {
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.imgLarge img {
  aspect-ratio: 6 / 4;
  object-fit: cover;
}

.Head {
  background: url(../images/common/head_bg.jpg) center center/cover no-repeat;
  padding: 40px 0;
}

.Head .en {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: clamp(2.6rem, 8.0vw, 8.0rem);
  line-height: 1.1em;
  text-align: center;
  margin-bottom: 14px;
}

.Head h1,
.fAddress h2,
.title1,
.ul4>li h4 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
  line-height: 2.0em;
  font-weight: 600;
  /* display: flex; */
  align-items: center;
  grid-gap: 8px;
  color: #51A9C3;
}

.Head h1::before,
.fAddress h2::before,
.title1::before,
.ul4>li h4::before {
  /* content: '■';
  color: #0067CE;
  display: block; */
}

.subHead {
  margin-bottom: 32px;
}

.subHead>*:not(:last-child) {
  margin-bottom: 8px;
}

.subHead h2 {
  font-size: clamp(2.6rem, 4.8vw, 4.8rem);
  font-family: "Noto Serif JP", serif;
  line-height: 1.3em;
  font-weight: 600;
  white-space: nowrap;
}

.subHead .en {
  color: #51A9C3;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
  line-height: 1.1em;
}

h3 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(1.8rem, 3.2vw, 3.2rem);
  line-height: 1.5em;
  font-weight: bold;
}

.lead {
  max-width: 700px;
  font-size: clamp(1.6rem, 1.6vw, 1.6rem);
  line-height: 1.9em;
  /* font-weight: 500; */
  /* text-align: center; */
  margin: 0 auto;
  /* 水平方向に中央揃え */
  margin-bottom: 20px !important;
}

@media screen and (max-width: 767px) {
  .lead {
    text-align: center;
  }
}

.num {
  font-family: "Inter", system-ui;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}

.textR {
  text-align: right;
}

.width1 {
  max-width: 924px;
}

/* flex */
.flex,
.column2,
.column3,
.column4 {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

.column2 {
  grid-gap: 24px 80px;
}

.column3 {
  grid-gap: 24px 32px;
}

.column4 {
  grid-gap: 12px 40px;
}

.column2>*,
.column3>*,
.column4>* {
  width: 100%;
}

/* COLOR */
.col1 {
  color: #0067CE;
}

/* BG */
.bg1 {
  background: #E1F0FA;
}

.bg1 * {
  /* color: #191919 !important; */
}

.bg2 {
  background: #E8F1FA;
}

.bg3 {
  background: #F5FAFD;
}

.bg4 {
  border: #C8C8C8 1px solid;
}

.bgW {
  background: #FFFFFF;
}

/* TRIANGLE */
.triangle {
  background: #000000;
  width: 60px;
  height: calc(tan(60deg) * 60px / 2);
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.tUp {
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.tRight {
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.tDown {
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.tLeft {
  clip-path: polygon(0 50%, 100% 0, 100% 100%);
}

/* BTN */
.btn {
  width: 100%;
  max-width: 200px;
  margin-left: auto;
  margin-right: auto;
}

.btn>* {
  background: #191919;
  color: #FFFFFF;
  width: 100%;
  height: 56px;
  padding: 0 16px;
  line-height: 56px;
  font-weight: 700;
  text-align: center;
  /* border-radius: 40px; */
  display: block;
}

.bg1 .btn>* {
  background: #FFFFFF;
  color: #51A9C3 !important;
}

@media print,
screen and (min-width: 768px) {
  .btn>*::after {
    border-top: #FFFFFF 2px solid;
    border-right: #FFFFFF 2px solid;
    content: "";
    width: 0.4em;
    height: 0.4em;
    margin-left: 10px;
    display: inline-block;
    position: relative;
    top: -0.1em;
    left: 35%;
    transform: rotate(45deg);
  }
}

.btn>*::after {
  border-top: #FFFFFF 2px solid;
  border-right: #FFFFFF 2px solid;
  content: "";
  width: 0.4em;
  height: 0.4em;
  margin-left: 10px;
  display: inline-block;
  position: relative;
  top: -0.1em;
  transform: rotate(45deg);
}

.contactWrap {
  background: url("../images/common/contact_bg.jpg") center center no-repeat;
  background-size: cover;
  color: #FFFFFF;
  height: 60vw;
  /* padding: 24px 5.33%; */
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.contactWrap .inner>*:not(:last-child) {
  margin-bottom: 32px;
}

.contactWrap .textWrap h2 {
  font-size: clamp(2.0rem, 3.2vw, 3.2rem);
  line-height: 1.5em;
  font-weight: 500;
}

.contactWrap .textWrap .en {
  font-family: "Inter", system-ui;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: clamp(1.6rem, 2.0vw, 2.0rem);
  line-height: 1.5em;
}

.contactWrap .lead {
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
  line-height: 1.8em;
}

.contactWrap .btn>* {
  background: #FFFFFF;
  color: #141414;
}

.home .contactWrap .inner>*:not(:last-child) {
  margin-bottom: 24px;
}

.contactWrap p {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(1.7rem, 2.0vw, 2.0rem);
  font-weight: bold;
}

/* UL */
main ul:not([class])>li,
main ul.space>li {
  padding-left: 1.6em;
  text-align: justify;
}

main ul:not([class])>li::before,
main ul.space>li::before {
  content: '・';
  display: block;
  position: absolute;
  left: 0.3em;
  top: 0;
}

main ul.space>li:not(:last-child) {
  margin-bottom: 16px;
}

.ul1>li:not(:last-child) {
  padding-bottom: 40px;
  margin-bottom: 40px;
}

.ul1>li:not(:last-child)::after {
  content: '';
  border-bottom: #FFFFFF 1px solid;
  width: 100%;
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
}

.ul1>li>*:not(:last-child) {
  margin-bottom: 24px;
}

.ul1 h3 {
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  font-weight: 700;
}

.ul1 p {
  text-align: justify;
}

.ul2>li {
  background: #FFFFFF;
  padding: 32px 16px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 24px;
}

.ul2>li:not(:last-child) {
  margin-bottom: 24px;
}

.ul2>li .note>*:not(:last-child) {
  margin-bottom: 16px;
}

.ul2>li .mapWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 32px 24px;
}

.ul2>li .mapWrap .embed {
  padding-top: 76.25%;
}

.ul2>li .imgWrap {
  /* border-top: #C8C8C8 1px solid; */
  /* padding-top: 32px; */
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 16px 24px;
}

.ul2>li .imgWrap figure img {
  /* margin-bottom: 8px; */
}

.ul2>li .imgWrap figcaption {
  /* font-weight: 700; */
  /* text-align: right; */
}

.ul3>li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 24px 60px;
}

.ul3>li:not(:last-child) {
  margin-bottom: 32px;
}

.ul3>li .note>*:not(:last-child) {
  margin-bottom: 24px;
}

.ul4>li {
  background: #E8F1FA;
  padding: 24px 16px;
}

.ul4>li:not(:last-child) {
  margin-bottom: 16px;
}

.ul5>li {
  border-bottom: #FFFFFF 1px solid;
  padding-bottom: 12px;
  display: flex;
  justify-content: space-between;
  grid-gap: 16px;
}

.ul5>li:not(:last-child) {
  margin-bottom: 12px;
}

.ul6 {}

.ul6>li {
  border: #C8C8C8 1px solid;
  /*max-width: 144px;*/
  border-radius: 50%;
  aspect-ratio: 1 / 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.ul6>li h4 {
  font-size: clamp(1.7rem, 2.0vw, 2.0rem);
  line-height: 1.5em;
}

.ul6>li .en {
  color: #969696;
  font-family: "Inter", system-ui;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(1.0rem, 1.2vw, 1.2rem);
  line-height: 1.5em;
}

.ul7 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 24px 40px;
}

.ul7>li {
  border: #FFFFFF 1px solid;
  background: #FFFFFF;
  width: 100%;
  /* padding: 32px 24px; */
}

.ul7>li h3 {
  padding: 20px 24px;
}

.ul7>li p {
  padding: 0 24px 32px 24px;
}

.ul7>li>*:not(:last-child):not(.num) {
  /* margin-bottom: 16px; */
}

.ol1 {
  counter-reset: item;
}

.ol1>li:not(:last-child) {
  margin-bottom: 40px;
}

.ol1>li>*:not(:last-child) {
  margin-bottom: 24px;
}

.ol1>li>h3 {
  /* padding-left: 1.8em; */
}

.ol1>li>h3::before {
  /* font-family: "Inter", system-ui;
  counter-increment: item;
  content: counter(item, decimal-leading-zero);
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: clamp(1.9rem, 3.4vw, 3.4rem);
  line-height: 1.5em;
  position: absolute;
  left: 0px;
  top: 0px; */
}

.ol1 .ul3>li {
  border: #C8C8C8 1px solid;
  padding: 32px 16px;
  grid-gap: 24px 48px;
}

.ol1 .ul3>li .note h3 {
  font-size: clamp(1.7rem, 2.0vw, 2.0rem);
  color: #51A9C3;
}

.ol1 .ul3>li .note>*:not(:last-child) {
  margin-bottom: 16px;
}

.annotation {}

.annotation>* {
  padding-left: 1.5em;
}

.annotation>*::before {
  content: "※";
  display: block;
  position: absolute;
  left: 0px;
  top: 0px;
}

/* DL */
dl:not([class]) {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-gap: 0.5em 2.0em;
}

.dl1 {
  border-bottom: #191919 1px solid;
}

.dl1>* {
  border-top: #191919 1px solid;
  padding: 24px 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  grid-gap: 16px;
}

.dl1 dt {
  width: 26%;
  font-weight: 700;
}

.dl1 dd {
  flex: 1;
}

.dl1 dd>*:not(:last-child) {
  margin-bottom: 16px;
}

/* iframe */
.embed {
  width: 100%;
  padding-top: 56.25%;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.embed iframe,
.embed object,
.embed embed {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

/* Top */
.Main .over {
  text-align: right;
}

.Main .over::before {
  /* content: '';
  background: url("../images/top/bg1.png") center center no-repeat;
  background-size: contain;
  width: 30vw;
  height: 30vw;
  display: block;
  position: absolute;
  left: -3vw;
  bottom: -10vw; */
}

.Main .over img {
  width: 100vw;
  /* width: 80vw; */
}

@media screen and (max-width: 767px) {
  .Main .over img {
    width: 100vw;
    /* height: 50vh; */
    object-fit: cover;
  }
}

.Main h1 {
  position: absolute;
  left: 0;
  bottom: 0;
  /* top: 6vw; */
}

.Main h1 span {
  font-family: "Noto Serif JP", serif;
  background: #FFFFFF;
  color: #191919;
  margin-bottom: -42.5px;
  /* margin-bottom: 8px; */
  padding: 8px 40px;
  padding-left: 120px;
  font-size: clamp(2.6rem, 4.8vw, 4.8rem);
  line-height: 1.1em;
  font-weight: 500;
  display: block;
}

@media screen and (max-width: 1171px) {
  .Main h1 span {
    margin-bottom: -21.25px;
    padding: 8px 20px;
    padding-left: 60px;
  }
}

@media screen and (max-width: 767px) {
  .Main h1 span {
    margin-bottom: -21.25px;
    padding: 8px 20px;
    padding-left: 20px;
  }
}

.slide_animation {
  margin-bottom: 180px;
  position: relative;
}

.slide_animation::after {
  content: "";
  display: block;
  width: 100%;
  height: 180px;
  background-color: #F5FAFD;
  position: absolute;
  bottom: -180;
  left: 0;
}

@media screen and (max-width: 767px) {
  .slide_animation {
    margin-bottom: 90px;
    position: relative;
  }

  .slide_animation::after {
    content: "";
    display: block;
    width: 100%;
    height: 90px;
    background-color: #F5FAFD;
    position: absolute;
    bottom: -90;
    left: 0;
  }
}

.home .Company {
  background-color: #f5fafd;
  position: relative;
  border-top: 1px solid #CCCCCC;
}

/* 右上の画像 */
.home .Company::before {
  content: "";
  position: absolute;
  top: 0;
  /* 上から0 */
  right: 0;
  /* 右から0 */
  width: 891px;
  /* 画像の幅 */
  height: 513px;
  /* 画像の高さ */
  background-image: url('../images/top/imageA.png');
  /* 画像Aのパス */
  background-size: contain;
  /* 画像のサイズ調整 */
  background-repeat: no-repeat;
}

/* 左下の画像 */
.home .Company::after {
  content: "";
  position: absolute;
  bottom: 0;
  /* 下から0 */
  left: 0;
  /* 左から0 */
  width: 735px;
  /* 画像の幅 */
  height: 471px;
  /* 画像の高さ */
  background-image: url('../images/top/imageB.png');
  /* 画像Bのパス */
  background-size: contain;
  /* 画像のサイズ調整 */
  background-repeat: no-repeat;
}

@media screen and (max-width: 767px) {

  /* 右上の画像 */
  .home .Company::before {
    content: "";
    position: absolute;
    top: 0;
    /* 上から0 */
    right: 0;
    /* 右から0 */
    width: 444.5px;
    /* 画像の幅 */
    height: 256.5px;
    /* 画像の高さ */
    background-image: url('../images/top/imageA.png');
    /* 画像Aのパス */
    background-size: contain;
    /* 画像のサイズ調整 */
    background-repeat: no-repeat;
  }

  /* 左下の画像 */
  .home .Company::after {
    content: "";
    position: absolute;
    bottom: 0;
    /* 下から0 */
    left: 0;
    /* 左から0 */
    width: 367.5px;
    /* 画像の幅 */
    height: 235.5px;
    /* 画像の高さ */
    background-image: url('../images/top/imageB.png');
    /* 画像Bのパス */
    background-size: contain;
    /* 画像のサイズ調整 */
    background-repeat: no-repeat;
  }
}

/* section内の他の要素 */
#Content>section.Company>div>div.btn {
  z-index: 1 !important;
  /* デフォルトの重ね順 */
}

.home .Company .contWrap .note .en,
.home .Service .contWrap .note .en {
  font-family: "Inter", system-ui;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: clamp(6.0rem, 10.0vw, 10.0rem);
  line-height: 1.1em;
  position: absolute;
}

.home .Company .contWrap .note>*:not(:last-child):not(h2),
.home .Service .contWrap .note>*:not(:last-child):not(h2) {
  margin-bottom: 32px;
}

@media screen and (max-width: 767px) {

  .home .Company .contWrap .note>*:not(:last-child):not(h2),
  .home .Service .contWrap .note>*:not(:last-child):not(h2) {
    margin-bottom: 16px;
  }
}

.home .Company .contWrap .note>h2,
.home .Service .contWrap .note>h2 {
  margin-bottom: 24px;
}

.home .Company .itemWrap {
  text-align: center;
}

.home .Company .itemWrap {
  margin-bottom: 64px;
}

.home .Company .itemWrap>*:not(:last-child) {
  margin-bottom: 32px;
}

.home .Company .itemWrap h3 span {
  border-bottom: #0067CE 3px solid;
  padding-bottom: 8px;
  display: inline-block;
}

.home .Company .itemWrap .ul6 {
  display: flex;
  flex-wrap: wrap;
}

.home .Company .contWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  /* grid-gap: 32px 100px; */
  margin-bottom: 50px;
}

.home .Company .contWrap .note .en {
  color: #F0F0F0;
}

.home .Company .contWrap .note p {
  text-align: justify;
}

.home .Service {
  background-image: url("../images/top/bg2.png");
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100vw auto;
}

.home .Service .contWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 56px 0;
}

.home .Service .contWrap .note .en {
  color: rgba(0, 0, 0, 0.1) !important;
  mix-blend-mode: multiply;
}

.home .Service .contWrap .note .title1::before {
  color: #FFFFFF;
}

.service-overview h3 {
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  font-weight: bold;
}

.container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.project_item {
  width: calc(33.33% - 20px);
  /* margin: 10px; */
  /* background-color: #FFFFFF; */
  /* padding: 20px; */
}

/* モバイル用のスタイル */
@media (max-width: 768px) {
  .container {
    display: flex;
    flex-wrap: wrap;
    grid-gap: 5%;
    margin-top: 35px;
  }

  .project_item {
    width: 47.5%;
    margin-bottom: 5%;
    box-sizing: border-box;
  }

  /* 二段目のスタイル */
  .project_item:nth-child(3) {
    width: 47.5%;
    margin: 0 auto;
  }
}

/* 特定の要素のpaddingを解除 */
.no-padding {
  padding: 0;
}

/* Page */
.Page .cont>*:not(:last-child) {
  margin-bottom: 48px;
}

.Page .contWrap {
  display: flex;
  justify-content: space-between;
  grid-gap: 32px 72px;
}

.Page .contWrap .note>*:not(:last-child) {
  margin-bottom: 32px;
}

.Page .contWrap .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Project */
.project-list-container .ul2>li:not(:last-child) {
  /* margin-bottom: 0; */
}

.project-list-container .ul2>li {
  padding: 0;
  background: #F5FAFD;
}

/* Service */
main section:not(.Head):not(.full).Service.Page {
  padding-bottom: 0;
}

.serviceWrap {
  padding-bottom: 136px;
}

@media screen and (max-width: 767px) {
  .serviceWrap {
    padding-bottom: 56px;
  }
}

.serviceWrap .inner .bgW {
  padding: 0 16px;
}

.serviceWrap .inner .bgW>section:not(:last-child):not(.Link)::after {
  /* content: '';
  background: #0067CE;
  width: 100vw;
  height: 1px;
  display: block;
  position: absolute;
  left: calc(50% - 50vw);
  bottom: 0; */
}

.serviceWrap .pNav {
  padding-top: 32px;
  font-weight: 700;
  display: flex;
  grid-gap: 2.0em;
}

.serviceWrap .pNav a {
  display: flex;
  align-items: center;
  grid-gap: 10px;
}

.serviceWrap .pNav a i {
  background: #0067CE;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: block;
}

.serviceWrap .pNav a i::after {
  content: "";
  border-top: #FFFFFF 2px solid;
  border-right: #FFFFFF 2px solid;
  width: 0.4em;
  height: 0.4em;
  margin-left: 10px;
  display: block;
  position: absolute;
  left: calc(50% - 0.9em);
  top: calc(50% - 0.4em);
  transform: rotate(135deg);
}

.License h3 {
  text-align: center;
}

.heading3-stage-rigging-elements {
  font-family: "Noto Serif JP", serif !important;
  font-size: clamp(1.7rem, 2.0vw, 2.0rem);
  text-align: center;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-position: under;
}

.stage_hanging_equipment {
  border: #191919 1px solid;
  padding-top: 48px;
}

.stage_hanging_equipment h3 {
  font-family: "Noto Sans JP", sans-serif;
}

.stage_hanging_equipment>li {
  border: none !important;
  padding: 32px 16px;
  grid-gap: 24px 48px;
}

#stage_mechanism>div>ol>li:nth-child(1)>ul>li:nth-child(2) {
  margin-bottom: 0;
}

#stage_mechanism > div > ol > li:nth-child(1) > ul > li:nth-child(1)::before,
#stage_mechanism > div > ol > li:nth-child(1) > ul > li:nth-child(2)::before{
  content: "";
  position: absolute;
  bottom: -48px;
  /* 下線の上の余白 */
  left: 0;
  right: 0;
  height: 1px;
  /* 下線の高さ */
  background-color: #D9D9D9;
  margin: 48px;
}

@media screen and (max-width: 767px) {
  #stage_mechanism > div > ol > li:nth-child(1) > ul > li:nth-child(1)::before,
  #stage_mechanism > div > ol > li:nth-child(1) > ul > li:nth-child(2)::before {
    content: "";
    position: absolute;
    bottom: -17px;
    /* 下線の上の余白 */
    left: 0;
    right: 0;
    height: 1px;
    /* 下線の高さ */
    background-color: #D9D9D9;
    margin: 16px;
  }
}

#maintenance {
  border-top: 1px solid #CCCCCC;
}

section.RepairSection {
  padding-top: 0 !important;
}

/* Company */
.Overview .partnerWrap {
  padding: 32px 16px;
}

.Overview .partnerWrap>*:not(:last-child) {
  margin-bottom: 8px;
}

.Overview .partnerWrap .column3 {
  grid-gap: 8px 32px;
}

.History {}

/* Contact */
.Contact.Page .telWrap,
.Contact.Page .formWrap {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  padding: 32px 16px;
}

.Contact.Page .telWrap h3,
.Contact.Page .formWrap h3 {
  margin-bottom: 20px;
}

.telWrap {
  text-align: center;
}

.telWrap>*:not(:last-child) {
  margin-bottom: 10px;
}

.telWrap .num * {
  color: #0067CE;
}

.telWrap .num>*:not(:last-child) {
  margin-right: 10px;
}

.telWrap .num span {
  font-size: clamp(2.4rem, 3.8vw, 3.8rem);
  line-height: 1.2em;
}

.telWrap .num a {
  font-size: clamp(3.2rem, 5.6vw, 5.6rem);
  line-height: 1.2em;
}

.telWrap .hour {
  font-size: clamp(1.6rem, 2.0vw, 2.0rem);
  line-height: 1.2em;
}

.formWrap {
  text-align: center;
}


/*SP
-------------------------------------------------------*/
@media screen and (max-width: 767px) {

  /* flex */
  .flex:not(.flexFix) {
    flex-direction: column;
  }

  /* iframe */

  /* BTN*/

  /* UL */

  /* DL */

  /* Top */
  .home .Company,
  .home .Service {
    overflow: hidden;
  }

  .home .Company .itemWrap .sub>*:not(:first-child) {
    margin-bottom: -1.0vw;
  }

  .home .Company .itemWrap .sub .ul6>*:not(:last-child) {
    margin-bottom: -1.0vw;
  }

  .home .Company .itemWrap .ul6>li {
    width: 23%;
  }

  .home .Company .itemWrap .ul6>li:not(:first-child) {
    margin-left: -2%;
  }

  .home .Company .itemWrap .ul6>li:not(:first-child):nth-child(5) {
    margin-left: 10.5%;
  }

  .home .Company .contWrap .note .en,
  .home .Service .contWrap .note .en {
    left: -3.0rem;
    top: -36px;
  }

  .home .Service .contWrap .note h3 {
    margin-bottom: 0 !important;
  }

  .home .Company .contWrap .note,
  .home .Service .contWrap .note {
    flex: 1;
    background-color: #E1F0FA;
    padding: 32px 24px;
  }

  /* Page */
  .Page .contWrap {
    flex-wrap: wrap;
  }

  .Page .contWrap .img {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-bottom: -56px;
  }

  /* Service */

  /* Company */

  /* Recruit */
  .Requirements.Page .column2 {
    grid-gap: 0;

  }

  .Requirements.Page .column2>*:not(:last-child).dl1 {
    border-bottom: none;
  }

  /* Contact */
  .formWrap iframe {
    height: 760px !important;
  }

  .contactWrap {
    height: 100%;
    /* height: 380px; */
    padding: 12.5px;
    /* padding: 40px; */
  }

  .contactWrap .btn>*::after {
    border-top: #141414 2px solid;
    border-right: #141414 2px solid;
    content: "";
    width: 0.4em;
    height: 0.4em;
    margin-left: 10px;
    display: inline-block;
    position: relative;
    top: -0.1em;
    transform: rotate(45deg);
  }
}


/*PC
-------------------------------------------------------*/
@media print,
screen and (min-width: 768px) {

  .imgLarge img {
    aspect-ratio: 4 / 1;
  }

  .Head {
    /* background-position: right -32px bottom -56px; */
    /* background-size: 380px auto; */
    padding: 120px 0;
  }

  .Head h1 {}

  .subHead {}

  /* flex */
  .flex.sb {
    justify-content: space-between;
  }

  .flex.center {
    justify-content: center;
  }

  .flex.vcenter {
    align-items: center;
  }

  .column2>* {
    width: calc((100% - 80px) / 2);
    height: auto;
  }

  .column3>* {
    width: calc((100% - (32px * 2)) / 3);
    height: auto;
  }

  .column4>* {
    width: calc((100% - (40px * 3)) / 4);
    height: auto;
  }

  /* BG */

  /* BTN */
  .btn {}

  .btn>* {
    width: 100%;
    height: 64px;
    padding: 0 25px;
    /* padding: 0 16px; */
    line-height: 64px;
    text-align: justify;
  }

  .btn.pc {
    display: block;
  }

  .btn>*:hover {
    background: #51A9C3;
    color: #FFFFFF;
  }

  .bg1 .btn>*:hover {
    background: #51A9C3;
    color: #FFFFFF !important;
  }

  .contactWrap {
    height: 100%;
    /* height: 380px; */
    padding: 25px;
    /* padding: 40px; */
  }

  .contactWrap .inner>*:not(:last-child) {
    margin-bottom: 48px;
  }

  .home .contactWrap {
    padding: 64px 40px;
  }

  .home .contactWrap .inner>*:not(:last-child) {
    margin-bottom: 32px;
  }

  .home .contactWrap .btn>*:hover {
    color: #FFFFFF;
  }

  .contactWrap .btn>*::after {
    border-top: #141414 2px solid;
    border-right: #141414 2px solid;
    content: "";
    width: 0.4em;
    height: 0.4em;
    margin-left: 10px;
    display: inline-block;
    position: relative;
    top: -0.1em;
    left: 5%;
    transform: rotate(45deg);
  }

  .contactWrap .btn:hover>*::after {
    /* ... */
    border-top: #FFFFFF 2px solid;
    border-right: #FFFFFF 2px solid;
  }

  /* UL */
  .ul1>li:not(:last-child) {
    padding-bottom: 80px;
    margin-bottom: 80px;
  }

  .ul2>li {
    padding: 40px 48px;
    grid-gap: 24px 24px;
    /* grid-gap: 48px 24px; */
  }

  .ul2>li:not(:last-child) {
    margin-bottom: 48px;
  }

  .ul2>li .note {
    width: 27%;
    max-width: 288px;
  }

  .ul2>li .img,
  .ul2>li .mapWrap {
    flex: 1;
  }

  .ul2>li .mapWrap>* {
    width: calc((100% - 24px) / 2);
  }

  .ul2>li .mapWrap .embed {
    padding-top: 32.25%;
  }

  .ul2>li .imgWrap {
    /* padding-top: 48px; */
  }

  .ul2>li .imgWrap>* {
    width: calc((100% - 48px) / 3);
  }

  .ul3>li:not(:last-child) {
    margin-bottom: 56px;
  }

  .ul3>li .note {
    flex: 1;
  }

  .ul3>li .note>*:not(:last-child) {
    margin-bottom: 32px;
  }

  .ul3>li .img {
    width: 40%;
    max-width: 400px;
  }

  .ul4>li {
    padding: 32px 40px;
  }

  .ul4>li:not(:last-child) {
    margin-bottom: 24px;
  }

  .ul7>li {
    width: calc((100% - 40px) / 2);
    padding: 0;
    /* padding: 32px 40px; */
  }

  .ul7>li h3 {
    /* width: calc((100% - 40px) / 2); */
    padding: 32px 40px;
  }

  .ul7>li p {
    /* width: calc((100% - 40px) / 2); */
    padding: 0 40px 32px 40px;
  }

  .ol1>li:not(:last-child) {
    margin-bottom: 100px;
  }

  .ol1>li>*:not(:last-child) {
    margin-bottom: 32px;
  }

  .ol1 .ul3>li {
    padding: 48px;
  }

  .ol1 .ul3>li .note>*:not(:last-child) {
    margin-bottom: 24px;
  }

  /* DL */
  dl:not([class]),
  .dl1 {
    grid-gap: 1.5em 2.0em;
  }

  .dl1 dt {
    width: 32%;
    max-width: 200px;
  }

  /* Top */
  main.home section:not(.Head):not(.full) {
    padding: 120px 0;
    /* padding: 200px 0; */
  }

  .Main .over::before {
    width: 40vw;
    height: 40vw;
    left: -3vw;
    bottom: -15vw;
  }

  .Main .over img {
    width: 100vw;
    /* width: 75vw; */
  }

  .Main h1 {
    left: 0;
    bottom: 0;
    /* top: 8vw; */
  }

  .home .Company .contWrap .note .en,
  .home .Service .contWrap .note .en {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    position: absolute;
    left: -11.0rem;
    top: 0;
  }

  .home .Company .contWrap .note,
  .home .Service .contWrap .note {
    flex: 1;
    background-color: #E1F0FA;
    padding: 70px 55px;
  }

  .home .Company .contWrap .note>*:not(:last-child):not(h2),
  .home .Service .contWrap .note>*:not(:last-child):not(h2) {
    margin-bottom: 48px;
  }

  .home .Company .contWrap .note .btn,
  .home .Service .contWrap .note .btn {
    margin-left: 0;
  }

  .home .Company .itemWrap {
    margin-bottom: 104px;
  }

  .home .Company .itemWrap>*:not(:last-child) {
    margin-bottom: 40px;
  }

  .home .Company .itemWrap .sub {
    padding: 0 26px;
  }

  .home .Company .itemWrap .sub>*:not(:first-child) {
    margin-top: -10px;
  }

  .home .Company .itemWrap .sub>*:nth-child(2n + 2) {
    justify-content: flex-end;
  }

  .home .Company .itemWrap .ul6>li {
    width: 12.65%;
  }

  .home .Company .itemWrap .ul6>li:not(:first-child) {
    margin-left: -1%;
  }

  .home .Company .contWrap .img {
    width: 54%;
    max-width: 648px;
  }

  .home .Company .contWrap .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .home .Service .contWrap>* {
    width: 50%;
  }

  .home .Service::before {
    content: '';
    border-left: #FFFFFF 1px solid;
    height: 100%;
    display: block;
    position: absolute;
    left: 50%;
    top: 0;
  }

  .home .Service .contWrap {
    align-items: flex-start;
  }

  .home .Service .contWrap>.note {
    padding-right: 80px;
    position: sticky;
    left: 0;
    top: 40px;
  }

  .home .Service .contWrap>.sub .ul1>li {
    padding-left: 80px;
  }

  .home .Service .contWrap>.sub .ul1>li:not(:last-child)::after {
    width: 50vw;
  }

  /* Page */
  .Page .cont>*:not(:last-child) {
    margin-bottom: 64px;
  }

  .Page .contWrap {}

  .Page .contWrap>* {
    width: calc((100% - 72px) / 2);
  }

  .Page .contWrap .note>*:not(:last-child) {
    margin-bottom: 40px;
  }

  .Page .contWrap .img {
    width: 50vw;
    margin-right: calc(50% - 50vw);
    margin-top: -136px;
    margin-bottom: -136px;
  }

  .gridWrap {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto 1fr;
    grid-gap: 48px 64px;
  }

  /* Service */
  .serviceWrap .inner .bgW {
    padding: 0 100px;
  }

  .serviceWrap .pNav {
    padding-top: 56px;
    grid-gap: 4.0em;
  }

  /* Company */
  .Overview .partnerWrap {
    padding: 40px;
  }

  .History .inner {
    display: flex;
    justify-content: space-between;
    grid-gap: 40px;
  }

  .History .inner .subHead {
    width: 26%;
  }

  .History .inner .dl1 {
    flex: 1;
  }

  /* Recruit */
  .Requirements.Page .column2 {
    align-items: flex-start;
  }

  /* Contact */
  .Contact.Page .telWrap,
  .Contact.Page .formWrap {
    padding: 56px 48px;
  }

}


.service-list {
  /* display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 24px; */
}

.service-list li {
  font-weight: bold;
}

.service-list li::before {
  content: "";
  display: inline-block;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background-color: #51A9C3;
  margin-right: 9px;
}


.figure--image {
  border: 1px solid #191919;
}

.figcaption--centered {
  padding: 20px;
  /* text-align: center; */
}

.figcaption--centered h4 {
  font-size: clamp(1.7rem, 2.0vw, 2.0rem);
  color: #51A9C3;
}

.heading-underline-serif {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: clamp(2.0rem, 3.2vw, 3.2rem);
  line-height: 1.5em;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-position: under;
}

/* PC (例: 画面幅が768px以上) */
@media (min-width: 768px) {
  .item:nth-child(1) {
    order: 2;
  }

  .item:nth-child(2) {
    order: 1;
  }
}

.Company .inner>*:not(:last-child) {
  margin-bottom: 48px;
}

@media print,
screen and (min-width: 768px) {
  .Company .inner>*:not(:last-child) {
    margin-bottom: 64px;
  }
}

.company-overview {
  /* padding: 32px 16px; */
  z-index: 1 !important;
  /* デフォルトの重ね順 */
}

@media print,
screen and (min-width: 768px) {
  .company-overview {
    padding: 0 120px;
  }
}

/* トップ　納入実績 */
.top-project-section {
  background: url("../images/top/project_background_image.jpg") center center no-repeat;
  background-size: cover;
  color: #FFFFFF;
  /* height: 60vw; */
  /* padding: 24px 5.33%; */
}

.top-project-section .subHead .en {
  color: #FFFFFF;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
  line-height: 1.1em;
}

.top-project-section .headline .ja {
  display: block;
  line-height: 1.75;
  padding-top: 7px;
  font-size: 16px;
  font-family: "Noto Sans JP", sans-serif;
  color: #3E3A39;
}

.top-project-block {
  width: calc(100% - 600px);
  /* width: calc(100% - 350px); */
}

@media screen and (max-width: 1171px) {
  .top-project-block {
    width: calc(100% - 350px);
  }
}

@media screen and (max-width: 767px) {
  .top-project-block {
    width: 100%;
    /* padding: 32px 24px; */
  }
}

.top-project-block::-webkit-scrollbar {
  /* width: 6px; */
}

.top-project-block::-webkit-scrollbar-track {
  background-color: none;
}

.top-project-block::-webkit-scrollbar-thumb {
  background-color: #D9D9D9;
  border-radius: 6px;
}

.top-project-content {
  padding: 25px 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  border-bottom: #D9D9D9 solid 1px;
}

@media screen and (max-width: 767px) {
  .top-project-content {
    display: block;
  }
}

.top-project-content .date {
  display: block;
  width: 120px;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  color: #2F2821;
  letter-spacing: 0.05em;
}

.top-project-content .title {
  font-size: 20px;
  font-weight: 500;
  color: #2F2821;
}

.top-project-content .text-block {
  width: calc(100% - 120px);
}

@media screen and (max-width: 767px) {
  .top-project-content .date {
    display: block;
    width: 100%;
  }

  .top-project-content .title {
    margin-bottom: 15px;
  }

  .top-project-content .text-block {
    width: 100%;
  }
}

@media print,
screen and (min-width: 768px) {
  .top-project-section .inner {
    display: flex;
    justify-content: space-between;
    grid-gap: 80px;
  }
}

/* お知らせ */
.top-news-section .headline .ja {
  display: block;
  line-height: 1.75;
  padding-top: 7px;
  font-size: 16px;
  font-family: "Noto Sans JP", sans-serif;
  color: #3E3A39;
}

@media print,
screen and (min-width: 768px) {
  .flex-news-container {
    display: flex;
    justify-content: space-between;
    grid-gap: 44px;
  }
}

.top-news-block {
  width: calc(100% - 350px);
  height: 300px;
  overflow-y: scroll;
}

@media screen and (max-width: 767px) {
  .top-news-block {
    width: 100%;
    height: 300px;
  }
}

.top-news-block::-webkit-scrollbar {
  width: 6px;
}

.top-news-block::-webkit-scrollbar-track {
  background-color: none;
}

.top-news-block::-webkit-scrollbar-thumb {
  background-color: #D9D9D9;
  border-radius: 6px;
}

.top-news-content {
  padding: 25px 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  border-bottom: #D9D9D9 solid 1px;
}

.top-news-content:first-child {
  border-top: 1px solid #D9D9D9;
}

@media screen and (max-width: 767px) {
  .top-news-content {
    display: block;
  }
}

.top-news-content .date {
  display: block;
  width: 120px;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  color: #2F2821;
  letter-spacing: 0.05em;
}

.top-news-content .title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 500;
  color: #2F2821;
}

.top-news-content .text-block {
  width: calc(100% - 120px);
}

@media screen and (max-width: 767px) {
  .top-news-content .date {
    display: block;
    width: 100%;
  }

  .top-news-content .title {
    margin-bottom: 15px;
  }

  .top-news-content .text-block {
    width: 100%;
  }
}

@media print,
screen and (min-width: 768px) {
  .top-news-section .inner {
    display: flex;
    justify-content: space-between;
    grid-gap: 40px;
  }
}

/* 事業内容 */
@media print,
screen and (min-width: 768px) {
  .flex-container {
    display: flex;
    justify-content: space-between;
    grid-gap: 130px;
  }
}

.jc-start {
  justify-content: flex-start;
}

.ul2>li .gallery-item {
  /* border-top: #C8C8C8 1px solid; */
  /* padding-top: 32px; */
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-gap: 16px 24px;
}

@media print,
screen and (min-width: 768px) {
  .ul2>li .gallery-item {
    /* padding-top: 48px; */
  }

  .ul2>li .gallery-item>* {
    width: 23%;
    /* 各アイテムの幅を23%に設定 */
  }
}

.gallery-item figcaption {
  font-weight: bold;
}

/* 会社案内 */
.greeting {
  max-width: 850px;
  margin-left: auto;
  margin-right: auto;
}

.greeting p {
  /* text-align: justify; */
}

.signature {
  text-align: right;
  margin-top: 20px;
}

.signature span {
  font-size: 20px;
  font-weight: 600;
  color: #51A9C3;
}

.fill-available-space {
  flex: 1;
  text-align: center;
}



/*  */
.parent {
  position: relative;
  /* padding: 20px; */
}

.fixed-svg {
  position: absolute;
  bottom: 0;
  right: 0;
}

/* 納入実績 */
.project_list_nav {
  display: flex;
  justify-content: space-between;
  background: #E1F0FA;
  height: 40px;
  /* margin-bottom: 40px; */
}

.project_list_nav h4 {
  display: flex;
  align-items: center;
  padding-left: 12px;
}

.slideshow-container {
  max-width: 1000px;
  position: relative;
  margin: auto;
}

.gallerySlides {
  display: none;
  /* padding: 8px; */
  text-align: center;
}

.dot {
  height: 15px;
  width: 15px;
  margin: 0 2px;
  background-color: #bbb;
  border-radius: 50%;
  display: inline-block;
  transition: background-color 0.6s ease;
}

.active {
  background-color: #717171;
}

.fade {
  animation-name: fade;
  animation-duration: 1.5s;
}

@keyframes fade {
  from {
    opacity: 0.4
  }

  to {
    opacity: 1
  }
}
@media screen and (min-width: 767px) {
.text-block img{
  max-width: 40%;
}
}