.ci {
  position: relative;
  overflow: hidden;
}

.ci .container {
  --container-width: 1200px;
}

.ci .bg {
  position: absolute;
  top: 20px;
  right: -70px;
  width: 40.6%;
  aspect-ratio: 26 / 15;
  height: auto;
  background-repeat: no-repeat;
  background-size: contain;
}

.ci .content-title h2 ~ p {
  margin-top: 40px;
}

.ci .content-title .mean {
  margin-top: 20px;
}

.ci .content-title .mean h5 {
  line-height: 1.8;
  font-weight: 600;
}

.ci .content-title .mean h5 span {
  font-weight: 800;
}

.ci .box-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  column-gap: 30px;
  margin-top: 100px;
}

.box-wrap .logo-type ~ .logo-type {
  margin: 0;
}

.box-wrap .logo-type {
  flex: 1;
}

.logo-type ~ .logo-type,
.logo-type ~ .color-system {
  margin-top: 100px;
}

.logo-type .title,
.color-system .title {
  margin-bottom: 30px;
}

.logo-type .title h4,
.color-system .title h4 {
  font-size: 24px;
  line-height: 1;
}

.logo-type .tit-wrap {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}

.logo-type .item {
  width: 100%;
  height: auto;
  aspect-ratio: 2/1;
  border: 1px solid #eee;
  position: relative;
}

.logo-type .item .pattern-grid {
  background-image: linear-gradient(#eee 1px, transparent 1px),
    linear-gradient(to right, #eee 1px, transparent 1px);
  background-size: 3.125% 6.25%;
  width: 100%;
  height: 100%;
  position: absolute;
  top: -1px;
  left: -1px;
  z-index: -1;
}

.logo-type .item.full {
  aspect-ratio: 4/1;
}

.logo-type .item.full .pattern-grid {
  background-size: 1.5625% 6.25%;
}

.logo-type .image {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.type1 img {
  height: 50%;
}

.type2 img {
  width: 80%;
}

.type3 img {
  width: 56.5%;
}

.type4 img {
  width: 84%;
}

.color-system .grid {
  --grid-num: 3;
  --grid-t-num: 2;
  --grid-m-num: 1;
}

.color-system .color-item {
  display: flex;
  align-items: center;
  gap: 30px;
}

.color-system .color {
  width: 27.5%;
  aspect-ratio: 1/1;
}

.color-system .text {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  height: 100%;
}

.color-system .text p b {
  display: block;
}

/* Desktop ( 1024px ~)*/
@media all and (min-width: 1024px) {
}

/* Laptop ( 1024px ~ 1360px)*/
@media all and (min-width: 1024px) and (max-width: 1360px) {
  .color-system .grid {
    --grid-num: 2;
  }
}

/* Tablet ( 768px ~ 1023px)*/
@media all and (min-width: 768px) and (max-width: 1023px) {
  .ci .box-wrap {
    margin-top: 80px;
  }

  .logo-type ~ .logo-type,
  .logo-type ~ .color-system {
    margin-top: 80px;
  }

  .logo-type .title,
  .color-system .title {
    margin-bottom: 20px;
  }

  .logo-type .title h4,
  .color-system .title h4 {
    font-size: 20px;
  }

  .logo-type .item .pattern-grid {
    background-size: 4.56% 9.12%;
  }

  .logo-type .item.full .pattern-grid {
    background-size: 2.1% 8.4%;
  }

  .color-system .color-item {
    gap: 20px;
  }

  .color-system .text {
    row-gap: 10px;
  }

  .color-system .text p {
    font-size: 14px;
  }
}

/* Mobile ( ~ 767px)*/
@media all and (max-width: 767px) {
  .ci .bg {
    top: 30px;
    right: -40px;
  }

  .ci .content-title h2 ~ p {
    margin-top: 25px;
  }

  .ci .content-title .mean h5 {
    font-size: 15.5px;
  }

  .ci .box-wrap {
    display: block;
    margin-top: 60px;
  }

  .logo-type ~ .logo-type,
  .logo-type ~ .color-system,
  .box-wrap .logo-type ~ .logo-type {
    margin-top: 60px;
  }

  .logo-type .title,
  .color-system .title {
    margin-bottom: 20px;
  }

  .logo-type .title h4,
  .color-system .title h4 {
    font-size: 18px;
  }

  .logo-type .item .pattern-grid,
  .logo-type .item.full .pattern-grid {
    background-size: 3.875% 7.75%;
  }

  .logo-type .item.full {
    aspect-ratio: 2/1;
  }

  .color-system .color-item {
    gap: 20px;
  }

  .color-system .color {
    max-width: 120px;
  }
}
