#container {
  padding: 0;
  margin: 0 auto 10rem auto;
}

/* vi
------------------------------------ */
#header {
  position: fixed;
  top: 0;
}

#vi {
  margin: 0;
  position: relative;
}
#vi::after {
  content: "Scroll";
  position: absolute;
  bottom: 5rem;
  right: 2rem;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #FFF;
  font-family: "Red Hat Display", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.6rem;
  letter-spacing: 1px;
}
#vi::before {
  content: "";
  width: 1px;
  height: 4rem;
  display: block;
  background: #FFF;
  position: absolute;
  right: 3.3rem;
  bottom: 0;
  z-index: 3;
}
#vi .photo {
  width: 100vw;
  max-width: none;
  margin: 0;
  position: relative;
}
#vi .photo picture {
  position: relative;
  z-index: 0;
}
#vi .photo .text {
  position: absolute;
  top: 50%;
  z-index: 2;
  margin: 0 auto;
  left: clamp(2rem, 50vw - 550px, 50vw - 550px);
  left: 18%;
  transform: translateY(-50%);
  color: #FFF;
}
#vi .photo .text p {
  margin-bottom: 2rem;
  font-size: clamp(1.5rem, 1.4vw, 2rem);
}
#vi .photo .text .lead {
  font-size: clamp(3.2rem, 3.6vw, 5rem);
  line-height: 1.2;
  font-weight: 300;
}
#vi .photo .text .link {
  width: fit-content;
}
#vi .photo .text .link .btn01 {
  padding: 1.5rem 2rem 1.5rem 5rem;
  font-size: clamp(1.3rem, 1.1vw, 1.6rem);
}
@media screen and (max-width: 768px) {
  #vi .photo .text {
    position: absolute;
    top: auto;
    bottom: 4rem;
    transform: none;
    left: 2rem;
    display: grid;
    width: 70%;
  }
  #vi .photo .text p {
    margin-bottom: 2rem;
    font-size: clamp(1.6rem, 1.4vw, 2rem);
  }
  #vi .photo .text .lead {
    line-height: 1.2;
    font-weight: 300;
    margin-bottom: 10cqh;
  }
  #vi .photo .text .link {
    width: fit-content;
  }
  #vi .photo .text .link .btn01 {
    padding: 1.5rem 1rem 1.5rem 3rem;
  }
}

/* #information
------------------------------------ */
#information {
  display: grid;
  grid-template-columns: 28% auto;
  background: #EBF1F1;
  padding-bottom: clamp(4rem, 5.56vw, 8rem);
}
#information .head {
  padding: clamp(4rem, 5.56vw, 8rem) 2rem;
  padding-top: calc(5rem + clamp(4rem, 5.56vw, 8rem) + 4rem);
  padding-left: clamp(2rem, 50vw - 650px, 13rem);
}
#information .head .htype05 h2::before {
  display: none;
}
#information .head .link {
  width: fit-content;
  margin: 0 auto;
}
#information .info {
  background: #FFF;
  padding: clamp(4rem, 5.56vw, 8rem) 4rem;
  padding-right: clamp(2rem, 50vw - 650px, 13rem);
}
#information .info .categoryList {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  max-width: 1100px;
  margin: 0 0 0 0;
}
#information .info .categoryList li a {
  line-height: 1.2;
  background: #CFEDF2;
  display: block;
  padding: 1rem 2rem;
  border-radius: 8px;
  transition: 0.3s;
}
#information .info .categoryList li a.current, #information .info .categoryList li a:hover {
  opacity: 1;
  background: #1D88B9;
  color: #FFF;
}
#information .info .infoList {
  margin: 5rem 0 0;
  display: grid;
  grid-template-columns: min-content max-content 1fr;
  gap: 0 2rem;
  border-top: 1px dotted #D4D4D4;
  padding-top: 1rem;
}
#information .info .infoList > li {
  border-bottom: 1px dotted #D4D4D4;
  padding: 1.5rem 1rem;
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 3;
}
#information .info .infoList > li:nth-child(even) {
  background: #F9FBFB;
}
#information .info .infoList > li p {
  margin-bottom: 0 !important;
}
#information .info .infoList > li .cate li:not(:last-child) {
  margin-bottom: 0.5rem;
}
#information .info .infoList > li .cate li a {
  font-size: 1.4rem;
  border: 1px solid #1D88B9;
  color: #1D88B9;
  border-radius: 50vh;
  display: block;
  padding: 0.5rem 2rem;
  background: #FFF;
  text-align: center;
  line-height: 1;
}
#information .info .link {
  display: none;
}
@media screen and (max-width: 1024px) {
  #information {
    grid-template-columns: 1fr;
    padding: 0 2rem clamp(4rem, 5.56vw, 8rem);
  }
  #information .head {
    padding: clamp(4rem, 5.56vw, 8rem) 2rem;
  }
}
@media screen and (max-width: 768px) {
  #information {
    display: block;
  }
  #information .head {
    padding: clamp(2rem, 2.78vw, 4rem) 0 clamp(4rem, 5.56vw, 8rem);
    position: relative;
  }
  #information .head .htype05 {
    padding-left: 0;
    margin-bottom: 0;
  }
  #information .head .link {
    display: block;
    position: absolute;
    right: 0;
    bottom: clamp(4rem, 5.56vw, 8rem);
  }
  #information .info {
    padding: 0 0 clamp(4rem, 5.56vw, 8rem);
  }
  #information .info .listCover {
    background: #EBF1F1;
    position: relative;
    display: block;
    overflow: scroll;
    width: calc(100vw - 4rem);
  }
  #information .info .categoryList {
    display: flex;
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: 0.75rem;
    margin: 0 0 0 0;
    position: relative;
  }
  #information .info .categoryList li {
    flex-shrink: 0;
  }
  #information .info .categoryList li a {
    line-height: 1.2;
    background: #D5E4E8;
    display: block;
    padding: 0.75rem 1rem;
    border-radius: 3px 3px 0 0;
    transition: 0.3s;
    font-size: 1.5rem;
    white-space: nowrap;
  }
  #information .info .categoryList li a.current, #information .info .categoryList li a:hover {
    opacity: 1;
    background: #FFF;
    color: #444444;
  }
  #information .info .infoList {
    grid-template-columns: min-content 1fr;
    gap: 0 2rem;
    margin: 0;
    border-top: none;
    position: relative;
  }
  #information .info .infoList > li {
    border-bottom: none;
    padding: 1rem 2rem 1rem 2rem;
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
    gap: 1rem;
    position: relative;
  }
  #information .info .infoList > li:after {
    content: "";
    width: calc(100% - 4rem);
    height: 1px;
    position: absolute;
    left: 2rem;
    bottom: 0;
    display: block;
    border-bottom: 1px dotted #D4D4D4;
  }
  #information .info .infoList > li .date {
    order: 1;
  }
  #information .info .infoList > li .cate {
    order: 2;
    display: flex;
    flex-wrap: wrap;
    justify-content: end;
    gap: 0.5rem 0.5rem;
  }
  #information .info .infoList > li .cate li:not(:last-child) {
    margin-bottom: 0;
  }
  #information .info .infoList > li .cate li a {
    font-size: 1.2rem;
    padding: 0.5rem 1rem;
  }
  #information .info .infoList > li .title {
    grid-column: 1/3;
    order: 3;
  }
  #information .info .link {
    position: relative;
    display: block;
    width: fit-content;
    margin: 3rem auto 0;
  }
}

/* #feature
------------------------------------ */
#feature {
  background: #FFF;
  margin: 0;
  padding: clamp(4rem, 5.56vw, 8rem) 2rem;
}
#feature ul {
  width: fit-content;
  display: flex;
  margin: 0 auto;
  justify-content: center;
}
#feature ul li {
  max-width: 500px;
}
#feature ul li a {
  display: block;
  position: relative;
}
#feature ul li a:after {
  content: "";
  width: clamp(2rem, 3.7vw, 5rem);
  aspect-ratio: 1/1;
  border-radius: 3px 0 0 3px;
  background: #FFF url(/lib/img/cmn/icon_arrow_02.png) no-repeat center/contain;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  #feature ul {
    display: block;
  }
}

/* #business
------------------------------------ */
#business {
  background: #EBF1F1;
  margin: 0 0 2rem;
  padding: clamp(2rem, 2.78vw, 4rem) 0;
}
#business .htype05 h2::before {
  background: #FFFFFF;
}
#business .category {
  border-bottom: 18px solid #1D88B9;
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 0;
}
#business .category > li {
  aspect-ratio: 6/7;
}
#business .category > li a {
  color: #FFF;
  position: relative;
  display: flex;
  width: 100%;
  height: 100%;
  padding: clamp(2rem, 2.78vw, 4rem);
  transition: 0.5s;
  z-index: 0;
}
#business .category > li a.menu01 {
  background: url(/lib/img/top/menu_business_01.webp) no-repeat center center/cover;
}
#business .category > li a.menu02 {
  background: url(/lib/img/top/menu_business_02.webp) no-repeat center center/cover;
}
#business .category > li a.menu03 {
  background: url(/lib/img/top/menu_business_03.webp) no-repeat center center/cover;
}
#business .category > li a.menu04 {
  background: url(/lib/img/top/menu_business_04.webp) no-repeat center center/cover;
}
#business .category > li a:before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background: #192D51;
  opacity: 0.36;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  transition: 0.5s;
}
#business .category > li a:after {
  content: "";
  width: clamp(2rem, 3.7vw, 5rem);
  aspect-ratio: 1/1;
  border-radius: 3px 0 0 3px;
  background: #FFF url(/lib/img/cmn/icon_arrow_02.png) no-repeat center/contain;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 2;
}
#business .category > li a:hover {
  opacity: 1;
}
#business .category > li a:hover:before {
  opacity: 0.2;
}
#business .category > li a hgroup {
  z-index: 2;
}
#business .category > li a hgroup p {
  margin: 0 0;
  font-family: "Red Hat Display", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(1.2rem, 1.3vw, 1.8rem);
  font-weight: 800;
  letter-spacing: 0.05em;
  padding-left: -0.05em;
}
#business .category > li a hgroup h2 {
  font-size: clamp(1.8rem, 1.9vw, 2.6rem);
}
@media screen and (max-width: 1024px) {
  #business .category {
    border-bottom: 12px solid #1D88B9;
  }
  #business .category > li a {
    padding: clamp(2rem, 2.78vw, 4rem) clamp(1rem, 0.14vw, 2rem);
  }
}
@media screen and (max-width: 768px) {
  #business .category {
    border-bottom: none;
    grid-template-columns: 1fr 1fr;
  }
}

/* #products
------------------------------------ */
#products {
  background: #314D68;
  border-radius: 8px;
  margin: 0 2rem 2rem;
  padding: clamp(2rem, 2.78vw, 4rem) 2rem;
}
#products .htype05 {
  padding-left: 0;
}
#products .htype05 h2 {
  color: #FFF;
}
#products .htype05 h2::before {
  display: none;
}
#products .htype05 h2::after {
  background: #78CFF4;
}
#products .htype05 p {
  color: #78CFF4;
}
#products > div {
  max-width: 1100px;
  margin: 0 auto clamp(2rem, 2.78vw, 4rem);
}
#products > div h3 {
  color: white;
  text-align: center;
  padding-bottom: 1rem;
  position: relative;
  margin-bottom: 2rem;
  font-size: clamp(1.5rem, 1.4vw, 2rem);
}
#products > div h3::before {
  content: "";
  width: calc(100% + 4rem);
  height: 1px;
  background: #6A849E;
  left: 50%;
  bottom: 0;
  display: block;
  position: absolute;
  transform: translateX(-50%);
}
#products > div h3:after {
  content: "";
  width: 10rem;
  height: 3px;
  background: #CB3C3F;
  left: calc(50% - 5rem);
  bottom: -2px;
  display: block;
  position: absolute;
}
#products .gehealthcare {
  width: 100%;
}
#products .gehealthcare ul {
  display: flex;
  justify-content: center;
  gap: 1rem 1vw;
  flex-wrap: wrap;
}
#products .gehealthcare ul li {
  width: calc(33% - 0.6666666667vw);
  aspect-ratio: 286/130;
}
#products .gehealthcare ul li a {
  color: #FFF;
  position: relative;
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  padding: 2rem 2rem 2rem;
  transition: 0.5s;
  z-index: 0;
}
#products .gehealthcare ul li a.menu01 {
  background: url(/lib/img/cmn/menu_product_ge_01.webp) no-repeat center center/cover;
}
#products .gehealthcare ul li a.menu02 {
  background: url(/lib/img/cmn/menu_product_ge_02.webp) no-repeat center center/cover;
}
#products .gehealthcare ul li a.menu03 {
  background: url(/lib/img/cmn/menu_product_ge_03.webp) no-repeat center center/cover;
}
#products .gehealthcare ul li a.menu04 {
  background: url(/lib/img/cmn/menu_product_ge_04.webp) no-repeat center center/cover;
}
#products .gehealthcare ul li a.menu05 {
  background: url(/lib/img/cmn/menu_product_ge_05.webp) no-repeat center center/cover;
}
#products .gehealthcare ul li a:before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background: #314D68;
  opacity: 0.6;
  border: 2px solid #FFF;
  border-radius: 5px;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  transition: 0.5s;
}
#products .gehealthcare ul li a:hover {
  opacity: 1;
}
#products .gehealthcare ul li a:hover:before {
  opacity: 0.8;
}
#products .gehealthcare ul li a span, #products .gehealthcare ul li a dl {
  position: relative;
  z-index: 2;
  font-size: clamp(1.6rem, 1.3vw, 1.8rem);
  font-weight: 500;
  padding-left: calc(clamp(1.4rem, 1.3vw, 1.8rem) + 1vw);
}
#products .gehealthcare ul li a span::before, #products .gehealthcare ul li a dl::before {
  content: "";
  width: clamp(1.4rem, 1.3vw, 1.8rem);
  aspect-ratio: 1;
  background: #FFF url(/lib/img/cmn/icon_arrow_02.png) no-repeat 0/contain;
  display: block;
  border-radius: 2px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#products .gehealthcare ul li a dl {
  width: 100%;
}
#products .gehealthcare ul li a dl dd {
  margin-top: 0.25rem;
  padding-top: 0.25rem;
  border-top: 1px solid #FFF;
  font-size: clm(1.4, rem, 1.6);
}
#products .general {
  width: 100%;
}
#products .general ul {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 1vw;
}
#products .general ul li a {
  display: block;
  background: rgba(29, 136, 185, 0.6);
  border: 1px solid #FFF;
  padding: 1rem 2rem;
  aspect-ratio: 46/17;
  border-radius: 5px;
  color: #FFF;
  font-size: clamp(1.4rem, 1.3vw, 1.8rem);
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5vw;
}
#products .general ul li a::before {
  content: "";
  width: clamp(1.4rem, 1.3vw, 1.8rem);
  aspect-ratio: 1;
  background: #FFF url(/lib/img/cmn/icon_arrow_02.png) no-repeat 0/contain;
  display: block;
  border-radius: 2px;
  z-index: 2;
}
#products .general ul li a.menu01 {
  background: url(/lib/img/cmn/menu_product_general_01.webp) no-repeat center center/cover;
}
#products .general ul li a.menu02 {
  background: url(/lib/img/cmn/menu_product_general_02.webp) no-repeat center center/cover;
}
#products .general ul li a.menu03 {
  background: url(/lib/img/cmn/menu_product_general_03.webp) no-repeat center center/cover;
}
#products .general ul li a.menu04 {
  background: url(/lib/img/cmn/menu_product_general_04.webp) no-repeat center center/cover;
}
#products .general ul li a:after {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background: #314D68;
  opacity: 0.6;
  border-radius: 5px;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  transition: 0.5s;
}
#products .general ul li a:hover {
  opacity: 1;
}
#products .general ul li a:hover:after {
  opacity: 0.8;
}
#products .general ul li a span {
  z-index: 2;
  font-weight: 500;
}
#products .subContainer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#products .subContainer .sub {
  width: 48%;
}
#products .subContainer .sub h3::before {
  content: "";
  width: calc(100% + 4rem);
  height: 1px;
  background: #6A849E;
  left: 50%;
  bottom: 0;
  display: block;
  position: absolute;
  transform: translateX(-50%);
}
#products .subContainer .sub ul {
  width: 100%;
}
#products .subContainer .sub ul li a {
  display: block;
  background: rgba(29, 136, 185, 0.6);
  border: 1px solid #FFF;
  padding: 1rem 1rem;
  border-radius: 5px;
  color: #FFF;
  font-size: clamp(1.4rem, 1.3vw, 1.8rem);
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5vw;
}
#products .subContainer .sub ul li a::before {
  content: "";
  width: clamp(1.2rem, 1.3vw, 1.8rem);
  aspect-ratio: 1;
  background: #FFF url(/lib/img/cmn/icon_arrow_02.png) no-repeat 0/contain;
  display: block;
  border-radius: 2px;
}
@media screen and (max-width: 1024px) {
  #products .general ul li a {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
@media screen and (max-width: 768px) {
  #products > div {
    margin-top: 3rem;
  }
  #products .gehealthcare ul {
    display: block;
  }
  #products .gehealthcare ul li {
    margin-top: 1rem;
    width: 100%;
  }
  #products .general ul {
    display: block;
  }
  #products .general ul li {
    margin-top: 1rem;
    width: 100%;
  }
  #products .general ul li a {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  #products .subContainer {
    display: block;
  }
  #products .subContainer .sub {
    width: 100%;
    margin-top: 3rem;
  }
}

/* #companyinfo
------------------------------------ */
#companyinfo {
  padding: clamp(2rem, 2.78vw, 4rem) 2rem;
  background: #EBF1F1;
}
#companyinfo .inner {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
#companyinfo .inner > section a {
  aspect-ratio: 65/32;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  position: relative;
  width: 100%;
  height: 100%;
  padding: 0 clamp(2rem, 2.78vw, 4rem) 0 1rem;
}
#companyinfo .inner > section a::before {
  transition: 0.3s;
  width: 100%;
  height: 100%;
  content: "";
  background: #49789F;
  opacity: 0.6;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
#companyinfo .inner > section a:hover {
  opacity: 1;
}
#companyinfo .inner > section a:hover::before {
  opacity: 0.8;
}
#companyinfo .inner > section hgroup {
  position: relative;
  width: fit-content;
  color: #FFF;
  z-index: 2;
}
#companyinfo .inner > section hgroup h2 {
  font-family: "Red Hat Display", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(2.4rem, 2.6vw, 3.6rem);
  font-weight: 800;
  letter-spacing: 0.05em;
  padding-left: -0.05em;
  margin-block: calc((1cap - 1lh) / 2);
}
#companyinfo .inner > section hgroup p {
  margin: 0.5rem 0 0 0;
}
#companyinfo #company {
  background: url(/lib/img/top/bg_company.webp) no-repeat center/cover;
}
#companyinfo #access {
  background: url(/lib/img/top/bg_access.webp) no-repeat center/cover;
}
@media screen and (max-width: 768px) {
  #companyinfo .inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  #companyinfo .inner > section a {
    aspect-ratio: 12/5;
    padding-left: 50%;
    justify-content: flex-start;
  }
  #companyinfo #company {
    background: url(/lib/img/top/bg_company_sp.webp) no-repeat center/cover;
  }
  #companyinfo #access {
    background: url(/lib/img/top/bg_access_sp.webp) no-repeat center/cover;
  }
}

/* #recruit
------------------------------------ */
#recruit {
  background: url(/lib/img/top/bg_recruit.webp) no-repeat center/cover;
  padding: clamp(2rem, 2.78vw, 4rem) 2rem;
}
#recruit .inner {
  max-width: 1100px;
  margin: 0 auto;
}
#recruit .box {
  background: rgba(255, 255, 255, 0.7);
  border-radius: 5px;
  padding: clamp(2rem, 2.78vw, 4rem) 2rem;
  max-width: 60%;
  text-align: center;
}
#recruit .box h2 {
  font-family: "Red Hat Display", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(2.4rem, 3.4vw, 4.8rem);
  font-weight: 800;
  letter-spacing: 0.1em;
  padding-left: -0.1em;
  margin-bottom: 1.5rem;
  color: #1E89BA;
}
#recruit .box .link {
  width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  #recruit {
    background: url(/lib/img/top/bg_recruit_sp.webp) no-repeat center/cover;
  }
  #recruit .box {
    max-width: 55%;
    padding: clamp(2rem, 2.78vw, 4rem) 1rem;
  }
  #recruit .box h2 {
    margin-bottom: 0.5rem;
  }
}