@charset "UTF-8";

.main-wrap {}
.main-visual {
  position: relative;
}
.main-visual .img-wrap {
  max-width: 100%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.main-visual .img-wrap img {
  width: calc(100% + 15px);
  min-height: 350px;
}
.main-visual .text-wrap {
  max-width: 1280px;
  width: calc(100% - 16px);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  -moz-transform: translate(-50%,-50%);
  -ms-transform: translate(-50%,-50%);
  -o-transform: translate(-50%,-50%);
}

.main-visual .text-wrap.flex-text{
  display:flex;
  justify-content: flex-end;
  text-align: center;
}

.main-visual .text-wrap h3 {
  font-weight: 400;
  font-size: 2.375rem;
  line-height: 1.2;
  color: var(--black);
}
.main-visual .text-wrap h3 span {
  color: var(--mainColor);
  padding-top: 15px;
  font-size: 2.75rem;
}
.main-visual .text-wrap h4 {
  font-weight: 500;
  font-size: var(--size22);
  line-height: 1.59091;
  letter-spacing: -0.03em;
  color: var(--black03);
  margin-top: -5px;
}
.m-content .title {
  font-weight: 700;
  font-size: var(--size36);
  line-height: 1.3888889;
  color: var(--black);
}
.m-content01 {
  background: #5E40DC;
  padding: 2.5rem 0 4.375rem;
}
.m-content01 h3 {
  font-weight: 700;
  font-size: var(--size36);
  line-height: 1.611112;
  text-align: center;
  color:  var(--white);
}
.m-content01 .white-box {
  margin-top: 2.5rem;
  background-color: var(--white);
  padding: 2.8125rem 5rem;
  border-radius: 30px;
  justify-content: space-between;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  -o-border-radius: 30px;
}
.m-content01 .info-box {
  max-width: 500px;
  width: 48%;
}
.m-content01 .info-box h4 {
  font-weight: 700;
  font-size: var(--size24);
  line-height: 1.4166667;
  text-align: center;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* 원하는 줄 수 */
  overflow: hidden;
  /* height: 2.8333334em; */
  max-height: 2.8333334em;
}
.m-content01 .info-box ul {
  margin-top: 1.25rem;
}
.m-content01 .info-box li {
  position: relative;
  font-weight: 500;
  font-size: var(--size18);
  line-height: 1.33333334;
  padding: 5px 0;
  padding-left: 1.75rem;
  color: var(--black);
}
.m-content01 .info-box li::before {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  background-color: var(--black);
  position: absolute;
  top: calc(0.5625rem + 5px);
  left: 11px;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
}
.m-content01 .info-box a {
  width: 10rem;
  height: 3.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 1.25rem auto 0;
  background: var(--mainColor);
  color: var(--white);
  font-weight: 700;
  font-size: var(--size18);
  border-radius:50px;
  -webkit-border-radius:50px;
  -moz-border-radius:50px;
  -ms-border-radius:50px;
  -o-border-radius:50px;
}

.m-content02 {
  margin-top: 6.25rem;
}
.m-content02 .container > .flex-box {
  gap: 6.25rem;
  justify-content: center;
  align-items: flex-start;
}
.m-content02 .left-box {
  max-width: 600px;
  width: 100%;
}
.m-content02 .left-box .top-wrap {
  justify-content: space-between;
}
.m-content02 .left-box .top-wrap a {
  margin-top: 15px;
}
.m-content02 .left-box .top-wrap abbr img{
  display: inline-block;
  transform-origin: 50% 50%;
}
.m-content02 .left-box .top-wrap a:hover img{
  animation: spin-ccw 0.7s linear infinite;
  -webkit-animation: spin-ccw 0.7s linear infinite;
}
.m-content02 .left-box ul {
  margin-top: 3rem;
}
.m-content02 .left-box ul li {
  padding-bottom: 1.875rem;
  border-bottom: 1px solid var(--gray05);
  margin-bottom: 1.9375rem;
}
.m-content02 .left-box ul li:last-child {margin-bottom: 0;}
.m-content02 .left-box ul li h3 {
  font-weight: 500;
  font-size: var(--size18);
  line-height: 1.611112;
  color: var(--black);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.m-content02 .left-box ul li p.date {
  font-weight: 400;
  font-size: var(--size15);
  line-height: 1.6;
  letter-spacing: -0.03em;
  margin-top: var(--size15);
  color: var(--black09);
}
.m-content02 .right-box {
  max-width: 580px;
  width: 100%;
  gap: 1.25rem;
}
.m-content02 .right-box .box {
  width: calc(50% - 0.625rem);
  height: 12.5rem;
  padding: 1.875rem;
  box-sizing: border-box;
  background-repeat: no-repeat;
  background-position: bottom 20px right 20px;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  -ms-border-radius: 10px;
  -o-border-radius: 10px;
  font-weight: 600;
  font-size: var(--size24);
  line-height: 1.5833334;
  color: var(--white);
}
.m-content02 .right-box .box01 {
  background-color: #674ECF;
  background-image: url(/img/main/main_content02_1.png);
}
.m-content02 .right-box .box02 {
  background-color: #4122C3;
  background-image: url(/img/main/main_content02_2.png);
}
.m-content02 .right-box .box03 {
  background-color: #937EEC;
  background-position: bottom 20px right;
  background-image: url(/img/main/main_content02_3.png);
}
.m-content02 .right-box .box04 {
  background-color: #D1C8F7;
  background-image: url(/img/main/main_content02_4.png);
  color: var(--black);
}
.m-content03 {
  padding: 6.25rem 0;
}
.m-content03 .container > .flex-box {
  gap: 7.5rem;
  align-items: center;
}
.m-content03 ul {
  align-items: center;
  justify-content: flex-start;
  gap: 3.75rem;
}
.m-content03 .title {
  padding-bottom: calc(5px + 0.8125rem);
}
.m-content03 ul li .icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6.25rem;
  height: 6.25rem;
  background: rgba(65, 34, 195, 0.08);
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
}
.m-content03 ul li .icon-wrap img {
  display: block;
  max-width: 70%;
  max-height: 70%;
}
.m-content03 ul li p {
  font-weight: 500;
  font-size: var(--size16);
  line-height: 1.625;
  text-align: center;
  color: var(--black);
  margin-top: 10px;
}

@keyframes spin-ccw {
  to { transform: rotate(360deg); -webkit-transform: rotate(360deg); -moz-transform: rotate(360deg); -ms-transform: rotate(360deg); -o-transform: rotate(360deg); }
}