@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+KR&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Noto+Serif+KR&display=swap);

:root {
    --main_color: #535353;
    --sub_color01: #e8c391;
    --desc_color: #747474
}

a,
body,
button,
div,
em,
h1,
h2,
h3,
h4,
i,
input,
label,
li,
p,
section,
span,
textarea,
ul {
    font-family: "Noto Sans KR";
    color: inherit;
    font-weight: inherit
}

img {
    max-width: 100%
}

video::-webkit-media-controls {
    display: none !important
}

.di_none {
    display: none
}

.wrap_1400 {
    width: 100%;
    max-width: 1400px;
    margin-inline: auto
}

.wrap_1200 {
    width: 100%;
    max-width: 1200px;
    margin-inline: auto
}

section:not(.visual_wrap) {
    padding-block: 70px;
    position: relative
}

.tit_wrap {
    margin-bottom: 50px
}

.tit_wrap .desc+h3 {
    margin-top: 6px;
    word-break: keep-all;
    color: #000
}

.tit_wrap h3 {
    font-size: 32px;
    font-weight: 700;
    line-height: 1.3
}

h3 span {
    display: block;
    color: var(--main_color);
    font-weight: 700
}

.tit_wrap h3.big_font {
    font-size: 48px
}

.tit_wrap .desc {
    font-size: 18px;
    font-weight: 500
}

.main_c {
    color: var(--main_color)
}

.main_s {
    color: var(--sub_color01)
}

.icon_wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: bottom
}

.img_wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover
}

.img_wrap img.img_con {
    object-fit: contain
}

.txt_over {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis
}

.txt_over_02 {
    overflow: hidden;
    word-break: keep-all;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical
}

.txt_over_03 {
    overflow: hidden;
    word-break: keep-all;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical
}

.txt_over_07 {
    overflow: hidden;
    word-break: keep-all;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 7;
    -webkit-box-orient: vertical
}

.txt_over_04 {
    overflow: hidden;
    word-break: keep-all;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical
}

.flex {
    display: flex
}

.custom_scroll::-webkit-scrollbar {
    height: 5px;
    border-radius: 15px
}

.custom_scroll::-webkit-scrollbar-thumb {
    background: #999;
    border-radius: 15px
}

.custom_scroll::-webkit-scrollbar-track {
    background: #d7d7d7;
    border-radius: 15px
}

.sound_only {
    display: inline-block !important;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 0;
    line-height: 0;
    border: 0 !important;
    overflow: hidden !important
}

.M_only {
    display: none
}

.only_500 {
    display: none
}

.header {
    height: 140px;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 999999;
    transition: all .3s
}

.header.active {
    background-color: #fff;
    border-bottom: 1px solid #d4d4d4;
    transition: all .3s
}

.header.active nav ul a {
    color: #171717;
    font-size: 18px;
    font-weight: 700
}

.header.active nav ul a:hover {
    color: var(--main_color)
}

.header .wrap_1400 {
    height: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.header nav ul {
    display: flex;
    gap: 25px
}

.header nav ul a {
    color: #fff;
    font-size: 18px
}

.header nav ul a:hover {
    font-weight: 700
}

footer .company_wrap {
    background-color: #343434;
    display: flex;
    justify-content: center;
    padding: 30px 0 40px
}

footer .company_wrap ul {
    width: 100%;
    max-width: 1400px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

footer .company_wrap li {
    display: flex;
    gap: 10px;
    align-items: center
}

footer .company_wrap li+li::before {
    content: "";
    display: inline-block;
    width: 1px;
    height: 25px;
    background-color: #fff;
    margin-right: 40px
}

footer .company_wrap span {
    color: #fff;
    display: block
}

footer .company_wrap span.tit {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -.5px;
    word-break: keep-all
}

footer .company_wrap span.sub_tit {
    font-weight: 400;
    font-size: 13px
}

footer .footer_wrap {
    display: flex
}

footer .footer_blue {
    width: calc(50% - 80px);
    position: relative;
    background-color: var(--main_color)
}

footer .footer_blue>.flex {
    position: absolute;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 120px 0 80px;
    height: 100%;
    justify-content: space-between
}

footer .footer_blue .logo_wrap {
    width: 65%;
    max-width: 300px;
    filter: brightness(.85)
}

footer .footer_blue .logo_wrap:hover {
    filter: brightness(1)
}

footer .footer_blue .social_icon_wrap {
    display: flex;
    gap: 17px;
    justify-content: center;
    align-items: center
}

footer .footer_blue .social_icon_wrap a {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    filter: brightness(.85);
    line-height: 1.1
}

footer .footer_blue .social_icon_wrap a.brochure_btn {
    background-color: #fff;
    filter: none;
    border-radius: 20px;
    color: var(--main_color);
    font-size: 15px;
    width: 170px;
    height: 36px;
    gap: 5px;
    display: flex;
    align-items: center;
    justify-content: center
}

footer .footer_blue .social_icon_wrap a:hover {
    filter: brightness(1)
}

footer .footer_blue .social_icon_wrap a img {
    object-fit: scale-down
}

footer .footer_white {
    width: calc(50% + 80px);
    padding: 80px 80px
}

footer .footer_white p {
    color: var(--desc_color)
}

footer .footer_white p+p {
    margin-top: 3px
}

footer .footer_white p.main_c {
    font-weight: 700;
    color: var(--main_color)
}

footer .footer_white p.fax {
    margin-bottom: 25px
}

.quick_menu_wrap {
    position: fixed;
    top: 170px;
    right: 30px;
    display: inline-flex;
    flex-direction: column;
    transition: right .3s;
    z-index: 99999
}

.quick_menu_wrap.active {
    right: 30px;
    transition: right .3s
}

.quick_menu_wrap a {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 90px;
    height: 90px;
    padding: 10px 5px;
    border: 1px solid #d4d4d4;
    background-color: #fff;
    text-align: center
}

.quick_menu_wrap :where(a, button):hover {
    filter: brightness(1.15)
}

.quick_menu_wrap :where(a+a) {
    margin-top: 3px
}

.quick_menu_wrap a img {
    display: inline-block;
    width: 22px;
    height: 22px;
    object-fit: contain
}

.quick_menu_wrap a p {
    font-size: 15px;
    margin-top: 5px;
    letter-spacing: -.8px;
    text-align: center;
    color: var(--main_color)
}

.quick_menu_wrap .top_btn {
    width: 100%;
    height: 30px;
    line-height: 30px;
    text-align: center;
    background-color: var(--main_color);
    margin-top: 3px;
    color: #fff
}

.main_banner video {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    object-fit: cover;
    object-position: center
}

.main_banner {
    height: 100vh;
    position: relative;
    overflow: hidden
}

.main_banner::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .5);
    z-index: 1
}

.main_banner .main_banner_txt {
    z-index: 2;
    position: absolute;
    top: calc(50% + 30px);
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%
}

.main_banner .main_txt {
    color: #fff;
    font-size: 70px;
    font-weight: 600;
    letter-spacing: -1px;
    word-break: keep-all;
    text-shadow: 0 0 5px rgba(0, 0, 0, .3);
    text-align: center;
    margin: 50px 0 110px
}

.main_banner .sub_txt {
    text-align: center;
    font-family: "Noto Sans KR";
    line-height: 1.5;
    color: #fff;
    font-weight: 800;
    font-size: 28px;
    text-shadow: 0 0 5px rgba(0, 0, 0, .3)
}

.main_banner .main_ico_box {
    display: flex;
    gap: 30px
}

.scroll_wrap {
    position: absolute;
    bottom: 40px;
    color: #fff;
    font-weight: 500;
    left: 50%;
    transform: translateX(-50%)
}

.main_01::after {
    display: inline-block;
    content: "";
    width: 100%;
    height: 70%;
    position: absolute;
    background-image: url(../img/main_01_bg.png);
    background-size: cover;
    top: 44%;
    z-index: -1
}

.big_intro_wrap ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px
}

.big_intro_wrap ul li {
    width: calc(25% - 15px);
    position: relative;
    height: 560px
}

.big_intro_wrap ul li a {
    width: 100%;
    height: 100%;
    display: block
}

.big_intro_wrap ul li .info_sort {
    position: absolute;
    top: 20px;
    left: 20px;
    display: flex;
    gap: 12px
}

.big_intro_wrap ul li .info_sort span {
    font-size: 18px;
    font-weight: 500;
    color: var(--sub_color01)
}

.big_intro_wrap ul li .info_wrap {
    position: absolute;
    bottom: 30px;
    right: 20px;
    text-align: right
}

.big_intro_wrap ul li .info_wrap .name {
    font-size: 24px;
    font-weight: 700;
    color: #fff
}

.big_intro_wrap ul li .info_wrap .position {
    font-size: 18px;
    font-weight: 500;
    color: #fff
}

.big_intro_wrap ul li .info_wrap .sub_title {
    font-weight: 700;
    font-size: 25px;
    color: #e8c391;
    text-shadow: -1px 0 #2d2f44, 0 1px #2d2f44, 1px 0 #2d2f44, 0 -1px #2d2f44;
    word-break: keep-all
}

.big_intro_wrap ul li .info_wrap .sub_title .lawyer_mark {
    position: relative;
    top: -3px;
    margin-right: 3px
}

.big_intro_wrap ul li div.icon_wrap {
    background-image: url(../img/lawyer_bg.jpg);
    width: 100%;
    height: 100%;
    padding-top: 50px
}

.small_intro_wrap {
    width: 100%;
    overflow: hidden;
    position: relative;
    margin-top: 38px
}

.small_intro_wrap ul {
    height: 360px;
    display: flex;
    gap: 20px
}

.small_intro_wrap ul div.icon_wrap {
    background-color: #f6f6f6;
    height: 100%;
    padding-top: 25px
}

.small_intro_wrap ul li {
    background-color: #fff;
    position: relative;
    border: 1px solid #ddd;
    flex: 1;
    overflow: hidden
}

.small_intro_wrap ul li .icon_img {
    position: absolute;
    left: 20px;
    top: 20px
}

.small_intro_wrap ul li .img {
    position: absolute;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    width: auto;
    height: 100%
}

.small_intro_wrap ul li .img img {
    filter: drop-shadow(14px 2px 0 #ddd);
    height: 100%;
    width: auto;
    max-width: none
}

.small_intro_wrap ul li .info_sort {
    position: absolute;
    top: 10px;
    left: 15px;
    display: flex;
    gap: 12px
}

.small_intro_wrap ul li .info_sort span {
    font-size: 18px;
    font-weight: 500;
    color: var(--sub_color01)
}

.small_intro_wrap ul li .info_wrap {
    position: absolute;
    bottom: 0;
    right: 0;
    text-align: right;
    background-color: rgba(0, 0, 0, .7);
    padding: 15px
}

.small_intro_wrap ul li .info_wrap .name {
    font-size: 20px;
    font-weight: 700;
    color: #fff
}

.small_intro_wrap ul li .info_wrap .position {
    font-size: 16px;
    font-weight: 500;
    color: var(--sub_color01)
}

.small_intro_wrap ul li a {
    display: block;
    height: 100%;
    background-size: cover
}

.small_intro_wrap button {
    display: inline-block;
    width: 25px;
    height: 35px;
    background-color: rgba(0, 0, 0, .7);
    background-image: url(../img/next_btn_01.png);
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2
}

.small_intro_wrap .prev_btn {
    left: 0
}

.small_intro_wrap .next_btn {
    right: 0;
    transform: translateY(-50%) rotate(180deg)
}

.main_03 {
    background-image: url(../img/main_bg_01.jpg);
    background-size: cover
}

.main_03 .swiper-wrapper {
    align-items: stretch
}

.main_03 .swiper-wrapper li.swiper-slide {
    height: auto
}

.main_03 .wrap_1400 {
    position: relative
}

.main_03 .wrap_1400>.flex {
    display: flex;
    justify-content: space-between;
    align-items: end
}

.main_03 .tit_wrap h3 {
    color: #fff
}

.sch_wrap {
    max-width: 700px;
    width: calc(100% - 40px);
    position: relative
}

.sch_wrap .sch_box {
    display: inline-block;
    width: 100%;
    background-color: #fff;
    height: 70px;
    margin-bottom: 15px
}

.sch_wrap .sch_box input {
    display: inline-block;
    width: 100%;
    height: 100%;
    border: none;
    padding: 10px 15px;
    font-size: 16px
}

.sch_wrap .search_icon {
    width: 70px;
    height: 70px;
    background-color: var(--main_color);
    background-image: url(../img/search_icon.png);
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    right: 0
}

.sch_wrap .search_icon:hover {
    filter: brightness(1.2)
}

.main_03 .sch_cate_wrap {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
    margin: 30px 0
}

.main_03 .tit_wrap {
    margin-bottom: 0
}

.main_03 .sch_cate_wrap button {
    border: 1px solid #fff;
    color: #fff;
    padding: 5px 10px;
    text-align: center;
    padding-block: 5px;
    font-size: 16px
}

.main_03 .sch_cate_wrap button:hover {
    border: 1px solid var(--sub_color01);
    color: var(--sub_color01)
}

.main_03 .sch_cate_wrap button.active {
    border: 1px solid var(--sub_color01);
    color: var(--sub_color01)
}

.sch_con_wrap {
    overflow: hidden
}

.sch_con_wrap li>a {
    display: block;
    width: 100%;
    height: 100%;
    padding: 35px;
    background-color: #fff
}

.sch_con_wrap li>a .b_box {
    background-color: var(--main_color);
    color: #fff;
    padding: 5px 10px;
    margin-bottom: 10px;
    width: auto;
    min-width: 85px;
    text-align: center;
    display: inline-block
}

.sch_con_wrap li>a .con_tit {
    color: var(--main_color);
    font-size: 23px;
    margin-bottom: 20px;
    font-weight: 600
}

.sch_con_wrap li>a .sub_tit {
    font-weight: 600;
    margin-bottom: 5px;
    font-size: 17px
}

.sch_con_wrap li .desc_wrap .desc {
    font-size: 15px;
    color: var(--desc_color);
    min-height: 42px
}

.sch_con_wrap li .desc_wrap p:last-child span {
    font-size: 15px !important;
    color: var(--desc_color) !important;
    font-family: "Noto Sans KR" !important;
    line-height: 1.5;
    overflow: hidden;
    word-break: keep-all;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical
}

.sch_con_wrap li .example_wrap {
    position: relative;
    display: flex;
    justify-content: space-between;
    margin-top: 10px;
    gap: 10px
}

.sch_con_wrap li .example_wrap .icon {
    width: 27px;
    display: inline-block;
    padding-top: 15px
}

.sch_con_wrap li .img_wrap {
    width: 100%;
    max-width: 250px;
    margin-right: 30px;
    flex: 1
}

.icon_wrap span:last-of-type {
    display: block;
    color: var(--main_color);
    filter: brightness(1.05);
    font-weight: 500
}

.sch_con_wrap .pagination {
    display: block;
    text-align: center;
    margin-top: 50px
}

.sch_con_wrap .pagination span {
    width: 15px;
    height: 15px;
    background-color: #ccc
}

.main_03 .more_btn_wrap {
    position: absolute;
    bottom: 0;
    right: 0
}

.more_btn_wrap a {
    color: #fff;
    font-size: 18px
}

.main_03 .more_btn_wrap a:hover {
    filter: brightness(.85)
}

.main_03 .more_btn_wrap a img {
    margin-left: 10px;
    vertical-align: baseline
}

.main_04 {
    background-image: url(../img/main_bg_02.jpg)
}

.main_04 .more_btn_wrap {
    position: absolute;
    bottom: 0;
    right: 0
}

.main_04 .review_swiper_wrap {
    position: relative;
    margin-top: 80px;
    display: flex
}

.main_04 .review_swiper {
    overflow: hidden;
    width: 100%
}

.main_04 .tit_wrap {
    text-align: center;
    position: relative
}

.main_04 .tit_wrap :where(p, h3) {
    color: #fff !important
}

.main_04 .tit_wrap .desc+h3 {
    margin-top: 5px;
    word-break: keep-all
}

.main_04 .review_swiper li {
    background-color: #fff;
    padding: 40px;
    max-height: 300px;
    height: 100%
}

.main_04 .review_swiper li a {
    display: inline-block;
    width: 100%;
    height: 100%
}

.main_04 .review_swiper li .review_cate {
    color: #c4a176;
    font-weight: 600;
    margin-bottom: 25px
}

.main_04 .review_swiper li .review_tit {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 10px
}

.main_04 .review_swiper li .review_desc {
    color: var(--desc_color);
    font-size: 15px;
    line-height: 1.4
}

.review_swiper_wrap button {
    position: absolute;
    right: -70px;
    top: 50%;
    transform: translateY(-50%)
}

.review_swiper_wrap button.prev_btn {
    right: unset;
    left: -70px;
    transform: translateY(-50%) rotate(180deg)
}

.main_05 .tit_wrap {
    text-align: center
}

.main_05_list {
    display: flex;
    justify-content: space-between;
    gap: 10px
}

.main_05_list a {
    display: block;
    flex: 1;
    aspect-ratio: 1/2.3;
    position: relative;
    text-align: center;
    background-size: cover;
    background-position: center
}

.main_05_list a:nth-child(1) {
    background-image: url(../img/main_05_img3.png)
}

.main_05_list a:nth-child(2) {
    background-image: url(../img/main_05_img2.png)
}

.main_05_list a:nth-child(3) {
    background-image: url(../img/main_05_img6.png)
}

.main_05_list a:nth-child(4) {
    background-image: url(../img/main_05_img5.png)
}

.main_05_list a:nth-child(5) {
    background-image: url(../img/main_05_img4.png)
}

.main_05_list a:nth-child(6) {
    background-image: url(../img/main_05_img7.png)
}

.main_05_list a:nth-child(7) {
    background-image: url(../img/main_05_img8.png)
}

.main_05_list a p {
    color: #fff;
    width: 100%;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.main_05_list a p b {
    font-size: 22px;
    line-height: 1.1
}

.main_05_list a p span {
    font-size: 16px
}

.main_chk_wrap {
    position: relative
}

.main_10 .tit_wrap {
    margin-bottom: 20px
}

.main_10 {
    display: block
}

.main_chk_wrap::after {
    content: "";
    display: block;
    height: 316px;
    width: 100%;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--main_color)
}

.main_chk_wrap .chk_list_bg {
    position: absolute;
    right: 0;
    bottom: 30px;
    z-index: 1
}

.main_chk_wrap .wrap_1400 {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 22px
}

.main_chk_wrap .chk_list {
    display: inline-block
}

.main_chk_wrap .chk_list li {
    padding: 20px 12px;
    height: auto !important;
    cursor: pointer;
    border-bottom: 1px solid rgba(255, 255, 255, .4)
}

.main_chk_wrap .chk_list li:last-child {
    border-bottom: 0
}

.main_chk_wrap .chk_list li p {
    opacity: .4;
    color: #fff;
    display: flex;
    align-items: start;
    gap: 14px;
    font-size: 20px
}

.main_chk_wrap .chk_list li.swiper-slide-thumb-active p {
    opacity: 1
}

.chk_txt_wrap {
    width: 670px;
    height: 380px;
    background-color: #fff;
    overflow: hidden;
    box-shadow: 0 0 10px 5px rgba(0, 0, 0, .1)
}

.main_chk_wrap .chk_txt_box {
    align-items: center;
    flex-direction: column;
    justify-content: center;
    display: flex;
    background-color: #fff
}

.main_chk_wrap .chk_txt_box .chk_txt {
    padding: 15px 50px
}

.main_chk_wrap .chk_txt p {
    font-weight: 700;
    font-size: 24px;
    margin-bottom: 20px
}

.main_chk_wrap .chk_txt li {
    font-size: 18px;
    display: flex;
    gap: 5px;
    margin-bottom: 12px;
    word-break: keep-all
}

.main_chk_wrap .chk_txt li:last-child {
    margin-bottom: 0
}

.main_chk_wrap .chk_list li.active p {
    opacity: 1
}

.main_06 {
    display: flex;
    flex-direction: column;
    align-items: center
}

.main_06 .tit_wrap {
    text-align: center
}

.main_06 .tit_wrap .desc+h3 {
    margin-top: 5px
}

.main_06 .more_btn_wrap {
    width: calc(100% - 40px);
    max-width: 365px;
    height: 60px;
    text-align: center
}

.main_06 .more_btn_wrap button {
    width: 100%;
    height: 100%;
    background-color: #000;
    color: #fff;
    text-align: center;
    font-size: 18px
}

.main_06 .more_btn_wrap button:hover {
    background-color: var(--main_color)
}

.main_06 .wrap_1400 {
    max-width: 1200px;
    margin-bottom: 60px
}

.main_06 :where(li+li) {
    margin-top: 20px
}

.main_06 li {
    box-sizing: border-box;
    width: 100%;
    background-color: #fff;
    border: 1px solid #d6d6d6;
    padding: 30px 100px 30px 40px;
    position: relative;
    cursor: pointer
}

.main_06 .main_qna {
    border-top: 2px solid #d6d6d6
}

.main_06 .main_qna li {
    border: 0;
    margin-top: 0;
    padding: 30px 40px 30px 100px;
    border-bottom: 1px solid #d6d6d6
}

.main_06 .main_qna li.active {
    box-shadow: none;
    border: 0;
    border-bottom: 1px solid #d6d6d6
}

.main_06 .main_qna li.active::after {
    display: block;
    content: "-"
}

.main_06 li.active {
    box-shadow: 0 0 0 2px var(--main_color);
    border: 1px solid transparent
}

.main_06 li.active::after {
    display: none
}

.main_06 .main_qna li::after {
    transform: none;
    color: #000;
    top: 15px;
    left: 40px;
    right: auto
}

.main_06 li::after {
    content: "+";
    display: inline-block;
    position: absolute;
    right: 40px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 40px;
    font-weight: 500;
    color: #d4d4d4
}

.main_06 li .con_cate {
    font-weight: 500;
    margin-bottom: 7px
}

.main_06 li .con_tit {
    font-size: 20px;
    font-weight: 700;
    word-break: keep-all
}

.main_06 li .con_desc_wrap .desc {
    color: var(--desc_color);
    word-break: keep-all
}

.main_06 li.active .con_desc_wrap .show_answer {
    display: inline-block;
    margin-top: 20px
}

.main_06 li.active .con_desc_wrap .show_answer:hover {
    font-weight: 700
}

.main_06 li .con_desc_wrap {
    margin-top: 20px;
    display: none
}

.main_06 li:hover {
    border: 1px solid transparent;
    box-shadow: 0 0 0 2px var(--main_color)
}

.main_06 .main_qna li:hover {
    box-shadow: none;
    border: 0;
    border-bottom: 1px solid #d6d6d6
}

.main_06 li:hover::after {
    color: var(--main_color)
}

.main_06 .main_qna li:hover::after {
    color: #000
}

.main_07 {
    display: flex
}

.main_07::after {
    content: "";
    display: inline-block;
    width: 100%;
    height: 60%;
    background-color: var(--main_color);
    min-height: 300px;
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0
}

.main_07 .tit_wrap {
    color: #fff;
    text-align: right;
    width: calc(100% / 3);
    margin-right: 30px
}

.main_07 .tit_wrap .desc+h3 {
    margin-top: 5px
}

.main_07 .tit_wrap :where(p, h3) {
    color: #fff
}

.main_07 .news_swiper_wrap {
    width: calc(2 * (100% / 3));
    position: relative;
    display: flex
}

.main_07 .news_swiper_wrap .btn_wrap {
    position: absolute;
    left: -130px;
    top: 150px
}

.main_07 .news_swiper_wrap .btn_wrap button.prev_btn {
    transform: rotate(180deg)
}

.main_07 .news_swiper {
    overflow: hidden;
    padding-bottom: 10px;
    width: 100%
}

.main_07 .news_swiper li {
    display: inline-block;
    background-color: #fff;
    box-shadow: 1px 2px 5px 0 #ddd;
    padding: 40px
}

.main_07 .news_swiper li a {
    transition: all .3s;
    transform: scale(1);
    display: inline-block;
    width: 100%;
    height: 100%
}

.main_07 .news_swiper li:hover a {
    transform: scale(1.02);
    transition: all .3s
}

.main_07 .news_swiper li .con_cate {
    color: var(--main_color);
    margin-bottom: 20px;
    font-weight: 500
}

.main_07 .news_swiper li .con_tit {
    font-weight: 700;
    font-size: 20px;
    margin-block: 7px
}

.main_07 .news_swiper li .con_desc {
    color: var(--desc_color);
    font-size: 15px
}

.main_07 .news_swiper li .con_img {
    margin-top: 20px;
    height: 200px
}

.main_08 .tit_wrap {
    text-align: center
}

section.main_08 {
    background-color: #f0f0f0
}

.main_08 .wrap_1400 {
    max-width: 1100px;
    position: relative
}

.main_08 form div.flex>label>span {
    display: block;
    font-size: 18px;
    margin-bottom: 5px
}

.main_08 form>div {
    display: flex;
    flex-wrap: wrap;
    gap: 40px
}

.main_08 form>div>label {
    display: inline-block;
    width: calc(50% - 20px)
}

.main_08 form>div>label>span+input {
    border: 1px solid #ccc;
    padding: 5px 20px;
    height: 50px;
    line-height: 50px;
    font-size: 16px;
    width: 100%
}

.main_08 form>div>label>span+textarea {
    border: 1px solid #ccc;
    padding: 15px 20px;
    min-height: 150px;
    line-height: 1.3;
    font-size: 16px;
    width: 100%;
    color: #191919
}

.main_08 form .btn_wrap {
    width: calc(50% - 20px);
    position: absolute;
    bottom: 0;
    right: 0
}

.main_08 form .btn_wrap label {
    cursor: pointer
}

.main_08 form .btn_wrap input {
    filter: brightness(1.3);
    margin-right: 7px
}

.main_08 form .btn_wrap input:checked {
    filter: brightness(1.1);
    accent-color: var(--main_color)
}

.main_08 form .btn_wrap button {
    background-color: #000;
    color: #fff;
    width: 100%;
    height: 50px;
    text-align: center;
    margin-top: 10px;
    font-size: 18px
}

.main_08 form .btn_wrap button:hover {
    background-color: var(--main_color)
}

section.main_09 {
    display: flex;
    padding-block: 0;
    border-top: 1px solid #d4d4d4
}

.main_09 .map_wrap {
    width: calc(2*(100% / 3));
    max-width: 1200px;
    background-color: #f5f5f5;
    max-height: 750px;
    height: 100vh;
    border-right: 1px solid #d4d4d4
}

.main_09 .map_wrap .map {
    width: 100%;
    height: 100%
}

.main_09 .tit_wrap {
    margin-bottom: 30px
}

.main_09 .desc_wrap {
    padding: 60px;
    display: inline-flex;
    flex-direction: column;
    justify-content: space-between;
    width: calc(100% / 3);
    max-width: 450px
}

.main_09 .desc_wrap .map_info {
    display: flex;
    gap: 15px;
    margin-bottom: 20px;
    font-weight: 500;
    align-items: flex-start
}

.main_09 .desc_wrap .map_info .location_wrap,
.main_09 .desc_wrap .map_info.location2 {
    display: none
}

.main_09 .desc_wrap .map_info.location2.active {
    display: flex
}

.main_09 .desc_wrap .map_info .location_wrap.active {
    display: block
}

.main_09 .desc_wrap span:not(.icon_wrap) {
    display: block;
    font-weight: 500;
    flex: 1
}

.main_09 .desc_wrap .tell_01 {
    font-weight: 700 !important;
    font-size: 18px;
    margin-bottom: 2px
}

.main_09 .desc_wrap .tell_02 {
    font-weight: 700 !important;
    font-size: 22px;
    margin-bottom: 5px
}

.main_09 .desc_wrap .desc {
    color: var(--desc_color);
    font-size: 15px
}

.main_09 .map_btn_wrap {
    display: flex;
    flex-direction: column;
    gap: 15px;
    width: 100%
}

.main_09 .map_btn_wrap button {
    width: 100%;
    border: 1px solid #ccc;
    height: 50px;
    text-align: center
}

.main_09 .map_btn_wrap button:hover {
    width: calc(100% + 2px);
    border: 2px solid var(--main_color);
    color: var(--main_color);
    font-weight: 700
}

.main_09 .map_btn_wrap button.active {
    width: calc(100% + 2px);
    border: 2px solid var(--main_color);
    color: var(--main_color);
    font-weight: 700
}

.sub_page {
    margin-top: 200px;
    position: relative
}

.sub_tit_wrap {
    text-align: center
}

.sub_tit_wrap h3 {
    font-size: 42px;
    font-weight: 700;
    margin-bottom: 5px
}

.sub_tit_wrap .desc {
    font-size: 18px;
    word-break: keep-all
}

.breadcrumb {
    text-align: right;
    margin-top: 30px;
    padding-inline: 20px
}

.sub_page.wrap_1200 {
    position: relative
}

.breadcrumb a {
    display: inline-block;
    width: auto;
    color: var(--desc_color);
    position: relative
}

.breadcrumb a img {
    vertical-align: revert
}

.breadcrumb a:hover {
    color: #494848
}

.breadcrumb a:hover img {
    filter: brightness(.8)
}

.breadcrumb :where(a+a) {
    margin-left: 30px
}

.breadcrumb :where(a+a)::before {
    content: "";
    display: inline-block;
    width: 10px;
    height: 12px;
    background-image: url(../img/arrow.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    position: absolute;
    left: -20px;
    top: 7px
}

.sub_contact {
    background-image: url(../img/sub_contact_bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: right
}

.sub_contact form {
    display: flex
}

.sub_contact form .form_tit {
    flex: 1;
    min-width: 334px
}

.sub_contact form .form_con {
    flex: 2;
    padding-inline: 100px;
    display: flex;
    flex-direction: column
}

.sub_contact form .form_con label {
    margin-bottom: 25px
}

.sub_contact .form_tit .desc {
    font-weight: 700;
    font-size: 20px
}

.sub_contact h4 {
    font-weight: 700;
    font-size: 28px;
    color: #fff;
    margin-top: 10px
}

.sub_contact form .form_con span {
    color: #fff
}

.sub_contact form .form_con input {
    border: 1px solid #ddd;
    padding: 5px 10px;
    font-size: 16px;
    margin-right: 5px
}

.sub_contact form .form_con input[type=text] {
    width: 100%;
    margin-top: 10px;
    height: 60px;
    display: block
}

.sub_contact form .form_con textarea {
    border: 1px solid #ccc;
    padding: 10px;
    min-height: 150px;
    line-height: 1.3;
    font-size: 16px;
    width: 100%;
    color: #191919;
    margin-top: 10px
}

.sub_contact form .form_con input::placeholder {
    color: #666
}

.sub_contact form .form_con textarea::placeholder {
    color: #666
}

.sub_contact form .submit_btn {
    width: 100%;
    background-color: #000;
    color: #fff;
    text-align: center;
    height: 60px
}

.sub_contact form .submit_btn:hover {
    background-color: var(--main_color)
}

.list_page_wrap {
    text-align: center;
    margin-block: 40px
}

.list_page_wrap span.pg_button {
    opacity: .5
}

.list_page_wrap .pg_button {
    display: inline-block;
    width: 14px;
    height: 11px;
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    background-position: center
}

.list_page_wrap .pg_button.pg_start {
    background-image: url(../img/page_first.png)
}

.list_page_wrap .pg_button.pg_end {
    background-image: url(../img/page_last.png)
}

.list_page_wrap .pg_button.pg_prev {
    background-image: url(../img/page_prev.png)
}

.list_page_wrap .pg_button.pg_next {
    background-image: url(../img/page_next.png)
}

.list_page_wrap .pg_page {
    font-size: 14px;
    font-weight: 700
}

.list_page_wrap :where(.pg_page+.pg_page) {
    margin-left: 15px;
    margin-right: 5px
}

.list_page_wrap .pg_current {
    position: relative;
    color: #fff
}

.list_page_wrap .pg_current {
    content: "";
    width: 30px;
    height: 30px;
    display: inline-block;
    background-color: #171717;
    line-height: 29px;
    border-radius: 50px;
    z-index: -1;
    margin-right: 5px
}

.laywer_list {
    padding-block: 50px
}

.laywer_list ul {
    display: flex;
    flex-wrap: wrap
}

.laywer_list li {
    display: inline-block;
    width: calc((100% - 40px)/ 3);
    margin-bottom: 40px;
    margin-right: 20px
}

.laywer_list li:nth-child(3n) {
    margin-right: 0
}

.laywer_list li a {
    display: block;
    width: 100%;
    height: 100%
}

.laywer_list li a div.icon_wrap {
    padding-top: 30px;
    background-color: #efefef;
    width: 100%;
    height: 460px;
    overflow: hidden
}

.laywer_list li a div.icon_wrap img {
    transition: transform .3s
}

.laywer_list li a:hover div.icon_wrap img {
    transform: scale(1.02);
    transition: transform .3s
}

.laywer_list li a .desc_wrap {
    padding-left: 5px
}

.laywer_list li a .name {
    font-weight: 500;
    font-size: 23px;
    margin-top: 5px
}

.laywer_list li a .name em {
    font-style: normal;
    font-weight: 700
}

.laywer_list li a .main_c {
    font-weight: 700;
    margin-top: 15px;
    font-size: 20px
}

.laywer_list li a span.icon_wrap {
    display: inline-block;
    vertical-align: sub;
    margin-right: 7px
}

section.lawyer_img_wrap {
    padding-block: 0;
    background-color: #f6f6f6;
    padding-top: 50px;
    padding-bottom: 0;
    overflow: hidden;
    margin-top: 50px
}

.lawyer_img_wrap .flex {
    display: flex;
    width: 100%
}

.lawyer_img_wrap .name_wrap {
    text-align: right;
    flex: 1;
    margin-bottom: 100px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end
}

.lawyer_img_wrap .name_wrap .desc {
    display: flex;
    align-items: center;
    justify-content: end;
    gap: 5px;
    font-weight: 700;
    color: var(--main_color);
    font-size: 23px;
    line-height: 1.1
}

.lawyer_img_wrap .name_wrap .name {
    width: auto;
    font-size: 35px;
    font-weight: 500;
    margin-bottom: 25px;
    position: relative
}

.lawyer_img_wrap .name_wrap .name::after {
    content: "";
    display: inline-block;
    width: 340px;
    height: 1px;
    position: absolute;
    bottom: -13px;
    right: 0;
    background-color: #d4d4d4
}

.lawyer_img_wrap .name_wrap .eng_name {
    color: #a1a1a1;
    font-size: 20px
}

.lawyer_img_wrap .icon_wrap {
    padding-left: 50px;
    flex: 1
}

.lawyer_img_wrap .icon_wrap img {
    max-width: 270px;
    max-height: 430px;
    object-fit: cover;
    object-position: top
}

section.lawyer_info_wrap {
    position: relative;
    padding-block: 0;
    display: flex;
    justify-content: space-between;
    margin-bottom: 100px;
    margin-top: 100px
}

.lawyer_info_wrap .left_menu {
    width: 140px;
    position: sticky;
    top: 150px;
    z-index: 1;
    height: max-content
}

.lawyer_info_wrap .left_menu .menu_name {
    display: inline-flex;
    flex-direction: column;
    min-width: 80px
}

.lawyer_info_wrap .left_menu button {
    font-weight: 600;
    text-align: right;
    display: inline-block;
    font-size: 20px
}

.lawyer_info_wrap .left_menu button.active {
    color: var(--main_color)
}

.lawyer_info_wrap .left_menu .menu_name :where(button+button) {
    margin-top: 20px
}

.lawyer_info_wrap .progress_bar {
    display: inline-block;
    width: 4px;
    height: 100%;
    border-radius: 10px;
    background-color: #d4d4d4;
    position: absolute;
    top: 0;
    right: 0
}

.lawyer_info_wrap .progress_bar .bar {
    display: inline-block;
    width: 100%;
    height: calc(100% / 3);
    background-color: var(--main_color);
    border-radius: 20px;
    position: absolute;
    top: 0;
    right: 0;
    transition: top .3s
}

.lawyer_info_wrap .basic_list_wrap {
    position: relative;
    width: calc(100% - 250px)
}

.basic_list_wrap .tit_wrap {
    margin-bottom: 20px;
    padding-top: 50px
}

.basic_list_wrap li:nth-child(1) .tit_wrap {
    padding-top: 0
}

.basic_list_wrap .tit_wrap .desc {
    font-size: 16px;
    font-weight: 500
}

.basic_list_wrap .tit_wrap .tit {
    font-size: 26px;
    font-weight: 700
}

.basic_list_wrap .desc_wrap {
    padding-bottom: 50px;
    border-bottom: 1px solid #d4d4d4
}

.basic_list_wrap .desc_wrap .basic_list {
    padding-left: 5px;
    font-size: 20px;
    display: flex;
    margin-bottom: 5px;
    word-break: keep-all
}

.basic_list_wrap .desc_wrap .basic_list:last-child {
    margin-bottom: 0
}

.basic_list_wrap .desc_wrap .basic_list::before {
    display: inline-block;
    margin-right: 7px;
    font-weight: 700
}

.basic_list_wrap li:last-child .desc_wrap {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0
}

.intro_detail_slide {
    padding-top: 0
}

.intro_detail_slide .tit_wrap {
    margin-bottom: 30px
}

.intro_detail_slide .tit_wrap .tit {
    border-top: 1px solid #d4d4d4;
    font-size: 26px;
    font-weight: 700;
    padding-left: 40px;
    padding-top: 40px
}

.intro_detail_slide .success_slide_wrap {
    max-width: 1320px;
    position: relative;
    overflow: hidden
}

.intro_detail_slide>.wrap_1400 {
    position: relative
}

.intro_detail_slide button {
    position: absolute;
    top: calc((100%)/ 2);
    transform: translateY(-50%);
    filter: brightness(0);
    left: 0
}

.intro_detail_slide button.next_btn {
    position: absolute;
    transform: translateY(-50%) rotate(180deg);
    left: unset;
    right: 0;
    filter: brightness(0)
}

.intro_detail_slide .success_slide_wrap li {
    border: 1px solid #ddd;
    padding: 20px 30px
}

.intro_detail_slide .success_slide_wrap .cate {
    font-weight: 700;
    margin-bottom: 10px
}

.intro_detail_slide .success_slide_wrap .tit {
    margin-bottom: 5px;
    font-weight: 700;
    line-height: 1.5
}

.intro_detail_slide .success_slide_wrap .desc {
    color: var(--desc_color);
    line-height: 1.5;
    min-height: 42px;
    font-size: 14px
}

.intro_detail_slide .success_slide_wrap .detail_btn {
    display: inline-block;
    font-weight: 500;
    border: 1px solid #ddd;
    padding: 3px 25px;
    font-size: 14px;
    margin-top: 15px
}

.intro_detail_slide .success_slide_wrap .detail_btn:hover {
    color: var(--main_color)
}

.go_back_btn_wrap {
    margin-block: 60px;
    text-align: center
}

.go_back_btn_wrap a {
    width: 100%;
    display: inline-block;
    max-width: 250px;
    height: 60px;
    background-color: var(--main_color);
    line-height: 60px;
    text-align: center;
    color: #fff;
    font-weight: 400;
    font-size: 16px
}

.success_swiper_container {
    width: 100%;
    background-image: url(../img/sub_02_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    margin-top: 70px
}

.success_swiper_wrap {
    position: relative
}

.success_swiper {
    overflow: hidden
}

.success_swiper ul {
    height: 400px
}

.success_swiper li {
    background-color: #fff;
    display: flex;
    flex-direction: column
}

.success_swiper li a {
    display: block;
    width: 100%;
    height: 100%
}

.success_swiper li a:hover .img_wrap img {
    transform: scale(1.05);
    transition: transform .3s
}

.success_swiper li .desc_wrap {
    padding: 30px 25px;
    min-height: 168px;
    height: 50%
}

.success_swiper li .img_wrap {
    width: 100%;
    height: 50%;
    overflow: hidden
}

.success_swiper li .img_wrap img {
    opacity: .4;
    filter: grayscale(100%)
}

.success_swiper li .img_wrap img {
    transition: transform .3s
}

.success_swiper li .result {
    font-weight: 600;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 10px
}

.success_swiper li .result .icon_wrap img {
    object-position: center
}

.success_swiper li .con_tit {
    font-weight: 700;
    margin-bottom: 10px;
    font-size: 22px
}

.success_swiper li .con_desc {
    color: var(--desc_color)
}

.success_swiper li .desc_wrap p span {
    font-size: 15px !important;
    color: var(--desc_color) !important;
    font-family: "Noto Sans KR" !important;
    line-height: 1.5;
    overflow: hidden;
    word-break: keep-all;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical
}

.success_swiper .icon_wrap {
    width: 20px;
    height: 23px;
    vertical-align: text-top;
    display: inline-block
}

.success_swiper_wrap button.icon_wrap {
    position: absolute;
    display: inline-block;
    width: 30px;
    height: 40px;
    top: 50%;
    left: -50px;
    transform: translateY(-50%) rotate(180deg)
}

.success_swiper_wrap button.icon_wrap.next_btn {
    right: -50px;
    left: unset;
    transform: translateY(-50%) rotate(0)
}

.success_list_wrap .text_wrap .sub_tit {
    font-weight: 700;
    font-size: 18px;
    text-align: center;
    line-height: 1.5;
    word-break: keep-all
}

.success_list_wrap .text_wrap .sub_tit span {
    font-weight: 700;
    font-size: 18px;
    word-break: keep-all
}

.success_list_wrap .text_wrap .desc {
    color: var(--desc_color);
    font-weight: 500;
    margin-top: 3px;
    margin-bottom: 30px;
    text-align: center;
    word-break: keep-all
}

.success_list_wrap .success_list .list_search_wrap {
    width: 100%;
    text-align: center;
    margin-bottom: 50px
}

.success_list_wrap .success_list input {
    font-weight: 500;
    font-size: 16px;
    width: calc(100% - 80px);
    max-width: 600px;
    height: 50px;
    border: 1px solid #ccc;
    padding: 5px 10px;
    margin-right: 0
}

.success_list_wrap .success_list input::placeholder {
    color: #171717;
    font-weight: 500;
    font-size: 14px
}

.success_list_wrap .success_list button {
    background-color: #171717;
    color: #fff;
    width: 70px;
    height: 50px;
    text-align: center
}

.success_table_wrap {
    overflow-x: auto;
    padding-bottom: 2px
}

.success_list_wrap table {
    border-top: 1px solid #171717;
    width: 100%;
    border-bottom: 2px solid #d4d4d4
}

.success_list_wrap table tr {
    height: 50px;
    line-height: 50px;
    border-top: 1px solid #ccc
}

.success_list_wrap table .list_tit {
    max-width: 320px
}

.success_list_wrap table .list_result {
    max-width: 220px
}

.success_list_wrap table td {
    font-weight: 500;
    padding-right: 5px
}

.success_list_wrap table td:last-child {
    padding-right: 0
}

.success_list_wrap table td a {
    font-weight: 500
}

.success_list_wrap table a:hover {
    font-weight: 700
}

.success_list_wrap table td:not(.list_con) {
    text-align: center
}

.success_list_wrap table .list_con {
    max-width: 420px
}

.success_list_wrap table thead tr:first-child {
    border-top: none
}

.success_list_wrap table .list_result .icon_wrap {
    display: inline-block;
    width: 20px;
    margin-right: 3px;
    vertical-align: middle;
    position: relative;
    top: -2px
}

.success_list_wrap table .list_result {
    font-weight: 600;
    color: var(--main_color)
}

section.success_detail_wrap {
    padding-block: 0;
    padding: 30px 20px;
    border-top: 1px solid #171717;
    border-bottom: 1px solid #d4d4d4;
    margin-top: 50px
}

.success_detail_wrap .tit_cate {
    margin-bottom: 5px;
    font-weight: 600;
    font-size: 22px;
    display: flex;
    align-items: center;
    gap: 10px
}

.success_detail_wrap .tit_cate span {
    display: inline-block;
    width: 20px;
    height: 20px;
    margin-right: 5px;
    vertical-align: sub
}

.success_detail_wrap .con_tit {
    line-height: 1.5;
    font-weight: 700;
    font-size: 18px;
    margin-bottom: 5px;
    word-break: keep-all
}

.success_detail_wrap .con_date {
    color: var(--desc_color);
    font-size: 14px;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #d4d4d4
}

.success_detail_wrap .con_wrap .flex {
    display: flex
}

.success_detail_wrap .con_wrap :not(.cate) {
    font-weight: 500;
    line-height: 1.5;
    font-size: 15px !important;
    word-break: keep-all !important;
    font-family: "Noto Sans KR" !important
}

.success_detail_wrap .con_wrap .left_part {
    width: 70%
}

.success_detail_wrap .con_wrap .left_part>div {
    padding-bottom: 30px
}

.success_detail_wrap .con_wrap .left_part>:where(div+div) {
    padding-top: 30px;
    border-top: 1px solid #d4d4d4
}

.success_detail_wrap .con_wrap .cate {
    font-weight: 600;
    margin-bottom: 10px;
    font-size: 22px;
    display: flex;
    align-items: center;
    gap: 10px
}

.success_detail_wrap .con_wrap .cate span {
    display: inline-block;
    margin-right: 3px;
    width: 30px;
    height: 25px;
    vertical-align: sub
}

.success_detail_wrap .con_wrap .cate span img {
    object-position: center
}

.success_detail_wrap .con_wrap .right_part {
    width: 30%;
    max-width: 320px;
    margin-left: 40px
}

.success_detail_wrap .con_wrap .right_part .result_img {
    width: 100%;
    border: 1px solid #d4d4d4;
    padding: 15px
}

.review_list_wrap {
    padding-block: 40px
}

.review_list_wrap li {
    width: calc((100% - 35px)/ 2);
    border: 1px solid #d4d4d4;
    display: inline-block;
    margin-bottom: 30px
}

.review_list_wrap li:nth-child(2n-1) {
    margin-right: 30px
}

.review_list_wrap li a {
    display: inline-block;
    padding: 30px;
    width: 100%;
    height: 100%
}

.review_list_wrap li:hover {
    border: 1px solid #adacac
}

.list_content .con_cate {
    font-weight: 600;
    margin-bottom: 10px
}

.list_content .con_tit {
    font-weight: 700;
    margin-bottom: 5px;
    font-size: 18px
}

.list_content .con_desc {
    color: var(--desc_color);
    font-size: 15px;
    margin-bottom: 10px;
    font-weight: 500
}

.review_list.list_content .con_desc {
    min-height: 63px
}

.list_content p.more {
    font-size: 14px;
    margin-bottom: 5px;
    color: var(--desc_color);
    font-weight: 500
}

.list_content .con_info {
    text-align: right;
    padding-right: 10px;
    font-size: 15px;
    font-weight: 500
}

.list_content .con_info span {
    font-weight: 500
}

.list_content .con_info :where(span+span) {
    display: inline-block;
    margin-left: 3px
}

.list_content .con_info span.con_how::before {
    content: "";
    display: inline-block;
    width: 1px;
    height: 15px;
    background-color: #171717;
    margin-right: 7px;
    vertical-align: middle;
    margin-top: -3px
}

section.list_content_detail {
    padding-block: 0;
    padding: 0 0 20px;
    border-top: 1px solid #171717;
    border-bottom: 1px solid #d4d4d4;
    margin-top: 50px
}

.list_content_detail .con_tit_wrap {
    position: relative;
    border-bottom: 1px solid #d4d4d4;
    padding: 30px 10px
}

.list_content_detail .tit_cate {
    margin-bottom: 5px;
    font-weight: 600
}

.list_content_detail .tit_cate span {
    display: inline-block;
    width: 20px;
    height: 20px;
    margin-right: 5px;
    vertical-align: sub
}

.list_content_detail .con_sub_title {
    color: var(--main_color);
    font-weight: 700;
    font-size: 18px;
    margin-bottom: 10px
}

.list_content_detail .con_tit {
    line-height: 1.5;
    font-weight: 700;
    font-size: 18px;
    word-break: keep-all
}

.list_content_detail .con_info span.con_date {
    color: var(--desc_color);
    font-size: 14px;
    margin-left: 10px
}

.list_content_detail .con_info {
    font-size: 15px;
    margin-top: 10px;
    text-align: right
}

.list_content_detail .con_info :where(span+span) {
    display: inline-block;
    margin-left: 3px
}

.list_content_detail .con_info span.con_how::before {
    content: "";
    display: inline-block;
    width: 1px;
    height: 15px;
    background-color: #171717;
    margin-right: 7px;
    vertical-align: middle;
    margin-top: -3px
}

.list_content_detail .con_info span:not(.con_date) {
    font-weight: 500
}

.list_content_detail .con_desc_wrap {
    padding: 30px 20px
}

.list_content_detail .con_desc_wrap * {
    font-family: "Noto Sans KR" !important
}

section.work_cate_wrap {
    padding: 30px 0 0
}

section.work_cate_wrap.work_cate_list {
    padding: 0;
    padding-block: 30px
}

.work_cate_wrap ul {
    display: flex;
    flex-wrap: wrap;
    gap: 10px
}

.work_cate_wrap li {
    flex: auto;
    display: inline-block;
    border: 1px solid #d4d4d4
}

.work_cate_wrap li a {
    display: inline-block;
    height: 100%;
    width: 100%;
    padding: 25px 20px
}

.work_cate_wrap li .con_tit {
    border-bottom: 1px solid #d4d4d4;
    padding-bottom: 10px
}

.work_cate_wrap li.long .con_tit {
    padding-right: 50px
}

.work_cate_wrap li .con_more {
    font-size: 14px
}

.work_cate_wrap li.active {
    border: 2px solid var(--main_color)
}

.work_cate_wrap li:hover {
    border: 2px solid var(--main_color)
}

.work_cate_wrap li.active a {
    padding: 24px 19px
}

.work_cate_wrap li:hover a {
    padding: 24px 19px
}

.work_cate_wrap li:hover .con_tit {
    color: var(--main_color)
}

.work_cate_wrap li.active .con_tit {
    color: var(--main_color)
}

.sub_page .main_06 {
    background-color: transparent;
    padding: 50px 0 100px
}

.sub_page .main_06 ul {
    width: 100%
}

.sub_page .main_06 li.active {
    padding: 30px 40px 30px 40px
}

.sub_page .main_06 li :where(.con_tit, .desc) {
    word-break: keep-all
}

.answer_wrap {
    margin-top: 30px
}

.answer_wrap .icon {
    width: 100px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    vertical-align: top
}

.answer_wrap .icon_wrap {
    width: 50px;
    margin-bottom: 5px
}

.answer_wrap .icon span {
    font-weight: 600;
    color: var(--main_color)
}

.answer_wrap .answer {
    display: inline-block;
    width: calc(100% - 125px);
    background-color: #eee;
    margin-left: 20px;
    padding: 25px;
    position: relative;
    word-break: keep-all
}

.answer_wrap .answer::before {
    content: "";
    display: inline-block;
    position: absolute;
    border-top: 15px solid #eee;
    border-right: 15px solid #eee;
    border-left: 15px solid transparent;
    border-bottom: 15px solid transparent;
    top: 0;
    left: -25px
}

.news_wrap {
    padding-block: 60px
}

.news_wrap ul {
    font-size: 0
}

.news_wrap ul li {
    display: inline-block;
    width: calc((100% - 70px)/ 3);
    margin-bottom: 70px;
    vertical-align: top;
    padding: 15px;
    background-color: #f5f5f5
}

.news_wrap ul li>a .img_wrap {
    width: 100%;
    height: 200px;
    overflow: hidden
}

.news_wrap ul li>a:hover img {
    transform: scale(1.05);
    transition: transform .3s
}

.news_wrap ul li>a img {
    transition: transform .3s
}

.news_wrap ul li>a:hover .con_tit {
    font-weight: 700
}

.news_wrap ul :where(li+li) {
    margin-left: 30px
}

.news_wrap ul li:nth-child(3n+1) {
    margin-left: 0
}

.news_wrap .list_content .desc_wrap {
    border-bottom: none;
    margin-top: 15px
}

.news_wrap .list_content .con_cate {
    font-size: 15px;
    margin-bottom: 5px
}

.news_wrap .list_content .con_tit {
    font-size: 16px;
    height: 50px;
    font-weight: 600
}

.news_wrap .list_content .con_date {
    font-size: 14px;
    color: var(--desc_color)
}

section.news_detail_wrap {
    padding: 0 0 50px
}

.news_detail_wrap .con_info {
    text-align: left
}

.news_detail_wrap .con_info span.con_date {
    color: var(--desc_color);
    font-size: 14px;
    margin-left: 0
}

.news_detail_wrap .con_info span.con_view {
    color: var(--desc_color);
    font-size: 14px;
    margin-left: 10px
}

.news_detail_wrap .con_tit {
    font-size: 20px
}

.news_detail_wrap .con_desc_wrap {
    font-weight: 600
}

.news_detail_wrap .con_href {
    font-weight: 600;
    padding: 0 20px
}

.news_detail_wrap .con_href span {
    font-weight: 600
}

.news_detail_wrap .con_href:hover {
    font-weight: 600;
    text-decoration: underline
}

.online_counselling {
    text-align: center;
    padding-block: 80px
}

.online_counselling .flex {
    width: calc(100% - 20px);
    max-width: 980px;
    display: inline-flex;
    gap: 20px;
    justify-content: space-between
}

.online_counselling li {
    display: inline-flex;
    align-items: center;
    flex-direction: column;
    position: relative;
    flex: 1
}

.online_counselling li .icon_wrap {
    width: 90px;
    height: 90px;
    margin-bottom: 20px
}

.online_counselling :where(li+li)::before {
    content: "";
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url(../img/online_next.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%)
}

.online_counselling .list_content .con_tit {
    font-size: 20px
}

.int_tab {
    margin: 68px 0 40px;
    display: flex;
    align-content: center;
    justify-content: center;
    gap: 12px
}

.int_tab a {
    line-height: 48px;
    font-size: 20px;
    color: #797979;
    border: 1px solid #d4d4d4;
    width: 290px;
    height: 50px;
    background-color: #fff;
    text-align: center
}

.int_tab2 a {
    width: 225px
}

.int_tab a.active {
    border-color: var(--main_color);
    color: var(--main_color)
}

.greetings_wrap {
    display: flex;
    gap: 60px;
    margin-top: 95px
}

.greetings_wrap .txt_box {
    flex: 1
}

.greetings_wrap .txt_box>p {
    font-weight: 700;
    font-size: 30px;
    word-break: keep-all
}

.greetings_wrap .txt_box p span {
    color: var(--main_color)
}

.greetings_wrap .txt_box .txt {
    margin: 45px 0;
    color: #747474;
    font-size: 19px
}

.greetings_wrap .txt_box .txt p {
    word-break: keep-all;
    margin-bottom: 30px
}

.greetings_wrap .txt_box .txt p:last-child {
    margin-bottom: 0
}

.greetings_wrap .sign_box p {
    color: var(--main_color);
    font-weight: 700;
    font-size: 19px;
    margin-bottom: 12px
}

.greetings_wrap .sign_box p b {
    color: #000
}

.bottom_quick {
    background-color: #f5f5f5;
    padding: 40px 0
}

.bottom_quick_list {
    display: flex;
    gap: 15px
}

.bottom_quick_list a {
    display: block;
    background-color: #fff;
    border: 1px solid #d4d4d4;
    position: relative;
    padding: 30px 20px;
    flex: 1;
    display: flex;
    align-items: center;
    gap: 15px
}

.bottom_quick_list a p:first-child {
    font-weight: 700;
    font-size: 22px
}

.bottom_quick_list a p:last-child {
    font-size: 15px;
    color: #797979;
    letter-spacing: -.5px
}

.bottom_quick_list a .arrow {
    position: absolute;
    right: 18px;
    top: 18px
}

.introduction_imgs {
    display: flex;
    gap: 60px;
    margin-top: 75px;
    justify-content: center;
    position: relative
}

.introduction_imgs .intro_con img {
    border-radius: 40px 0 40px 0
}

.introduction_imgs>div.right {
    padding-top: 150px
}

.introduction_imgs>div div:first-of-type {
    margin-bottom: 80px
}

.introduction_imgs>div .txt p:first-child {
    font-weight: 700;
    font-size: 28px;
    margin-bottom: 5px
}

.introduction_imgs>div {
    position: relative
}

.introduction_imgs .intro_bg_txt {
    position: absolute;
    left: -50px;
    top: 27px
}

.introduction_imgs>div .txt {
    padding: 0 15px;
    margin-top: 40px
}

.introduction_imgs>div .txt p:last-child {
    color: var(--desc_color);
    font-size: 18px;
    word-break: keep-all
}

.bottom_contact {
    background-image: url(../img/bottom_banner.png);
    background-size: cover;
    padding: 15px 20px;
    border-top: 6px solid var(--sub_color01);
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 999
}

.bottom_contact.off {
    position: relative
}

.bottom_contact form {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    max-width: 1800px;
    margin: 0 auto;
    justify-content: center
}

.bottom_contact .form_tit {
    text-align: right
}

.bottom_contact .form_tit p {
    font-size: 18px;
    margin-bottom: 5px
}

.bottom_contact .form_tit h4 {
    font-size: 23px;
    font-weight: 700;
    color: #fff
}

.bottom_contact .form_con {
    display: flex;
    align-items: end;
    gap: 15px
}

.bottom_contact .form_con>label {
    display: flex;
    align-items: center;
    gap: 10px
}

.bottom_contact .form_con>label #user_ph {
    width: 300px
}

.bottom_contact .form_con>label span {
    color: #fff;
    font-size: 20px
}

.bottom_contact .form_con>label input {
    height: 45px;
    padding: 0 10px;
    border: 1px solid #d6d6d6;
    width: 230px;
    font-size: 16px
}

.bottom_contact .form_btn_box button {
    background-color: #000;
    color: #fff;
    border: 1px solid #fff;
    font-size: 20px;
    height: 45px;
    width: 190px;
    line-height: 43px;
    text-align: center
}

.bottom_contact .form_btn_box {
    display: flex;
    gap: 15px;
    align-items: center;
    flex-direction: row-reverse
}

.bottom_contact .form_btn_box label {
    color: #fff;
    font-size: 15px;
    display: block;
    cursor: pointer
}

.bottom_contact .form_info_box {
    padding-right: 20px
}

.bottom_contact .form_info_box .txt p:first-child {
    color: var(--sub_color01);
    font-size: 15px;
    margin-bottom: 5px
}

.bottom_contact .form_info_box .txt p {
    font-weight: 900;
    font-size: 25px;
    color: #fff;
    line-height: 1.1
}

.info_list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 60px
}

.info_list .info_tit {
    margin-top: 10px;
    font-size: 20px
}

.info_list .info_thumb {
    position: relative;
    height: 270px
}

.info_list .info_thumb img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    object-position: center
}

.info_list .info_thumb>p {
    position: absolute;
    color: #fff;
    width: 100%;
    text-align: center;
    word-break: keep-all;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    font-weight: 700;
    font-size: 25px
}

.info_list .info_thumb::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .5)
}

.info_list .info_thumb img {
    width: 100%
}

.M_only_800 {
    display: none !important
}

.work_cate_title span {
    font-weight: 700;
    font-size: 30px;
    color: var(--main_color);
    flex: 1
}

.work_cate_title {
    display: flex;
    align-items: center;
    margin-bottom: 25px
}

.work_cate_title img {
    margin-right: 15px
}

.work_cate_view img {
    max-width: 100%
}

#work_view .wv_box:not(:last-child) {
    margin-bottom: 60px
}

#work_view .tit1 {
    font-weight: 700;
    font-size: 23px;
    margin-bottom: 16px
}

#work_view .tit1.tit1_minus {
    position: relative;
    left: -10px
}

#work_view .tit1 span {
    font-weight: 400
}

#work_view .tit2 span {
    font-weight: 400;
    font-size: 13px
}

#work_view .tit2 {
    font-weight: 700;
    font-size: 23px;
    margin-bottom: 10px;
    color: var(--main_color)
}

#work_view .tit3 {
    word-break: keep-all;
    font-weight: 500;
    font-size: 18px;
    margin-bottom: 10px
}

#work_view .work_table table {
    table-layout: fixed;
    border-top: 1px solid #000;
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    border-bottom: 1px solid #000
}

#work_view .work_table thead th {
    font-weight: 700;
    color: #fff;
    font-size: 18px;
    vertical-align: middle;
    background-color: var(--main_color);
    border: 1px solid #d4d4d4;
    height: 50px
}

#work_view .work_table.work_table_color_b thead th {
    background-color: #191919
}

#work_view .work_table.work_table_color_b tbody th {
    background-color: #fff
}

#work_view .work_table tbody th {
    background-color: #f5f5f5;
    font-size: 16px;
    border: 1px solid #d4d4d4;
    font-weight: 400;
    vertical-align: middle;
    padding: 5px 6px
}

#work_view .wv_table_box:not(:last-child) {
    margin-bottom: 30px
}

#work_view .wv_table_box .work_table2 {
    margin-top: 15px
}

#work_view .work_table tbody td {
    font-size: 16px;
    border: 1px solid #d4d4d4;
    vertical-align: middle
}

#work_view .work_table1 tbody td {
    text-align: center;
    height: 50px;
    padding: 5px 25px
}

#work_view .work_table2 tbody td {
    padding: 18px 25px
}

#work_view .work_table2 tbody td .blue {
    color: #3f62c4;
    font-weight: 700
}

#work_view .work_table2 tbody td .red {
    color: #ff5959;
    font-weight: 700
}

#work_view .work_table2 tbody td b {
    color: #444
}

#work_view .work_table .table_info {
    line-height: 1.5;
    font-size: 12px;
    color: var(--desc_color);
    margin-top: 15px
}

#work_view .work_table tr>:first-child {
    border-left: 0
}

#work_view .work_table tr>:last-child {
    border-right: 0
}

#work_view .work_table .wvt2_th1 {
    width: 70px
}

#work_view .work_table .vertical_write {
    writing-mode: vertical-lr
}

#work_view .wv_box .txt_box1 {
    padding-left: 10px;
    font-size: 18px;
    line-height: 1.5
}

#work_view .wv_box .tb_main_list {
    margin-top: 20px
}

#work_view .wv_box .tb_main_list>li:not(:last-child) {
    margin-bottom: 10px
}

#work_view .wv_box .tb_main_list>li>p {
    position: relative;
    padding-left: 22px
}

#work_view .wv_box .tb_main_list>li>p span {
    position: absolute;
    left: 0;
    top: 0
}

#work_view .wv_box .tb_sub_list {
    color: var(--desc_color);
    padding-left: 15px
}

#work_view .txt_box_wrap:not(:last-child) {
    margin-bottom: 25px
}

#work_view .tb_desc1 {
    word-break: keep-all;
    margin-bottom: 10px;
    font-size: 16px
}

#work_view .tb_desc2 {
    font-size: 16px;
    padding-left: 10px;
    line-height: 1.5
}

#work_view .tb_desc2 p {
    margin-bottom: 6px;
    position: relative;
    word-break: keep-all;
    padding-left: 10px
}

#work_view .tb_desc2 p::before {
    content: "-";
    position: absolute;
    left: 0;
    top: 0
}

#work_view .wv2_txt1::before {
    content: "·";
    position: absolute;
    left: 0;
    top: 0
}

#work_view .wv2_txt1 {
    margin-bottom: 6px;
    position: relative;
    padding-left: 10px;
    word-break: keep-all
}

#hd_pop {
    max-width: 1920px;
    position: absolute;
    top: 150px;
    left: 0;
    display: flex;
    justify-content: center;
    width: 100%;
    gap: 10px;
    padding: 0 15px;
    z-index: 99999;
    flex-wrap: wrap
}

.hd_pops img {
    max-width: 100%;
    height: auto
}

.hd_pops {
    max-height: calc(90vh - 80px);
    max-width: 450px;
    font-family: "Noto Sans KR" !important
}

.hd_pops p {
    font-family: "Noto Sans KR" !important
}

#hd_pop p {
    font-size: 0
}

#hd_pop p {
    font-size: 0;
    height: 100%
}

.hd_pops img {
    width: 100%;
    height: 100%
}

.hd_pops_footer {
    padding: 0;
    background: #000;
    color: #fff;
    text-align: left;
    position: relative;
    font-family: "Noto Sans KR";
    font-size: 16px
}

.hd_pops_footer:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: ""
}

.hd_pops_footer button {
    padding: 10px;
    border: 0;
    color: #fff
}

.hd_pops_footer .hd_pops_reject {
    background: #000;
    text-align: left;
    font-family: "Noto Sans KR";
    font-size: 16px
}

.hd_pops_footer .hd_pops_close {
    background: #393939;
    position: absolute;
    top: 0;
    right: 0
}

.hd_pops_footer .hd_pops_close {
    background: #393939;
    position: absolute;
    top: 0;
    right: 0
}

.m_banner {
    display: none
}

.main_cate_wrap {
    border-top: 1px solid #d4d4d4
}

.main_cate_wrap ul {
    display: flex;
    justify-content: center;
    width: 1400px;
    margin: 0 auto
}

.main_cate_wrap ul li {
    flex: auto;
    border-right: 1px solid #d4d4d4
}

.main_cate_wrap ul li:last-child {
    border-right: 0
}

.main_cate_wrap ul li a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    padding: 30px 20px;
    width: 100%
}

.main_cate_wrap ul li a p:first-child {
    font-size: 23px
}

.main_cate_wrap ul li a p:last-child {
    font-size: 15px;
    color: var(--desc_color)
}

.hashtag_wrap {
    display: flex;
    gap: 10px
}

.hashtag_wrap a {
    font-weight: 700;
    font-size: 18px;
    background-color: var(--main_color);
    color: #fff;
    padding: 5px 15px;
    border-radius: 20px;
    display: inline-block
}

.work_cate_wrap_title {
    display: none
}

.lawyer_box .wrap_1400 {
    display: flex;
    position: relative
}

.lawyer_box .main_lawyer_img {
    position: absolute;
    bottom: -120px;
    left: 50%;
    transform: translateX(-50%);
    cursor: pointer
}

section.main_01 {
    padding-block: 0;
    padding-bottom: 70px;
    overflow: hidden
}

.lawyer_box {
    position: relative
}

.main_01::before {
    z-index: -2;
    content: "";
    width: 58%;
    height: 100%;
    background-color: #f0f0f0;
    display: block;
    position: absolute;
    left: 0;
    top: 0
}

.lawyer_box .left .txt p:first-child {
    font-size: 23px;
    margin-bottom: 30px
}

.lawyer_box .left {
    width: 60%;
    padding-top: 180px;
    position: relative;
    background-image: url(../img/main_proseciton_bg.png);
    background-repeat: no-repeat;
    background-position: 48% 89%
}

.lawyer_box .right {
    flex: 1;
    padding-top: 200px;
    padding-left: 125px;
    padding-bottom: 230px
}

.lawyer_box .left .txt p:last-child {
    color: #797979;
    font-size: 40px;
    line-height: 1.4;
    font-family: "Noto Serif KR";
    font-weight: 700
}

.lawyer_box .left .txt p:last-child span {
    font-family: "Noto Serif KR", serif;
    color: #000
}

.lawyer_box .right .title {
    font-family: "Noto Serif KR", serif;
    line-height: 1.3;
    font-size: 30px;
    margin-bottom: 35px
}

.lawyer_box .right .title span {
    color: #c4a176;
    font-family: "Noto Serif KR", serif;
    font-size: 40px;
    font-weight: 700
}

.lawyer_box .right .txt_list {
    color: var(--desc_color);
    font-size: 23px;
    line-height: 1.4
}

.lawyer_box .right .txt_list ul {
    margin-bottom: 40px
}

.lawyer_box .right .txt_list ul:last-child {
    margin-bottom: 0
}

.lawyer_box .right .txt_list ul li {
    position: relative;
    padding-left: 15px
}

.lawyer_box .right .txt_list ul li::before {
    content: "·";
    position: absolute;
    left: 0;
    top: 2px
}

.main_02 {
    background-image: url(../img/step_bg.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center
}

.main_02 .step_tit {
    text-align: center;
    font-size: 40px;
    color: #fff;
    font-family: "Noto Serif KR", serif;
    font-weight: 700;
    margin-bottom: 40px
}

.main_02 .step_list {
    display: flex;
    align-items: center;
    justify-content: center
}

.main_02 .step_list .step_box .txt {
    position: relative
}

.main_02 .step_list .step_box {
    position: relative;
    padding: 15px 45px 15px 70px;
    color: #fff;
    box-sizing: border-box;
    flex: 1
}

.main_02 .step_list .step_box::after {
    content: "";
    height: 100%;
    width: 20px;
    right: -20px;
    top: 0;
    position: absolute;
    background-image: url(../img/step_line.png);
    background-repeat: no-repeat;
    background-size: contain;
    display: block
}

.main_02 .step_list .step_box .step_img {
    position: absolute;
    right: 0;
    top: 0
}

.main_02 .step_list .step_box p:first-child {
    color: #797979;
    font-size: 18px;
    margin-bottom: 15px
}

.main_02 .step_list .step_box p:nth-child(2) {
    font-weight: 700;
    font-size: 25px;
    margin-bottom: 10px
}

.main_02 .step_list .step_box p:last-of-type {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: -.7px
}

.main_02 .step_list .step_box p:last-of-type span {
    color: #e8c391
}

.main_02 .tit2 {
    margin: 0 5px;
    text-align: center;
    font-size: 27px;
    color: #f0f0f0;
    margin: 150px 0 25px
}

.main_02 .tit2 img {
    vertical-align: middle;
    position: relative;
    top: -2px
}

.main_02 .tit2 span {
    color: #c4a176
}

.main_02 .step_tit_img {
    overflow: hidden;
    text-align: center;
    position: relative;
    padding-bottom: 181px
}

.main_02 .step_tit_img .main {
    top: 56%;
    left: 59%;
    z-index: 1;
    position: absolute;
    mix-blend-mode: exclusion;
    transform: translate(-50%, -50%)
}

.main_02 .step_tit_img .light {
    position: absolute;
    right: 0;
    top: -13px
}

.main_02 .step_peoples {
    margin-top: 60px;
    text-align: center;
    position: relative
}

.main_02 .step_peoples_txt {
    padding-right: 170px;
    display: flex;
    align-items: start;
    justify-content: center;
    gap: 180px;
    position: absolute;
    width: 100%;
    color: #c4a176;
    bottom: 40px;
    left: 0
}

.main_02 .step_peoples_txt .txt:nth-child(2) {
    padding-top: 20px
}

section.main_02 {
    padding-block: 0;
    padding-top: 70px
}

.main_02 .step_peoples_txt .txt {
    text-align: left
}

.main_02 .step_peoples_txt p:first-child {
    font-family: "Noto Serif KR", serif;
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 10px
}

.main_02 .step_peoples_txt ul {
    color: #fefefe
}

.main_02 .step_peoples_txt li {
    line-height: 1.5;
    font-size: 20px;
    margin-bottom: 8px;
    font-weight: 500
}

.main_02 .step_peoples_txt li:last-child {
    margin-bottom: 0
}

.main_02 .txt:nth-child(2) {
    text-align: center
}

.process_banner {
    background-image: url(../img/process_2_banner.png);
    background-position: center;
    background-size: cover;
    padding: 95px 0
}

.process_banner .pb_txt_wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center
}

.process_banner .pb_txt_wrap .pb_txt {
    border-radius: 100px;
    border: 3px solid rgba(255, 255, 255, .5);
    width: 450px;
    text-align: center;
    height: 174px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column
}

.process_banner .pb_txt_wrap .pb_txt p:first-child {
    color: #fff;
    font-size: 20px;
    letter-spacing: -1px
}

.process_banner .pb_txt_wrap .pb_txt p:last-child {
    font-weight: 700;
    font-size: 28px;
    margin-top: 4px;
    color: #fff;
    letter-spacing: -.5px
}

.process_banner .pb_txt_wrap .pb_txt:last-child {
    margin-left: -24px
}

.process_banner .pb_plus {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background-color: #fff
}

.process_banner .pb_plus span {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.process_list {
    margin: 80px 0 160px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: column;
    position: relative;
    gap: 50px
}

.process_list>div {
    position: relative;
    display: flex
}

.process_list .txt {
    position: absolute;
    white-space: nowrap;
    top: 15px
}

.process_list .txt p:first-child {
    font-weight: 700;
    font-size: 15px;
    color: #797979
}

.process_list .txt p:nth-child(2) {
    font-weight: 700;
    font-size: 22px;
    color: #000
}

.process_list .txt p {
    margin-bottom: 5px;
    color: var(--desc_color);
    font-size: 18px
}

.process_list .txt p:last-child {
    margin-bottom: 0
}

.process_list .left .txt {
    text-align: right;
    right: 130%
}

.process_list .right .txt {
    text-align: left;
    left: 130%
}

.process_list .ico {
    display: inline-block;
    width: 95px;
    height: 95px;
    background-color: #fff;
    border: 1px solid #d4d4d4;
    border-radius: 50%;
    position: relative;
    box-sizing: border-box;
    overflow: hidden
}

.process_list::before {
    content: "";
    width: 2px;
    height: 100%;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    background-color: #d4d4d4;
    display: block
}

.process_list .ico img {
    max-width: 100%;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.process_info_wrap>div {
    padding: 55px 20px;
    display: flex;
    border-bottom: 1px solid #d4d4d4;
    align-items: start
}

.process_info_wrap>div:last-child {
    border-bottom: 0
}

.process_info_wrap>div .tit {
    width: 37%;
    font-weight: 700;
    font-size: 22px;
    line-height: 1.5
}

.process_info_wrap>div .desc {
    flex: 1
}

.process_info_wrap>div .desc p {
    font-size: 18px;
    color: #797979;
    line-height: 1.5;
    word-break: keep-all;
    margin-bottom: 30px
}

.process_info_wrap>div .desc p:last-child {
    margin-bottom: 0
}

.process_info_wrap>div .desc p b {
    color: #000
}

.work_view_wrap {
    margin-top: 25px
}

#work_view .wv_info_box {
    border: 1px solid #797979;
    padding: 40px 35px;
    font-size: 17px;
    line-height: 1.8;
    letter-spacing: -.5px
}

#work_view .wv_info_box div:not(:last-child, .info_desc) {
    margin-top: 8px
}

#work_view .wv_info_box div:not(.tit, .tit1) {
    color: #797979;
    display: flex;
    gap: 3px
}

#work_view .wv_info_box div:not(.tit, .tit1) p {
    flex: 1;
    word-break: keep-all
}

.privacy_link {
    font-weight: 700;
    margin-top: 25px;
    color: #333;
    display: block
}

@media screen and (max-width:1650px) {
    .bottom_contact .form_con {
        margin-right: 40px
    }
}

@media screen and (max-width:1600px) {
    .main_02 .step_peoples_txt p:first-child {
        font-size: 24px
    }

    .main_02 .step_list .step_box {
        padding: 15px 35px 15px 70px
    }

    .main_02 .step_list .step_box p:nth-child(2) {
        font-size: 22px
    }

    .main_02 .tit2 {
        font-size: 24px
    }

    .main_02 .step_list .step_box p:first-child {
        font-size: 16px;
        margin-bottom: 10px
    }

    .main_02 .step_list .step_box p:last-of-type {
        font-size: 16px
    }

    .main_02 .step_peoples_txt li {
        font-size: 18px
    }

    .main_02 .step_tit {
        font-size: 32px
    }

    .lawyer_box .main_lawyer_img {
        width: 390px
    }

    .lawyer_box .right .txt_list {
        font-size: 18px
    }

    .main_banner .main_txt {
        font-size: 55px
    }

    .main_banner .sub_txt {
        font-size: 24px
    }

    .main_banner .main_ico_box img {
        width: 80px
    }

    .lawyer_box .left .txt p:first-child {
        font-size: 18px
    }

    .lawyer_box .left .txt p:last-child {
        font-size: 30px
    }

    .lawyer_box .right .title {
        font-size: 22px
    }

    .lawyer_box .right .title span {
        font-size: 32px
    }

    .main_cate_wrap ul {
        width: 100%
    }

    .main_cate_wrap ul li a p:first-child {
        font-size: 18px
    }

    .main_cate_wrap ul li a p:last-child {
        font-size: 13px
    }

    .main_cate_wrap ul li a {
        gap: 10px;
        padding: 20px 15px
    }

    .main_cate_wrap ul li a>img {
        height: 35px;
        object-fit: contain
    }

    .main_chk_wrap .chk_list li p {
        font-size: 16px
    }

    .main_chk_wrap .chk_txt p {
        font-size: 22px
    }

    .main_chk_wrap .chk_txt li {
        font-size: 16px
    }

    .chk_txt_wrap {
        width: 570px;
        height: 320px
    }

    .main_chk_wrap .chk_list li {
        padding: 10px 12px
    }

    .main_chk_wrap .chk_list li p img {
        width: 24px
    }

    .main_chk_wrap .chk_list_bg img {
        width: 800px
    }

    .main_chk_wrap::after {
        height: 235px
    }

    .bottom_contact .form_tit h4 {
        font-size: 19px
    }

    .bottom_quick_list a p:first-child {
        font-size: 18px
    }

    .bottom_quick_list a p:last-child {
        font-size: 14px;
        word-break: keep-all
    }

    .bottom_quick_list a span {
        width: 40px;
        display: block
    }

    .bottom_quick_list a {
        padding: 14px 14px
    }

    .bottom_quick_list a span img {
        width: 100%
    }

    .bottom_contact .form_con>label span {
        font-size: 18px
    }

    .bottom_contact .form_tit h4 {
        font-size: 19px
    }

    .bottom_contact .form_tit p {
        font-size: 16px
    }

    .bottom_contact .form_con>label input {
        height: 40px;
        width: 170px
    }

    .bottom_contact .form_info_box {
        align-items: center
    }

    .bottom_contact .form_con {
        margin: 0 20px
    }

    .bottom_contact .form_info_box>img {
        width: 40px;
        height: 40px;
        object-fit: contain
    }

    .bottom_contact .form_con>label #user_ph {
        width: 200px
    }

    .bottom_contact .form_info_box .txt p:first-child {
        font-size: 13px
    }

    .bottom_contact .form_info_box .txt p {
        font-size: 21px
    }

    .bottom_contact .form_btn_box button {
        width: 140px;
        height: 40px;
        font-size: 16px;
        line-height: 38px
    }

    .wrap_1400 {
        width: calc(100% - 40px);
        max-width: 1400px;
        margin-inline: auto
    }

    .wrap_1200 {
        width: calc(100% - 40px);
        max-width: 1200px;
        margin-inline: auto
    }

    .tit_wrap h3 {
        font-size: 28px
    }

    footer .company_wrap {
        padding: 40px 20px 60px
    }

    footer .company_wrap li+li::before {
        margin-right: 35px
    }

    .quick_menu_wrap a {
        width: 55px;
        height: 55px;
        padding: 5px 1px
    }

    .quick_menu_wrap a p {
        font-size: 10px;
        margin-top: 0
    }

    .big_intro_wrap ul li {
        max-width: 270px;
        height: 400px
    }

    .big_intro_wrap ul li div.icon_wrap {
        padding-top: 60px
    }

    .main_04 .review_swiper_wrap {
        justify-content: center
    }

    .main_04 .review_swiper {
        max-width: 1200px;
        width: calc(100% - 160px)
    }

    .review_swiper_wrap button {
        position: absolute;
        right: 20px;
        top: 50%;
        transform: translateY(-50%)
    }

    .review_swiper_wrap button.prev_btn {
        right: unset;
        left: 20px;
        transform: translateY(-50%) rotate(180deg)
    }

    .intro_detail_slide .success_slide_wrap {
        max-width: calc(100% - 60px)
    }

    .success_swiper_wrap {
        width: calc(100% - 140px)
    }
}

@media screen and (max-width:1420px) {
    .main_02 .tit2 {
        font-size: 22px;
        margin: 90px 0 0
    }

    .main_02 .step_peoples img {
        width: 700px
    }

    .main_02 .step_peoples_txt {
        padding-right: 7%
    }

    .main_02 .step_peoples_txt li {
        font-size: 16px
    }

    .main_02 .tit2 img {
        width: 25px
    }

    .main_02 .step_peoples_txt p:first-child {
        font-size: 20px
    }

    .main_02 .step_tit_img .light {
        width: 790px
    }

    .main_02 .step_list .step_box {
        padding: 15px 55px 15px 30px
    }

    .main_02 .step_list .step_box::after {
        right: 0
    }

    .main_02 .step_list .step_box .step_img {
        height: 65px
    }

    .lawyer_box .left {
        background-size: 180px
    }

    .lawyer_box .main_lawyer_img {
        width: 330px
    }

    .lawyer_box .right {
        padding-top: 80px;
        padding-left: 85px;
        padding-bottom: 160px
    }

    .lawyer_box .left .txt p:first-child {
        font-size: 16px;
        margin-bottom: 10px
    }

    .lawyer_box .left .txt p:last-child {
        font-size: 25px
    }
}

@media screen and (max-width:1240px) {
    .greetings_wrap .greetings_img {
        width: 400px
    }

    .greetings_wrap .greetings_img img {
        width: 100%
    }

    .greetings_wrap .txt_box .txt {
        font-size: 16px;
        margin: 25px 0
    }

    .greetings_wrap .txt_box>p {
        font-size: 24px
    }

    .greetings_wrap .sign_box p {
        font-size: 16px
    }

    .greetings_wrap .sign_box img {
        width: 180px
    }

    .greetings_wrap {
        gap: 40px
    }

    .introduction_imgs>div .intro_con img {
        width: 100%
    }

    .introduction_imgs {
        padding: 0 50px
    }

    .introduction_imgs>div .txt p:last-child {
        font-size: 16px
    }

    .introduction_imgs>div .txt p:first-child {
        font-size: 22px;
        margin-bottom: 5px
    }

    .introduction_imgs {
        gap: 40px
    }

    .introduction_imgs .intro_bg_txt {
        width: 30px
    }

    .introduction_imgs>div .txt {
        margin-top: 25px
    }

    .introduction_imgs>div div:first-of-type {
        margin-bottom: 50px
    }
}

@media screen and (max-width:1200px) {
    .small_intro_wrap ul li .icon_img {
        left: 10px;
        top: 10px
    }

    .header.active nav ul a {
        font-size: 16px
    }

    .header nav ul {
        gap: 15px
    }

    .main_chk_wrap::after {
        height: 205px
    }

    .main_chk_wrap .chk_list li p img {
        width: 20px
    }

    .main_chk_wrap .chk_list li p {
        gap: 8px
    }

    .chk_txt_wrap {
        width: 480px;
        height: 270px
    }

    .info_list {
        gap: 20px
    }

    .info_list .info_tit {
        font-size: 18px;
        word-break: keep-all
    }

    .info_list .info_thumb {
        height: auto;
        aspect-ratio: 1/.6
    }

    .info_list .info_thumb>p {
        font-size: 20px
    }

    footer .footer_blue .social_icon_wrap {
        gap: 10px;
        align-items: center
    }

    footer .footer_blue .social_icon_wrap a.brochure_btn {
        font-size: 13px;
        width: 130px
    }

    footer .footer_blue .social_icon_wrap a.brochure_btn img {
        width: 15px
    }

    .bottom_contact .form_info_box>img {
        display: none
    }

    .bottom_contact .form_tit h4 {
        font-size: 17px
    }

    .bottom_contact .form_tit p {
        font-size: 14px
    }

    .bottom_contact .form_con>label span {
        font-size: 16px
    }

    .bottom_contact .form_con>label input {
        width: 150px
    }

    .bottom_contact .form_con>label #user_ph {
        width: 160px
    }

    .bottom_contact .form_btn_box button {
        width: 120px
    }

    .bottom_contact .form_info_box .txt p {
        font-size: 18px
    }

    .bottom_contact .form_info_box .txt p:first-child {
        font-size: 12px
    }

    .bottom_contact .form_con {
        margin: 0 14px;
        gap: 10px
    }

    .tit_wrap h3 {
        font-size: 26px
    }

    .header {
        height: 100px
    }

    .header .logo_wrap {
        width: 160px
    }

    footer .company_wrap span {
        color: #fff;
        display: block;
        font-size: 15px
    }

    footer .company_wrap li+li::before {
        margin-right: 10px
    }

    footer .footer_white {
        width: calc(50% + 80px);
        padding: 80px 50px
    }

    .quick_menu_wrap {
        top: 120px
    }

    .quick_menu_wrap.active {
        right: 20px
    }

    .tit_wrap .desc+h3 {
        margin-top: 5px
    }

    .big_intro_wrap ul li {
        max-width: 220px;
        height: 330px
    }

    .small_intro_wrap ul li {
        max-width: 220px
    }

    .small_intro_wrap ul {
        justify-content: center
    }

    .big_intro_wrap ul li div.icon_wrap {
        padding-top: 45px
    }

    .big_intro_wrap ul li .info_wrap .name {
        font-size: 20px
    }

    .big_intro_wrap ul li .info_wrap .position {
        font-size: 14px
    }

    .big_intro_wrap ul li .info_sort {
        top: 10px;
        left: 15px
    }

    .big_intro_wrap ul li .info_sort .icon_wrap {
        width: 25px;
        height: 25px
    }

    .big_intro_wrap ul li .info_wrap {
        position: absolute;
        bottom: 15px;
        right: 15px
    }

    .big_intro_wrap ul li .info_sort span {
        font-size: 14px
    }

    .small_intro_wrap ul {
        height: 200px
    }

    .small_intro_wrap ul li .info_wrap .name {
        font-size: 18px
    }

    .small_intro_wrap ul li .info_wrap .position {
        font-size: 14px
    }

    .small_intro_wrap ul li .info_wrap {
        padding: 10px
    }

    .sch_wrap {
        max-width: 600px
    }

    .sch_wrap .sch_cate_wrap button {
        padding: 5px;
        font-size: 14px
    }

    .sch_con_wrap li .img_wrap {
        width: 100%;
        max-width: 150px;
        margin-right: 30px
    }

    .sch_con_wrap li>a {
        padding: 25px
    }

    .more_btn_wrap a {
        color: #fff;
        font-size: 16px
    }

    .main_04 .review_swiper li {
        background-color: #fff;
        padding: 20px;
        max-height: 200px
    }

    .main_04 .review_swiper li .review_cate {
        margin-bottom: 10px
    }

    .main_04 .review_swiper li .review_tit {
        font-size: 16px
    }

    .main_04 .review_swiper li .review_desc {
        color: var(--desc_color);
        font-size: 14px
    }

    .main_04 .review_swiper {
        max-width: 1200px;
        width: calc(100% - 80px)
    }

    .review_swiper_wrap button {
        position: absolute;
        right: -5px;
        top: 50%;
        transform: translateY(-50%);
        width: 30px;
        height: 30px
    }

    .review_swiper_wrap button.prev_btn {
        left: -5px
    }

    .main_04 .review_swiper_wrap {
        position: relative;
        margin-top: 40px
    }

    .main_04 .more_btn_wrap {
        right: 40px;
        top: 67px
    }

    .main_05 .flex .white_icon_wrap {
        flex: 5
    }

    .main_06 li {
        padding: 20px 100px 20px 30px
    }

    .main_06 li .con_tit {
        font-size: 18px;
        font-weight: 700
    }

    .main_08 .form_wrap {
        display: flex;
        justify-content: center
    }

    .main_08 .form_wrap form {
        max-width: 700px;
        width: 100%
    }

    .main_08 form .btn_wrap {
        width: calc(50% - 20px);
        position: absolute;
        bottom: 107px;
        left: calc(50% + 20px);
        max-width: 330px
    }

    .main_08 form div.flex>label>span {
        display: block;
        font-size: 16px
    }

    .main_08 form>div>label>span+input {
        font-size: 14px;
        padding: 5px 10px
    }

    .main_08 form>div>label>span+textarea {
        padding: 15px 10px;
        font-size: 14px
    }

    .main_09 .desc_wrap {
        padding: 60px 35px
    }

    .sub_page {
        margin-top: 160px
    }

    .sub_tit_wrap {
        text-align: center;
        margin-bottom: 30px
    }

    .sub_tit_wrap h3 {
        font-size: 36px
    }

    .breadcrumb {
        text-align: center
    }

    .breadcrumb :where(a+a)::before {
        content: "";
        display: inline-block;
        width: 8px;
        height: 10px;
        background-size: contain;
        left: -20px;
        top: 7px
    }

    .laywer_list li a span.icon_wrap {
        display: inline-block;
        width: 16px;
        height: 20px;
        vertical-align: sub;
        margin-right: 7px
    }

    .success_list_wrap table :where(td, th) {
        font-size: 14px
    }

    .review_list_wrap li a {
        padding: 25px
    }

    .work_cate_wrap li .con_tit {
        font-size: 16px
    }

    .sub_page .main_06 li.active {
        padding: 20px 30px
    }

    .news_wrap {
        padding-block: 40px
    }

    .news_wrap ul li {
        margin-bottom: 70px
    }

    .news_wrap ul :where(li+li) {
        margin-left: 20px
    }

    .news_wrap .list_content .con_tit {
        font-size: 15px;
        height: 43px
    }

    footer .company_wrap span.tit {
        font-size: 18px
    }

    .main_chk_wrap .chk_list_bg img {
        width: 650px
    }

    .main_chk_wrap .chk_txt li {
        font-size: 14px
    }

    .main_chk_wrap .chk_txt p {
        font-size: 18px
    }

    .process_banner .pb_txt_wrap .pb_txt p:first-child {
        font-size: 16px
    }

    .process_banner .pb_txt_wrap .pb_txt p:last-child {
        font-size: 24px
    }

    .process_banner .pb_txt_wrap .pb_txt {
        width: 380px;
        height: 130px
    }

    .process_list .txt p:nth-child(2) {
        font-size: 18px
    }

    .process_list .txt p {
        font-size: 16px
    }

    .process_list .ico {
        width: 75px;
        height: 75px
    }

    .process_list .ico img {
        padding: 15px
    }

    .process_list .txt p:first-child {
        font-size: 12px
    }

    .process_info_wrap>div .tit {
        font-size: 18px
    }

    .process_info_wrap>div .desc p {
        font-size: 16px
    }

    .process_info_wrap>div .desc p {
        margin-bottom: 10px
    }

    .process_list {
        margin: 50px 0 130px
    }

    .process_info_wrap>div {
        padding: 35px 10px
    }
}

@media screen and (max-width:1024px) {
    .main_02 .step_tit_img .light {
        width: 670px
    }

    .process_banner .pb_plus {
        width: 70px;
        height: 70px
    }

    .process_banner .pb_txt_wrap .pb_txt p:last-child {
        font-size: 22px
    }

    .process_banner .pb_plus span img {
        width: 25px
    }

    .process_list .txt p {
        font-size: 14px
    }

    .process_list .right .txt {
        left: 115%
    }

    .process_list .left .txt {
        right: 115%
    }

    .process_list .txt p:nth-child(2) {
        font-size: 16px
    }

    .process_info_wrap>div .tit {
        font-size: 16px
    }

    .process_info_wrap>div .desc p {
        font-size: 14px
    }

    .main_banner .main_txt {
        font-size: 45px;
        margin: 50px 0 70px
    }

    .main_banner .sub_txt {
        font-size: 20px
    }

    .main_banner .main_ico_box img {
        width: 60px
    }

    .big_intro_wrap ul li .info_wrap .sub_title .lawyer_mark img {
        width: 16px
    }

    .big_intro_wrap ul li .info_wrap .sub_title .lawyer_mark {
        margin-right: 0
    }

    .m_banner {
        display: block
    }

    .pc_banner {
        display: none
    }

    .main_chk_wrap .chk_txt_box .chk_txt {
        padding: 0
    }

    .main_chk_wrap .chk_list_bg img {
        display: none
    }

    .chk_txt_wrap {
        width: 90%;
        height: auto;
        background-color: transparent;
        box-shadow: none
    }

    .main_chk_wrap .chk_list {
        width: 100%;
        padding: 20px 20px 0;
        background-color: var(--main_color)
    }

    .main_chk_wrap .chk_txt p {
        font-size: 14px
    }

    .main_chk_wrap .chk_txt_box {
        padding: 10px;
        background-color: transparent
    }

    .main_chk_wrap .chk_txt_box .chk_txt {
        background-color: #fff;
        width: 100%;
        box-shadow: 0 0 10px 5px rgba(0, 0, 0, .1);
        padding: 40px 30px
    }

    .main_chk_wrap .chk_txt li {
        font-size: 13px;
        margin-bottom: 6px;
        display: flex;
        gap: 4px;
        word-break: keep-all
    }

    .main_chk_wrap .wrap_1400 {
        flex-wrap: wrap;
        margin: 0;
        flex-direction: column;
        width: 100%
    }

    .main_05_list a {
        flex: none;
        width: calc(33.333% - 10px)
    }

    .main_05_list a:nth-child(7) {
        width: 100%;
        aspect-ratio: 1/.3
    }

    .main_05_list a p b {
        font-size: 16px
    }

    .main_05_list a p span {
        font-size: 13px;
        line-height: normal
    }

    .main_05_list {
        flex-wrap: wrap
    }

    .hd_pops_footer {
        font-size: 12px
    }

    #hd_pop {
        top: 80px;
        align-items: start;
        flex-direction: column
    }

    .hd_pops {
        width: calc(100% - 40px);
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        top: 0
    }

    #hd_pop p {
        width: 100%;
        height: 100%
    }

    .hd_pops img {
        width: 100%;
        height: 100%;
        object-fit: contain
    }

    .greetings_wrap .greetings_img {
        background-color: #f5f5f5;
        overflow: hidden;
        height: 450px;
        width: 100%;
        padding: 25px;
        text-align: center
    }

    .greetings_wrap {
        margin-top: 40px
    }

    .int_tab a {
        flex: 1;
        width: auto;
        font-size: 15px;
        height: 40px;
        line-height: 38px
    }

    .greetings_wrap .greetings_img img {
        max-width: 400px
    }

    .greetings_wrap {
        flex-direction: column
    }

    .greetings_wrap .txt_box .txt {
        white-space: normal;
        word-break: keep-all
    }

    .greetings_wrap .greetings_img {
        margin: 0 auto
    }

    .bottom_quick_list {
        flex-wrap: wrap
    }

    .bottom_quick_list a {
        flex: none;
        width: calc(50% - 12.5px)
    }

    .footer_logo img {
        max-width: 150px;
        filter: brightness(.5)
    }

    .success_detail_wrap .con_wrap .cate {
        font-size: 18px
    }

    .success_detail_wrap .con_wrap .hashtag_wrap a {
        padding: 3px 10px;
        font-size: 14px !important
    }

    .hashtag_wrap {
        gap: 5px;
        flex-wrap: wrap
    }

    .bottom_contact form {
        justify-content: start
    }

    .bottom_contact .form_tit {
        text-align: left
    }

    .bottom_contact form>div {
        width: 100%
    }

    .bottom_contact .form_con {
        display: block;
        margin: 20px 0
    }

    .bottom_contact .form_con>label input {
        width: auto;
        flex: 1;
        min-width: 0
    }

    .bottom_contact .form_con>label #user_ph {
        width: auto
    }

    .bottom_contact .form_con>label span {
        font-size: 15px
    }

    .bottom_contact .form_con>label span {
        width: 80px
    }

    .bottom_contact .form_con>:not(:last-child) {
        margin-bottom: 10px
    }

    .bottom_contact .form_info_box>img {
        display: block
    }

    .M_only {
        display: revert
    }

    section:not(.visual_wrap) {
        padding-block: 100px
    }

    section.main_02 {
        padding-block: 0;
        padding-top: 50px
    }

    section.list_content_detail {
        padding-block: 0
    }

    section.success_detail_wrap {
        padding-block: 0;
        padding: 30px 20px
    }

    section.lawyer_img_wrap {
        padding-block: 50px 0
    }

    section.lawyer_info_wrap {
        padding-block: 0;
        margin-top: 50px
    }

    section.list_content_detail {
        padding-block: 0 50px
    }

    section.main_09 {
        padding-block: 0
    }

    .tit_wrap .desc {
        font-size: 16px
    }

    .tit_wrap h3 {
        font-size: 21px;
        line-height: 1.5
    }

    .tit_wrap {
        width: 100%;
        margin-bottom: 40px
    }

    .header {
        height: 60px
    }

    .header.active .bar {
        background-color: #000
    }

    .header.active nav ul a {
        color: #fff;
        font-size: 18px;
        font-weight: 500
    }

    .header .logo_wrap {
        position: absolute;
        top: 7px;
        left: 50%;
        transform: translateX(-50%);
        width: 140px
    }

    .header .menu_button {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 14px;
        padding: 15px;
        cursor: pointer;
        z-index: 101;
        -webkit-transition: .3s;
        transition: .3s
    }

    .header .menu_button .bar:nth-of-type(1) {
        margin-top: 0
    }

    .header .menu_button .bar:nth-of-type(3) {
        margin-bottom: 0
    }

    .header .bar {
        position: relative;
        display: block;
        width: 20px;
        height: 2px;
        margin: 6px auto;
        background-color: #fff;
        -webkit-transition: .3s;
        transition: .3s
    }

    .header .cross .bar {
        background-color: #ccc
    }

    .header .cross .bar:nth-of-type(1) {
        -webkit-transform: translateY(9px) rotate(-45deg);
        -ms-transform: translateY(9px) rotate(-45deg);
        transform: translateY(9px) rotate(-45deg)
    }

    .header .cross .bar:nth-of-type(2) {
        opacity: 0
    }

    .header .cross .bar:nth-of-type(3) {
        -webkit-transform: translateY(-7px) rotate(45deg);
        -ms-transform: translateY(-7px) rotate(45deg);
        transform: translateY(-7px) rotate(45deg)
    }

    .header nav {
        position: fixed;
        top: 0;
        right: 0;
        z-index: 100;
        display: inline-block;
        transition: transform 1s;
        transform: translateX(100%);
        width: 100%;
        height: 100vh;
        background-color: rgba(0, 0, 0, .85);
        z-index: -1
    }

    .header nav.active {
        display: inline-block;
        transition: transform 1s;
        transform: translateX(0)
    }

    .header nav ul {
        display: flex;
        gap: 25px;
        flex-direction: column;
        margin-top: 80px;
        align-items: center;
        padding-right: 0
    }

    footer .company_wrap ul {
        flex-wrap: wrap
    }

    footer .company_wrap li {
        display: flex;
        gap: 15px;
        align-items: center;
        flex: 1 1 45%;
        padding: 7px
    }

    footer .company_wrap {
        padding: 20px
    }

    footer .footer_white {
        width: 100%;
        padding: 40px 20px;
        font-size: 14px
    }

    footer .company_wrap span.icon_wrap {
        width: 20px;
        height: 20px
    }

    footer .company_wrap span {
        color: #fff;
        display: block;
        font-size: 14px
    }

    footer .company_wrap li+li::before {
        content: "";
        display: none
    }

    footer .footer_blue::before {
        z-index: -1
    }

    footer .footer_wrap {
        display: flex;
        flex-direction: column
    }

    footer .footer_blue {
        width: 100%
    }

    footer .footer_blue>.flex {
        position: unset;
        flex-direction: row;
        padding: 50px 20px
    }

    footer .footer_blue .logo_wrap {
        width: 160px;
        filter: brightness(1)
    }

    footer .footer_blue .social_icon_wrap {
        display: flex;
        gap: 10px
    }

    footer .footer_white {
        width: 100%;
        padding: 60px 20px
    }

    footer .footer_blue .social_icon_wrap a {
        display: inline-flex;
        width: 30px;
        height: 30px;
        filter: brightness(1)
    }

    .quick_menu_wrap {
        position: fixed;
        top: auto;
        bottom: 120px;
        transition: right .3s
    }

    .quick_menu_wrap.active {
        right: 20px;
        transition: right .3s
    }

    .visual_wrap {
        min-height: unset
    }

    .visual_wrap .desc_wrap .main_desc {
        font-size: 25px
    }

    .visual_wrap .desc_wrap .sub_desc {
        font-weight: 400;
        font-size: 22px
    }

    .visual_wrap .desc_wrap .icon_wrap {
        display: flex;
        gap: 20px;
        height: 70px
    }

    .main_02 .tit2 {
        font-size: 18px
    }

    .main_02 .step_peoples img {
        width: 360px
    }

    .main_02 .step_peoples_txt li {
        font-size: 14px;
        margin-bottom: 4px
    }

    .lawyer_box .right .txt_list {
        font-size: 14px
    }

    .main_02 .step_list .step_box p:last-of-type {
        font-size: 14px
    }

    .lawyer_box .main_lawyer_img {
        bottom: -152px
    }

    .main_02 .step_list .step_box p:nth-child(2) {
        font-size: 18px
    }

    .main_02 .step_list .step_box .step_img {
        height: 50px
    }

    .main_02 .step_list .step_box {
        padding: 15px 35px 15px 10px
    }

    .lawyer_box .left .txt p:last-child {
        font-size: 22px
    }

    .lawyer_box .left {
        padding-top: 60px
    }

    .lawyer_box .left .txt p:first-child {
        font-size: 15px
    }

    .lawyer_box .right .title {
        font-size: 18px
    }

    .lawyer_box .right {
        padding-left: 65px
    }

    .lawyer_box .right .title {
        margin-bottom: 15px
    }

    .lawyer_box .right .title span {
        font-size: 25px
    }

    .lawyer_box .right .txt_list ul {
        margin-bottom: 15px
    }

    .main_01::after {
        height: 78%
    }

    .lawyer_box .main_lawyer_img {
        width: 270px
    }

    .big_intro_wrap ul li {
        width: calc((100% - 60px)/ 4);
        height: 300px
    }

    .big_intro_wrap ul li div.icon_wrap {
        padding-top: 30px
    }

    .tit_wrap h3.big_font {
        font-size: 36px
    }

    .big_intro_wrap ul li .info_sort {
        top: 5px;
        left: 6px;
        gap: 5px
    }

    .big_intro_wrap ul li .info_sort .icon_wrap {
        width: 18px;
        height: 18px
    }

    .big_intro_wrap ul li .info_sort span {
        font-size: 12px
    }

    .small_intro_wrap ul li .info_wrap .name {
        font-size: 16px
    }

    .small_intro_wrap ul li .info_wrap .position {
        font-size: 12px
    }

    .main_03 .wrap_1400>.flex {
        flex-direction: column
    }

    .sch_wrap {
        max-width: unset;
        width: calc(100% - 0px);
        margin-top: 20px
    }

    .sch_wrap .sch_box {
        margin-bottom: 0
    }

    .sch_con_wrap {
        margin-top: 0
    }

    .sch_con_wrap li>a {
        padding: 20px
    }

    .sch_con_wrap li>a .b_box {
        min-width: 75px;
        font-size: 14px
    }

    .sch_con_wrap li>a .con_tit {
        font-size: 16px;
        margin-bottom: 10px
    }

    .sch_con_wrap li>a .sub_tit {
        font-size: 14px
    }

    .sch_con_wrap li .desc_wrap .desc {
        font-size: 14px;
        color: var(--desc_color)
    }

    .main_04 .tit_wrap {
        margin-bottom: 50px
    }

    .main_05 .flex {
        flex-direction: column;
        align-items: center
    }

    .main_05 .flex .blue_icon_wrap {
        flex: 5;
        margin-bottom: 20px;
        max-width: 650px;
        margin-right: 0
    }

    .main_05 .flex .white_icon_wrap {
        flex: 5;
        width: 100%;
        max-width: 618px
    }

    .main_05 .flex .blue_icon_wrap a p {
        margin-top: 10px;
        font-weight: 500;
        font-size: 16px
    }

    .main_05 .flex .white_icon_wrap a p.tit {
        font-size: 16px
    }

    .main_06 li .con_cate {
        font-weight: 500;
        margin-bottom: 5px;
        font-size: 14px
    }

    .main_06 li .con_tit {
        font-size: 16px
    }

    .main_06 li .con_desc_wrap {
        margin-top: 10px;
        font-size: 14px
    }

    .main_06 li.active .con_desc_wrap button {
        margin-top: 15px
    }

    .main_06 .more_btn_wrap {
        width: calc(100% - 40px);
        max-width: 265px;
        height: 50px
    }

    .main_06 .more_btn_wrap button {
        font-size: 16px
    }

    .main_06 li .con_desc_wrap .show_answer {
        font-weight: 700
    }

    .main_07 .news_swiper li .con_cate {
        color: var(--main_color);
        margin-bottom: 10px
    }

    .main_07 .news_swiper li .con_tit {
        font-weight: 700;
        font-size: 16px
    }

    .main_07 .news_swiper li .con_desc {
        color: var(--desc_color);
        font-size: 14px
    }

    .main_08 form>div {
        display: flex;
        flex-wrap: wrap;
        gap: 20px
    }

    .main_08 form>div>label {
        display: inline-block;
        width: calc(50% - 10px)
    }

    .main_08 form .btn_wrap {
        bottom: 105px
    }

    .main_08 form .btn_wrap button {
        font-size: 16px
    }

    .main_09 .map_wrap {
        width: 55%;
        max-width: 1200px;
        background-color: #f5f5f5;
        max-height: 750px;
        height: 100vh
    }

    .main_09 .desc_wrap {
        padding: 30px 25px;
        max-width: unset;
        width: 45%
    }

    .main_09 .desc_wrap .map_info {
        display: flex;
        gap: 10px
    }

    .main_09 .desc_wrap span.icon_wrap {
        width: 25px;
        height: 25px
    }

    .main_09 .desc_wrap span:not(.icon_wrap) {
        display: block;
        font-weight: 500;
        font-size: 15px
    }

    .main_09 .map_btn_wrap button {
        font-size: 14px
    }

    .sub_page {
        margin-top: 90px
    }

    .breadcrumb {
        margin-top: 0
    }

    .sub_tit_wrap {
        margin-bottom: 15px
    }

    section.success_detail_wrap {
        margin-top: 30px
    }

    .sub_tit_wrap h3 {
        font-size: 30px
    }

    .sub_tit_wrap .desc {
        font-size: 16px
    }

    .breadcrumb {
        top: 95px
    }

    .breadcrumb a {
        font-size: 14px
    }

    .sub_contact form {
        display: flex;
        flex-direction: column
    }

    .sub_contact form .form_con {
        flex-direction: column;
        margin-top: 50px;
        padding-inline: 0
    }

    .sub_contact form .submit_btn {
        background-color: var(--main_color);
        color: #fff
    }

    .sub_contact form .form_con input[type=text] {
        height: 45px
    }

    .sub_contact form .submit_btn {
        height: 50px
    }

    .laywer_list li {
        width: calc((100% - 40px)/ 3)
    }

    .laywer_list li a div.icon_wrap {
        height: 350px
    }

    .lawyer_img_wrap .name_wrap .desc {
        font-size: 16px
    }

    .lawyer_img_wrap .name_wrap .name {
        font-size: 20px
    }

    .lawyer_img_wrap .name_wrap .name::after {
        width: 220px
    }

    .lawyer_img_wrap .name_wrap .lawyer_ico img {
        width: 25px
    }

    .lawyer_img_wrap {
        height: auto
    }

    .lawyer_info_wrap {
        margin-top: 60px
    }

    .lawyer_info_wrap .left_menu {
        width: 130px;
        top: 65px
    }

    .lawyer_info_wrap .basic_list_wrap {
        position: relative;
        width: calc(100% - 170px)
    }

    .basic_list_wrap .tit_wrap {
        margin-bottom: 13px;
        padding-top: 30px
    }

    .basic_list_wrap .tit_wrap .desc {
        font-size: 15px;
        font-weight: 500
    }

    .basic_list_wrap .tit_wrap .tit {
        font-size: 20px;
        font-weight: 700
    }

    .basic_list_wrap .desc_wrap {
        padding-bottom: 30px;
        border-bottom: 1px solid #d4d4d4
    }

    .success_swiper_wrap {
        width: calc(100% - 100px)
    }

    .success_swiper_wrap button.icon_wrap {
        width: 20px;
        height: 30px;
        left: -35px
    }

    .success_swiper_wrap button.icon_wrap.next_btn {
        left: unset;
        right: -35px
    }

    .success_list_wrap .text_wrap .sub_tit {
        font-size: 16px
    }

    .success_list_wrap .text_wrap .sub_tit span {
        font-size: 16px
    }

    .success_list_wrap .text_wrap .desc {
        font-size: 14px;
        margin-top: 20px
    }

    .review_list_wrap li:nth-child(2n-1) {
        margin-right: 20px
    }

    .review_list_wrap li {
        width: calc((100% - 25px)/ 2);
        border: 1px solid #d4d4d4;
        display: inline-block;
        margin-bottom: 30px
    }

    .review_list_wrap li a {
        padding: 25px
    }

    .list_content .con_cate {
        margin-bottom: 7px;
        font-size: 14px
    }

    .list_content .con_tit {
        font-size: 16px
    }

    .list_content .con_desc {
        font-size: 14px
    }

    .list_content .con_info {
        font-size: 14px
    }

    .work_cate_wrap li {
        min-width: calc((100% - 53px)/ 4)
    }

    .work_cate_wrap li:nth-child(4n+1) {
        margin-left: 0
    }

    .news_wrap ul li {
        width: calc((100% - 25px)/ 2);
        margin-bottom: 40px
    }

    .news_wrap ul :where(li+li) {
        margin-left: 20px
    }

    .news_wrap ul li:nth-child(3n+1) {
        margin-left: 20px
    }

    .news_wrap ul li:nth-child(2n+1) {
        margin-left: 0
    }

    .news_wrap ul li>a .img_wrap {
        height: 250px
    }

    .news_wrap .list_content .con_tit {
        font-size: 15px
    }

    .online_counselling .list_content .con_tit {
        font-size: 17px
    }

    .online_counselling li .icon_wrap {
        width: 70px;
        height: 70px
    }

    .online_counselling :where(li+li)::before {
        width: 16px;
        height: 16px
    }

    .main_cate_wrap ul li a>img {
        height: 25px;
        width: 30px
    }

    .main_cate_wrap ul li a p:first-child {
        font-size: 16px
    }

    .main_cate_wrap ul {
        flex-wrap: wrap
    }

    .main_cate_wrap ul li {
        width: 100%;
        border-bottom: 1px solid #d4d4d4;
        border-right: 0
    }

    .main_cate_wrap ul li:last-child {
        border-bottom: 0
    }

    .main_cate_wrap ul li a {
        justify-content: start;
        padding: 10px
    }

    section.main_01 {
        padding-block: 0;
        padding-bottom: 70px
    }
}

@media screen and (max-width:800px) {
    .main_02 .step_tit_img {
        padding-bottom: 100px
    }

    .main_banner .main_txt {
        margin: 30px 0 40px
    }

    .main_banner .main_ico_box img {
        width: 50px
    }

    .main_banner .main_ico_box {
        gap: 20px
    }

    .main_banner .main_banner_txt {
        padding: 0 20px
    }

    .main_banner .main_txt {
        font-size: 35px
    }

    .main_banner .sub_txt {
        font-size: 18px;
        word-break: keep-all
    }

    .main_02 .step_peoples_txt {
        bottom: 20px
    }

    .main_02 .step_peoples_txt p:first-child {
        font-size: 12px;
        letter-spacing: -.8px
    }

    .main_02 .step_peoples_txt li {
        letter-spacing: -.6px;
        font-size: 9px
    }

    .main_02 .step_peoples_txt {
        left: -10px;
        width: calc(100% + 20px);
        gap: 20px;
        padding-right: 1%
    }

    .main_02 .step_list {
        flex-direction: column
    }

    .main_02 .step_list .step_box {
        width: 100%;
        padding: 15px 10px 35px 10px
    }

    .main_02 .step_tit {
        font-size: 25px
    }

    .main_02 .tit2 img {
        width: 18px;
        display: block;
        margin: 5px auto
    }

    .main_02 .tit2 {
        margin: 60px 0 0;
        font-size: 16px
    }

    .main_02 .step_list .step_box::after {
        top: auto;
        background-position: center;
        width: 100%;
        right: 0;
        height: 20px;
        background-image: url(../img/m_step_line.png);
        bottom: -10px
    }

    .lawyer_box .wrap_1400 {
        flex-direction: column
    }

    .lawyer_box .left {
        background-image: none;
        width: 100%;
        padding-top: 0
    }

    .main_01::after {
        top: 27%
    }

    .main_01::before {
        width: 100%
    }

    .lawyer_box .left .txt p:last-child {
        font-size: 16px
    }

    .lawyer_box .main_lawyer_img {
        width: 145px;
        transform: none;
        left: auto;
        right: 0;
        bottom: -25px
    }

    .lawyer_box .right {
        padding-top: 20px;
        padding-bottom: 10px;
        background-size: 120px;
        background-image: url(../img/main_proseciton_bg.png);
        background-repeat: no-repeat;
        background-position: center 38%;
        padding-left: 0
    }

    .lawyer_box .right .txt_list {
        font-size: 12px
    }

    .lawyer_box .right .txt_list ul li {
        padding-left: 12px
    }

    .lawyer_box .right .title {
        font-size: 16px
    }

    .lawyer_box .right .txt_list ul {
        margin-bottom: 6px
    }

    .lawyer_box .left .txt p:first-child {
        font-size: 12px
    }

    #work_view .wv_box:not(:last-child) {
        margin-bottom: 30px
    }

    #work_view .wv_box .txt_box1 {
        padding-left: 0
    }

    #work_view .work_table tbody th {
        font-size: 12px;
        padding: 5px 5px;
        word-break: break-all
    }

    #work_view .work_table tbody td {
        font-size: 12px;
        word-break: break-all
    }

    .int_tab {
        margin: 20px 0 20px
    }

    .work_cate_title img {
        width: 30px;
        margin-right: 10px
    }

    .work_cate_title span {
        font-size: 20px
    }

    #work_view .tb_desc2 {
        padding-left: 5px;
        font-size: 12px
    }

    .int_tab2 {
        gap: 5px;
        flex-wrap: wrap
    }

    .int_tab2 a {
        flex: auto;
        width: calc(50% - 5px)
    }

    #work_view .tit2 span {
        display: block
    }

    #work_view .work_table thead th {
        font-size: 13px;
        height: 30px;
        word-break: break-all
    }

    #work_view .tit3 {
        font-size: 14px
    }

    #work_view .tit1 {
        font-size: 18px;
        word-break: keep-all
    }

    #work_view .tit1 span {
        font-size: 16px
    }

    #work_view .wv_info_box {
        font-size: 14px;
        padding: 20px
    }

    #work_view .wv_box .tb_sub_list {
        font-size: 14px
    }

    #work_view .tit2 {
        font-size: 18px
    }

    #work_view .work_table2 tbody td {
        padding: 5px 8px
    }

    #work_view .tb_desc1 {
        font-size: 12px;
        margin-bottom: 4px
    }

    #work_view .work_table1 tbody td {
        height: 30px;
        padding: 5px 5px
    }

    .quick_menu_wrap a img {
        width: 22px;
        height: 22px
    }

    .quick_menu_wrap {
        right: 10px
    }

    .main_01 .more_btn_wrap {
        text-align: center;
        margin-top: 15px
    }

    .main_01 .more_btn_wrap a img {
        margin-left: 10px;
        position: relative;
        width: 25px;
        height: 25px;
        object-fit: contain;
        vertical-align: text-top
    }

    .small_intro_wrap ul {
        flex-wrap: wrap;
        gap: 10px;
        height: auto
    }

    .small_intro_wrap ul li {
        width: calc(50% - 5px);
        flex: none;
        aspect-ratio: 1/1.2;
        max-width: none
    }

    .big_intro_wrap ul li .info_wrap .sub_title {
        font-size: 20px;
        word-break: keep-all
    }

    .big_intro_wrap ul li .info_wrap {
        right: 3px;
        bottom: 3px
    }

    .bottom_contact .form_con>label span {
        display: none
    }

    .main_05 .flex .blue_icon_wrap a img {
        height: 40px
    }

    .M_only_800_none {
        display: none !important
    }

    .M_only_800 {
        display: block !important
    }

    .bottom_contact .form_con .m_form {
        display: flex;
        width: 100%;
        gap: 10px
    }

    .bottom_contact .form_con {
        margin: 0;
        position: relative;
        display: flex;
        align-items: center;
        padding-top: 30px
    }

    .bottom_contact .form_con>label {
        flex: 1;
        margin-bottom: 0
    }

    .bottom_contact .form_btn_box {
        width: 80px;
        display: block
    }

    .bottom_contact .form_btn_box button {
        width: 100%;
        height: 35px;
        line-height: 35px;
        border: 0;
        background-color: var(--main_color);
        color: #fff
    }

    .bottom_contact .form_con>:not(:last-child) {
        margin-bottom: 0
    }

    .bottom_contact .form_btn_box label {
        position: absolute;
        left: 0;
        margin-bottom: 0;
        top: 0
    }

    .bottom_contact .form_con>label input {
        min-width: 0;
        font-size: 14px;
        padding: 0 5px;
        height: 35px;
        width: 100%
    }

    .bottom_contact .form_con>label #user_ph {
        width: 100%
    }

    .user_chk_txt {
        color: #fff;
        font-size: 13px;
        margin-top: 5px
    }

    .bottom_contact {
        box-sizing: border-box;
        padding: 10px 10px 20px
    }

    .bottom_contact .form_con .m_form .submit_btn {
        background-color: var(--main_color);
        color: #fff;
        font-size: 15px;
        padding: 0 5px;
        text-align: center
    }

    .success_table_wrap {
        overflow: visible
    }

    .success_list_wrap thead {
        display: none
    }

    .success_list_wrap table .list_con {
        width: auto;
        white-space: normal;
        overflow: visible;
        text-overflow: none;
        max-width: none;
        word-break: keep-all;
        color: var(--desc_color)
    }

    .success_list_wrap table .list_con .more {
        color: #000;
        font-weight: 700;
        margin-top: 10px
    }

    .success_list_wrap table .list_tit {
        width: auto;
        max-width: none;
        font-weight: 700;
        margin-bottom: 8px
    }

    .success_list_wrap table .list_result {
        width: auto;
        max-width: none;
        position: absolute;
        left: 20px;
        top: 20px
    }

    .success_list_wrap table,
    .success_list_wrap tbody,
    .success_list_wrap td,
    .success_list_wrap tr {
        display: block
    }

    .success_list_wrap tbody {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        width: 100%
    }

    .success_list_wrap table tr {
        height: auto;
        width: 100%;
        line-height: normal;
        padding: 50px 20px 20px;
        box-sizing: border-box;
        border: 1px solid #ccc;
        position: relative
    }

    .success_list_wrap table td:not(.list_con) {
        text-align: left
    }

    .success_list_wrap table {
        border: 0
    }

    .sch_con_wrap li .img_wrap {
        max-width: 100%
    }

    .intro_detail_slide .success_slide_wrap {
        max-width: 100%
    }

    .intro_detail_slide .success_slide_wrap li {
        padding: 20px
    }

    .introduction_imgs .intro_bg_txt {
        width: 20px
    }

    .introduction_imgs {
        padding: 0 30px
    }

    .introduction_imgs .intro_bg_txt {
        left: -30px
    }

    .introduction_imgs>div .txt {
        padding: 0
    }

    .introduction_imgs>div .txt p:last-child {
        font-size: 14px
    }

    .introduction_imgs>div .txt p:first-child {
        font-size: 18px
    }

    .introduction_imgs>div.right {
        padding-top: 0
    }

    .introduction_imgs .intro_con img {
        border-radius: 0
    }

    .introduction_imgs>div .txt p:last-child br {
        display: none
    }

    .introduction_imgs>div {
        flex: 1
    }

    .introduction_imgs>div .txt p:last-child {
        min-height: 80px
    }

    .introduction_imgs {
        gap: 20px
    }

    .introduction_imgs>div div:first-of-type {
        margin-bottom: 20px
    }

    .quick_menu_wrap.active {
        right: 10px
    }

    .sub_page .main_06 {
        padding: 50px 0 0
    }
}

@media screen and (max-width:768px) {
    .hd_pops_con {
        height: auto !important;
        width: auto !important
    }

    .breadcrumb a {
        font-size: 12px
    }

    .breadcrumb :where(a+a)::before {
        width: 6px;
        height: 8px;
        top: 5px
    }

    .breadcrumb a img {
        vertical-align: top
    }

    .process_list .ico {
        width: 65px;
        height: 65px
    }

    .process_list .txt {
        position: relative;
        top: 0;
        flex: 1;
        white-space: normal
    }

    .process_banner .pb_txt_wrap .pb_txt p:last-child {
        font-size: 18px
    }

    .process_banner .pb_plus {
        width: 50px;
        height: 50px
    }

    .process_banner .pb_txt_wrap .pb_txt {
        width: 310px;
        height: 100px;
        border: 2px solid rgba(255, 255, 255, .5)
    }

    .process_banner .pb_txt_wrap .pb_txt p:first-child {
        font-size: 14px
    }

    .process_info_wrap>div .desc p br {
        display: none
    }

    .process_list .txt p {
        word-break: keep-all;
        position: relative;
        padding-left: 8px
    }

    .process_list .txt p span {
        position: absolute;
        left: 0;
        top: 2px
    }

    .process_list .left .txt {
        right: 0;
        text-align: left
    }

    .process_list .right .txt {
        left: 0
    }

    .process_list {
        margin: 50px 0;
        gap: 20px;
        flex-direction: column;
        flex-wrap: wrap;
        align-items: start
    }

    .process_list>div {
        justify-content: start;
        align-items: start;
        flex-direction: row-reverse;
        gap: 15px;
        width: 100%
    }

    .process_list::before {
        display: none
    }

    .process_banner {
        padding: 35px 0
    }

    .process_banner .pb_txt_wrap {
        flex-direction: column;
        gap: 15px
    }

    .process_banner .pb_txt_wrap .pb_txt:last-child {
        margin-left: 0
    }

    .process_info_wrap>div {
        flex-direction: column;
        gap: 15px
    }

    .process_info_wrap>div .tit {
        width: 100%
    }

    .bottom_quick_list a {
        width: 100%
    }

    .bottom_quick_list a span {
        width: 30px
    }

    .bottom_quick_list a p:first-child {
        font-size: 16px
    }

    .bottom_quick_list a p:last-child {
        font-size: 13px
    }

    .M_none {
        display: none !important
    }

    .sch_con_wrap .pagination {
        margin-top: 15px
    }

    section:not(.visual_wrap) {
        padding-block: 40px
    }

    section.main_02 {
        padding-block: 0;
        padding-top: 40px
    }

    .success_swiper_container {
        margin-top: 40px
    }

    section.main_09 {
        padding-block: 0
    }

    section.success_detail_wrap {
        padding-block: 0;
        padding: 30px 20px
    }

    section.lawyer_img_wrap {
        padding-block: 50px 0
    }

    section.lawyer_info_wrap {
        padding-block: 0;
        margin-top: 50px
    }

    section.list_content_detail {
        padding-block: 0 30px
    }

    .list_content_detail .con_tit_wrap {
        padding: 15px 10px
    }

    .news_detail_wrap .con_href {
        display: block;
        font-size: 14px;
        padding: 0 10px
    }

    .main_09 .map_wrap {
        border-right: 0
    }

    .main_07 .news_swiper li {
        padding: 25px
    }

    .visual_wrap {
        height: calc(var(--vh, 1vh) * 100)
    }

    .visual_wrap .desc_wrap .main_desc {
        font-size: 18px;
        padding: 0 30px;
        word-break: keep-all
    }

    .visual_wrap .desc_wrap .sub_desc {
        font-size: 18px
    }

    .big_intro_wrap ul li {
        max-width: unset;
        width: calc((100% - 40px)/ 3);
        height: 210px
    }

    .big_intro_wrap ul li div.icon_wrap {
        padding-top: 0
    }

    section.main_03 {
        padding-block: 50px 90px
    }

    .main_03 .more_btn_wrap {
        bottom: -35px;
        right: 50%;
        transform: translateX(50%);
        width: 100%;
        text-align: center
    }

    .main_06 li {
        padding: 20px 90px 20px 20px
    }

    .main_06 .main_qna li {
        padding: 20px 20px 20px 60px
    }

    .main_06 .main_qna li::after {
        font-size: 30px;
        top: 9px;
        left: 25px
    }

    .main_08 form>div {
        display: flex;
        flex-wrap: wrap;
        gap: 20px;
        flex-direction: column;
        align-items: center
    }

    .main_08 form>div>label {
        display: inline-block;
        width: 100%;
        max-width: 400px
    }

    .main_08 form .btn_wrap {
        bottom: 67px;
        position: unset;
        max-width: 400px;
        width: 100%
    }

    .main_09 {
        flex-direction: column
    }

    .main_09 .map_wrap {
        width: 100%;
        max-width: unset;
        max-height: 210px;
        height: 100vh
    }

    .main_09 .desc_wrap {
        width: 100%;
        max-width: unset;
        flex-direction: column-reverse
    }

    .main_09 .desc_wrap .location span:not(.icon_wrap) {
        display: inline
    }

    .main_09 .info_wrap {
        margin-top: 20px
    }

    .main_09 .map_btn_wrap {
        flex-wrap: wrap;
        flex-direction: row;
        gap: 10px
    }

    footer .footer_blue>.flex {
        padding: 15px 10px;
        justify-content: center
    }

    .footer_logo {
        margin-bottom: 15px
    }

    .footer_logo img {
        filter: brightness(.5);
        max-width: 150px
    }

    footer .footer_white {
        padding: 40px 20px 60px
    }

    .main_09 .map_btn_wrap button {
        width: calc(50% - 7.5px)
    }

    .main_09 .map_btn_wrap button:hover {
        width: calc(50% - 7.5px)
    }

    .main_09 .map_btn_wrap button.active {
        width: calc(50% - 7.5px)
    }

    .sub_tit_wrap h3 {
        font-size: 26px
    }

    .sub_tit_wrap .desc {
        font-size: 16px
    }

    .sub_contact h4 {
        font-size: 22px
    }

    .sub_contact form .form_con span {
        font-size: 15px
    }

    .go_back_btn_wrap a {
        width: 100%;
        display: inline-block;
        max-width: 150px;
        height: 50px;
        background-color: var(--main_color);
        line-height: 50px;
        text-align: center;
        color: #fff;
        font-weight: 400;
        font-size: 16px
    }

    .laywer_list li {
        width: calc((100% - 10px)/ 3);
        margin-right: 5px
    }

    .laywer_list li:nth-child(3n) {
        margin-right: 0
    }

    .laywer_list li a div.icon_wrap {
        height: auto !important;
        aspect-ratio: 1/1.5;
        padding-top: 10px
    }

    .laywer_list li a .main_c {
        font-weight: 700;
        margin-top: 14px;
        font-size: 11px
    }

    .laywer_list li a span.icon_wrap {
        width: 12px;
        height: 16px;
        margin-right: 2px
    }

    .laywer_list li a .name {
        font-weight: 500;
        font-size: 10px;
        letter-spacing: -.5px
    }

    .laywer_list li a .desc_wrap {
        padding-left: 0
    }

    .laywer_list li a .name em {
        font-style: normal;
        font-weight: 700;
        font-size: 12px
    }

    .success_swiper ul {
        height: 360px
    }

    .success_swiper li .result {
        font-weight: 600;
        margin-bottom: 10px;
        font-size: 14px
    }

    .success_swiper li .con_tit {
        font-size: 16px;
        margin-bottom: 5px
    }

    .success_swiper li .con_desc {
        font-size: 15px
    }

    .success_swiper .icon_wrap {
        width: 20px;
        height: 20px
    }

    .success_detail_wrap .con_wrap .flex {
        flex-direction: column
    }

    .success_detail_wrap .con_wrap .left_part {
        width: 100%
    }

    .success_detail_wrap .con_wrap .right_part {
        margin-left: 0;
        border-top: 1px solid #d4d4d4;
        width: 100%;
        max-width: unset;
        padding-block: 30px
    }

    .success_detail_wrap .con_wrap .right_part .result_img {
        max-width: 450px
    }

    .success_detail_wrap {
        padding: 20px 10px;
        margin-top: 30px
    }

    .success_detail_wrap .con_tit {
        font-size: 16px
    }

    .review_list_wrap li {
        width: 100%
    }

    .review_list_wrap li a {
        padding: 20px
    }

    .review_list_wrap li:nth-child(2n-1) {
        margin-right: 0
    }

    .list_content_detail {
        padding: 15px;
        margin-top: 35px
    }

    .list_content_detail .tit_cate {
        font-size: 14px
    }

    .list_content_detail .con_tit {
        font-size: 16px
    }

    .list_content_detail .con_info {
        font-size: 14px
    }

    .list_content_detail .con_desc_wrap {
        padding: 20px 10px;
        font-size: 15px
    }

    .work_cate_wrap li {
        min-width: calc((100% - 53px)/ 3)
    }

    .work_cate_wrap li .con_tit {
        font-size: 14px
    }

    .work_cate_wrap li .con_more {
        font-size: 13px
    }

    .work_cate_wrap li a {
        padding: 15px
    }

    .work_cate_wrap li:hover .con_tit {
        color: #000
    }

    .work_cate_wrap li:hover {
        border-color: #d4d4d4;
        border-width: 1px
    }

    .work_cate_wrap li:hover a {
        padding: 15px
    }

    .sub_page .main_06 li.active {
        padding: 20px
    }

    .answer_wrap .icon {
        width: 50px
    }

    .answer_wrap .icon span {
        font-size: 13px;
        text-align: center
    }

    .answer_wrap .answer {
        width: calc(100% - 85px);
        margin-left: 30px;
        padding: 20px
    }

    .answer_wrap .answer::before {
        border-top: 10px solid #eee;
        border-right: 10px solid #eee;
        border-left: 10px solid transparent;
        border-bottom: 10px solid transparent;
        top: 0;
        left: -20px
    }

    .news_wrap ul li>a .img_wrap {
        height: 200px
    }

    .online_counselling {
        padding-block: 50px
    }

    .online_counselling .flex {
        flex-direction: column
    }

    .online_counselling li {
        margin-bottom: 40px
    }

    .online_counselling :where(li+li)::before {
        left: 50%;
        top: -40px;
        transform: translate(-50%, 0) rotate(90deg)
    }

    .main_04 .more_btn_wrap {
        top: auto;
        right: auto;
        position: relative;
        text-align: center;
        margin-top: 15px
    }
}

@media screen and (max-width:640px) {
    .info_list {
        grid-template-columns: repeat(1, 1fr)
    }

    .info_list li {
        border-bottom: 1px solid #ddd
    }

    .info_list .info_tit {
        font-size: 16px;
        padding-bottom: 10px
    }

    .info_list .info_thumb {
        aspect-ratio: 1/.5
    }

    .info_list .info_thumb>p {
        font-size: 18px
    }

    .introduction_imgs {
        flex-direction: column
    }

    .introduction_imgs>div .txt p:last-child {
        min-height: 0
    }

    .M_only.none_640 {
        display: none !important
    }

    .intro_detail_slide .tit_wrap .tit {
        padding-left: 20px;
        padding-top: 20px;
        font-size: 20px
    }

    footer .company_wrap li {
        flex: 100%;
        border-bottom: 1px solid #666;
        padding: 10px 20px
    }

    footer .company_wrap li:last-child {
        border-bottom: 0
    }

    footer .company_wrap {
        padding: 0
    }

    footer .company_wrap span.tit {
        font-weight: 400;
        font-size: 17px
    }

    footer .company_wrap span.icon_wrap {
        width: 30px;
        height: 30px
    }

    footer .company_wrap span.icon_wrap img {
        width: 100%;
        height: 100%;
        object-fit: contain
    }

    .main_07 {
        display: flex;
        flex-direction: column
    }

    .visual_wrap .desc_wrap .icon_wrap {
        display: flex;
        gap: 10px;
        height: 40px;
        width: 40px;
        max-width: 400px;
        justify-content: center
    }

    .main_03 .more_btn_wrap a img {
        width: 25px;
        height: 25px;
        object-fit: contain;
        vertical-align: text-top
    }

    .main_07 .tit_wrap {
        color: #fff;
        text-align: center;
        width: 100%;
        margin-right: 0
    }

    .main_07 .news_swiper_wrap {
        width: 100%;
        padding-left: 150px
    }

    .main_07 .news_swiper_wrap .btn_wrap {
        position: absolute;
        left: 20px;
        top: unset;
        bottom: 230px
    }

    .sub_contact h4 {
        font-size: 18px
    }

    .sub_contact form .form_con {
        flex-direction: column;
        margin-top: 30px;
        padding-inline: 0
    }

    .go_back_btn_wrap a {
        width: 100%;
        max-width: 120px;
        height: 45px;
        line-height: 45px;
        font-weight: 400;
        font-size: 14px
    }

    .go_back_btn_wrap {
        margin-block: 40px;
        text-align: center
    }

    .laywer_list li a div.icon_wrap {
        height: 280px
    }

    .lawyer_info_wrap .left_menu {
        width: 90px
    }

    .lawyer_info_wrap .left_menu .menu_name {
        margin-left: 10px;
        min-width: 50px
    }

    .lawyer_info_wrap .progress_bar {
        top: 2px
    }

    .lawyer_info_wrap .basic_list_wrap {
        position: relative;
        width: calc(100% - 120px)
    }

    .lawyer_img_wrap .name_wrap {
        margin-bottom: 80px
    }

    .lawyer_img_wrap .icon_wrap {
        padding-left: 15px
    }

    .basic_list_wrap .tit_wrap .tit {
        font-size: 18px
    }

    .lawyer_info_wrap .left_menu button {
        font-size: 14px
    }

    .basic_list_wrap .desc_wrap .basic_list {
        padding-left: 5px;
        font-size: 14px
    }

    .list_content_detail .con_info {
        text-align: left
    }

    .work_cate_wrap li a {
        padding: 10px
    }

    .work_cate_wrap li:hover a {
        padding: 10px
    }

    .sub_page .main_06 li .con_tit {
        font-size: 15px
    }

    .sub_page .main_06 li .con_cate {
        font-size: 13px
    }

    .news_wrap ul li>a .img_wrap {
        height: 180px
    }
}

@media screen and (max-width:500px) {
    .small_intro_wrap ul li .icon_img {
        left: 10px;
        top: 5px
    }

    .small_intro_wrap ul li .icon_img img {
        max-height: 20px
    }

    .big_intro_wrap ul li .info_wrap .sub_title .lawyer_mark img {
        width: 19px
    }

    .big_intro_wrap ul li .info_wrap .sub_title .lawyer_mark {
        margin-right: 2px
    }

    .only_500 {
        display: revert
    }

    .big_intro_wrap ul li {
        height: 180px
    }

    .big_intro_wrap ul li div.icon_wrap {
        padding-top: 10px
    }

    .big_intro_wrap ul li .info_wrap .name {
        font-size: 18px
    }

    .big_intro_wrap ul li .info_wrap .sub_title {
        letter-spacing: -1.8px;
        line-height: .1;
        font-size: 14px
    }

    .tit_wrap h3 {
        font-size: 21px
    }

    .big_intro_wrap ul {
        gap: 10px
    }

    .big_intro_wrap ul li {
        width: calc((100% - 20px)/ 3)
    }

    .sch_wrap .sch_box {
        height: 50px
    }

    .sch_wrap .sch_box input {
        padding: 10px 10px;
        font-size: 14px
    }

    .sch_wrap .search_icon {
        width: 50px;
        height: 50px;
        background-size: 50%
    }

    .sch_wrap .sch_cate_wrap {
        flex-wrap: wrap
    }

    .sch_wrap .sch_cate_wrap button {
        flex: 1 1 45%
    }

    .main_05 .flex .blue_icon_wrap a {
        display: inline-block;
        width: calc((100% - 15px)/ 2)
    }

    .main_05 .flex .white_icon_wrap {
        flex-wrap: wrap
    }

    .main_05 .flex .white_icon_wrap a {
        flex: 1 1 30%
    }

    .main_05 .flex .white_icon_wrap a:nth-child(4) {
        margin-top: 20px;
        border-left: 1px solid #ccc !important
    }

    .main_05 .flex .white_icon_wrap a:nth-child(5) {
        margin-top: 20px
    }

    .main_06 li {
        padding: 20px 20px 60px
    }

    .main_06 li.active {
        padding: 20px
    }

    .main_06 .main_qna li {
        padding: 20px 20px 20px 60px
    }

    .main_06 li::after {
        content: "+";
        display: inline-block;
        position: absolute;
        right: 50%;
        top: unset;
        transform: translate(50%, 0);
        font-size: 35px;
        font-weight: 500;
        color: #d4d4d4;
        bottom: 10px
    }

    .main_07 .news_swiper_wrap {
        width: 100%;
        padding-left: 0
    }

    .main_07 .news_swiper {
        padding-left: 15%
    }

    .main_07 .news_swiper_wrap .btn_wrap {
        display: none
    }

    .laywer_list li a div.icon_wrap {
        height: 260px
    }

    .lawyer_img_wrap .name_wrap .desc {
        font-size: 14px;
        padding-left: 10px;
        word-break: break-all
    }

    .lawyer_img_wrap .name_wrap .desc span {
        word-break: keep-all
    }

    .lawyer_img_wrap {
        height: 330px
    }

    .lawyer_img_wrap .name_wrap .name {
        font-size: 16px;
        margin-bottom: 15px
    }

    .lawyer_img_wrap .name_wrap .name::after {
        width: 170px;
        bottom: -8px
    }

    .lawyer_img_wrap .name_wrap .eng_name {
        font-size: 14px
    }

    .lawyer_img_wrap .icon_wrap {
        padding-left: 15px;
        height: 280px
    }

    .lawyer_info_wrap .left_menu {
        width: 80px
    }

    .lawyer_info_wrap .left_menu .menu_name {
        margin-left: 0
    }

    .lawyer_info_wrap .basic_list_wrap {
        position: relative;
        width: calc(100% - 100px)
    }

    .list_content_detail .con_desc_wrap {
        padding: 20px 10px
    }

    .work_cate_wrap li {
        min-width: calc((100% - 53px)/ 2)
    }

    .work_cate_wrap li.active a {
        padding: 10px
    }

    .work_cate_wrap :where(li+li) {
        margin-left: 0
    }

    .work_cate_wrap li:nth-child(5n+1) {
        margin-left: 0
    }

    .work_cate_wrap li:nth-child(4n+1) {
        margin-left: 0
    }

    .work_cate_wrap li:nth-child(3n+1) {
        margin-left: 0
    }

    .work_cate_wrap li .con_tit {
        font-size: 14px
    }

    .work_cate_wrap li .con_more {
        font-size: 13px
    }

    .sub_page .main_06 li {
        padding: 20px 20px 50px
    }

    .sub_page .main_06 li.active {
        padding: 20px
    }

    .main_06 li::after {
        bottom: 0
    }

    .sub_page .main_06 li .icon {
        display: none
    }

    .answer_wrap .answer {
        width: calc(100% - 15px);
        margin-left: 15px;
        padding: 20px
    }

    .news_wrap ul li {
        width: 100%;
        margin-bottom: 30px
    }

    .news_wrap ul :where(li+li) {
        margin-left: 0
    }

    .news_wrap ul li:nth-child(3n+1) {
        margin-left: 0
    }

    .news_wrap ul li:nth-child(2n+1) {
        margin-left: 0
    }

    .main_03 .sch_cate_wrap button {
        font-size: 14px
    }

    .main_03 .sch_cate_wrap {
        gap: 5px
    }

    .main_07 .news_swiper li .con_img {
        height: auto;
        aspect-ratio: 1/.6
    }
}