* {letter-spacing: -0.01em;}
ul {list-style: none; padding: 0;}
.sub-top {background: url("/html/_img/sub/solution/top_bg_solution.png") no-repeat center / cover;}
#sub_wrap {padding: clamp(6rem, 8.3vw, 16rem) 0;}
.sub-wrap {padding: 0;}

.common-top-title {display: flex; flex-direction: column; align-items: center; margin-bottom: clamp(6rem, 6.3vw, 12rem);}
.common-top-title img {width: clamp(8rem, 6vw, 11.4rem);}
.common-top-title h2 {font-size: clamp(2.3rem, 2vw, 3.6rem); font-weight: 700; line-height: 1.3; margin-top: 2rem; position: relative; z-index: 2;
}

.common-title-box {display: flex; align-items: center; gap: 1.5rem;}
.common-title-box span {font-size: clamp(2.5rem, 2.1vw, 4rem); font-weight: 700; color: #e6303d;}
.common-title-box h3 {font-size: clamp(2rem, 1.3vw, 2.4rem); font-weight: 600; color: #000;}

.quote::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: clamp(2.5rem, 2.6vw, 5rem);
  width: clamp(5rem, 5.2vw, 10rem);
  height: clamp(7rem, 7.3vw, 14rem);
  background: url("/html/_img/sub/solution/icon-quote.png") no-repeat 0 / contain;
  z-index: -1;
}

@media (max-width: 768px) {
  .quote::before {top: 15%;}
}

/* xenopure.php */
.xeno-container .sec01,
.xenoq-container .sec01,
.molecular-container .sec01 {
  padding-bottom: clamp(6rem, 6.3vw, 12rem);
}
.xeno-container .sec01 .contents-wrap .content-wrap {
  display: flex;
  flex-direction: column;
  gap: clamp(4rem, 4.2vw, 8rem);
  padding-left: clamp(3rem, 3.1vw, 6rem);
}
.xeno-container .sec01 .contents-wrap .content-wrap p {
  font-size: clamp(2rem, 1.3vw, 2.4rem);
  line-height: 1.4;
}
.xeno-container .sec01 .contents-wrap .image-box {
  margin-top: 6rem;
}
.xeno-container .sec01 .contents-wrap .image-box img {
  width: 100%;
}

.xeno-container .sec02 {
  background: #f5f5f5;
  padding: clamp(6rem, 8.3vw, 16rem) 0;
}
.xeno-container .sec02 .contents-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4rem;
}
.xeno-container .sec02 .contents-box .list-wrap {
  margin-top: clamp(4rem, 4.2vw, 8rem);
}
.xeno-container .sec02 .contents-box .list-wrap ul {
  display: flex;
  justify-content: center;
  gap: clamp(2rem, 4vw, 8rem);
}
.xeno-container .sec02 .contents-box .list-wrap ul li {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  width: 100%;
}
.xeno-container .sec02 .contents-box .list-wrap ul li img {
  width: clamp(12rem, 12vw, 20rem);
  height: clamp(12rem, 12vw, 20rem);
}
.xeno-container .sec02 .contents-box .list-wrap ul li p {
  font-size: clamp(1.6rem, 0.9vw, 1.8rem);
  font-weight: 500;
  color: #000;
  text-align: center;
}
.xeno-container .sec02 .contents-box .result-wrap {
  display: flex;
  justify-content: center;
  gap: clamp(1rem, 1vw, 2rem);
  width: 100%;
}
.xeno-container .sec02 .contents-box .result-wrap p {
  font-size: clamp(1.6rem, 1vw, 2rem);
  font-weight: 700;
  max-width: 69rem;
  width: 100%;
  color: #fff;
  background: #e8332c;
  border: 1px solid #b90700;
  padding: clamp(1.5rem, 1.6vw, 3rem) clamp(1rem, 1vw, 2rem);
  text-align: center;
  border-radius: 1.5rem;
}
.xeno-container .sec02 .contents-box .arrow-img {
  width: clamp(4rem, 3.1vw, 6rem);
}

.xeno-container .sec03 {
  padding-top: clamp(6rem, 6.3vw, 12rem);
}
.xeno-container .sec03 .grid-wrap {
  margin-top: clamp(2rem, 2.1vw, 4rem);
}
.xeno-container .sec03 .grid-wrap ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
.xeno-container .sec03 .grid-wrap ul li {
  display: flex;
  justify-content: space-between;
  padding: clamp(2.5rem, 2.2vw, 4rem);
  border: 1px solid #ddd;
  border-radius: 1rem;
}
.xeno-container .sec03 .grid-wrap ul li h5 {
  font-size: clamp(1.8rem, 1.3vw, 2.4rem);
  font-weight: 600;
  line-height: 1.3;
  color: #000;
  margin-bottom: 1.5rem;
}
.xeno-container .sec03 .grid-wrap ul li p {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  font-size: clamp(1.6rem, 0.9vw, 1.8rem);
  line-height: 1.4;
  color: #555;
}
.xeno-container .sec03 .grid-wrap ul li p span {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.xeno-container .sec03 .grid-wrap ul li p i {
  display: inline-block;
  width: .4rem;
  height: .4rem;
  background: #e6303d;
  border-radius: 100%;
  flex-shrink: 0;
}
.xeno-container .sec03 .grid-wrap ul li .image-wrap img {
  width: 100%;
}

@media (max-width: 768px) {
  .xeno-container .sec03 .grid-wrap ul {
    grid-template-columns: 1fr;
  }
  .xeno-container .sec02 .contents-box .list-wrap ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
  .xeno-container .sec03 .grid-wrap ul li .image-wrap {
    width: 40%;
  }
}

@media (max-width: 480px) {
  .xeno-container .sec02 .contents-box .list-wrap ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .xeno-container .sec03 .grid-wrap ul li {
    flex-direction: column;
  }
  .xeno-container .sec03 .grid-wrap ul li .image-wrap {
    margin-left: auto;
    margin-top: 2rem;
  }
}
 
/* xenoq.php */
.xenoq-container .sec01 .sequence-wrap {
  margin-top: clamp(3rem, 3.1vw, 6rem);
  padding-left: clamp(2.5rem, 2.6vw, 5rem);
}
.xenoq-container .sec01 .sequence-wrap .title-box {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 1vw, 2rem);
  margin-bottom: 3.2rem;
}
.xenoq-container .sec01 .sequence-wrap .title-box span {
  font-size: clamp(1.6rem, 1vw, 2rem);
  font-weight: 600;
  color: #e6303d;
  border: 2px solid #e6303d;
  border-radius: 3rem;
  padding: clamp(0.6rem, 0.4vw, 0.8rem) clamp(1.2rem, 1.2vw, 1.6rem);
}
.xenoq-container .sec01 .sequence-wrap .title-box span b {
  font-size: clamp(1.8rem, 1.1vw, 2.2rem);
  font-weight: 700;
}
.xenoq-container .sec01 .sequence-wrap .title-box p {
  font-size: clamp(1.6rem, 0.9vw, 1.8rem);
  font-weight: 600;
  color: #555;
}
.xenoq-container .sec01 .sequence-wrap .list-wrap ul {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(1rem, 1vw, 2rem);
}
.xenoq-container .sec01 .sequence-wrap .list-wrap ul li img {
  width: clamp(4.3rem, 4.9vw, 9.4rem);
}
.xenoq-container .sec01 .sequence-wrap .list-wrap ul li.text {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 12.2rem;
  font-size: clamp(1.8rem, 1.1vw, 2.2rem);
  font-weight: 600;
  color: #fff;
  background: #e8332c;
  border: 1px solid #b90700;
  border-radius: 1.5rem;
  padding: 3rem 2rem;
}
.xenoq-container .sec01 .image-wrap {
  text-align: center;
  margin-top: clamp(3rem, 3.1vw, 6rem);
}
.xenoq-container .sec01 .image-wrap img {
  width: 100%;
  max-width: 1080px;
}

.xenoq-container .sec02 {
  background: #f5f5f5;
  padding: clamp(6rem, 8.3vw, 16rem) 0;
}
.xenoq-container .sec02 .image-wrap {
  display: flex;
  justify-content: center;
  margin-top: clamp(3rem, 3.1vw, 6rem);
}
.xenoq-container .sec02 .image-wrap img {
  width: 100%;
  max-width: 700px;
  min-width: 0;
}

.xenoq-container .sec03 {
  padding-top: clamp(6rem, 6.3vw, 12rem);
}
.xenoq-container .sec03 .circle-wrap {
  margin-top: clamp(3rem, 3.1vw, 6rem);
}
.xenoq-container .sec03 .circle-wrap ul {
  display: flex;
  justify-content: center;
  gap: clamp(4rem, 5.3vw, 12rem);
}
.xenoq-container .sec03 .circle-wrap ul li {
  width: clamp(26rem, 24vw, 32rem); 
  height: clamp(26rem, 24vw, 32rem);
  border-radius: 100%;
  border: clamp(6px, 0.6vw, 10px) solid #e6303d;
  text-align: center;
  padding: 1rem;
  flex-shrink: 0;
}
.xenoq-container .sec03 .circle-wrap ul li div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 100%;
  border: 3px solid #ccc;
}
.xenoq-container .sec03 .circle-wrap ul li span {
  display: block;
  margin-bottom: .5rem;
  font-family: 'Pretendard';
  font-size: clamp(3.5rem, 3.6vw, 7rem);
  font-weight: 700;
  color: #e6303d;
}
.xenoq-container .sec03 .circle-wrap ul li p {
  font-size: clamp(1.8rem, 1.1vw, 2.2rem);
  font-weight: 600;
  line-height: 1.5;
  color: #000;
}
.xenoq-container .sec03 .content-wrap p {
  font-size: clamp(2rem, 1.3vw, 2.4rem);
  line-height: 1.4;
}

@media (max-width: 768px) {
  .xenoq-container .sec02 .image-wrap {
    flex-direction: column;
  }
  .xenoq-container .sec01 .sequence-wrap .list-wrap ul li.text {
    height: 16rem;
  }
  .xenoq-container .sec01 .sequence-wrap .list-wrap ul li.text br {
    display: none;
  }
}

@media (max-width: 480px) {
  .xenoq-container .sec01 .sequence-wrap {
    padding-left: 0;
  }
  .xenoq-container .sec01 .sequence-wrap .list-wrap ul {
    flex-direction: column;
  }
  .xenoq-container .sec01 .sequence-wrap .list-wrap ul li img {
    transform: rotate(90deg);
    margin: 2rem 0;
  }
  .xenoq-container .sec01 .sequence-wrap .list-wrap ul li.text {
    height: auto;
  }
  .xenoq-container .sec03 .circle-wrap ul {
    gap: 1rem;
    justify-content: space-between;
  }
  .xenoq-container .sec03 .circle-wrap ul li {
    width: 48%;
    height: auto;
    aspect-ratio: 1 / 1;
  }
}

@media (max-width: 360px) {
  .xenoq-container .sec03 .circle-wrap ul {
    flex-direction: column;
    gap: 2.5rem;
  }
  .xenoq-container .sec03 .circle-wrap ul li {
    width: 100%;
  }
}

/* molecular.php */
.molecular-container .sec02 {
  padding: clamp(6rem, 6.3vw, 12rem) 0;
}
.molecular-container .circle-wrap {
  margin-top: clamp(3rem, 3.1vw, 6rem);
}
.molecular-container .circle-wrap ul {
  display: flex;
  justify-content: center;
  gap: clamp(2rem, 6.3vw, 12rem);
}
.molecular-container .circle-wrap ul li {
  width: clamp(20rem, 15.6vw, 30rem);
  height: clamp(20rem, 15.6vw, 30rem);
  border-radius: 100%;
  border: clamp(4px, 0.6vw, 10px) solid #0C5A7E;
  text-align: center;
  padding: clamp(0.5px, 0.5vw, 1rem);
  flex-shrink: 0;
}
.molecular-container .circle-wrap ul li div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 100%;
  border: 3px solid #ccc;
}
.molecular-container .circle-wrap ul li span {
  font-family: 'Pretendard';
  display: block;
  margin-bottom: .5rem;
  font-size: clamp(2.2rem, 2.3vw, 5rem);
  font-weight: 700;
  color: #0C5A7E;
}
.molecular-container .circle-wrap ul li span.md {
  margin-bottom: clamp(1rem, 1.6vw, 3rem);
}
.molecular-container .circle-wrap ul li p {
  font-size: clamp(1.3rem, 1.4vw, 2.2rem);
  font-weight: 600;
  line-height: 1.5;
  color: #000;
}

.molecular-container .sec-list {
  background: #f5f5f5;
  padding: clamp(3rem, 3.1vw, 6rem) 0;
}
.molecular-container .sec-list .list-wrap {
  width: fit-content;
  margin: 0 auto;
}
.molecular-container .sec-list .list-wrap ul {
  display: flex;
  flex-direction: column;
  gap: clamp(3rem, 2.1vw, 4rem);
}
.molecular-container .sec-list .list-wrap ul li {
  display: flex;
  gap: clamp(3rem, 3.1vw, 6rem);
}
.molecular-container .sec-list .list-wrap ul li h4 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24rem;
  height: 4.6rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background: #e6303d;
  border-radius: 1rem;
  font-size: clamp(1.7rem, 1.1vw, 2.2rem);
  font-weight: 600;
  text-align: center;
  flex-shrink: 0;
}
.molecular-container .sec-list .list-wrap ul li p {
  font-size: clamp(1.6rem, 1vw, 2rem);
  color: #555;
  line-height: 1.5;
  word-break: keep-all;
}

@media (max-width: 768px) {
  .molecular-container .circle-wrap ul {
    gap: 1.5rem;
  }
  .molecular-container .sec-list .list-wrap ul li h4 {
    width: 18rem;
    height: 4rem;
  }
}

@media (max-width: 520px) {
  .molecular-container .circle-wrap ul {
    gap: .5rem;
  }
  .molecular-container .circle-wrap ul li {
    width: 14rem;
    height: 14rem;
    border-width: 4px;
    padding: .5rem;
  }
}

@media (max-width: 420px) {
  .molecular-container .sec-list .list-wrap ul li {
    flex-direction: column;
    gap: 1.5rem;
  }
}

@media (max-width: 360px) {
  .molecular-container .circle-wrap ul {
    flex-direction: column;
    gap: 2rem;
  }
  .molecular-container .circle-wrap ul li {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    border-width: 6px;
    padding: 1rem;
  }
}