main {
  overflow-x: hidden;
}

section {
  scroll-margin-top: 140px;
}

.sec_label {
  font-size: clamp(17px, 0.94vw, 18px);
  font-weight: 600;
}

.sec_tit {
  font-size: clamp(29px, 2.08vw, 40px);
  line-height: 1.4; /* 56px */
  white-space: nowrap;
  font-weight: 600;
}

.sec_txt {
  font-size: clamp(20px, 1.25vw, 24px);
  line-height: 1.58;
  font-weight: 500;
}

#snb {
  position: fixed;
  width: calc((100vw - 1420px) / 2);
  top: 140px;
  left: 0;
  z-index: 10;
}
#snb div {
  flex-direction: column;
}
#snb a {
  width: auto;
  font-weight: 600;
  color: #ccc;
  margin-bottom: clamp(37px, 1.93vw, 37px);
}
#snb a.on {
  color: var(--color-point);
}
#snb a:last-child {
  margin-bottom: 0;
}

/* ----- sec1 ----- */
.sec1 .container {
  gap: clamp(10px, 1.04vw, 20px);
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: clamp(280px, 15.63vw, 300px) clamp(160px, 15.63vw, 300px) clamp(190px, 14.32vw, 275px);
  grid-template-areas: "swiper swiper swiper swiper" "box2 box2 box3 box3" "box2 box2 box4 box5";
}
.sec1 .container .box {
  border-radius: 10px;
  overflow: hidden;
}
.sec1 .container .box1 {
  grid-area: swiper;
}
.sec1 .container .box2 {
  grid-area: box2;
}
.sec1 .container .box3 {
  grid-area: box3;
}
.sec1 .container .box4 {
  grid-area: box4;
}
.sec1 .container .box5 {
  grid-area: box5;
}

#mainSwiper {
  width: 100%;
  overflow: hidden;
  position: relative;
}
#mainSwiper .swiper-slide {
  position: relative;
}
#mainSwiper img {
  overflow: hidden;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transition: transform 0s;
  transform-origin: center center;
}
#mainSwiper .txt_box {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  padding: clamp(40px, 4.43vw, 85px) clamp(20px, 4.17vw, 80px);
}
#mainSwiper h2 {
  font-size: clamp(30px, 1.67vw, 32px);
  line-height: 1.38; /* 44px */
  font-weight: 700;
  margin-bottom: 14px;
  color: #fff;
}
#mainSwiper h2 span {
  letter-spacing: 0.05em;
  transform: scale(1.4);
  opacity: 0;
  transition: letter-spacing 0s, opacity 0s;
}
#mainSwiper p {
  font-size: clamp(19px, 1.04vw, 20px);
  line-height: 1.4; /* 28px */
  color: #fff;
}
#mainSwiper p .word {
  display: inline-block;
  opacity: 0;
  transform: translateX(-2px);
  margin-right: 0.01em;
}
#mainSwiper .swiper-slide-prev img {
  transform: scale(1.1);
}
#mainSwiper .swiper-slide-active img {
  transform: scale(1.1);
  transition: 9s;
}
#mainSwiper .swiper-slide-active h2 span {
  opacity: 1;
  letter-spacing: 0;
  transform: scale(1);
  transition: letter-spacing 1.5s ease-out, opacity 1s;
}
#mainSwiper .swiper-slide-active h2 span:nth-of-type(2) {
  transition-delay: 0.6s;
}
#mainSwiper .swiper-slide-active p .word {
  opacity: 1;
  transform: translateX(0);
  transition: all 0.9s ease-out;
}
#mainSwiper .swiper-slide-active p .word:nth-child(1) {
  transition-delay: 1.9s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(2) {
  transition-delay: 2s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(3) {
  transition-delay: 2.1s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(4) {
  transition-delay: 2.2s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(5) {
  transition-delay: 2.3s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(6) {
  transition-delay: 2.4s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(7) {
  transition-delay: 2.5s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(8) {
  transition-delay: 2.6s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(9) {
  transition-delay: 2.7s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(10) {
  transition-delay: 2.8s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(11) {
  transition-delay: 2.9s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(12) {
  transition-delay: 3s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(13) {
  transition-delay: 3.1s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(14) {
  transition-delay: 3.2s;
}
#mainSwiper .swiper-slide-active p .word:nth-child(15) {
  transition-delay: 3.3s;
}
#mainSwiper .swiper-pagination {
  bottom: 10px;
  top: unset;
}
#mainSwiper .swiper-pagination-bullet {
  width: 7px;
  height: 7px;
  background: #fff;
  opacity: 0.5;
  margin: 0 5px;
}
#mainSwiper .swiper-pagination-bullet-active {
  background-color: var(--color-point);
  opacity: 1;
}

.sec1 h4 {
  font-weight: 600;
  text-transform: uppercase;
}
.sec1 .box2 a {
  height: 100%;
  flex-direction: column;
}
.sec1 .box2 a:hover img {
  transform: scale(1.03);
}
.sec1 .box2 a:hover span {
  background: #fff;
  color: #222;
}
.sec1 .box2 .img_box {
  flex: 1;
  min-height: 0;
  width: 100%;
  position: relative;
}
.sec1 .box2 .img_box img {
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: 0.6s;
}
.sec1 .box2 .img_box::after {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  content: "";
  background: rgba(0, 0, 0, 0.3);
  z-index: 1;
}
.sec1 .box2 .txt_box {
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  background: #1f1e1c;
  color: #fff;
  padding: clamp(20px, 2.6vw, 50px);
  gap: clamp(30px, 2.08vw, 40px);
}
.sec1 .box2 p {
  font-size: clamp(16px, 1.67vw, 32px);
  font-weight: 600;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  word-break: break-all;
}
.sec1 .box2 span {
  padding: clamp(8px, 0.78vw, 15px) clamp(12px, 1.25vw, 24px);
  font-size: clamp(13px, 0.83vw, 16px);
  border: 1px solid #fff;
  border-radius: 25px;
  transition: 0.5s;
}
.sec1 .box3 {
  height: 100%;
}
.sec1 .box3 a {
  height: 100%;
  width: 100%;
  position: relative;
}
.sec1 .box3 a::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
}
.sec1 .box3 a:hover img {
  transform: scale(1.03);
}
.sec1 .box3 img {
  height: 100%;
  object-fit: cover;
  transition: 0.6s;
}
.sec1 .box3 .txt_box {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: clamp(15px, 1.56vw, 30px);
  flex-direction: column;
}
.sec1 .box3 h4 {
  color: #fff;
}
.sec1 .box3 p {
  color: #fff;
  font-size: clamp(16px, 1.04vw, 20px);
  font-weight: 600;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.sec1 .box4 i,
.sec1 .box5 i {
  width: 12px;
  height: 12px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  transition: 0.3s;
}
.sec1 .box4 > a:hover i,
.sec1 .box5 > a:hover i {
  transform: translate(4px, -4px);
}
.sec1 .box4 {
  background: var(--color-point);
  padding: clamp(15px, 1.56vw, 30px);
  color: #fff;
}
.sec1 .box4 > a {
  width: 100%;
}
.sec1 .box4 h4 {
  color: #fff;
}
.sec1 .box4 i {
  background-image: url(../img/link_w_ico.svg);
}
.sec1 .box4 .links {
  font-size: clamp(15px, 1.04vw, 20px);
  font-weight: 600;
}
.sec1 .box4 .links a {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  transition: 0.3s;
  word-break: break-all;
}
.sec1 .box4 .links a:first-child {
  margin-bottom: clamp(23px, 1.88vw, 36px);
}
.sec1 .box4 .links a:hover {
  /*transform: scale(1.01);*/
  letter-spacing: 0.02em;
}
.sec1 .box5 {
  background: #eee;
}
.sec1 .box5 a {
  height: 100%;
  padding: clamp(15px, 1.56vw, 30px);
}
.sec1 .box5 span {
  width: 100%;
  font-size: clamp(15px, 1.04vw, 20px);
  font-weight: 700;
}
.sec1 .box5 i {
  background-image: url(../img/link_b_ico.svg);
}

/* ----- sec2 ----- */
.sec2 {
  gap: clamp(15px, 1.56vw, 30px);
}
.sec2 .sec_tit {
  letter-spacing: -0.04em;
}
.sec2 .box {
  width: calc((100% - clamp(15px, 1.56vw, 30px)) / 2);
}
.sec2 .box1 {
  flex-direction: column;
}
.sec2 .box2 .swiper-pagination {
  display: none;
}

#newsLinkSwiper {
  width: 100%;
  margin-top: auto;
  margin-bottom: 0;
  overflow: hidden;
  height: calc(clamp(90px, 6.77vw, 130px) * 3 + clamp(5px, 1.35vw, 26px) * 3);
}
#newsLinkSwiper h4 {
  width: 100%;
  font-size: clamp(18px, 1.04vw, 20px);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  font-weight: 600;
  transition: 0.3s;
}
#newsLinkSwiper h4 span {
  position: relative;
}
#newsLinkSwiper h4 span::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #444;
  transition: transform 1s ease;
  transform: scaleX(0);
  transform-origin: right;
}
#newsLinkSwiper a {
  padding: 0 clamp(15px, 1.56vw, 30px);
  transition: background 0.4s;
  height: clamp(90px, 6.77vw, 130px);
}
#newsLinkSwiper a > span {
  font-size: clamp(13px, 0.73vw, 14px);
  font-weight: 600;
  margin-bottom: clamp(8px, 0.73vw, 14px);
}
#newsLinkSwiper a > span span {
  font-weight: 500;
}
#newsLinkSwiper .swiper-slide-active a {
  background: #f8f8f8;
}
#newsLinkSwiper .swiper-slide-active a h4 span::after {
  transform: scaleX(1);
  transform-origin: left;
}

#newsSwiper {
  overflow: hidden;
  height: 100%;
}
#newsSwiper .swiper-wrapper {
  height: 100%;
}
#newsSwiper .swiper-slide {
  height: auto;
  display: flex;
}
#newsSwiper a {
  height: 100%;
  flex-direction: column;
}
#newsSwiper a:hover img {
  transform: scale(1.03);
}
#newsSwiper a:hover span {
  background: #fff;
  color: #222;
}
#newsSwiper .img_box {
  flex: 1;
  height: 100%;
  width: 100%;
  overflow: hidden;
  position: relative;
}
#newsSwiper .img_box img {
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: 0.6s;
}
#newsSwiper .txt_box {
  position: relative;
  z-index: 1;
  background: #1f1e1c;
  color: #fff;
  padding: clamp(20px, 2.08vw, 40px);
  gap: clamp(20px, 4.69vw, 90px);
}
#newsSwiper p {
  font-size: clamp(16px, 1.04vw, 20px);
  line-height: 1.6; /* 32px */
  font-weight: 600;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  word-break: break-all;
}
#newsSwiper span {
  font-size: clamp(14px, 0.94vw, 18px);
  padding: clamp(8px, 0.78vw, 15px) clamp(12px, 1.25vw, 24px);
  border: 1px solid #fff;
  border-radius: 25px;
  transition: 0.5s;
}
#newsSwiper .swiper-notification {
  display: none;
}

/* ----- sec3 ----- */
#workSwiper {
  overflow: hidden;
}
#workSwiper .swiper-slide {
  display: flex;
  gap: clamp(10px, 2.6vw, 50px);
}
#workSwiper .swiper-slide > div {
  width: calc((100% - clamp(10px, 2.6vw, 50px)) / 2);
}
#workSwiper .img_box {
  border-radius: 10px;
  overflow: hidden;
}
#workSwiper .img_box a {
  position: relative;
	height:100%;
}
#workSwiper .img_box img {
  width: 100%;
  object-fit: cover;
  object-position: center;
  height: 100%;
}
#workSwiper .detail {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: clamp(20px, 3.13vw, 60px) clamp(20px, 2.6vw, 50px);
  opacity: 0;
  transition: 0.5s 0.5s;
}
#workSwiper h3 {
  color: #fff;
  font-size: clamp(27px, 1.67vw, 32px);
  font-weight: 600;
  margin-bottom: 13px;
}
#workSwiper p {
  color: #fff;
  font-size: clamp(16px, 0.94vw, 18px);
  line-height: 1.56; /* 28px */
  font-weight: 500;
}
#workSwiper .txt_box {
  padding: clamp(10px, 1.04vw, 20px) 0;
}
#workSwiper .txt_box p {
  color: #222;
  font-weight: 500;
  font-size: clamp(16px, 1.04vw, 20px);
  line-height: 1.6; /* 32px */
  opacity: 0;
  transform: translateX(-10px);
  transition: 0.9s;
}
#workSwiper.is-view .swiper-slide-active .detail {
  opacity: 1;
}
#workSwiper.is-view .swiper-slide-active p {
  opacity: 1;
  transform: translateY(0);
}
#workSwiper.is-view .swiper-slide-active p:nth-child(1) {
  transition-delay: 0.32s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(2) {
  transition-delay: 0.44s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(3) {
  transition-delay: 0.56s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(4) {
  transition-delay: 0.68s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(5) {
  transition-delay: 0.8s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(6) {
  transition-delay: 0.92s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(7) {
  transition-delay: 1.04s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(8) {
  transition-delay: 1.16s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(9) {
  transition-delay: 1.28s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(10) {
  transition-delay: 1.4s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(11) {
  transition-delay: 1.52s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(12) {
  transition-delay: 1.64s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(13) {
  transition-delay: 1.76s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(14) {
  transition-delay: 1.88s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(15) {
  transition-delay: 2s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(16) {
  transition-delay: 2.12s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(17) {
  transition-delay: 2.24s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(18) {
  transition-delay: 2.36s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(19) {
  transition-delay: 2.48s;
}
#workSwiper.is-view .swiper-slide-active p:nth-child(20) {
  transition-delay: 2.6s;
}
#workSwiper .swiper-pagination {
  position: inherit;
  top: unset;
  left: unset;
  bottom: unset;
  right: unset;
  text-align: left;
}
#workSwiper .swiper-pagination .swiper-pagination-bullet {
  margin: 0;
  width: auto;
  height: auto;
  background: none;
  margin-right: clamp(16px, 1.56vw, 30px);
  padding: 0 6px 12px;
  font-size: clamp(15px, 1.04vw, 20px);
  font-weight: 600;
  color: #999;
  opacity: 1;
  border-radius: 0;
  transition: 0.3s;
  position: relative;
}
#workSwiper .swiper-pagination .swiper-pagination-bullet::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #1c42d8;
  transition: transform 0.3s ease;
  transform: scaleX(0);
  transform-origin: right;
}
#workSwiper .swiper-pagination .swiper-pagination-bullet-active {
  color: var(--color-point);
}
#workSwiper .swiper-pagination .swiper-pagination-bullet-active::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* ----- sec4 ----- */
#lawyerSwiper {
  overflow: hidden;
}
#lawyerSwiper a {
  overflow: hidden;
  border-radius: 4px;
  background-color: #1f1e1c;
  height: clamp(420px, 22.92vw, 440px);
  position: relative;
}
#lawyerSwiper a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #1c42d8;
  transition: transform 0.5s ease, filter 0.7s;
  transform: scaleX(0);
  transform-origin: right;
  filter: blur(30px);
}
#lawyerSwiper img {
  /*width: clamp(240px, 13.39vw, 257px);*/
	width:clamp(290px, 16.67vw, 320px);
  position: absolute;
  z-index: 1;
  bottom: 0;
  right: -35px;
}
#lawyerSwiper .txt_box {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  flex-direction: column;
  padding: clamp(50px, 2.6vw, 50px) clamp(40px, 2.08vw, 40px);
}
#lawyerSwiper dt {
  font-size: clamp(20px, 1.04vw, 20px);
  line-height: 1.2; /* 24px */
  font-weight: 500;
  margin-bottom: 10px;
  color: #c0cbf8;
}
#lawyerSwiper dd {
  font-size: clamp(22px, 1.25vw, 24px);
  line-height: 1.21; /* 29px */
  font-weight: 700;
  color: #fff;
}
#lawyerSwiper span {
  margin-top: auto;
  margin-bottom: 0;
  color: #fff;
  font-size: clamp(16px, 0.94vw, 18px);
  font-weight: 700;
  opacity: 0;
  filter: blur(5px);
  transition: 0.3s;
}
#lawyerSwiper i {
  margin-left: 10px;
  width: 24px;
  height: 24px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/more_w_ico.svg);
  transform: rotate(-360deg);
  transition: transform 0.4s;
}
#lawyerSwiper .swiper-slide:hover a::after,
#lawyerSwiper .swiper-slide-active a::after {
  transform: scaleX(1);
  transform-origin: left;
  filter: blur(0);
}
#lawyerSwiper .swiper-slide:hover dt,
#lawyerSwiper .swiper-slide-active dt {
  color: #fff;
}
#lawyerSwiper .swiper-slide:hover span,
#lawyerSwiper .swiper-slide-active span {
  opacity: 1;
  filter: blur(0);
}
#lawyerSwiper .swiper-slide:hover i,
#lawyerSwiper .swiper-slide-active i {
  transform: rotate(0deg);
}

/* ----- sec5 ----- */
.sec5 .links {
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(12px, 1.25vw, 24px);
}
.sec5 .links .img_box {
  overflow: hidden;
  width: clamp(180px, 12.5vw, 240px);
}
.sec5 .links img {
  height: 100%;
  transition: 0.4s;
	height: 100%; 
	min-width: 100%;
	object-fit: cover; 
	object-position: center; 
	display: block;
}
.sec5 .links .txt_box {
  width: calc(100% - clamp(180px, 12.5vw, 240px));
  background: #f8f8f8;
  padding: clamp(20px, 2.08vw, 40px);
}
.sec5 .links i {
  width: clamp(28px, 1.77vw, 34px);
  height: clamp(20px, 1.25vw, 24px);
  margin-bottom: clamp(10px, 1.04vw, 20px);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.sec5 .links i.blog {
  background-image: url(../img/blog_ico.svg);
}
.sec5 .links i.youtube {
  background-image: url(../img/youtube_ico.svg);
}
.sec5 .links h4 {
  font-size: clamp(19px, 1.15vw, 22px);
  line-height: 1.45; /* 32px */
  font-weight: 600;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-bottom: 10px;
  transition: 0.4s;
}
.sec5 .links p {
  font-size: clamp(15px, 0.83vw, 16px);
  line-height: 1.5; /* 24px */
  color: #999;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  transition: 0.4s;
  overflow: hidden;
}
.sec5 .links:hover img {
  filter: brightness(0.7);
}
.sec5 .links a:hover h4,
.sec5 .links a:hover p {
  letter-spacing: 0.02em;
}
.sec5 .links a:hover img {
  transform: scale(1.02);
  filter: brightness(1);
}

/* ----------------------------- */
/* --------------RWD------------ */
/* ----------------------------- */
@media (max-width: 1650px) {
  #snb {
    display: none;
  }
}
@media (max-width: 1100px) {
  #workSwiper .swiper-slide {
    flex-wrap: wrap;
  }
  #workSwiper .swiper-slide > div {
    width: 100%;
  }
  #workSwiper .img_box {
    height: clamp(200px, 27.27vw, 300px);
    overflow: hidden;
  }
}
@media (max-width: 900px) {
  .sec5 .links {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media (max-width: 750px) {
  main {
    overflow: hidden;
  }
  .sec_label {
    font-size: clamp(15px, 3.47vw, 26px);
    font-weight: 600;
  }
  .sec_tit {
    font-size: clamp(24px, 7.2vw, 54px);
    line-height: 1.33; /* 72px */
    font-weight: 600;
    white-space: wrap;
  }
  .sec_txt {
    font-size: clamp(19px, 4vw, 30px);
    line-height: 1.6; /* 48px */
    font-weight: 500;
  }
  .sec1 .container {
    gap: clamp(10px, 5.33vw, 40px);
    grid-template-columns: 1fr;
    grid-template-rows: clamp(280px, 56vw, 420px) clamp(320px, 95.33vw, 715px) repeat(3, clamp(160px, 50.67vw, 380px));
    grid-template-areas: "swiper" "box2" "box3" "box4" "box5";
  }
  #mainSwiper .txt_box {
    padding: 0 clamp(20px, 6.67vw, 50px);
  }
  #mainSwiper h2 {
    font-size: clamp(22px, 5.07vw, 38px);
    line-height: 1.42; /* 54px */
    font-weight: 700;
    white-space: nowrap;
  }
  #mainSwiper p {
    font-size: clamp(16px, 3.73vw, 28px);
    line-height: 1.43; /* 40px */
    letter-spacing: -0.02em;
  }
  #mainSwiper .swiper-pagination-bullet {
    width: clamp(6px, 1.07vw, 8px);
    height: clamp(6px, 1.07vw, 8px);
    margin: clamp(2px, 0.67vw, 5px);
  }
  .sec1 .box2 .txt_box {
    flex-wrap: wrap;
    gap: clamp(20px, 5.33vw, 40px);
    padding: clamp(20px, 6.67vw, 50px);
  }
  .sec1 .box2 .txt_box p {
    width: 100%;
    font-size: clamp(18px, 5.33vw, 40px);
    line-height: 1.4; /* 56px */
    font-weight: 600;
  }
  .sec1 .box2 .txt_box span {
    margin-left: auto;
    font-size: clamp(14px, 3.47vw, 26px);
    line-height: 1.19; /*31px*/
    font-weight: 700;
    padding: clamp(7px, 2.27vw, 17px) clamp(15px, 4.67vw, 35px);
    border-radius: 200px;
  }
  .sec1 .box3 .txt_box {
    padding: clamp(15px, 6vw, 45px);
  }
  .sec1 .box3 h4,
  .sec1 .box3 p {
    font-size: clamp(15px, 4vw, 30px);
  }
  .sec1 .box4 i,
  .sec1 .box5 i {
    width: clamp(10px, 2.13vw, 16px);
    height: clamp(10px, 2.13vw, 16px);
  }
  .sec1 .box4 {
    padding: clamp(15px, 6vw, 45px);
  }
  .sec1 .box4 h4,
  .sec1 .box4 .links {
    font-size: clamp(15px, 4vw, 30px);
  }
  .sec1 .box4 .links a:first-child {
    margin-bottom: 4vw; /*30px*/
  }
  .sec1 .box5 a {
    padding: clamp(15px, 6vw, 45px);
  }
  .sec1 .box5 h4,
  .sec1 .box5 span {
    font-size: clamp(15px, 4vw, 30px);
  }
  .sec2 {
    flex-wrap: wrap;
    gap: 0;
  }
  .sec2 .box {
    width: 100%;
  }
  #newsLinkSwiper {
    display: none;
  }
  #newsSwiper {
    overflow-x: hidden;
  }
  #newsSwiper .txt_box {
    flex-wrap: wrap;
    gap: clamp(20px, 5.33vw, 40px);
    padding: clamp(20px, 6.67vw, 50px);
  }
  #newsSwiper p {
    width: 100%;
    font-size: clamp(18px, 5.33vw, 40px);
    line-height: 1.4; /* 56px */
    font-weight: 600;
  }
  #newsSwiper span {
    margin-left: auto;
    font-size: clamp(14px, 3.47vw, 26px);
    line-height: 1.19; /*31px*/
    font-weight: 700;
    padding: clamp(7px, 2.27vw, 17px) clamp(15px, 4.67vw, 35px);
    border-radius: 200px;
  }
  .sec2 .box2 .swiper-pagination {
    display: block;
    position: inherit;
  }
  .sec2 .box2 .swiper-pagination .swiper-pagination-bullet {
    width: clamp(6px, 1.33vw, 10px);
    height: clamp(6px, 1.33vw, 10px);
    margin: 0 clamp(5px, 1.33vw, 10px);
    display: inline-block;
    position: relative;
  }
  .sec2 .box2 .swiper-pagination .swiper-pagination-bullet::after {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    content: "";
    background: var(--color-point);
    opacity: 0.3;
    width: 0;
    height: 0;
    border-radius: 100%;
    transition: 0.3s;
  }
  .sec2 .box2 .swiper-pagination .swiper-pagination-bullet-active::after {
    width: clamp(12px, 2.67vw, 20px);
    height: clamp(12px, 2.67vw, 20px);
  }
  .sec3 .sec_tit br {
    display: none;
  }
  #workSwiper .swiper-slide {
    gap: clamp(20px, 6.67vw, 50px);
  }
  #workSwiper .img_box {
    height: clamp(230px, 42.67vw, 320px);
  }
  #workSwiper .detail {
    padding: clamp(15px, 6vw, 45px);
    display: flex;
    align-content: flex-end;
    flex-wrap: wrap;
  }
  #workSwiper h3 {
    width: 100%;
    font-size: clamp(20px, 4.53vw, 34px);
  }
  #workSwiper p {
    font-size: clamp(15px, 3.73vw, 28px);
    line-height: 1.36; /* 38px */
  }
  #workSwiper .txt_box p {
    font-size: clamp(14px, 3.73vw, 28px);
    line-height: 1.5; /* 42px */
    word-break: break-all;
    display: inline;
  }
  #workSwiper .swiper-pagination {
    display: flex;
    flex-wrap: nowrap;
    white-space: nowrap;
    overflow-x: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
    overflow-y: auto;
  }
  #workSwiper .swiper-pagination .swiper-pagination-bullet {
    font-size: clamp(14px, 4vw, 30px);
    margin-right: clamp(5px, 3.33vw, 20px);
    padding: 0 clamp(0px, 0.8vw, 6px) clamp(10px, 1.73vw, 13px);
  }
  #workSwiper .swiper-pagination .swiper-pagination-bullet::after {
    height: clamp(2px, 0.53vw, 4px);
  }
  #lawyerSwiper a {
    height: clamp(280px, 80vw, 600px);
  }
  #lawyerSwiper img {
    width: clamp(160px, 46.67vw, 350px);
    right: clamp(-50px, -6.67vw, -30px);
  }
  #lawyerSwiper .txt_box {
    padding: clamp(10px, 8vw, 60px) clamp(10px, 6.67vw, 50px);
  }
  #lawyerSwiper dt {
    font-size: clamp(14px, 4vw, 30px);
    margin-bottom: clamp(5px, 2.67vw, 20px);
  }
  #lawyerSwiper dd {
    font-size: clamp(16px, 6.67vw, 50px);
  }
  #lawyerSwiper span {
    font-size: clamp(14px, 3.47vw, 26px);
  }
  #lawyerSwiper i {
    margin-left: clamp(10px, 1.33vw, 10px);
    width: clamp(18px, 3.2vw, 24px);
    height: clamp(18px, 3.2vw, 24px);
  }
  .sec5 .links {
    gap: clamp(10px, 4vw, 30px);
  }
  .sec5 .links .img_box {
    width: clamp(70px, 22.67vw, 170px);
  }
  .sec5 .links img {
    object-fit: cover;
    transform: scale(1);
    transition: transform 0s;
    transform-origin: center center;
  }
  .sec5 .links .txt_box {
    width: calc(100% - clamp(70px, 22.67vw, 170px));
    padding: clamp(15px, 6vw, 45px);
  }
  .sec5 .links i {
    width: clamp(24px, 4.93vw, 37px);
    height: clamp(18px, 4vw, 30px);
    background-size: contain;
  }
  .sec5 .links h4 {
    font-size: clamp(16px, 4.53vw, 34px);
  }
  .sec5 .links p {
    font-size: clamp(14px, 3.73vw, 28px);
  }
}
@media (max-width: 500px) {
  #mainSwiper h2 {
    white-space: wrap;
  }
}