/* section treatment_intro */
.header-margin {margin-top: 82px;}
.intro-box {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
.intro_image,
.intro_text {
    border:1px solid var(--main-cream2);
    min-height: 500px;
    overflow: hidden;
}
.intro_text {
    padding: 60px;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 20px;
}
.intro_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.point01 {
    width: 260px;
    height: 75px;
    object-fit: contain;
    background: url("../public/image/theme/point01.png") no-repeat;
}
.title {
    font-family: 'NotoSerifKR Variable';
    font-size: 48px;
    font-weight: 600;
}
.sub-title {
    font-family: 'SUIT Variable';
    font-size: 32px;
    font-weight: 600;
}
/* 인트로 */
.intro_description {
    font-size: 20px;
    position: relative;
}
.intro_description02 {
    font-size: 20px;
    position: relative;
}
.intro_description p {
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.35s ease;
    position: absolute;
    top: 20px;
    right: 0;
    font-size: 20px;
    font-weight: 300;
}

.intro_description p.active {
    opacity: 1;
    transform: translateY(0);
}

.treatment-process li {
    border: 1px solid var(--main-black);
    padding: 8px 40px;
    text-align: center;
    cursor: pointer;
    font-size: 20px;
}
.treatment-process li:nth-child(1):hover,
.treatment-process li:nth-child(3):hover,
.treatment-process li:nth-child(5):hover,
.treatment-process li:nth-child(7):hover,
.treatment-process li:nth-child(9):hover {
    background-color: var(--main-green);
    color: white;
    transition: all .3s;
}
.treatment-process li:nth-child(1).active,
.treatment-process li:nth-child(3).active,
.treatment-process li:nth-child(5).active,
.treatment-process li:nth-child(7).active,
.treatment-process li:nth-child(9).active{
    background-color: var(--main-green);
    color: white;
    transition: all .3s;
}
.process-icon {
    border: none !important;
    margin: 10px 0;
    cursor: default !important;
}
.process-icon img {
    width: 50px;
    height: 100%;
    object-fit: contain;
}
/* 인트로 스타일2 */
.intro_text_inner {
    display: flex;
    flex-direction: row;
}
.intro_text_inner .sub-title {
    width: 30%;
}
.intro_text_inner ul {
    width: 70%;
}
.desr_line {
    width: 100%;
    border-top: 1px solid var(--main-cream2);
    padding: 20px 0;
    text-align: right;
}
/* 인트로 스타일3 */
.intro_text_inner02 {
    display: flex;
    flex-direction: column;
    gap: 60px;
}
.desr_line02 {
    width: 100%;
    border-top: 1px solid var(--main-cream2);
    padding: 20px 0;
    text-align: right;
}
/* 인트로 스타일4 */
.intro_text_inner03 {
    display: flex;
    flex-direction: column;
}
.intro_text_inner03 div {
    display: flex;
    flex-direction: row;
    gap: 60px;
}
.intro_text_inner03 div:nth-child(1) {
    padding-bottom: 100px;
}

/* 추천대상 */
.treatment-recommend li {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    padding: 10px 0;
    font-size: 20px;
}
.treatment-recommend li p span {
    font-weight: 700;
}

/* section treatment_special */
.special_title_group {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 40px;
    padding: 80px 0;
}
.special_title {
    display: flex;
}
.special_title p:nth-child(2) {margin-left: 10px;}
.special_title p {
    font-family: 'NotoSerifKR Variable';
    font-weight: 600;
    /* writing-mode: vertical-rl; */
    /* text-orientation: upright; */
    /* letter-spacing: 8px; */
    font-size: 48px;
}
.special_description {
    display: flex;
    gap: 40px;
    position: relative;
}
.special_description .point05 {
    position: absolute;
    right: -80px;
    bottom: -10px;
    width: 40px;
}

.special_description p {
    font-size: 20px;
    font-weight: 300;
    line-height: 150%;
    text-align: center;
}
.special_content01 {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 80px;
    padding: 80px 400px;
    border:1px solid var(--main-cream2);
    background: linear-gradient(to top, #ECE8E000,#ECE8E060),
    url(../public/image/theme/special_bg.jpg);
    background-blend-mode: multiply;
    margin-bottom: 40px;
}
.special_content {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 80px;
    padding: 80px 400px;
    border:1px solid var(--main-cream2);
    background: linear-gradient(to top, #ECE8E000,#ECE8E060),
    url(../public/image/theme/special_bg.jpg);
    background-blend-mode: multiply;
    margin-bottom: 40px;
}

.special_con_tit {
    width: calc(30% - 5%);
    margin-right: 5%;
}
.special_con_desc {
    width: 70%;
}
.special_con_tit p {
    font-size: 30px;
    font-weight: 500;
}
.special_con_tit p:first-child {
    font-family: 'NotoSerifKR Variable', serif;
    color: var(--main-green);
    font-size: 60px;
}
.special_con_desc {
    display: flex;
    flex-direction: column;
    gap: 60px;
    border-left: 1px dashed var(--main-green);
    padding-left: 30px;
}
/* 타투-스타일1 */
.special_desc_box {
    position: relative;
}
.special_desc_box::before {
    content: "";
    position: absolute;
    left: -38px;
    top: 0;

    width: 16px;
    height: 16px;

    background-color: var(--main-green);
    border-radius: 50%;
}
.special_desc_box p {
    line-height: 150%;
    font-size: 18px;
}
.special_desc_box .desc_box_bold {
    font-weight: 700;
}
.special_desc_box p span {
    font-weight: 600;
}

/* banner */
.banner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 170px 0;
    margin: 90px 0;
    background: 
        linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)),
        url("../public/image/theme/banner.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.banner p {
    color: white;
    font-size: 24px;
}
.banner p:first-child {
    font-weight: 700;
}

/* treatment_detail */
.treatment_detail {
    display: flex;
    flex-direction: column;
    padding-left: 200px;
}

.detail_wrap {
    display: flex;
    flex-direction: row;
}
.detail_title {
    width: calc(20% - 5%);
    margin-right: 5%;
}
.detail_contents {
    width: 80%;
}

.detail_regular_price {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    padding-bottom: 80px;
}
.detail_title p:nth-child(2) {
    font-family: 'NotoSerifKR Variable';
    font-size: 48px;
    font-weight: 600;
}
.price-focus {
    font-size: 24px;
    font-weight: 700;
}
.detail_con_tit {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 20px;
    padding: 40px 60px;
}
.detail_con_tit p:first-child {
    font-family: 'SUIT Variable';
    color: white;
    font-size: 34px;
    font-weight: 800;
}
.detail_con_tit p:nth-child(2) {
    color: var(--main-baige);
    font-weight: 600;
    font-size: 20px;
    margin-top: 10px;
}
.detail_con_desc {
    border: 1px solid var(--main-cream2);
    border-top: 0;
    display: flex;
    flex-direction: row;
}
.detail_con_desc ul {
    display: flex;
}

.detail_con_tit {
    background-color: var(--main-green);
}
.detail_con_desc ul li {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px 40px;
}
.detail_con_desc ul li p {
    text-align: center;
    white-space: nowrap;
}
.container {
    width: 60%;
    position: relative;
    padding: 30px 60px;
}
.container_size {
    width: 35%;
}
.container02 {
    border-left: 1px dashed var(--main-cream2);
    padding: 30px 60px;
}

/* 주의사항 */
.detail_qna_group {
    flex-direction: column;
    width: 100%;
}

.quastion_btn {
    border: 1px solid var(--main-black);
    border-right: 0;
}
.detail_con_desc .detail_qna_group .faq_item {
    display: initial;
    padding: 0;
}
.quastion {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 10px 260px 10px 60px !important;
}
.quastion p {
    font-size: 20px;
}

.answer_box {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    padding: 0 60px;
    transition:  
        height 0.45s cubic-bezier(.22,.61,.36,1),
        opacity 0.5s ease,
        padding 0.35s ease,
        transform 0.35s ease;
}
.answer_box p {
    text-align: left !important;
    margin-bottom: 16px;
    font-size: 18px;
}
.faq_item.active .answer_box {
    opacity: 1;
    padding: 30px 60px 120px 60px !important;
    transform: translateY(0);
}

.quastion img {
    transition: transform 0.35s ease;
}
.faq_item.active .quastion img {
    transform: rotate(180deg);
}

@media screen and (max-width: 1100px) {
    .intro_image,
    .intro_text {
        border:1px solid var(--main-cream2);
        min-height: auto;
        max-height: 100% !important;
        overflow: hidden;
    }
    .header-margin {
        margin-top: 62px;
    }
    .title {font-size: 40px;}
    .sub-title {font-size: 26px; margin-bottom: 20px;}
    .intro_description {
        width: 100%;
        font-size: 16px;
        position: relative;
    }
    .intro_text_inner02 {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }
    .intro_description02 {
        padding-bottom: 20px;
        font-size: 16px;
    }
    .desr_line02 {
        width: 100%;
        border-top: 1px solid var(--main-cream2);
        padding: 5px 0;
        text-align: right;
    }
    .intro_description p.active {
        opacity: 1;
        transform: translateY(0);
        font-size: 16px;
    }
    .intro_description p {
        font-size: 16px;
        opacity: 0;
        transform: translateY(10px);
        transition: all 0.35s ease;
        position: absolute;
        top: 20px;
        right: 0;
        font-weight: 300;
    }
    .intro_text {
        padding: 30px;
        position: relative;
        display: flex;
        flex-direction: column;
        gap: 20px;
    }
    .intro_text_inner {
        display: flex;
        flex-direction: column;
    }
    .intro_text_inner .sub-title,
    .intro_text_inner ul {
        width: 100%;
    }
    .process-icon img {
        width: 30px;
        height: 100%;
        object-fit: contain;
    }
    .treatment-process li {
        border: 1px solid var(--main-black);
        padding: 8px 40px;
        text-align: center;
        cursor: pointer;
        font-size: 18px;
    }
    .process-icon {
        padding: 0 40px !important;
    }

    .treatment-recommend li {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 8px;
        padding: 10px 0;
        font-size: 16px;
    }
    .recommend-icon {
        width: 10%;
    }
    .treatment-recommend li p:nth-child(2) {
        width: 80%;
    }
    .special_title_group {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 20px;
        padding: 80px 0;
    }
    .special_title p {
        font-family: 'NotoSerifKR Variable';
        font-weight: 600;
        font-size: 32px;
    }
    .special_description p {
        font-size: 16px;
        font-weight: 300;
        line-height: 150%;
        text-align: center;
    }
    .special_description .point05 {
        position: absolute;
        right: -80px;
        bottom: -8px;
        width: 40px;
    }
    .special_content01 {
        display: flex;
        justify-content: flex-start;
        align-items: flex-start;
        gap: 40px;
        padding: 80px 60px;
        border: 1px solid var(--main-cream2);
        background: linear-gradient(to top, #ECE8E000, #ECE8E060), url(../public/image/theme/special_bg.jpg);
        background-blend-mode: multiply;
        margin-bottom: 20px;
    }
    .special_content {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        gap: 40px;
        padding: 80px 60px;
        border: 1px solid var(--main-cream2);
        background: linear-gradient(to top, #ECE8E000, #ECE8E060), url(../public/image/theme/special_bg.jpg);
        background-blend-mode: multiply;
        margin-bottom: 20px;
    }
    .special_con_tit p {
        font-size: 22px;
        font-weight: 500;
    }
    .special_desc_box p {
        line-height: 150%;
        font-size: 16px;
    }
    /* 시술 상세내용 */
    .detail_wrap {
        display: flex;
        flex-direction: row;
        gap: 20px;
    }
    .treatment_detail {
        display: flex;
        flex-direction: column;
        padding-left: 30px;
    }
    .detail_con_tit p:first-child {
        font-size: 26px;
    }
    .detail_title p:nth-child(2) {
        font-size: 32px;
    }
    .detail_con_tit {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 20px;
        padding: 20px 40px;
    }
    .detail_subtitle {
        font-size: 18px;
        font-weight: 600;
        margin-bottom: 10px !important;
    }
    .container {
        width: 100%;
        position: relative;
        padding: 20px 40px !important;
    }
    .detail_regular_price {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr);
        padding-bottom: 40px;
        gap: 10px;
    }
    .detail_con_desc {
        border: 1px solid var(--main-cream2);
        border-top: 0;
        display: flex;
        flex-direction: column;
    }
    .detail_con_desc ul {
        display: flex;
        flex-direction: column;
    }
    .detail_con_desc ul li {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 20px 10px;
    }
    .package_ul li {
        border-right: 0 !important;
        border-bottom: 1px dashed var(--main-green);
        display: grid;
        grid-template-columns: repeat(3, 2fr);
    }
    .container_size {
        width: 100%;
    }
    .container02 {
        border-left: 0 !important;
        border-top: 1px dashed var(--main-cream2);
        padding: 20px 40px;
    }
    .quastion {
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        padding: 10px 40px 10px 40px !important;
    }
    .faq_item.active .answer_box {
        opacity: 1;
        padding: 30px 30px 120px 30px !important;
        transform: translateY(0);
    }
    .faq_item.active .answer_box_long {
        opacity: 1;
        padding: 30px 30px 250px 30px !important;
        transform: translateY(0);
    }
    .detail_con_desc ul .faq_item .answer_box p {
        text-align: center;
        white-space: wrap;
    }
}
@media screen and (max-width: 900px) {
    .intro_description02 {
        padding-bottom: 60px;
        font-size: 16px;
    }
}
@media screen and (max-width: 768px) {
    .point01 {
        width: 160px;
        height: 50px;
        background: url("../public/image/theme/point01.png") no-repeat center;
        background-size: cover;
    }
    .title {
        font-size: 32px;
    }
    .intro_text_inner03 div {
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        gap: 0;
    }
    .intro_description02 {
        padding-bottom: 60px;
        font-size: 16px;
    }
}
@media screen and (max-width: 450px) {
    .intro-box {
        display: flex;
        flex-direction: column;
    }
    .intro_text {
        border: 1px solid var(--main-cream2);
        min-height: auto;
        max-height: 100% !important;
        object-fit: cover;
        overflow: hidden;
    }
    .intro_image {
        border: 1px solid var(--main-cream2);
        min-height: auto;
        max-height: 280px !important;
        object-fit: cover !important;
        overflow: hidden;
    }
    .point01 {
        width: 120px;
        height: 40px;
        background: url(../public/image/theme/point01.png) no-repeat center;
        background-size: cover;
    }
    .title {
        font-size: 26px;
    }
    .sub-title {
        font-size: 20px;
        margin-bottom: 20px;
    }
    .intro_description {
        width: 100%;
        font-size: 15px;
        position: relative;
    }
    .intro_description02 {
        padding-bottom: 60px;
        font-size: 15px;
    }
    .banner {
        padding: 80px 0;
        margin: 90px 0;
    }
    .banner p {
        color: white;
        font-size: 18px;
    }
    
}
