html {
    scroll-behavior: smooth; /* Enable smooth scrolling */
}
body{
    background-color: var(--white-100, #fdfdff);
    /* min-width: 1080px; */
}
*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    list-style: none;
    color: var(--purelize-primary-300, #353535);
    font-family: 'Inter', sans-serif;
}
a{
    font-family: 'Inter', sans-serif;
    text-decoration: none !important;
}

.flex-row{
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}
.flex-row-left{
    justify-content: flex-start;
}


/* -------- Global Styles-------- */
.nav-contact{
    background-color: #353535;
}
.nav-contact:hover{
    background-color: #008471;
}
.nav-contact:active{
    background-color: #52AB9E;
}

.nav-list a{
    font-size: 20px;
}
.nav-list a:hover{
    color: var(--purelize-primary-500, #008471);
}
.nav-contact a{
    color: var(--purelize-territory-500, #f7f9ec);
    text-align: center;
    font-family: 'Inter', sans-serif;
    font-size: var(--ctabtn-font-size, 22px);
    line-height: var(--ctabtn-line-height, 110%);
    font-weight: var(--ctabtn-font-weight, 400);
}


/* -------- Desktop -------- */
/*  Navigation  */
.navigation{
    width: 100%;
    /* min-width: 1080px; */
    top: 0;
    right: 0;
    left: 0;
    position: fixed;
    padding: 24px 104px;
    z-index: 2;
}
.nav{
    width: 100%;
    padding: 24px 24px 24px 32px;
    align-items: center;
    justify-content: space-between;
    border-radius: 80px;
    background-color: rgba(253, 253, 255, 0.4);
    backdrop-filter: blur(16px);
    position: relative;
    z-index: 3;
}

.purelize-logo{
    height: 44px;
    margin-right: 24px;
    cursor: pointer;
}
.nav-logo{
    height: 100%;
}

.nav-list{
    /* padding: 16px; */
    margin: 16px 40px 16px 16px;
    cursor: pointer;
}
.nav-contact{
    padding: 24px 36px;
    border-radius: 200px;
    cursor: pointer;
}

.navLists li{
    display: inline-block;
}

.hamburger{
    display: none;
    flex-direction: column;
    cursor: pointer;
    position: relative;
    /* z-index: 1001; */
}
.hamburger .bar {  
    width: 40px;
    height: 3px;
    background-color: #1C1D1D;
    margin: 5px 0;
    border-radius: 6px;
    transition: 0.2s;
}

/* Overaly Menu */
.overlay-nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: #FDFDFF;
    display: none;
    /* display: flex; */
    justify-content: center;
    align-items: center;
    /* z-index: 2; */
}

.overlay-menu {
    list-style: none;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 0 20px;
}
.overlay-menu li {
    margin: 24px 0;
}
.overlay-menu li:last-child{
    margin-top: 80px;
}
.overlay-menu li .nav-list a{
    font-size: 24px;
}
.overlay-menu li .nav-contact a{
    color: #FDFDFF;
}

.nav-selected a{
    color: #008471 !important;
}
.nav-list a.active {
    color: #008471 !important;
}


/* -------- Index Main Page Styles-------- */
/*  Hero Section  */
/* main{
    height: 3500px;
} */

.hero-section{
    width: 100%;
    height: 100vh;
    min-height: 900px;
    /* padding: 0 104px; */
    display: flex;
    align-items: flex-end;
    justify-content: center;

    /* background-image: url("../Img/Main/HeroSection3.png"); */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

#hero-section {
    position: relative;
    width: 100%;
    height: atuo; /* 섹션의 높이를 화면 전체로 설정 */
    overflow: hidden; /* 비디오가 섹션을 넘치지 않도록 설정 */
}

.hero-content{
    /* height: 65%; */
    width: 80%;
    max-width: 1100px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 104px;
    margin-bottom: 140px;
    position: relative;
    z-index: 1; /* 콘텐츠가 비디오 위에 보이도록 설정 */
    color: white; /* 글자 색을 비디오 위에서 잘 보이도록 설정 */

}
.hero-content-text{
    display: flex;
    flex-direction: column;
    text-align: center;
}

#hero-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; /* 비디오가 섹션을 채우도록 설정 */
    z-index: -1; /* 비디오가 콘텐츠 뒤에 있도록 설정 */
    background-color: #fdfdff;
}




.dot-span{
    margin-bottom: 48px;
}
.dot{
    height: 16px;
    width: 16px;
    margin: 0 16px 0 8px;
    background: var(--purelize-primary-500, #008471);
    border-radius: 50%;
    display: inline-block;
    position: relative;
}
.dot-span span{
    font-size: var(--bodytext-18purelize-font-size, 18px);
    line-height: var(--bodytext-18purelize-line-height, 150%);
    font-weight: var(--bodytext-18purelize-font-weight, 400);
    position: relative;
}
h1{
    color: var(--purelize-primary-500, #1c1d1d);
    text-align: center;
    font-family: 'Satoshi-Regular';
    font-size: var(--h1purelize-font-size, 100px);
    line-height: var(--h1purelize-line-height, 110%);
    letter-spacing: var(--h1purelize-letter-spacing, -0.01em);
    font-weight: var(--h1purelize-font-weight, 450);
    position: relative;
    align-self: stretch;
    display: flex;
    align-items: center;
    justify-content: center;
}

.go-to-down{
    height: 100px;
    width: 100px;
    border: 1px solid var(--purelize-primary-500, #1c1d1d);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;

    margin: 0 8px;
}
.arrow-down{
    height: 40px;

    animation: bounce 1s infinite ease-in-out;
}
.go-to-down:hover{
    background-color: #008471;
    border: none;
}
.go-to-down:hover .arrow-down{
    height: 40px;
    content: url("../Img/Icon/ArrowDownWhite.png");
}
.go-to-down:active{
    background-color: #52AB9E;
    border: none;
}

@keyframes bounce{
    0%, 100%{
        transform: translateY(0) /* Start and end at the original position*/

    }
    20%, 60%{
        transform: translateY(12px);
    }
    40%{
        transform: translateY(8px);
    }
}

/* -------- Feature Section -------- */
@keyframes slide{
    from{
        transform: translateX(0);
    }
    to{
        transform: translateX(-100%);
    }
}

.feature-section{
    padding: 12px 0;
    background: var(--purelize-territory-500, #f7f9ec);
    overflow: hidden;
    white-space: nowrap;
}
.feature-section:hover .feature-slide{
    animation-play-state: paused;
}
.feature-slide{
    display: inline-flex;
    animation: 20s slide infinite linear;
}

.feature{
    display: flex;
    align-items: center;
    margin: 0 24px;
}
.feature-img{
    height: 52px;
    width: 52px;
    margin: 6px;
}
.feature-text{
    margin-left: 8px;
    color: var(--purelize-primary-500, #008471);
    text-align: left;
    font-family: 'Inter', sans-serif;
    font-size: var(--featuretextpurelize-font-size, 28px);
    line-height: var(--featuretextpurelize-line-height, 150%);
    font-weight: var(--featuretextpurelize-font-weight, 400);
}



/* -------- Product Section -------- */
.product-section{
    width: 100%;
    padding: 140px 104px 80px 140px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 80px;
}
.product-content{
    width: 85%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.product-content-text{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 24px;
}
.text-center{
    text-align: center;
}

h2{
    color: var(--purelize-primary-500, #1c1d1d);
    text-align: left;
    font-family: 'Satoshi-Regular';
    font-size: var(--h2purelize-font-size, 72px);
    line-height: var(--h2purelize-line-height, 125%);
    letter-spacing: var(--h1purelize-letter-spacing, -0.01em);
    font-weight: var(--h2purelize-font-weight, 450);
}

.button{
    height: 88px;
    border: 1px solid var(--white-700, #a9aaad);
    border-radius: 100px;
    padding: 12px 12px 12px 24px;
    margin-top: 40px;
    display: inline-flex;
    position: relative;
    flex-direction: row;
    align-content: center;
    gap: 80px;
    overflow: hidden;
    cursor: pointer;
    align-items: center;
    justify-content: space-between;

    transition: all 0.3s ease;
}


.btnText{
    /* width: 60%; */
    font-family: 'Inter', sans-serif;
    font-size: 22px;
    font-weight: var(--btntextpurelize-font-weight, 400);
    font-style: var(--btntextpurelize-font-style, normal);
    color: var(--purelize-primary-500, #1c1d1d);
    align-self: center;
}

.go-to-next{
    height: 56px;
    width: 56px;
    background-color: var(--purelize-primary-500, #008471);
    border-radius: 50%;
    display: inline-flex;
    justify-content: center;
    align-items: center;

    transition: all 0.3s ease;
}
.arrow-right{
    width: 24px;
}

.go-to-next-hover{
    position: absolute;
    align-self: center;
    right: 15px;
    height: 52px;
    width: 52px;
    border-radius: 50%;
    z-index: -1;
    background-color: var(--purelize-primary-500, #008471);

    transition: all 0.3s ease;
}

/* Btn Hover */
.button:hover{
    border: none;
}

.button:hover .go-to-next-hover{
    right: 0;
    width: 400px;
    height: 400px;
}
.button:hover .btnText{
    color: var(--white-100, #fdfdff);
    border: none;
}
/* Btn Active */
.button:active .go-to-next-hover,
.button:active .go-to-next{
    background-color: var( --purelize-primary-300, #008471);
}

/* Product */
.products{
    width: 100%;
    display: flex;
    flex-direction: row;
    gap: 20px;
    margin-bottom: 24px;
}

.product{
    width: 100%;
    height: 680px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    border-radius: 16px;
    overflow: hidden;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
}
#product1{
    background-image: url("../Img/Product/product_OleBee.jpg");
}
#product1:hover{
    background-image: url("../Img/Product/product_OleBee_withBg.jpg");
}
#product2{
    background-image: url("../Img/Product/product_VitalaxQ.jpg");
}
#product2:hover{
    background-image: url("../Img/Product/product_VitalaxQ_withBg.jpg");
}
#product3{
    background-image: url("../Img/Product/product_BetaGuard.jpg");
}
#product3:hover{
    background-image: url("../Img/Product/product_BetaGuard_withBg.jpg");
}
#product4{
    background-image: url("../Img/Product/product_Visiora.jpg");
}
#product4:hover{
    background-image: url("../Img/Product/product_Visiora_withBg.jpg");
}
#product5{
    background-image: url("../Img/Product/product_NMN.jpg");
}
#product5:hover{
    background-image: url("../Img/Product/product_NMN_withBg.jpg");
}
#product6{
    background-image: url("../Img/Product/product_ComingSoon.jpg");
}
#product6:hover{
    background-image: url("../Img/Product/product_ComingSoon_withBg.jpg");
    cursor: default;   
}


.product-summary{
    padding: 32px;
    display: flex;
    justify-content: space-between;
    align-items: center;

    background-color: rgba(253, 253, 255, 0.3);
    backdrop-filter: blur(2px);
}

.product-summary-text{
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 80%;
}
h5{
    font-family: 'Satoshi-Regular';
    font-size: var(--h5purelize-font-size, 40px);
    line-height: var(--h5purelize-line-height, 125%);
    font-weight: var(--h5purelize-font-weight, 450);
    font-style: var(--h5purelize-font-style, normal);
}
.product-brief{
    font-family: 'Inter', sans-serif;
    font-size: var(--bodytext-24purelize-font-size, 24px);
    line-height: var(--bodytext-24purelize-line-height, 150%);
    font-weight: 300;
    font-style: var(--bodytext-24purelize-font-style, normal);
}

.go-to-next-product{
    height: 56px;
    width: 56px;
    border-radius: 50%;
    border: 1px solid var(--white-700, #a9aaad);
    display: flex;
    justify-content: center;
    align-items: center;

    transition: all 0.3s ease;
}
.product:hover .go-to-next-product{
    border: none;
    background-color: var(--purelize-primary-500, #008471);
}
.product:hover .arrow-right{
    content: url("../Img/Icon/ArrowRight.png");
}
.product:active .go-to-next-product{
    border: none;
    background-color: var( --purelize-primary-300, #52ab9e);
}
.product:active .arrow-right{
    content: url("../Img/Icon/ArrowRight.png");
}


/* ------About Section------ */
.about-section{
    width: 100%;
    padding: 56px 104px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 84px;
    background-color: var(--purelize-territory-500, #f7f9ec);
}
.about-content{
    width: 100%;
    display: flex;
    flex-direction: column;
    padding: 120px 48px;
    border-radius: 20px;
    background-image: url("../Img/Main/AboutSection.png");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}
.about-content *{
    color: var(--white-100, #fdfdff);
}
.white-dot{
    background-color: var(--white-100, #fdfdff);
}

.about-content-text{
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 280px;
}
.about-content-text .dot-span,
.about-content-text h2{
    width: 100%;
}

.about-content-body{
    width: 100%;
    display: flex;
    flex-direction: row;
}
.empty-block{
    width: 100%;
}
.about-content-text-body{
    width: 100%;
    font-family: 'Inter', sans-serif;
    font-size: var(--bodytext-24purelize-font-size, 24px);
    line-height: var(--bodytext-24purelize-line-height, 150%);
    font-weight: var(--bodytext-24purelize-font-weight, 300);
    font-style: var(--bodytext-24purelize-font-style, normal);
}

/* About Detail */
.abouts{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 84px;

    position: relative;
}
.about{
    width: 100%;
    padding: 24px 24px 24px 48px;
    border-radius: 20px;
    background-color: var(--white-100, #fdfdff);
    display: flex;
    gap: 10%;

    position: sticky;
    top: 160px;
}
.about-text{
    margin: 24px 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 55%;
    gap: 80px;
}
.about-title{
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.about-no{
    color: var(--white-100, #fdfdff);
    font-size: var(--bodytext-18purelize-font-size, 18px);
    line-height: var(--bodytext-18purelize-line-height, 150%);
    font-weight: var(--bodytext-18purelize-font-weight, 400);
}
h4{
    font-family: 'Satoshi-Regular';
    font-size: var(--h4purelize-font-size, 48px);
    line-height: var(--h4purelize-line-height, 125%);
    font-weight: var(--h4purelize-font-weight, 450);
    font-style: var(--h4purelize-font-style, normal);
}
.about-body{
    font-size: var(--bodytext-18purelize-font-size, 18px);
    line-height: 160%;
    font-weight: 300;
}
.about-img{
    width: 40%;
    height: 600px;
    border-radius: 16px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.img1{
    background-image: url("../Img/Main/AboutSection1.png");
}
.img2{
    background-image: url("../Img/Main/AboutSection2.png");
}
.img3{
    background-image: url("../Img/Main/AboutSection3.png");
}
.img4{
    background-image: url("../Img/Main/AboutSection4.png");
}


/* ---------Last Section--------- */
.last-section{
    width: 100%;
    padding: 360px 104px 720px 104px;
    background: var(--purelize-primary-500, #008471);
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.double-quotation-marks{
    width: 74px;
    height: 62px;
    background-image: url("../Img/Icon/DoubltQuotation.png");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.last-section h3{
    color: var(--white-100, #fdfdff)
}
h3{
    width: 80%;
    padding: 0 36px;
    font-family: 'Satoshi-Regular';
    font-size: var(--h3purelize-font-size, 64px);
    line-height: var(--h3purelize-line-height, 125%);
    font-weight: var(--h3purelize-font-weight,450);
    font-style: var(--h3purelize-font-style, normal);
}


/* Footer */
footer{
    width: 100%;
    padding: 56px 104px 80px 104px;
    background-color: var(--purelize-primary-500, #008471);
    
}
.footer-not-main-page{
    background-color: var(--purelize-primary-500, #1c1d1d);
}
footer  *{
    color: var(--white-100, #fdfdff);
    text-align: left;
    font-family: 'Inter', sans-serif;
    font-size: var(--bodytext-18purelize-font-size, 18px);
    line-height: var(--bodytext-18purelize-line-height, 150%);
    letter-spacing: var(--h1purelize-letter-spacing, -0.01em);
    font-weight: 300;
    font-style: var(--bodytext-18purelize-font-style, normal);
}

.footer-content{
    display: flex;
    gap: 120px;
}
/* Footer Nav */
.footer-nav{
    width: 100%;
    display: inline-flex;
    justify-content: space-between;
}
.footer-nav-logo{
    width: 45px;
}
.footer-nav-shop-list{
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Footer Info */
.footer-info{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 52px;
}
.made-by{
    font-family: var(--bodytext-16purelize-font-family, Roboto-Regular, sans-serif);
    font-size: var(--bodytext-16purelize-font-size, 16px);
    line-height: var(--bodytext-16purelize-line-height, 150%);
    font-weight: 300;
    font-style: var(--bodytext-16purelize-font-style, normal);
}

/* -------- Products Page Styles-------- */
.products-head-img{
    height: 400px;
    background-image: url('../Img/Product/AllProducts.png');
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
.products-section{
    width: 100%;
    padding: 140px 104px 80px 104px;
    display: flex;
    flex-direction: column;
}
.products-content-text .flex-row{
    justify-content: flex-start;
}
.products-content-text h2{
    text-align: start;
    margin-bottom: 80px;
}
.product-info-main{
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* -------- Product Page Styles-------- */
.product-head-img{
    height: 160px;
}
.product-flex-row{
    padding: 64px 104px;
    height: 100%;
    display: flex;
    flex-direction: row;
    gap: 80px;
}
.product-page-img-section{
    width: 50%;
    height: 50vw;
    display: flex;
    flex-direction: column-reverse;
    gap: 16px;
}
.product-page-info-section{
    color: #1C1D1D;
    width: 50%;
}

.product-imgs{
    width: 100%;
    display: flex;
    /* flex-direction: column; */
    gap: 16px;
}
.product-main-img{
    border-radius: 16px;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    height: 100%;
    width: 100%;

}
.product-img{
    width: 80px;
    height: 80px;
    border-radius: 16px;
    background-color: #6f6f6f;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    cursor: pointer;
    transition: outline 0.1s ease;
}
.product-img.selected{
    outline: 2px solid #52ab9e !important; /* 강조 색상 */
    outline-offset: 1px;
}
.product-img:hover {
    outline: 2px solid #008471; /* 강조 색상 */
}

.product-info-list{
    padding-top: 16px;
}
.product-info {
    width: 100%;
    border-bottom: 1px solid #353535;
    padding: 24px 0;
}

.product-info-subject {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
}

.toggle-icon {
    position: relative;
    width: 24px;
    height: 24px;
}

.stick {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 2px;
    background-color: #333;
    transform: translateY(-50%);
    border-radius: 2px;
}

.horizontal {
    width: 100%;
}

.vertical {
    width: 100%;
    transform: translateY(-50%) rotate(0deg); /* 기본적으로 보이지 않도록 설정 */
    opacity: 0;
    transition: opacity 0.3s, transform 0.3s;
}
.product-info-detail {
    display: none; /* 기본적으로 숨김 */
    margin-top: 12px;
    font-size: 1em;
    color: #333;
}

.ingredient{
    display: flex;
    justify-content: space-between;
    margin: 8px 0;
}
.numberUnit{
    margin-top: 4px;
    text-align: right;
}
.note{
    color: #656565;
}
/* Toggle active 상태 */
.active .vertical {
    opacity: 1;
    transform: translateY(-50%) rotate(90deg); /* 직각으로 보이도록 */
}



/* Font */
.product-price,
.product-price *{
    font-size: 22px;
    font-style: italic;
    color: #005A4D;
}
.product-info-detail p,
.product-page-brief{
    font-size: 18px;
    line-height: 150%;
    font-weight: 300;
}
.product-info-purpose{
    font-size: 20px;
    line-height: 135%;
}

/* Product 1 */


/* Product 2 */



/* -------- Contact Page Styles-------- */
/* Content */
.contact-page{
    height: auto;
    padding: 200px 104px 64px 104px;
    /* gap: 4%; */
    display: flex;
    justify-content: space-between;
}
.contact-completed-page{
    /* height: 100vh; */
    height: 1020px;
}

.contact-content{
    width: 55%;
    height: auto;
    /* height: 727.5px; */
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
/* .contact-content p{
    justify-self: flex-end;
} */
.contact-content p,
.form-label,
.necessary{  
    color: var(--purelize-primary-500, #1c1d1d);
    text-align: left;
    font-family: 'Inter', sans-serif;
    font-size: var(--bodytext-18purelize-font-size, 18px);
    line-height: var(--bodytext-18purelize-line-height, 150%);
    letter-spacing: var(--h1purelize-letter-spacing, -0.01em);
    font-weight: var(--bodytext-18purelize-font-weight, 300);
    font-style: var(--bodytext-18purelize-font-style, normal);
}

/* Form */
.contact-form{
    width: 45%;
    height: 100%;
    margin-left: 80px;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.complete-section{
    height: 100%;
    display: flex;
    align-items: flex-end;
}
.necessary{
    color: #D72C0D;
    margin-left: 4px;
}

.table{
    width: 100%;
}
.form{
    position: relative;
    margin-bottom: 28px;
}
.input-full,
.form-control{
    width: 100%;
    padding: 14px 8px;
    border: none;
    border-bottom: 1px solid var(--purelize-primary-500, #1c1d1d);
    background-color: var(--white-100, #fdfdff);
    font-size: 18px;
    color: #767676;
    font-weight: 300;
}
.input-full:focus,
.form-control:focus{
    border-color: #008471;
    outline: none;
}
.form-control{
    height: 128px;
}
.label-gap{
    margin-top: 4px;
}
/* Radios */
.radio-form{
    margin-bottom: 12px;
}
.label-gap2{
    height: 12px;
}
.form-check{
    display: inline-flex;
    margin-right: 32px;
}
.form-check:last-child{
    margin-right: 0px;
}
.form-check-label{
    font-size: 16px;
    color: #1C1C1C;
    font-weight: 300;
}
.form-check-input{
    margin-right: 12px;
    margin-bottom: 20px;
}

input[type="radio"]{
    width: 24px;
    height: 24px;
    display: grid;
    place-content: center;
    accent-color: #008471;

    appearance: none;
    border: 1px solid #767676;
    border-radius: 50%;
    position: relative;
}
input[type="radio"]:checked::before {
    content: '';
    width: 14px;
    height: 14px;
    background-color: #008471;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
input[type="radio"]:hover {
    background: rgba(184, 221, 215, 0.3);
    border: 1px solid #008471;
    box-shadow: 0 0 0 8px rgba(184, 221, 215, 0.3);
}

input[type="radio"]:hover::before {
    content: '';
    width: 16px;
    height: 16px;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
input[type="radio"]:active {
    background: rgba(184, 221, 215, 0.8);
    border: 1px solid #008471;
    box-shadow: 0 0 0 8px rgba(184, 221, 215, 0.8);
}

.disable-btn{
    cursor: default;
}
.disable-btn .btnText{
    color: var(--white-700, #a9aaad);
}
.disable-btn .go-to-next{
    background-color: var(--white-700, #a9aaad);
}
.disable-btn .go-to-next-hover{
    background-color: var(--white-700, #a9aaad);
}
.disable-btn:hover{
    border: 1px solid var(--white-700, #a9aaad);
}
.disable-btn:hover .btnText,
.disable-btn:active .btnText{
    color: var(--white-700, #a9aaad);
}
.disable-btn:hover .go-to-next,
.disable-btn:active .go-to-next{
    background-color: var(--white-700, #a9aaad);
}
.disable-btn:hover .go-to-next-hover{
    display: none;
}

/* ✅ 활성화 상태 기본 */
#button-inquiry.enable-btn{
    background-color: transparent;   /* 기본은 기존 디자인 유지(원래 배경이 있다면 그걸로) */
    cursor: pointer;
  }
  
  /* ✅ hover 시: 버튼 전체 배경을 arrow 원 배경색(#008471)으로 */
  #button-inquiry.enable-btn:hover{
    background-color: #008471;
  }
  
  /* ✅ hover 시 텍스트 색(필요시 흰색 유지) */
  #button-inquiry.enable-btn:hover .btnText{
    color: #ffffff;
  }
  
  /* ✅ hover 시: 오른쪽 화살표 원(.go-to-next)도 동일 색 유지 */
  #button-inquiry.enable-btn:hover .go-to-next{
    background-color: #008471;
  }
  
  /* ✅ disable 상태에서는 hover가 먹지 않게(안전장치) */
  #button-inquiry.disable-btn{
    pointer-events: none;
  }
  
  
  


/* -------- Contact Page Styles-------- */

/* -------- Contact Sucess Page Styles-------- */











@media only screen and (max-width:1194px){
    .product-flex-row{
        flex-direction: column;
    }
    .product-page-img-section,
    .product-page-info-section{
        width: 100%;
    }
    .product-page-img-section{
        height: 100vw;
    }
}

/* -------- Index Main Page Styles-------- */
/* ------------ width 1080 px ------------ */

@media only screen and (max-width:1024px){
    .navigation{
        padding: 24px 24px;
    }
    .nav{
        padding: 20px 20px 20px 28px;
    }
    .navLists{
        display: none;
    }
    
    .overlay-nav.active{
        display: flex;
    }

    .hamburger{
        display: flex;
    }
    .hamburger.active .bar:nth-child(1) {
        transform: rotate(45deg) translate(9px, 9px);
    }
    .hamburger.active .bar:nth-child(2) {
        opacity: 0;
    }
    .hamburger.active .bar:nth-child(3) {
        transform: rotate(-45deg) translate(9px, -9px);
    }

     /* Overaly Menu */
    .overlay-menu {
        margin-top: 80px;
        padding: 0 20px;
    }
    /* .overlay-menu li {
        padding: 24px;
    } */
    .overlay-menu li:last-child{
        margin-top: 40px;
    }
    .overlay-menu li .nav-list a{
        font-size: 20px;
    }
    .nav-list{
        margin: 0;
    }

    .hero-section{
        min-height: 960px;
        padding: 0 32px;
    }

    .product-section,
    .products-section{
        width: 100%;
        padding: 140px 32px 80px 32px;
    }
    .product-flex-row{
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .about-section{
        padding: 56px 32px;
    }
    .last-section{
        width: 100%;
        padding: 360px 32px 720px 32px;
    }
    .products{
        flex-direction: column;
    }
    .product{
        height: 640px;
    }

    .product-name{
        font-size: 32px;
    }
    .product-brief{
        font-size: 18px;
    }

    .about-content-text{
        flex-direction: column;
        margin-bottom: 240px;
    }
    .about-content-body{
        flex-direction: column;
    }

    .about{
        flex-direction: column;
    }
    .about-text{
        width: 100%;
    }
    .about-img{
        margin-top: 24px;
        height: 440px;
        width: 100%;
    }

    /* ----------Products Page---------- */
    


    /* ----------Contact Page---------- */
    .completed-page{
        position: relative;
        display: flex;
        flex-direction: column;
    }
    .contact-page{
        height: 100%;
        position: relative;
        padding: 200px 32px 64px 32px;
        flex-direction: column;
    }
    .contact-completed-page{
        height: 100vh;
    }
    .contact-content{
        width: 100%;
        justify-content: flex-start;
        gap: 40px;
    }
    
    /* Form */
    .contact-form{
        width: 100%;
        margin-top: 80px;
        margin-left: 0;
    }


    footer{
        padding: 56px 32px 80px 32px;
    }
    .footer-content{
        flex-direction: column;
        gap: 120px;
    }
    .footer-not-main-page{
        position: relative;
    }

}

/* ------------ width 700 px ------------ */
@media only screen and (max-width:700px){
    .product-content{
        width: 100%;
    }
    .products-head-img{
        flex-direction: column;
    }
    .product{
        height: 600px;
    }

    .product-page-img-section{
        height: 100%;
    }
    .product-main-img{
        height: 100vw;
    }

        
    .about{
        position: relative;
        top: 0;
    }
    
}


/* ------------ width 440 px ------------ */

@media only screen and (max-width:440px){
    body{
        display: flex;
        flex-direction: column;
        min-height: 100vh;
    }
    /* Nav */
    .navigation{
        padding: 0;
    }
    .nav{
        padding: 24px 20px;
        border-radius: 0;
    }

        /* Overaly Menu */
    .overlay-nav .nav-contact{
        width: 100%;
    }
    
    
    /* Font */
    h1{
        font-size: 64px;
    }
    h2{
        font-size: 52px;
    }
    h3{
        font-size: 48px;
        width: 100%;
        padding: 0;
    }
    h4{
        font-size: 36px;
    }

    /* Button */
    .button{
        width: 100%;
        gap: 16px;
    }
    .btnText{
        width: 60%;
    }
    .dot-span{
        margin-bottom: 24px;
    }
    .dot-span span{
        font-size: 14px;
    }


/* Main Page */
    .hero-section{
        height: 100%;
        min-height: 700px;
        padding: 0 20px;
    }
    .hero-content{
        margin-bottom: 80px;
        width: 100%;
        gap: 64px;
    }

    /* Product Section */
    .product-head-img{
        height: 120px;
    }
    .product-summary{
        padding: 16px;
    }
    .product-section{
        width: 100%;
        padding: 140px 20px 80px 20px;
        gap: 64px;
    }
    
    .product-imgs{
        gap: 8px;
        flex-wrap: wrap;
    }
    .product-img{
        aspect-ratio: 1;
    }

    /* About Section */
    .about-section{
        padding: 0px;
        gap: 0px;
    }
    .about-content{
        padding: 120px 20px;
        border-radius: 0;
    }
    .about-content-text{
        margin-bottom: 180px;
    }
    .about-content-text{
        margin-bottom: 120px;
    }
    .about-img{
        height: 300px;
    }
    .about-content-text-body{
        font-size: 18px;
    }
    .abouts{
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 40px;
        position: relative;
        padding-bottom: 80px;
    }
    .about{
        padding: 24px 20px;
        border-radius: 0px;
        top: 40px;
    }
    .about-text{
        gap: 48px;
    }

    .last-section{
        padding: 240px 20px 440px 20px;
        gap: 40px;
    }
    .double-quotation-marks{
        width: 64px;
        height: 52px;
    }


/* Contact Page */
    .contact-page{
        height: 100%;
        padding: 160px 20px 64px 20px;
    }


/* Products Page */
.products-head-img{
    height: 180px;
}
.products-section{
    padding: 88px 20px 80px 20px;
}
.product-flex-row{
    padding-top: 32px;
    padding-bottom: 32px;
    gap: 64px;
}


/* Footer */
    .footer-content *{
        font-size: 16px;
    }
    .footer-nav{
        display: flex;
        flex-direction: column;
        gap: 48px;
    }
    .footer-content{
        gap: 80px;
    }
    .footer-nav-shop-list{
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
    .product-detail{
        font-size: 14px;
    }

}