html { scroll-behavior: smooth; }
body { margin: 0; color: var(--gray_1); background: var(--gray_f); }
body.nav_open, body.popup_open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }

/* ======================================================
   Header
   ====================================================== */

.site_header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 2000;
}

/* =========================
   Header Top
========================= */

.header_top {
    max-height: var(--h36);
    overflow: hidden;
    color: var(--gray_f);
    background: var(--point2);
    opacity: 1;
    transform: translateY(0);
    transition: max-height .28s ease, opacity .22s ease, transform .28s ease;
}

.header_top_inner {
    min-height: var(--h36);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap16);
    font-size: var(--fs_14);
}

.header_company {
    margin: 0;
    opacity: .88;
    line-height: 1.3;
}

.header_tel {
    font-weight: 800;
    line-height: 1.3;
}

/* =========================
   Header Main
========================= */

.header_main {
    background: rgba(var(--gray_f_rgb), .88);
    backdrop-filter: blur(var(--w16));
    -webkit-backdrop-filter: blur(var(--w16));
    border-bottom: var(--w1) solid rgba(var(--gray_0_rgb), .06);
    transition: background .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.header_inner {
    min-height: var(--h76);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap40);
    transition: min-height .28s ease, gap .28s ease;
}

/* =========================
   Logo
========================= */

.site_logo {
    display: inline-flex;
    align-items: center;
    color: var(--point2);
    font-size: var(--fs_24);
    font-weight: 900;
    letter-spacing: -0.04em;
    transition: color .25s ease, font-size .28s ease;
}

.site_logo::before {
    content: "";
    width: var(--w12);
    height: var(--h12);
    margin-right: var(--m10);
    border-radius: var(--br_pill);
    background: var(--point);
    box-shadow: 0 0 0 var(--w8) rgba(var(--point_rgb), .12);
    transition: width .28s ease, height .28s ease, margin .28s ease, box-shadow .28s ease;
}

.site_logo_text {
    display: block;
    line-height: 1;
    white-space: nowrap;
}

/* =========================
   PC Nav
========================= */

.site_nav {
    display: flex;
    align-items: center;
    gap: var(--gap34);
    color: var(--gray_2);
    font-size: var(--fs_16);
    font-weight: 700;
    transition: gap .28s ease, font-size .28s ease;
}

.site_nav_link {
    position: relative;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    line-height: 1;
    transition: color .2s ease, padding .28s ease, background .2s ease, box-shadow .2s ease;
}

.site_nav_link:not(.nav_cta)::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: calc(var(--h8) * -1);
    width: 100%;
    height: var(--h2);
    background: var(--point);
    transform: scaleX(0);
    transform-origin: left center;
    opacity: 0;
    transition: transform .18s ease, opacity .18s ease;
}

.site_nav_link:not(.nav_cta):hover {
    color: var(--point);
}

.site_nav_link.is_active {
    color: var(--point);
}

.site_nav_link.is_active:not(.nav_cta)::after {
    transform: scaleX(1);
    opacity: 1;
}

.nav_cta {
    padding: var(--p8) var(--p22);
    border-radius: var(--br_pill);
    color: var(--gray_f);
    background: linear-gradient(135deg, var(--point), var(--point2));
    box-shadow: 0 var(--h12) var(--w28) rgba(var(--point_rgb), .24);
}

.nav_cta.is_active {
    color: var(--gray_f);
    background: linear-gradient(135deg, var(--point2), var(--point3));
    box-shadow: 0 var(--h12) var(--w28) rgba(var(--point2_rgb), .28);
}

/* =========================
   Menu Button
========================= */

.menu_btn {
    position: relative;
    display: none;
    width: var(--w44);
    height: var(--h44);
    padding: 0;
    border: 0;
    border-radius: var(--br_pill);
    background: var(--point2_lighter);
    cursor: pointer;
}

.menu_btn_line {
    position: absolute;
    left: 50%;
    top: 50%;
    display: block;
    width: var(--w18);
    height: var(--h2);
    margin: 0;
    border-radius: var(--br_pill);
    background: var(--point2);
    transform: translate(-50%, -50%);
    transform-origin: center center;
    transition: transform .22s ease, opacity .18s ease, background .18s ease;
}

.menu_btn_line:nth-child(1) {
    transform: translate(-50%, calc(-50% - var(--h6)));
}

.menu_btn_line:nth-child(2) {
    transform: translate(-50%, -50%);
}

.menu_btn_line:nth-child(3) {
    transform: translate(-50%, calc(-50% + var(--h6)));
}

.menu_btn:hover .menu_btn_line {
    background: var(--point);
}

.menu_btn_text {
    position: absolute;
    overflow: hidden;
    width: var(--w1);
    height: var(--h1);
    clip: rect(0, 0, 0, 0);
}

/* =========================
   PC Scroll State
   - 모바일에는 적용하지 않음
========================= */

@media (min-width: 992px) {
    .site_header.is_scrolled .header_top {
        max-height: 0;
        opacity: 0;
        transform: translateY(-100%);
        pointer-events: none;
    }

    .site_header.is_scrolled .header_main {
        background: rgba(var(--gray_f_rgb), .94);
        border-bottom-color: rgba(var(--gray_0_rgb), .08);
        box-shadow: 0 var(--h14) var(--w36) rgba(var(--gray_0_rgb), .08);
    }

    .site_header.is_scrolled .header_inner {
        min-height: var(--h62);
        gap: var(--gap30);
    }

    .site_header.is_scrolled .site_logo {
        font-size: var(--fs_21);
    }

    .site_header.is_scrolled .site_logo::before {
        width: var(--w10);
        height: var(--h10);
        margin-right: var(--m8);
        box-shadow: 0 0 0 var(--w6) rgba(var(--point_rgb), .10);
    }

    .site_header.is_scrolled .site_nav {
        gap: var(--gap24);
        font-size: var(--fs_15);
    }

    .site_header.is_scrolled .nav_cta {
        padding: var(--p7) var(--p18);
        box-shadow: 0 var(--h10) var(--w24) rgba(var(--point_rgb), .20);
    }
}

/* =========================
   Mobile
   - 스크롤 상태여도 디자인 고정
========================= */

@media (max-width: 991px) {
    .header_top {
        display: none;
    }

    .header_main {
        background: rgba(var(--gray_f_rgb), .88);
        backdrop-filter: blur(var(--w16));
        -webkit-backdrop-filter: blur(var(--w16));
        border-bottom: var(--w1) solid rgba(var(--gray_0_rgb), .06);
        box-shadow: none;
    }

    .header_inner {
        min-height: var(--h66);
        gap: var(--gap20);
    }

    .site_header.is_scrolled .header_inner {
        min-height: var(--h56);
    }

    .site_logo {
        font-size: var(--fs_22);
    }

    .site_logo::before {
        width: var(--w10);
        height: var(--h10);
        margin-right: var(--m8);
        box-shadow: 0 0 0 var(--w6) rgba(var(--point_rgb), .10);
    }

    .menu_btn {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        flex: 0 0 var(--w44);
    }

    .site_nav {
        position: fixed;
        top: var(--h66);
        left: 0;
        right: 0;
        display: grid;
        gap: 0;
        padding: var(--p18);
        color: var(--gray_2);
        font-size: var(--fs_16);
        background: rgba(var(--gray_f_rgb), .97);
        border-bottom: var(--w1) solid rgba(var(--gray_0_rgb), .08);
        box-shadow: 0 var(--h24) var(--w60) rgba(var(--gray_0_rgb), .14);
        transform: translateY(-120%);
        opacity: 0;
        pointer-events: none;
        transition: transform .24s ease, opacity .24s ease;
    }

    .site_header.is_scrolled .site_nav {
        top: var(--h56);
    }

    body.nav_open .site_nav {
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
    }

    .site_nav_link {
        padding: var(--p16) var(--p12);
        border-bottom: var(--w1) solid var(--gray_ef);
        font-size: var(--fs_17);
        line-height: 1.2;
    }

    .site_nav_link::after {
        display: none;
    }

    .site_nav_link.is_active {
        color: var(--point);
        background: rgba(var(--point_rgb), .06);
    }

    .nav_cta {
        justify-content: center;
        margin-top: var(--m12);
        padding: var(--p16) var(--p18);
        border-bottom: 0 !important;
        color: var(--gray_f);
        background: linear-gradient(135deg, var(--point), var(--point2));
        box-shadow: 0 var(--h12) var(--w28) rgba(var(--point_rgb), .24);
    }

    .nav_cta.is_active {
        color: var(--gray_f);
        background: linear-gradient(135deg, var(--point2), var(--point3));
        box-shadow: 0 var(--h12) var(--w28) rgba(var(--point2_rgb), .28);
    }

    body.nav_open .menu_btn_line:nth-child(1) {
    transform: translate(-50%, -50%) rotate(45deg);
    }

    body.nav_open .menu_btn_line:nth-child(2) {
        opacity: 0;
    }

    body.nav_open .menu_btn_line:nth-child(3) {
        transform: translate(-50%, -50%) rotate(-45deg);
    }
}

@media (max-width: 767px) {
    .site_logo {
        font-size: var(--fs_20);
    }

    .menu_btn {
        width: var(--w40);
        height: var(--h40);
        flex-basis: var(--w40);
    }
}
/* ======================================================
   Landing
   ====================================================== */
.landing_page { overflow: hidden; }

/* ======================================================
   Section
   ====================================================== */
.landing_section {
    padding: var(--p120) 0;
    overflow: hidden;
    position: relative;
    /* box-shadow: inset 0 var(--h1) 0 rgba(var(--point2_rgb), .045); */
}
.section_head {
    max-width: 760px;
    margin-bottom: var(--m54);
    word-break: keep-all;
}

.section_head.ta_cen {
    margin-left: auto;
    margin-right: auto;
}

.section_head h2 {
    margin: 0;
    color: var(--gray_1);
    font-size: var(--fs_44);
    font-weight: 700;
    line-height: 1.18;
    letter-spacing: -0.06em;
}

.section_head p:not(.section_kicker) {
    margin: var(--m18) 0 0;
    color: var(--gray_5);
    font-size: var(--fs_18);
    line-height: 1.6;
}

/* 부모에 fc_f, fc_1, fc_2 같은 색상 유틸을 줬을 때 자식도 따라가게 */
.section_head[class*="fc_"] h2,
.section_head[class*="fc_"] p:not(.section_kicker) {
    color: inherit;
}

/* 흰색 섹션 헤더용 키커 */
.section_head.fc_f .section_kicker {
    color: var(--gray_f);
    background: rgba(var(--gray_f_rgb), .14);
}

/* 흰색 섹션 헤더용 설명문 */
.section_head.fc_f p:not(.section_kicker) {
    color: rgba(var(--gray_f_rgb), .82);
}
.section_kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--p40);
    padding: var(--p10) var(--p20);
    border-radius: var(--br_pill);
    color: var(--point);
    background: rgba(var(--point_rgb), .1);
    border: 1px solid rgba(var(--point_rgb), .1);
    font-size: var(--fs_20);
    font-weight: 600;
    line-height: 1;
    margin-bottom: var(--m20);
}



/* ======================================================
   Main Hero
   ====================================================== */

.main_hero {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 100vh;
    padding-top: var(--h120);
    overflow: hidden;
    color: var(--gray_f);
    background:
        radial-gradient(circle at 76% 18%, rgba(var(--point_rgb), .48), transparent 30%),
        radial-gradient(circle at 86% 84%, rgba(var(--point3_rgb), .44), transparent 36%),
        radial-gradient(circle at 15% 80%, rgba(var(--point_rgb), .24), transparent 34%),
        linear-gradient(135deg, var(--point2_darker) 0%, var(--point2_dark) 42%, var(--point3_darker) 74%, var(--point2_darker) 100%);
}

.main_hero::before {
    content: "";
    position: absolute;
    top: calc(var(--h180) * -1);
    right: calc(var(--w140) * -1);
    width: var(--w500);
    height: var(--h500);
    border-radius: var(--br_pill);
    background: radial-gradient(circle, rgba(var(--gray_f_rgb), .18), transparent 62%);
    filter: blur(var(--w10));
    pointer-events: none;
}

.main_hero::after {
    content: "";
    position: absolute;
    left: calc(var(--w200) * -1);
    bottom: calc(var(--h200) * -1);
    width: var(--w600);
    height: var(--h600);
    border-radius: var(--br_pill);
    background: radial-gradient(circle, rgba(var(--point3_rgb), .34), transparent 66%);
    filter: blur(var(--w20));
    pointer-events: none;
}

.hero_wrap {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(var(--w400), var(--w600));
    align-items: center;
    gap: var(--gap70);
    padding-top: var(--p80);
    padding-bottom: var(--p90);
}

.hero_copy {
    position: relative;
    min-width: 0;
}

.hero_eyebrow {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--gap10);
    min-height: var(--mnh40);
    margin: 0 0 var(--m25);
    padding: 0 var(--p18);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .24);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .12);
    color: rgba(var(--gray_f_rgb), .92);
    font-size: var(--fs_16);
    font-weight: 700;
    line-height: 1;
    letter-spacing: .06em;
    box-shadow:
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .18),
        0 var(--h12) var(--w30) rgba(var(--gray_0_rgb), .14);
    backdrop-filter: blur(var(--w10));
    -webkit-backdrop-filter: blur(var(--w10));
}

.hero_eyebrow::before {
    content: "";
    width: var(--w8);
    height: var(--h8);
    border-radius: var(--br_pill);
    background: var(--point);
    box-shadow:
        0 0 0 var(--w5) rgba(var(--point_rgb), .22),
        0 0 var(--w18) rgba(var(--point_rgb), .80);
}

.hero_title {
    position: relative;
    margin: 0;
    color: var(--gray_f);
    font-size: clamp(3.2rem, 5.8vw, 5.6rem);
    line-height: .98;
    letter-spacing: -0.08em;
    text-shadow: 0 var(--h10) var(--w30) rgba(var(--gray_0_rgb), .24);
}

.hero_title_point {
    position: relative;
    display: inline-block;
    color: var(--gray_f);
}

.hero_title_point::before {
    content: "";
    position: absolute;
    left: calc(var(--w8) * -1);
    right: calc(var(--w8) * -1);
    bottom: var(--h6);
    height: .34em;
    border-radius: var(--br_pill);
    background: linear-gradient(90deg, rgba(var(--point_rgb), .78), rgba(var(--point3_rgb), .74));
    z-index: -1;
    box-shadow: 0 var(--h10) var(--w24) rgba(var(--point_rgb), .28);
}

.hero_desc {
    max-width: var(--mxw640);
    margin: var(--m30) 0 0;
    color: rgba(var(--gray_f_rgb), .95);
    font-size: var(--fs_22);
    font-weight: 500;
    line-height: 1.65;
    letter-spacing: -0.04em;
    word-break: keep-all;
}

.hero_metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gap12);
    max-width: 630px;
    margin-top: var(--m45);
}

.hero_metric {
    position: relative;
    overflow: hidden;
    min-height: var(--mnh100);
    padding: var(--p24);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .18);
    border-radius: var(--br_25);
    background:
        radial-gradient(circle at 85% 15%, rgba(var(--gray_f_rgb), .26), transparent 34%),
        linear-gradient(135deg, rgba(var(--gray_f_rgb), .18), rgba(var(--gray_f_rgb), .055));
    box-shadow:
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .28),
        inset 0 0 var(--w35) rgba(var(--gray_f_rgb), .035),
        0 var(--h18) var(--w45) rgba(var(--gray_0_rgb), .16);
    backdrop-filter: blur(var(--w16)) saturate(1.35);
    -webkit-backdrop-filter: blur(var(--w16)) saturate(1.35);
}

.hero_metric::before {
    content: "";
    position: absolute;
    top: calc(var(--h35) * -1);
    right: calc(var(--w35) * -1);
    width: var(--w95);
    height: var(--h95);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .08);
    filter: blur(var(--w12));
    pointer-events: none;
}

.hero_metric::after {
    content: "";
    position: absolute;
    left: calc(var(--w45) * -1);
    bottom: calc(var(--h45) * -1);
    width: var(--w105);
    height: var(--h105);
    border-radius: var(--br_pill);
    background: rgba(var(--point3_rgb), .18);
    filter: blur(var(--w14));
    pointer-events: none;
}

.hero_metric_label {
    position: relative;
    z-index: 1;
    display: block;
    color: rgba(var(--gray_f_rgb), .8);
    font-size: var(--fs_14);
    font-weight: 500;
    line-height: 1.2;
}

.hero_metric_value {
    position: relative;
    z-index: 1;
    display: block;
    margin-top: var(--m12);
    color: var(--gray_f);
    font-size: var(--fs_32);
    font-weight: 700;
    line-height: 1.12;
    letter-spacing: -0.07em;
    text-shadow: 0 var(--h8) var(--w18) rgba(var(--gray_0_rgb), .22);
}

.hero_actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap12);
    margin-top: var(--m35);
}

.btn_primary,
.btn_outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--mnh58);
    padding: 0 var(--p30);
    border-radius: var(--br_pill);
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
    background-clip: padding-box;
}

.btn_primary {
    color: var(--gray_f);
    font-size: var(--fs_18);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .20);
    background: linear-gradient(135deg, var(--point), var(--point3));
    box-shadow:
        0 var(--h18) var(--w38) rgba(var(--point_rgb), .34),
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .28);
    text-shadow: 1px 1px 1px rgba(var(--gray_0_rgb), .20);
}

.btn_outline {
    color: var(--gray_f);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .28);
    background: rgba(var(--gray_f_rgb), .10);
    box-shadow:
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .18),
        0 var(--h12) var(--w30) rgba(var(--gray_0_rgb), .12);
    backdrop-filter: blur(var(--w10));
    -webkit-backdrop-filter: blur(var(--w10));
}

.btn_primary:hover,
.btn_outline:hover {
    transform: translateY(calc(var(--h2) * -1));
}

.btn_primary:hover {
    box-shadow:
        0 var(--h24) var(--w48) rgba(var(--point_rgb), .42),
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .30);
}

.btn_outline:hover {
    border-color: rgba(var(--gray_f_rgb), .44);
    background: rgba(var(--gray_f_rgb), .16);
}

/* 우측 이미지 영역 */
.hero_panel {
    position: relative;
    min-width: 0;
    width: 100%;
}

.hero_panel::before {
    content: "";
    position: absolute;
    inset: var(--h5) var(--w10) var(--h5) var(--w30);
    border-radius: var(--br_45);
    background: linear-gradient(135deg, rgba(var(--point_rgb), .46), rgba(var(--point3_rgb), .34));
    transform: rotate(74deg);
    box-shadow:
        0 var(--h28) var(--w80) rgba(var(--gray_0_rgb), .20),
        0 0 var(--w60) rgba(var(--point3_rgb), .22);
}

.hero_panel::after {
    content: "";
    position: absolute;
    top: -1rem;
    right: -2rem;
    width: var(--w140);
    height: var(--h140);
    border-radius: var(--br_35);
    background: rgba(var(--gray_f_rgb), .16);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .18);
    transform: rotate(25deg);
    pointer-events: none;
}

.hero_image {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
}

/* Main Hero responsive */
@media (max-width: 1199px) {
    .main_hero {
        padding-top: var(--h110);
    }

    .hero_wrap {
        grid-template-columns: minmax(0, 1fr) minmax(var(--w350), var(--w450));
        gap: var(--gap45);
        padding-top: var(--p70);
        padding-bottom: var(--p80);
    }

    .hero_title {
        font-size: clamp(2.8rem, 5.8vw, 4.8rem);
    }

    .hero_desc {
        font-size: var(--fs_20);
    }

    .hero_metric {
        padding: var(--p20);
    }

    .hero_metric_value {
        font-size: var(--fs_28);
    }

    .hero_image {
        height: var(--h500);
    }
}

@media (max-width: 991px) {
    .main_hero {
        min-height: auto;
        padding-top: var(--h66);
    }

    .hero_wrap {
        grid-template-columns: 1fr;
        gap: var(--gap45);
        padding-top: var(--p70);
        padding-bottom: var(--p80);
    }

    .hero_copy {
        text-align: center;
    }

    .hero_eyebrow {
        margin-left: auto;
        margin-right: auto;
    }

    .hero_desc {
        margin-left: auto;
        margin-right: auto;
    }

    .hero_metrics {
        margin-left: auto;
        margin-right: auto;
    }

    .hero_actions {
        justify-content: center;
    }

    .hero_panel {
        width: 70%;
        max-width:var(--mxw640) ;
        margin: 3rem auto 0;
    }

    .hero_image {
        height: var(--h420);
    }
}

@media (max-width: 767px) {
    .hero_metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: var(--gap8);
        margin-top: var(--m35);
    }

    .hero_metric {
        min-height: 0;
        padding: var(--p14) var(--p10);
        border-radius: var(--br_15);
        text-align: center;
    }

    .hero_metric_label {
        font-size: var(--fs_12);
    }

    .hero_metric_value {
        margin-top: var(--m8);
        font-size: var(--fs_20);
        letter-spacing: -0.06em;
    }

    .hero_actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--gap10);
    }

    .btn_primary,
    .btn_outline {
        width: 100%;
        min-height: var(--mnh54);
        padding: 0 var(--p12);
        font-size: var(--fs_15);
    }
}

/* ======================================================
   Product Section
   ====================================================== */

.product_section {
    /* background:
        radial-gradient(circle at 12% 14%, rgba(var(--point_rgb), .12), transparent 32%),
        radial-gradient(circle at 90% 86%, rgba(var(--point3_rgb), .08), transparent 34%),
        linear-gradient(180deg, var(--point_lighter) 0%, var(--gray_f8) 54%, var(--gray_f) 100%); images/product_obj.png*/
    background-color: var(--point2_lighter);
    background-image: url("../images/product_obj.png");
    background-repeat: no-repeat;
    background-position: left var(--w100) bottom var(--h150);
    background-size: min(55%, 780px) auto;
}


.product_wrap {
    display: grid;
    grid-template-columns: .72fr 1.28fr;
    gap: var(--gap55);
    align-items: start;
}

.product_info_area {
    display: grid;
    gap: var(--gap25);
}

/* 대표 상품 카드 */
.product_main_card {
    position: relative;
    overflow: hidden;
    padding: var(--p40);
    border-radius: var(--br_30);
    background: var(--gray_f);
    box-shadow: 0 var(--h25) var(--w60) rgba(var(--point2_rgb), .10);
}

.product_main_card.is_featured {
    color: var(--gray_f);
    background:
        radial-gradient(circle at 88% 8%, rgba(var(--gray_f_rgb), .07), transparent 28%),
        radial-gradient(circle at 8% 100%, rgba(var(--point3_dark_rgb), .36), transparent 50%),
        radial-gradient(circle at 82% 72%, rgba(var(--point3_dark_rgb), .28), transparent 48%),
        radial-gradient(circle at 62% 62%, rgba(var(--point_rgb), .22), transparent 44%),
        linear-gradient(135deg, var(--point2_darker), var(--point2_dark) 42%, var(--point3_darker) 74%, var(--point2_darker));
}

.product_main_card.is_featured::before {
    content: "";
    position: absolute;
    top: calc(var(--h60) * -1);
    right: calc(var(--w60) * -1);
    width: var(--w220);
    height: var(--h220);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .12);
    filter: blur(var(--w5));
    pointer-events: none;
}

.product_main_card.is_featured::after {
    content: "";
    position: absolute;
    right: var(--w35);
    bottom: var(--h35);
    width: var(--w130);
    height: var(--h130);
    border-radius: var(--br_40);
    background: rgba(var(--gray_f_rgb), .08);
    transform: rotate(18deg);
    filter: blur(var(--w2));
    pointer-events: none;
}

.product_card_head {
    position: relative;
    z-index: 1;
}

.product_badge {
    display: inline-flex;
    align-items: center;
    gap: var(--gap10);
    min-height: var(--mnh35);
    padding: 0 var(--p15);
    border: 1px solid rgba(var(--gray_f_rgb), .25);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .14);
    color: var(--gray_f);
    font-size: var(--fs_14);
    font-weight: 700;
    line-height: 1;
}

.product_badge::before {
    content: "";
    width: var(--w8);
    height: var(--h8);
    border-radius: var(--br_pill);
    background: var(--gray_f);
    box-shadow: 0 0 0 var(--w5) rgba(var(--gray_f_rgb), .12);
}

.product_card_head h3 {
    margin: var(--m25) 0 0;
    color: inherit;
    font-size: var(--fs_40);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.06em;
}

.product_card_head p {
    max-width: var(--mxw600);
    margin: var(--m20) 0 0;
    color: rgba(var(--gray_f_rgb), .86);
    font-size: var(--fs_18);
    line-height: 1.65;
    word-break: keep-all;
}

/* 핵심 요약 */
.product_summary_grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gap15);
    margin-top: var(--m35);
}

.product_summary_item {
    position: relative;
    overflow: hidden;
    padding: var(--p25);
    border: 1px solid rgba(var(--gray_f_rgb), .28);
    border-radius: var(--br_25);
    background:
        linear-gradient(135deg, rgba(var(--point2_darker_rgb), .38), rgba(var(--point_dark_rgb), .22)),
        linear-gradient(135deg, rgba(var(--gray_f_rgb), .14), rgba(var(--gray_f_rgb), .05));
    backdrop-filter: blur(var(--w12)) saturate(1.25);
    -webkit-backdrop-filter: blur(var(--w12)) saturate(1.25);
    box-shadow:
        inset 0 1px 0 rgba(var(--gray_f_rgb), .32),
        inset 0 0 var(--w30) rgba(var(--gray_0_rgb), .08),
        0 var(--h15) var(--w35) rgba(var(--gray_0_rgb), .10);
}

.product_summary_item::before {
    content: "";
    position: absolute;
    left: var(--w20);
    right: var(--w20);
    top: 0;
    height: var(--h1);
    background: linear-gradient(90deg, transparent, rgba(var(--gray_f_rgb), .72), transparent);
    pointer-events: none;
}

.product_summary_item::after {
    content: "";
    position: absolute;
    right: calc(var(--w25) * -1);
    bottom: calc(var(--h25) * -1);
    width: var(--w70);
    height: var(--h70);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .20);
    filter: blur(var(--w12));
    pointer-events: none;
}

.product_summary_item span {
    position: relative;
    z-index: 1;
    display: block;
    color: rgba(var(--gray_f_rgb), .82);
    font-size: var(--fs_14);
    font-weight: 700;
}

.product_summary_item strong {
    position: relative;
    z-index: 1;
    display: block;
    margin-top: var(--m10);
    color: var(--gray_f);
    font-size: var(--fs_28);
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -0.06em;
    text-shadow: 0 var(--h2) var(--w8) rgba(var(--gray_0_rgb), .18);
}

.product_summary_item p {
    position: relative;
    z-index: 1;
    margin: var(--m10) 0 0;
    color: rgba(var(--gray_f_rgb), .76);
    font-size: var(--fs_14);
    line-height: 1.45;
}

/* 하단 체크 리스트 */
.product_key_list {
    position: relative;
    z-index: 1;
    display: grid;
    gap: var(--gap10);
    margin: var(--m35) 0 0;
    padding: var(--p25);
    border: 1px solid rgba(var(--gray_f_rgb), .16);
    border-radius: var(--br_25);
    background: rgba(var(--gray_0_rgb), .10);
    list-style: none;
}

.product_key_list li {
    position: relative;
    padding-left: var(--p30);
    color: rgba(var(--gray_f_rgb), .90);
    font-size: var(--fs_16);
    font-weight: 600;
    line-height: 1.6;
    word-break: keep-all;
}

.product_key_list li::before {
    content: "✓";
    position: absolute;
    top: var(--h2);
    left: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--w20);
    height: var(--h20);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .18);
    color: var(--gray_f);
    font-size: var(--fs_13);
    font-weight: 900;
    line-height: 1;
}

/* 조건 카드 */
.product_condition_grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gap20);
}

.product_condition_card {
    position: relative;
    min-height: var(--mnh205);
    padding: var(--p30);
    border: var(--w1) solid transparent;
    border-radius: var(--br_25);
    background:
        linear-gradient(rgba(var(--gray_f_rgb), .94), rgba(var(--gray_f_rgb), .94)) padding-box,
        linear-gradient(135deg, rgba(var(--point_rgb), .26), rgba(var(--point3_rgb), .14)) border-box;
    box-shadow: 0 var(--h18) var(--w45) rgba(var(--point2_rgb), .07);
    overflow: hidden;
}

.product_condition_card.wide {
    grid-column: 1 / -1;
    min-height: 0;
}

.condition_num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--w45);
    height: var(--h45);
    border-radius: var(--br_15);
    color: var(--gray_f);
    background: linear-gradient(135deg, var(--point), var(--point3));
    font-size: var(--fs_15);
    font-weight: 900;
    line-height: 1;
    box-shadow: 0 var(--h10) var(--w25) rgba(var(--point_rgb), .20);
}

.product_condition_card h3 {
    margin: var(--m20) 0 0;
    color: var(--gray_1);
    font-size: var(--fs_22);
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: -0.04em;
}

.product_condition_card p {
    margin: var(--m15) 0 0;
    color: var(--gray_5);
    font-size: var(--fs_16);
    line-height: 1.7;
    word-break: keep-all;
}

.product_condition_card small {
    display: block;
    margin-top: var(--m15);
    padding-top: var(--p15);
    border-top: 1px solid var(--gray_ed);
    color: var(--gray_6);
    font-size: var(--fs_13);
    line-height: 1.65;
    word-break: keep-all;
}

@media (max-width: 1199px) {
    .product_wrap {
        grid-template-columns: 1fr;
        gap: var(--gap40);
    }
}

@media (max-width: 991px) {
    .product_summary_grid {
        grid-template-columns: 1fr;
    }

    .product_condition_grid {
        grid-template-columns: 1fr;
    }

    .product_condition_card {
        min-height: 0;
    }
}

@media (max-width: 767px) {
    .product_section {
        background-position: right 30px top 50px;
        background-size: min(40%, 360px) auto;
    }
    .product_main_card {
        padding: var(--p30);
        border-radius: var(--br_25);
    }

    .product_card_head h3 {
        font-size: var(--fs_34);
    }

    .product_summary_item,
    .product_key_list {
        border-radius: var(--br_15);
        padding: var(--p15);
    }

    .product_condition_card {
        padding: var(--p15);
        border-radius: var(--br_20);
        text-align: center;
    }

}

/* ======================================================
   Limit Section
   - 첫 번째 폼 / FAQ 하단 폼 배경 분리
   ====================================================== */
.limit_section > .wrap {
    position: relative;
    z-index: 1;
}

/* 첫 번째 폼: 메인 CTA 느낌의 딥 블루 */
#limit.limit_section {
    color: var(--gray_f);
    background:
        radial-gradient(circle at 14% 16%, rgba(var(--gray_f_rgb), .12), transparent 30%),
        radial-gradient(circle at 84% 18%, rgba(var(--point_rgb), .20), transparent 34%),
        radial-gradient(circle at 86% 84%, rgba(var(--point3_rgb), .30), transparent 38%),
        linear-gradient(135deg, var(--point2_darker) 0%, var(--point2_dark) 46%, var(--point_dark) 100%);
    box-shadow: none;
}

#limit.limit_section::before {
    content: "";
    position: absolute;
    top: calc(var(--h80) * -1);
    right: calc(var(--w80) * -1);
    width: var(--w260);
    height: var(--h260);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .10);
    filter: blur(var(--w20));
    pointer-events: none;
}

#limit .section_head {
    color: var(--gray_f) !important;
}

#limit .section_head .section_kicker {
    color: rgba(var(--gray_f_rgb), .76) !important;
}

/* 두 번째 폼: FAQ 이후 이어지는 밝은 연하늘 CTA */
#limit_bottom.limit_section {
    color: var(--gray_2);
    background:
        radial-gradient(circle at 12% 14%, rgba(var(--point_rgb), .15), transparent 34%),
        radial-gradient(circle at 88% 16%, rgba(var(--gray_f_rgb), .86), transparent 32%),
        radial-gradient(circle at 86% 84%, rgba(var(--point3_rgb), .12), transparent 36%),
        linear-gradient(180deg, var(--gray_f8) 0%, var(--point_lighter) 48%, var(--point2_lighter) 100%);
    /* box-shadow:
        inset 0 var(--h1) 0 rgba(var(--point_rgb), .10),
        inset 0 calc(var(--h1) * -1) 0 rgba(var(--point2_rgb), .08); */
}

#limit_bottom.limit_section::before {
    content: "";
    position: absolute;
    left: calc(var(--w70) * -1);
    bottom: calc(var(--h80) * -1);
    width: var(--w240);
    height: var(--h240);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .08);
    filter: blur(var(--w20));
    pointer-events: none;
}

#limit_bottom.limit_section::after {
    content: "";
    position: absolute;
    top: calc(var(--h90) * -1);
    right: calc(var(--w90) * -1);
    width: var(--w260);
    height: var(--h260);
    border-radius: var(--br_pill);
    background: rgba(var(--point3_rgb), .07);
    filter: blur(var(--w20));
    pointer-events: none;
}

#limit_bottom .section_head {
    color: var(--gray_2) !important;
}

#limit_bottom .section_head > .section_kicker {
    color: var(--point_dark) !important;
    background: rgba(var(--point_rgb), .10);
    border-color: rgba(var(--point_rgb), .12);
}

#limit_bottom .section_head > h2 {
    color: var(--point2_darker) !important;
}

#limit_bottom .section_head > p:not(.section_kicker) {
    color: var(--gray_5) !important;
}

#limit_bottom .limit_form_box {
    border-color: rgba(var(--point_rgb), .12);
    background: rgba(var(--gray_f_rgb), .98);
    box-shadow: 0 var(--h25) var(--w70) rgba(var(--point2_rgb), .10);
}


/* ======================================================
   Point Section
   ====================================================== */

.point_section {
    /* background:
        radial-gradient(circle at 14% 16%, rgba(var(--point_rgb), .09), transparent 30%),
        radial-gradient(circle at 86% 18%, rgba(var(--point3_rgb), .14), transparent 32%),
        linear-gradient(180deg, var(--gray_f) 0%, var(--point3_lighter) 48%, var(--point_lighter) 100%); */
    background: var(--point_lighter);
}

/* ======================================================
   3개 핵심 카드
   ====================================================== */

.point_core_grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gap25);
}

.point_core_card {
    position: relative;
    overflow: hidden;
    min-height: var(--mnh260);
    padding: var(--p35);
    border-radius: var(--br_30);
    color: var(--gray_f);
    box-shadow: 0 var(--h20) var(--w50) rgba(var(--point2_rgb), .12);
}

.point_core_card::before {
    content: "";
    position: absolute;
    right: calc(var(--w40) * -1);
    bottom: calc(var(--h40) * -1);
    width: var(--w150);
    height: var(--h150);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .12);
    filter: blur(var(--w10));
    pointer-events: none;
}

.point_core_card::after {
    content: "";
    position: absolute;
    inset: 0;
    border: var(--w1) solid rgba(var(--gray_f_rgb), .18);
    border-radius: inherit;
    pointer-events: none;
}

.point_core_01 {
    background:
        radial-gradient(circle at 88% 10%, rgba(var(--gray_f_rgb), .14), transparent 28%),
        linear-gradient(135deg, var(--point2_darker), var(--point));
}

.point_core_02 {
    background:
        radial-gradient(circle at 88% 10%, rgba(var(--gray_f_rgb), .12), transparent 28%),
        linear-gradient(135deg, var(--point2_darker), var(--point2), var(--point_dark));
}

.point_core_03 {
    background:
        radial-gradient(circle at 88% 10%, rgba(var(--gray_f_rgb), .12), transparent 28%),
        linear-gradient(135deg, var(--point3_darker), var(--point3), var(--point_dark));
}

.point_core_top {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap15);
}

.point_num {
    display: inline-flex;
    align-items: center;
    min-height: var(--mnh35);
    padding: 0 var(--p15);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .24);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .12);
    color: rgba(var(--gray_f_rgb), .86);
    font-size: var(--fs_14);
    font-weight: 700;
    line-height: 1;
    letter-spacing: .08em;
}

.point_core_icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--w60);
    width: var(--w60);
    height: var(--h60);
    border-radius: var(--br_15);
    background: rgba(var(--gray_f_rgb), .16);
    color: var(--gray_f);
    box-shadow: inset 0 0 0 var(--w1) rgba(var(--gray_f_rgb), .20);
}

.point_core_icon_symbol {
    display: block;
    color: inherit;
    font-size: var(--fs_34) !important;
    font-weight: normal;
    line-height: 1;
}

.point_core_card h3 {
    position: relative;
    z-index: 1;
    margin: var(--m35) 0 0;
    color: var(--gray_f);
    font-size: var(--fs_26);
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: -0.05em;
    word-break: keep-all;
}

.point_core_card p {
    position: relative;
    z-index: 1;
    margin: var(--m15) 0 0;
    color: rgba(var(--gray_f_rgb), .85);
    font-size: var(--fs_16);
    line-height: 1.65;
    word-break: keep-all;
}

/* ======================================================
   10개 장점 카드 영역
   ====================================================== */

.point_benefit_area {
    position: relative;
    margin-top: var(--m35);
    padding: var(--p30);
    border: var(--w1) solid rgba(var(--point_rgb), .10);
    border-radius: var(--br_30);
    background:
        radial-gradient(circle at 10% 0%, rgba(var(--gray_f_rgb), .80), transparent 34%),
        linear-gradient(135deg, rgba(var(--gray_f_rgb), .72), rgba(var(--point_lighter_rgb), .58));
    box-shadow: 0 var(--h25) var(--w60) rgba(var(--point2_rgb), .08);
    overflow: hidden;
}

.point_benefit_area::before {
    content: "";
    position: absolute;
    top: calc(var(--h80) * -1);
    right: calc(var(--w80) * -1);
    width: var(--w220);
    height: var(--h220);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .08);
    filter: blur(var(--w20));
    pointer-events: none;
}

.point_benefit_head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--gap25);
    padding-bottom: var(--p30);
}

.point_benefit_label {
    display: inline-flex;
    align-items: center;
    min-height: var(--mnh35);
    padding: 0 var(--p15);
    border: var(--w1) solid rgba(var(--point_rgb), .18);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .76);
    color: var(--point_dark);
    font-size: var(--fs_15);
    font-weight: 600;
    line-height: 1;
}

.point_benefit_head strong {
    max-width: var(--mxw600);
    color: var(--point2_darker);
    font-size: var(--fs_16);
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: -0.05em;
    text-align: right;
    word-break: keep-all;
}

/* 10개 카드: 원래 5열 유지 + 가독성 강화 */
.point_benefit_grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: var(--gap15);
}

.point_benefit_card {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: var(--mnh165);
    padding: var(--p25) var(--p20);
    border: var(--w1) solid rgba(var(--point2_rgb), .10);
    border-radius: var(--br_25);
    background:
        linear-gradient(180deg, rgba(var(--gray_f_rgb), .98), rgba(var(--gray_f_rgb), .90));
    box-shadow:
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .90),
        0 var(--h10) var(--w25) rgba(var(--point2_rgb), .055);
    text-align: center;
}
.point_benefit_card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: var(--h4);
    background: linear-gradient(90deg, var(--point), var(--point3));
    opacity: .55;
    pointer-events: none;
}

.point_benefit_card::after {
    content: "";
    position: absolute;
    right: calc(var(--w30) * -1);
    bottom: calc(var(--h30) * -1);
    width: var(--w85);
    height: var(--h85);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .055);
    filter: blur(var(--w10));
    pointer-events: none;
}

.point_benefit_icon {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--w45);
    width: var(--w45);
    height: var(--h45);
    margin: 0 auto;
    border-radius: var(--br_15);
    color: var(--gray_f);
    background: linear-gradient(135deg, var(--point), var(--point3));
    box-shadow: 0 var(--h10) var(--w20) rgba(var(--point_rgb), .14);
}

.point_benefit_icon_symbol {
    display: block;
    color: inherit;
    font-size: var(--fs_26) !important;
    font-weight: normal;
    line-height: 1;
}

.point_benefit_card p {
    position: relative;
    z-index: 1;
    margin: var(--m18) 0 0;
    color: var(--gray_6);
    font-size: var(--fs_15);
    font-weight: 500;
    line-height: 1.4;
    text-align: center;
    word-break: keep-all;
}

.point_benefit_card strong {
    position: relative;
    z-index: 1;
    display: block;
    margin-top: var(--m8);
    color: var(--point2_darker);
    font-size: var(--fs_20);
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.05em;
    text-align: center;
    word-break: keep-all;
}

/* 카드별 포인트 톤만 살짝 다르게 */
.point_benefit_card:nth-child(3n + 1)::before {
    background: linear-gradient(90deg, var(--point), var(--point_dark));
}

.point_benefit_card:nth-child(3n + 2)::before {
    background: linear-gradient(90deg, var(--point2), var(--point));
}

.point_benefit_card:nth-child(3n)::before {
    background: linear-gradient(90deg, var(--point3), var(--point2));
}

.point_benefit_card:nth-child(3n + 1) .point_benefit_icon {
    background: linear-gradient(135deg, var(--point), var(--point_dark));
}

.point_benefit_card:nth-child(3n + 2) .point_benefit_icon {
    background: linear-gradient(135deg, var(--point2), var(--point));
}

.point_benefit_card:nth-child(3n) .point_benefit_icon {
    background: linear-gradient(135deg, var(--point3), var(--point2));
}

.point_benefit_card:nth-child(3n + 1) strong {
    color: var(--point_dark);
}

.point_benefit_card:nth-child(3n + 2) strong {
    color: var(--point2_darker);
}

.point_benefit_card:nth-child(3n) strong {
    color: var(--point3_darker);
}

.point_benefit_card:hover {
    border-color: rgba(var(--point_rgb), .22);
    background: var(--gray_f);
    box-shadow:
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .95),
        0 var(--h16) var(--w35) rgba(var(--point2_rgb), .09);
}

/* ======================================================
   Responsive
   ====================================================== */

@media (max-width: 1199px) {
    .point_benefit_grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991px) {
    .point_core_grid {
        grid-template-columns: 1fr;
    }

    .point_benefit_head {
        align-items: flex-start;
        flex-direction: column;
    }

    .point_benefit_head strong {
        text-align: left;
    }

    .point_benefit_grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .point_core_card {
        min-height: 0;
        padding: var(--p30);
        border-radius: var(--br_25);
    }
    .point_core_card h3 {
        margin: var(--m15) 0 0;
    }

    .point_core_icon {
        flex-basis: var(--w55);
        width: var(--w55);
        height: var(--h55);
    }

    .point_benefit_area {
        padding: var(--p25);
        border-radius: var(--br_25);
    }

    .point_benefit_head {
        padding-bottom: var(--p25);
    }

    .point_benefit_grid {
        grid-template-columns: 1fr;
        gap: var(--gap15);
    }

    .point_benefit_card {
        min-height: 0;
        padding: var(--p20);
        border-radius: var(--br_20);
    }

    .point_benefit_icon {
        width: var(--w45);
        height: var(--h45);
        border-radius: var(--br_15);
    }

    .point_benefit_icon_symbol {
        font-size: var(--fs_26);
    }
}


/* ======================================================
   Calculator Section
   - 문장형 계산 UI
   ====================================================== */

.calculator_section {
    background:
        radial-gradient(circle at 86% 14%, rgba(var(--point_rgb), .06), transparent 30%),
        linear-gradient(180deg, var(--point2_lighter) 0%, var(--gray_f) 48%, var(--point2_lighter) 100%);
}

#calculator .section_body {
    padding: var(--p10);
    border-radius: calc(var(--br_30) + var(--p10));
    background: linear-gradient(135deg, var(--point), var(--point3));
    box-shadow: 0 var(--h24) var(--w70) rgba(var(--point2_rgb), .14);
}

.calc_box {
    --calc_radius_field: var(--br_8);
    --calc_btn_w: var(--w260);

    max-width: calc(1440px + var(--w40));
    margin: 0 auto;
    border-radius: var(--br_30);
    background: var(--gray_f);
    overflow: hidden;
}

/* 상단 입력 영역 */
.calc_input_area {
    position: relative;
    box-sizing: border-box;
    min-height: var(--mnh210);
    padding: var(--p64) calc(var(--calc_btn_w) + var(--w90)) var(--p42) var(--p58);
    border-bottom: var(--w1) solid var(--gray_e3);
}

/* 문장 영역 */
.calc_copy {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

/* 첫 번째 문장 */
.calc_phrase {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--gap8);
    width: 100%;
    max-width: 100%;
    margin: 0;
    color: var(--gray_2);
    font-size: var(--fs_28);
    font-weight: 500;
    line-height: 1.9;
    letter-spacing: -0.05em;
    word-break: keep-all;
    white-space: nowrap;
}

.calc_phrase_group {
    display: inline-flex !important;
    padding: .3rem;
    align-items: center;
    flex: 0 0 auto;
    width: auto;
    gap: var(--gap6);
    white-space: nowrap;
}

.calc_phrase .calc_text,
.calc_phrase .calc_unit {
    display: inline-flex !important;
    align-items: center;
    flex: 0 0 auto;
    width: auto !important;
    max-width: none;
    margin: 0;
    line-height: 1.3;
    white-space: nowrap;
    vertical-align: middle;
}

.calc_phrase .calc_inline_field {
    display: inline-flex !important;
    align-items: center;
    justify-content: flex-start;
    flex: 0 0 auto;
    width: auto;
    max-width: none;
    min-height: var(--mnh58);
    box-sizing: border-box;
    margin: 0;
    border: var(--w1) solid var(--gray_c);
    border-radius: var(--calc_radius_field);
    background: var(--gray_f);
    overflow: hidden;
    vertical-align: middle;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.calc_phrase .calc_inline_field:focus-within {
    border-color: var(--point);
    background: var(--gray_f);
    box-shadow: 0 0 0 var(--w4) rgba(var(--point_rgb), .12);
}

.calc_phrase .calc_amount_field {
    width: var(--w160) !important;
}

.calc_phrase .calc_month_field {
    width: var(--w150) !important;
}

.calc_phrase .calc_rate_field {
    width: var(--w122) !important;
}

/* common.css input 스타일 중복 제거 */
.calc_phrase .calc_inline_field input,
.calc_phrase .calc_inline_field select {
    display: block;
    width: 100%;
    min-width: 0;
    height: var(--h58);
    box-sizing: border-box;
    padding: 0 var(--p18);
    border: 0 !important;
    border-radius: 0 !important;
    outline: 0;
    background: transparent !important;
    box-shadow: none !important;
    color: var(--point);
    font-size: var(--fs_26);
    font-weight: 500;
    line-height: 1;
    margin: 0;
}

.calc_phrase .calc_inline_field select {
    cursor: pointer;
}

/* 두 번째 문장 */
.calc_question {
    margin: var(--m12) 0 0;
    color: var(--gray_2);
    font-size: var(--fs_28);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: -0.05em;
    word-break: keep-all;
}

.calc_question em {
    color: var(--point);
    font-style: normal;
    font-weight: 800;
    text-decoration: underline;
    text-underline-offset: var(--w4);
}

/* 버튼 */
.calc_submit {
    position: absolute;
    top: var(--h72);
    right: var(--w58);
    width: var(--calc_btn_w);
    height: var(--h68);
    min-height: 0;
    aspect-ratio: auto;
    padding: 0 var(--p30);
    border: 0;
    border-radius: var(--br_pill);
    color: var(--gray_f);
    background: linear-gradient(135deg, var(--point), var(--point3));
    font-size: var(--fs_18);
    font-weight: 900;
    letter-spacing: -0.03em;
    box-shadow: 0 var(--h16) var(--w36) rgba(var(--point_rgb), .28);
    cursor: pointer;
    white-space: nowrap;
    transition: transform .18s ease, box-shadow .18s ease;
}

.calc_submit:hover {
    transform: translateY(calc(var(--h2) * -1));
    box-shadow: 0 var(--h22) var(--w44) rgba(var(--point_rgb), .34);
}

/* 결과 영역 */
.calc_result {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--p46) var(--p40) var(--p58);
    text-align: center;
}

.calc_result > span {
    color: var(--gray_6);
    font-size: var(--fs_20);
    font-weight: 800;
    line-height: 1.2;
}

.calc_result strong {
    display: block;
    margin-top: var(--m14);
    color: var(--gray_2);
    font-size: var(--fs_38);
    font-weight: 900;
    line-height: 1.25;
    letter-spacing: -0.06em;
}

.calc_result strong em {
    color: var(--point3);
    font-size: var(--fs_58);
    font-style: normal;
    font-weight: 900;
    letter-spacing: -0.07em;
}

.calc_result p {
    margin: var(--m28) 0 0;
    color: var(--gray_5);
    font-size: var(--fs_16);
    font-weight: 500;
    line-height: 1.7;
    word-break: keep-all;
}

.calc_result p i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--w18);
    height: var(--h18);
    margin-right: var(--m6);
    border-radius: var(--br_pill);
    background: var(--point);
    color: var(--gray_f);
    font-size: var(--fs_12);
    font-style: normal;
    font-weight: 900;
    line-height: 1;
}

.calc_result p b {
    color: var(--point);
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: var(--w3);
}

/* Calculator Section responsive */
@media (max-width: 1199px) {
    .calc_box {
        --calc_btn_w: var(--w200);
    }

    .calc_input_area {
        padding-right: calc(var(--calc_btn_w) + var(--w60));
        padding-left: var(--p45);
    }

    .calc_phrase {
        flex-wrap: wrap;
        gap: var(--gap10) var(--gap8);
        font-size: var(--fs_24);
        white-space: normal;
    }

    .calc_phrase_group {
        width: auto;
    }

    .calc_question {
        font-size: var(--fs_24);
    }

    .calc_phrase .calc_inline_field input,
    .calc_phrase .calc_inline_field select {
        font-size: var(--fs_24);
    }
}

@media (max-width: 991px) {
    .calc_input_area {
        min-height: 0;
        padding: var(--p45) var(--p35) var(--p38);
    }

    .calc_phrase {
        justify-content: center;
    }

    .calc_submit {
        position: static;
        width: 100%;
        height: var(--h60);
        margin-top: var(--m28);
    }

    .calc_result strong {
        font-size: var(--fs_34);
    }

    .calc_result strong em {
        font-size: var(--fs_50);
    }
}

@media (max-width: 767px) {
    #calculator .section_body {
        padding: var(--p6);
        border-radius: calc(var(--br_25) + var(--p6));
    }

    .calc_box {
        border-radius: var(--br_25);
    }

    .calc_input_area {
        padding: var(--p30) var(--p20) var(--p28);
    }

    .calc_phrase {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--gap10);
        font-size: var(--fs_20);
        line-height: 1.35;
        letter-spacing: -0.04em;
        white-space: normal;
    }

    .calc_phrase_group {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        gap: var(--gap8);
        white-space: nowrap;
    }

    .calc_phrase .calc_text,
    .calc_phrase .calc_unit {
        font-size: var(--fs_18);
        line-height: 1.35;
    }

    .calc_phrase .calc_inline_field {
        height: var(--h45) !important;
        min-height: var(--h45) !important;
        border-radius: var(--br_8);
    }

    .calc_phrase .calc_amount_field {
        width: var(--w120) !important;
    }

    .calc_phrase .calc_month_field {
        width: var(--w90) !important;
    }

    .calc_phrase .calc_rate_field {
        width: var(--w90) !important;
    }

    .calc_phrase .calc_inline_field input,
    .calc_phrase .calc_inline_field select {
        height: var(--h45) !important;
        min-height: var(--h45) !important;
        padding: 0 var(--p12);
        font-size: var(--fs_18);
        line-height: 1;
        margin: 0;
    }

    .calc_question {
        margin-top: var(--m20);
        font-size: var(--fs_20);
        line-height: 1.45;
        letter-spacing: -0.04em;
        white-space: normal;
        text-align: center;
    }

    .calc_submit {
        width: 100%;
        height: var(--h54);
        margin-top: var(--m24);
        font-size: var(--fs_16);
    }

    .calc_result {
        padding: var(--p36) var(--p20) var(--p42);
    }

    .calc_result > span {
        font-size: var(--fs_17);
    }

    .calc_result strong {
        margin-top: var(--m12);
        font-size: var(--fs_26);
        line-height: 1.35;
    }

    .calc_result strong em {
        display: block;
        margin-top: var(--m6);
        font-size: var(--fs_42);
    }

    .calc_result p {
        margin-top: var(--m24);
        font-size: var(--fs_14);
        text-align: left;
    }
}


/* ======================================================
   Process Section
   ====================================================== */
.process_section {
     background:
        /* radial-gradient(circle at 15% 15%, rgba(var(--point_rgb), .08), transparent 30%),
        radial-gradient(circle at 86% 82%, rgba(var(--point4_rgb), .03), transparent 34%),
        linear-gradient(180deg, var(--point2_lighter) 0%, var(--gray_f8) 58%, rgba(var(--point3_lighter_rgb), .2) 100%); */
        rgba(var(--gray_f8_rgb), 0.5);
}

.process_list {
    position: relative;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: var(--gap36);
    margin: 0;
    padding: 0;
    list-style: none;
}

.process_item {
    position: relative;
    min-width: 0;
}
.process_item[data-animate-in] {
    transform-origin: center center;
}
.process_item::after {
    content: "";
    position: absolute;
    top: 50%;
    right: calc(var(--w24) * -1);
    width: var(--w12);
    height: var(--h12);
    border-top: var(--w2) solid rgba(var(--point_rgb), .22);
    border-right: var(--w2) solid rgba(var(--point_rgb), .22);
    transform: translateY(-50%) rotate(45deg);
    z-index: 1;
}

.process_item:last-child::after {
    display: none;
}

.process_card {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    height: 100%;
    min-height: var(--mnh240);
    padding: var(--p28);
    border: 1px solid rgba(var(--point2_rgb), .12);
    border-radius: var(--br_30);
    background: rgba(var(--gray_f_rgb), .94);
    box-shadow: 0 var(--h20) var(--w50) rgba(var(--point2_rgb), .08);
    /* transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; */
    z-index: 2;
}

.process_card:hover {
    /* transform: translateY(calc(var(--h4) * -1)); */
    border-color: rgba(var(--point_rgb), .24);
    box-shadow: 0 var(--h28) var(--w60) rgba(var(--point2_rgb), .12);
}

.process_card::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: var(--p1);
    border-radius: calc(var(--br_30) + var(--p1));
    background: linear-gradient(135deg, rgba(var(--point_rgb), .22), rgba(var(--point3_rgb), .12));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    pointer-events: none;
}

.process_top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap12);
    margin-bottom: var(--m22);
}

.process_step {
    display: inline-flex;
    align-items: center;
    min-height: var(--mnh32);
    padding: 0 var(--p12);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .08);
    color: var(--point_dark);
    font-size: var(--fs_13);
    font-weight: 900;
    letter-spacing: .04em;
    line-height: 1;
}

.process_icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--w60);
    width: var(--w60);
    height: var(--h60);
    border-radius: var(--br_15);
    background: linear-gradient(135deg, var(--point), var(--point3));
    color: var(--gray_f);
    box-shadow: 0 var(--h12) var(--w24) rgba(var(--point_rgb), .22);
}

.process_icon_symbol {
    display: block;
    color: inherit;
    font-size: var(--fs_32) !important;
    font-weight: normal;
    line-height: 1;
}

.process_card strong {
    display: block;
    margin: 0;
    color: var(--gray_1);
    font-size: var(--fs_24);
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: -0.04em;
}

.process_card p {
    margin: var(--m14) 0 0;
    color: var(--gray_5);
    font-size: var(--fs_16);
    line-height: 1.65;
    word-break: keep-all;
}

@media (max-width: 1199px) {
    .process_list {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .process_item:nth-child(3)::after {
        display: none;
    }
}

@media (max-width: 991px) {
    .process_list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .process_item::after {
        display: none;
    }

    .process_card {
        min-height: var(--mnh220);
    }
}

@media (max-width: 767px) {
    .process_list {
        grid-template-columns: 1fr;
        gap: var(--gap14);
    }

    .process_card {
        min-height: 0;
        padding: var(--p24);
        border-radius: var(--br_25);
    }

    .process_card::before {
        border-radius: calc(var(--br_25) + var(--p1));
    }

    .process_top {
        margin-bottom: var(--m18);
    }

    .process_icon {
        flex: 0 0 var(--w48);
        width: var(--w48);
        height: var(--h48);
    }

    .process_card strong {
        font-size: var(--fs_22);
    }
}

/* ======================================================
   Review Section
   ====================================================== */

.review_section {
    /* background:
        radial-gradient(circle at 85% 15%, rgba(var(--point_rgb), .08), transparent 30%),
        radial-gradient(circle at 12% 84%, rgba(var(--point3_rgb), .06), transparent 34%),
        linear-gradient(180deg, var(--gray_f) 0%, var(--gray_f8) 52%, var(--point_lighter) 100%); */
    background:
        radial-gradient(circle at 15% 15%, rgba(var(--point_rgb), .08), transparent 30%),
        radial-gradient(circle at 86% 82%, rgba(var(--point4_rgb), .03), transparent 34%),
        linear-gradient(180deg, var(--point2_lighter) 0%, var(--gray_f8) 58%, rgba(var(--point3_lighter_rgb), .2) 100%);
}


.review_grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gap25);
}

.review_card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: var(--mnh420);
    padding: var(--p10);
    border-radius:var(--br_30);
    background: linear-gradient(135deg, rgba(var(--point_rgb), .35), rgba(var(--point3_rgb), .20));
    box-shadow: 0 var(--h20) var(--w50) rgba(var(--point2_rgb), .08);
    overflow: hidden;
}

.review_card::before {
    content: "";
    position: absolute;
    top: var(--h20);
    right: var(--w20);
    width: var(--w70);
    height: var(--h70);
    border-radius: var(--br_pill);
    background: rgba(var(--gray_f_rgb), .34);
    filter: blur(var(--w20));
    pointer-events: none;
}

.review_card:nth-child(2) {
    background: linear-gradient(135deg, rgba(var(--point2_rgb), .32), rgba(var(--point_rgb), .18));
}

.review_card:nth-child(3) {
    background: linear-gradient(135deg, rgba(var(--point3_rgb), .32), rgba(var(--point_rgb), .18));
}

.review_profile {
    position: relative;
    display: flex;
    align-items: center;
    gap: var(--gap20);
    padding: var(--p20) var(--p20) 0;
    z-index: 1;
}

.review_thumb {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--w85);
    width: var(--w85);
    height: var(--h85);
    margin: 0;
    border-radius: var(--br_25);
    background:
        radial-gradient(circle at 30% 25%, rgba(var(--gray_f_rgb), .95), rgba(var(--gray_f_rgb), .35)),
        linear-gradient(135deg, rgba(var(--point_rgb), .16), rgba(var(--point3_rgb), .10));
    box-shadow: inset 0 0 0 1px rgba(var(--gray_f_rgb), .55);
    overflow: hidden;
}

.review_thumb img {
    display: block;
    width: var(--w60);
    height: var(--h60);
    object-fit: contain;
}

.review_meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 0;
}

.review_badge {
    display: inline-flex;
    align-items: center;
    min-height: var(--mnh30);
    padding: 0 var(--p15);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .08);
    border:1px solid rgba(var(--point_rgb), .25);
    color: var(--point_dark);
    font-size: var(--fs_14);
    font-weight: 700;
    line-height: 1;
}

.review_card:nth-child(2) .review_badge {
    background: rgba(var(--point2_rgb), .08);
    border:1px solid rgba(var(--point2_rgb), .25);
    color: var(--point2);
}

.review_card:nth-child(3) .review_badge {
    background: rgba(var(--point3_rgb), .10);
    border:1px solid rgba(var(--point3_rgb), .25);
    color: var(--point3_dark);
}

.review_meta strong {
    display: block;
    margin-top: var(--m10);
    color: var(--point_darker);
    font-size: var(--fs_20);
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.04em;
}

.review_card:nth-child(2) .review_meta strong {
    color: var(--point2_dark);
}

.review_card:nth-child(3) .review_meta strong {
    color: var(--point3_darker);
}

.review_meta small {
    display: block;
    margin-top: var(--m5);
    color: var(--gray_6);
    font-size: var(--fs_15);
    font-weight: 500;
    line-height: 1.3;
}

.review_content {
    position: relative;
    flex: 1;
    margin-top: var(--m25);
    padding: var(--p30);
    border-radius: var(--br_20);
    background: rgba(var(--gray_f_rgb), .96);
    z-index: 1;
}

.review_content p {
    margin: 0;
    color: var(--gray_2);
    font-size: var(--fs_17);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: -0.04em;
    word-break: keep-all;
}

@media (max-width: 991px) {
    .review_grid {
        grid-template-columns: 1fr;
    }

    .review_card {
        min-height: 0;
    }
}

@media (max-width: 767px) {
    .review_grid {
        gap: var(--gap20);
    }

    .review_card {
        padding: var(--p10);
        /* border-radius: calc(var(--br_25) + var(--p10)); */
    }

    .review_profile {
        gap: var(--gap15);
        padding: var(--p20) var(--p20) 0;
    }

    .review_thumb {
        flex-basis: var(--w75);
        width: var(--w75);
        height: var(--h75);
        /* border-radius: var(--br_20); */
    }

    .review_thumb img {
        width: var(--w50);
        height: var(--h50);
    }

    .review_meta {
        flex-direction: row;
        gap: var(--gap5);
        align-items: center;
    }

    .review_meta strong, .review_meta small{
        margin: 0 !important;
    }


    .review_content {
        margin-top: var(--m20);
        padding: var(--p25);
        border-radius: var(--br_20);
    }
}


/* ======================================================
   FAQ Section
   - 항상 펼쳐진 FAQ 카드형
   - gradient border frame
   ====================================================== */

.faq_section {
    background-color: var(--gray_f);
    background-image:
        url("../images/faq_obj.png"),
        radial-gradient(circle at 12% 18%, rgba(var(--point_rgb), .075), transparent 30%),
        radial-gradient(circle at 86% 82%, rgba(var(--point3_rgb), .055), transparent 34%),
        linear-gradient(180deg, var(--point_lighter) 0%, var(--gray_f8) 50%, var(--gray_f) 100%);
    background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
    background-position:
        left var(--w120) bottom -300px,
        12% 18%,
        86% 82%,
        center;
    background-size:
        min(40%, 510px) auto,
        cover,
        cover,
        cover;
}

@media (max-width: 767px) {
    .faq_section {
        background-position: right 20px top 50px, 12% 18%, 86% 82%, center;
        background-size: min(40%, 400px) auto, cover, cover, cover;
    }
}


.faq_wrap {
    display: grid;
    grid-template-columns: .55fr 1fr;
    gap: var(--gap50);
    align-items: start;
}

.faq_list {
    display: grid;
    gap: var(--gap18);
}

/* 그라디언트 보더용 바깥 래퍼 */
.faq_item_frame {
    padding: var(--p1);
    border-radius: calc(var(--br_30) + var(--p1));
    background: linear-gradient(135deg, var(--point), var(--point2), var(--point3));
    box-shadow: 0 var(--w10) var(--w30) rgba(var(--point2_rgb), .08);
}

.faq_item {
    position: relative;
    overflow: hidden;
    padding: var(--p30);
    border-radius: var(--br_30);
    background: rgba(var(--gray_f_rgb), 1.0);
}

/* 기존 왼쪽 라인 제거 */
.faq_item::before {
    display: none;
}

.faq_q {
    display: flex;
    align-items: flex-start;
    gap: var(--gap14);
}

.faq_q span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--w34);
    width: var(--w34);
    height: var(--h34);
    border-radius: var(--br_pill);
    color: var(--gray_f);
    background: linear-gradient(135deg, var(--point), var(--point3));
    font-size: var(--fs_16);
    font-weight: 500;
    line-height: 1;
    box-shadow: 0 var(--w8) var(--w18) rgba(var(--point_rgb), .24);
}

.faq_item_frame:nth-child(2) .faq_q span {
    background: linear-gradient(135deg, var(--point2), var(--point));
}

.faq_item_frame:nth-child(3) .faq_q span {
    background: linear-gradient(135deg, var(--point), var(--point3));
}

.faq_q h3 {
    margin: 0;
    color: var(--gray_2);
    font-size: var(--fs_22);
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: -0.04em;
}

.faq_a {
    margin-top: var(--m18);
    padding: var(--p20);
    border-radius: var(--br_20);
    background: rgba(var(--point_rgb), .045);
}

.faq_item_frame:nth-child(2) .faq_a {
    background: rgba(var(--point2_rgb), .045);
}

.faq_item_frame:nth-child(3) .faq_a {
    background: rgba(var(--point3_rgb), .055);
}

.faq_a p {
    margin: 0;
    color: var(--gray_5);
    font-size: var(--fs_16);
    line-height: 1.75;
    word-break: keep-all;
}

@media (max-width: 1199px) {
    .faq_wrap {
        grid-template-columns: 1fr;
    }
}


details { border-radius: 22px; background: var(--gray_f); border: 1px solid rgba(var(--gray_0_rgb), .07); overflow: hidden; }
summary { cursor: pointer; padding: 24px 28px; font-size: var(--fs_20); font-weight: 900; list-style: none; }
summary::-webkit-details-marker { display: none; }
details p { margin: 0; padding: 0 28px 26px; color: var(--gray_5); line-height: 1.65; }

/* ======================================================
   Notice Section
   ====================================================== */

.notice_section {
    color: var(--gray_f);
    background-color: var(--gray_1);
    background-image:
        url("../images/warning.png"),
        radial-gradient(circle at 50% 100%, rgba(var(--point4_rgb), .18), transparent 34%),
        linear-gradient(180deg, var(--point2_darker) 0%, var(--gray_1) 52%, var(--gray_0) 100%);
    background-size: contain, cover, cover;
    background-repeat: no-repeat;
    background-position: center bottom, center, center;
}

.notice_section::before {
    content: "";
    position: absolute;
    top: calc(var(--h120) * -1);
    left: 50%;
    width: var(--w420);
    height: var(--h420);
    border-radius: var(--br_pill);
    background: rgba(var(--point_rgb), .12);
    filter: blur(var(--w30));
    transform: translateX(-50%);
    pointer-events: none;
}

.notice_wrap {
    position: relative;
    z-index: 1;
    text-align: center;
}

.notice_top_img {
    display: block;
    width: var(--w300);
    max-width: 100%;
    height: auto;
    margin: 0 auto;
}

.notice_title_box {
    margin-top: var(--m40);
    margin-bottom: var(--m50);
    letter-spacing: -0.06em;
    word-break: keep-all;
}

.notice_title {
    margin: 0;
    color: var(--gray_f);
    font-size: var(--fs_50);
    font-weight: 900;
    line-height: 1.2;
}

.notice_title_marker {
    display: inline;
    color: var(--gray_f);
    background:
        linear-gradient(to top, rgba(var(--point4_rgb), .95) 35%, transparent 35%);
}

.notice_desc {
    margin: var(--m18) 0 0;
    color: rgba(var(--gray_f_rgb), .88);
    font-size: var(--fs_25);
    font-weight: 500;
    line-height: 1.45;
}

.notice_listbox {
    position: relative;
    overflow: hidden;
    width: fit-content;
    max-width: 100%;
    margin: 0 auto var(--m50);
    padding: var(--p24) var(--p35);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .30);
    border-radius: var(--br_25);
    background: rgba(var(--gray_f_rgb), .06);
    box-shadow:
        0 var(--h8) var(--w32) rgba(var(--gray_0_rgb), .16),
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .48),
        inset 0 calc(var(--h1) * -1) 0 rgba(var(--gray_f_rgb), .10);
    backdrop-filter: blur(var(--w7));
    -webkit-backdrop-filter: blur(var(--w7));
}

.notice_listbox::before {
    content: "";
    position: absolute;
    top: 0;
    left: var(--w20);
    right: var(--w20);
    height: var(--h1);
    background: linear-gradient(90deg, transparent, rgba(var(--gray_f_rgb), .80), transparent);
    pointer-events: none;
}

.notice_listbox::after {
    content: "";
    position: absolute;
    top: var(--h20);
    bottom: var(--h20);
    left: 0;
    width: var(--w1);
    background: linear-gradient(180deg, rgba(var(--gray_f_rgb), .70), transparent, rgba(var(--gray_f_rgb), .26));
    pointer-events: none;
}

.notice_list_header {
    margin: 0 0 var(--m16);
    color: var(--gray_f);
    font-size: var(--fs_22);
    font-weight: 800;
    line-height: 1.35;
}

.notice_list {
    display: grid;
    gap: var(--gap8);
    margin: 0;
    padding: 0;
    list-style: none;
}

.notice_item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--gap5);
    color: var(--gray_f);
}

.notice_item_icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--point4);
    font-size: var(--fs_22) !important;
    font-weight: normal;
    line-height: 1;

}

.notice_item_text {
    margin: 0;
    color: inherit;
    font-size: var(--fs_18);
    font-weight: 500;
    line-height: 1.6;
    word-break: keep-all;
}

.notice_point_line {
    color: var(--point4);
    font-weight: 900;
    border-bottom: var(--w2) solid var(--point4);
}

.notice_footer {
    width: 100%;
    max-width: var(--mxw1000);
    margin: 0 auto;
    color: rgba(var(--gray_f_rgb), .84);
    font-size: var(--fs_17);
    font-weight: 500;
    line-height: 1.7;
    text-align: center;
    word-break: keep-all;
}

/* Notice Section responsive */
@media (max-width: 991px) {
    .notice_title_box {
        margin-top: var(--m30);
        margin-bottom: var(--m35);
    }

    .notice_title {
        font-size: var(--fs_40);
    }

    .notice_desc {
        margin-top: var(--m15);
        font-size: var(--fs_20);
    }

    .notice_listbox {
        margin-bottom: var(--m35);
        padding: var(--p25) var(--p30);
    }

    .notice_list_header {
        font-size: var(--fs_20);
    }

    .notice_item_text {
        font-size: var(--fs_16);
    }

    .notice_footer {
        font-size: var(--fs_15);
    }
}

@media (max-width: 767px) {
    .notice_top_img {
        width: var(--w220);
    }

    .notice_title_box {
        margin-top: var(--m25);
        margin-bottom: var(--m30);
    }

    .notice_title {
        font-size: var(--fs_34);
    }

    .notice_desc {
        font-size: var(--fs_18);
        line-height: 1.55;
    }

    .notice_listbox {
        width: 100%;
        padding: var(--p22) var(--p18);
        border-radius: var(--br_20);
    }

    .notice_list {
        gap: var(--gap12);
    }

    .notice_item {
        align-items: center;
        justify-content: center;
        /* align-items: flex-start;
        justify-content: flex-start; */
        text-align: left;
    }

    .notice_item_icon {
        /* margin-top: var(--m2); */
    }

    .notice_item_text {
        font-size: var(--fs_15);
    }

    .notice_footer {
        font-size: var(--fs_14);
    }
}

.site_footer { padding: 58px 0 80px; color: var(--gray_7); background: var(--gray_0); }
.footer_wrap { display: grid; gap: 22px; }
.footer_brand strong { display: block; color: var(--gray_f); font-size: var(--fs_24); }
.footer_brand p { margin: 8px 0 0; }
.footer_links { display: flex; flex-wrap: wrap; gap: 18px; color: var(--gray_f); font-weight: 700; }
.footer_info p, .footer_warning p, .copyright { margin: 6px 0; line-height: 1.65; }
.footer_warning { padding-top: 18px; border-top: 1px solid rgba(var(--gray_f_rgb), .12); }

/* ======================================================
   Floating Aside
   ====================================================== */

.floating_aside {
    position: fixed;
    right: var(--w28);
    bottom: var(--h28);
    z-index: 1900;
    display: grid;
    justify-items: center;
    gap: var(--gap10);
}

.float_btn {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--gap4);
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: var(--br_pill);
    text-align: center;
    cursor: pointer;
    box-sizing: border-box;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}

.float_btn:hover {
    transform: translateY(calc(var(--h3) * -1));
}

/* 위 3개 버튼 공통 */
.float_main_btn {
    width: var(--w72);
    height: var(--h72);
    /* color: var(--gray_f);
    background: var(--point2);
    box-shadow: 0 var(--h16) var(--w34) rgba(var(--point2_rgb), .22); */
    color: var(--gray_f);
    border: var(--w1) solid rgba(var(--gray_f_rgb), .08);
    background: rgba(var(--point2_darker_rgb), .7);
    box-shadow:
        inset 0 var(--h1) 0 rgba(var(--gray_f_rgb), .18),
        0 var(--h12) var(--w30) rgba(var(--gray_0_rgb), .12),
        0 var(--h16) var(--w34) rgba(var(--point2_rgb), .22);
    backdrop-filter: blur(var(--w10));
    -webkit-backdrop-filter: blur(var(--w10));
    text-shadow: 1px 1px 1px rgba(var(--gray_0_rgb), .20);
}

.float_main_btn:hover {
    background: var(--point2_dark);
    box-shadow: 0 var(--h20) var(--w42) rgba(var(--point2_rgb), .26);
}

/* TOP 버튼만 작게 */
.top_btn {
    width: var(--w58);
    height: var(--h58);
    color: var(--point2_darker);
    background: rgba(var(--gray_f_rgb), .96);
    border: var(--w1) solid rgba(var(--point2_rgb), .12);
    box-shadow: 0 var(--h12) var(--w28) rgba(var(--gray_0_rgb), .14);
}

.top_btn:hover {
    color: var(--point);
    background: var(--gray_f);
    box-shadow: 0 var(--h16) var(--w34) rgba(var(--gray_0_rgb), .18);
}

.float_icon {
    display: block;
    color: inherit;
    font-size: var(--fs_28) !important;
    font-weight: normal;
    line-height: 1;
}

.float_text {
    display: block;
    color: inherit;
    font-size: var(--fs_11);
    font-weight: 500;
    line-height: 1;
    letter-spacing: .03em;
}

.top_btn .float_icon {
    font-size: var(--fs_24) !important;
}

.top_btn .float_text {
    font-size: var(--fs_10);
}

@media (max-width: 767px) {
    .floating_aside {
        right: var(--w16);
        bottom: var(--h16);
        gap: var(--gap8);
    }

    .floating_aside .float_m_hide {
        display: none !important;
    }

    .float_main_btn {
        width: var(--w60);
        height: var(--h60);
    }

    .top_btn {
        width: var(--w50);
        height: var(--h50);
    }

    .float_icon {
        font-size: var(--fs_24) !important;
    }

    .float_text {
        font-size: var(--fs_10);
    }

    .top_btn .float_icon {
        font-size: var(--fs_22) !important;
    }
}

/* ======================================================
   Footer
   ====================================================== */

.site_footer {
    padding: var(--p90) 0;
    background: var(--gray_f8);
    color: var(--gray_5);
    font-size: var(--fs_18);
    line-height: 1.4;
    letter-spacing: -0.04em;
}

.site_footer_wrap {
    display: flex;
    flex-direction: column;
    gap: var(--gap25);
}

.site_footer_top {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: var(--gap25);
}

.site_footer_brand {
    display: flex;
    align-items: center;
    min-width: var(--mnw200);
}

.site_footer_logo {
    margin: 0;
    color: var(--gray_2);
    font-size: var(--fs_23);
    font-weight: 500;
    line-height: 1.25;
}

.site_footer_company {
    /* flex: 1 1 var(--mnw600); */
    min-width: 0;
}

.site_footer_company_head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap15);
}

.site_footer_reg {
    position: relative;
    margin: 0;
    padding-left: var(--p14);
    color: var(--gray_3);
    font-size: var(--fs_18);
    font-weight: 600;
    line-height: 1.4;
}

.site_footer_reg::before {
    content: "";
    position: absolute;
    left: 0;
    top: .62em;
    width: var(--w4);
    height: var(--h4);
    border-radius: var(--br_pill);
    background: var(--point);
}

.site_footer_policy {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--gap12);
    font-size: var(--fs_17);
}

.site_footer_link {
    color: var(--point);
    font-weight: 600;
    transition: color .18s ease;
}

.site_footer_link:hover {
    color: var(--point_dark);
}

.site_footer_info {
    margin: var(--m25) 0 0;
    color: var(--gray_5);
    font-size: var(--fs_17);
    line-height: 1.7;
    word-break: keep-all;
}

.site_footer_info_item {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-right: var(--m10);
    padding-left: var(--p12);
}

.site_footer_info_item::before {
    content: "";
    position: absolute;
    left: 0;
    top: .72em;
    width: var(--w3);
    height: var(--h3);
    border-radius: var(--br_pill);
    background: currentColor;
    opacity: .45;
}

.site_footer_divider {
    width: 100%;
    height: var(--h1);
    margin: 0;
    border: 0;
    background: var(--gray_e3);
}

.site_footer_notice {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gap50);
}

.site_footer_col {
    min-width: 0;
}

.site_footer_notice_title {
    display: flex;
    align-items: center;
    gap: var(--gap8);
    margin: 0 0 var(--m25);
    color: var(--gray_2);
    font-size: var(--fs_20);
    font-weight: 600;
    line-height: 1.4;
}

.site_footer_notice_icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--point);
    font-size: var(--fs_22) !important;
    font-weight: normal;
    line-height: 1;
}

.site_footer_list {
    display: flex;
    flex-direction: column;
    gap: var(--gap8);
    margin: 0;
    padding: 0;
    list-style: none;
}

.site_footer_list + .site_footer_list {
    margin-top: var(--m25);
}

.site_footer_list_item {
    position: relative;
    margin: 0;
    padding-left: var(--p18);
    color: var(--gray_5);
    font-size: var(--fs_16);
    line-height: 1.65;
    word-break: keep-all;
}

.site_footer_list_item::before {
    position: absolute;
    left: 0;
    top: 0;
    color: currentColor;
    opacity: .7;
}

.site_footer_list_dot .site_footer_list_item::before {
    content: "·";
}

.site_footer_list_dash .site_footer_list_item::before {
    content: "-";
    transform: scale(.9);
}

.site_footer_list_point .site_footer_list_item {
    color: rgba(var(--point_rgb), .82);
}

.site_footer_list_point .site_footer_list_item {
    color: rgba(var(--point_rgb), .82);
}

.site_footer_list_dash .site_footer_list_item {
    font-weight: 700;
}
.site_footer_info_cards {
    display: flex;
    flex-direction: column;
    gap: var(--gap8);
}

.site_footer_info_card {
    display: flex;
    align-items: flex-start;
    gap: var(--gap8);
    margin: 0;
    padding: var(--p12) var(--p20);
    border: var(--w1) solid rgba(var(--point_rgb), .12);
    border-radius: var(--br_10);
    background: var(--gray_f);
    color: var(--gray_5);
    font-size: var(--fs_18);
    line-height: 1.55;
    word-break: keep-all;
}

.site_footer_info_card_label {
    flex: 0 0 auto;
    color: rgba(var(--point_rgb), .82);
    font-weight: 700;
}

.site_footer_info_card_text {
    min-width: 0;
    color: inherit;
}

.site_footer_arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(var(--gray_5_rgb), .55);
    font-size: .9em;
    font-weight: 700;
    line-height: 1;
}

.site_footer_right_list {
    margin-top: var(--m25);
}

.site_footer_marker {
    color: var(--point);
    font-weight: 700;
    box-shadow: inset 0 -.45em 0 rgba(var(--point_rgb), .12);
}

.site_footer_copy {
    margin: var(--m20) 0 0;
    color: rgba(var(--gray_5_rgb), .80);
    font-size: var(--fs_16);
    line-height: 1.4;
    text-align: right;
}

/* Footer responsive */
@media (max-width: 1199px) {
    .site_footer_notice {
        gap: var(--gap35);
    }
}

@media (max-width: 991px) {
    .site_footer {
        padding: var(--p70) 0;
    }

    .site_footer_top {
        flex-direction: column;
    }

    .site_footer_company {
        flex-basis: auto;
    }

    .site_footer_company_head {
        align-items: flex-start;
        flex-direction: column;
    }

    .site_footer_notice {
        grid-template-columns: 1fr;
        gap: var(--gap35);
    }

    .site_footer_info_card {
        font-size: var(--fs_16);
    }

    .site_footer_copy {
        text-align: left;
    }
}

@media (max-width: 767px) {
    .site_footer {
        padding: var(--p55) 0;
        font-size: var(--fs_15);
    }

    .site_footer_wrap {
        gap: var(--gap20);
    }
    .site_footer_col + .site_footer_col{
        padding-right: 5rem;
    }

    .site_footer_logo {
        font-size: var(--fs_22);
    }

    .site_footer_reg,
    .site_footer_policy,
    .site_footer_info {
        font-size: var(--fs_15);
    }

    .site_footer_notice_title {
        margin-bottom: var(--m18);
        font-size: var(--fs_18);
    }

    .site_footer_list_item {
        font-size: var(--fs_14);
        line-height: 1.6;
    }

    .site_footer_info_card {
        display: block;
        padding: var(--p12) var(--p15);
        border-radius: var(--br_10);
        font-size: var(--fs_14);
    }

    .site_footer_info_card_label {
        display: inline;
    }

    .site_footer_info_card_text {
        display: inline;
    }

    .site_footer_copy {
        font-size: var(--fs_14);
    }
}

/* ======================================================
   Site Popup
   ====================================================== */

.site_popup {
    position: fixed;
    inset: 0;
    z-index: 30000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--p20);
}

.site_popup.is_open {
    display: flex;
}

.popup_dim {
    position: absolute;
    inset: 0;
    background: rgba(var(--gray_0_rgb), .58);
    backdrop-filter: blur(var(--w8));
    -webkit-backdrop-filter: blur(var(--w8));
}

.popup_box {
    position: relative;
    width: min(680px, 100%);
    max-height: min(720px, 86vh);
    padding: var(--p35);
    border: var(--w1) solid rgba(var(--point_rgb), .08);
    border-radius: var(--br_30);
    background: var(--gray_f);
    box-shadow: 0 var(--h30) var(--w90) rgba(var(--gray_0_rgb), .28);
    box-sizing: border-box;
}

.popup_title,
.popup_box h2 {
    margin: 0 0 var(--m20);
    color: var(--point2);
    font-size: var(--fs_26);
    font-weight: 800;
    line-height: 1.35;
    letter-spacing: -0.04em;
}

.popup_scroll {
    max-height: 56vh;
    overflow-y: auto;
    padding-right: var(--p5);
    color: var(--gray_5);
    font-size: var(--fs_16);
    line-height: 1.7;
    word-break: keep-all;
}

.popup_close {
    position: absolute;
    top: calc(var(--h16) * -1);
    right: calc(var(--w16) * -1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--w42);
    height: var(--h42);
    padding: 0 0 var(--p3);
    border: 0;
    border-radius: var(--br_pill);
    color: var(--gray_f);
    background: var(--point2);
    font-size: var(--fs_28);
    font-weight: 400;
    line-height: 1;
    cursor: pointer;
    box-shadow: 0 10px 24px rgba(var(--point2_rgb), .24);
    transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.popup_close:hover {
    transform: translateY(calc(var(--h2) * -1));
    background: var(--point);
    box-shadow: 0 14px 30px rgba(var(--point_rgb), .30);
}

/* 개인정보 동의 팝업 내용 */
.privacy_popup_content {
    color: var(--gray_3);
    font-size: var(--fs_16);
    line-height: 1.75;
    word-break: keep-all;
}

.privacy_popup_text,
.privacy_popup_content p {
    margin: 0;
}

.privacy_popup_recipient {
    margin-bottom: var(--m18) !important;
    color: var(--gray_1);
    font-weight: 800;
}

.privacy_popup_subtitle {
    margin: var(--m25) 0 var(--m15);
    color: var(--point2);
    font-size: var(--fs_18);
    font-weight: 800;
    line-height: 1.4;
}

.privacy_popup_list {
    display: grid;
    gap: var(--gap10);
    margin: 0;
    padding: 0;
}

.privacy_popup_item {
    padding: var(--p15);
    border: var(--w1) solid rgba(var(--point_rgb), .10);
    border-radius: var(--br_15);
    background: var(--gray_f8);
}

.privacy_popup_term {
    margin-bottom: var(--m6);
    color: var(--gray_1);
    font-size: var(--fs_15);
    font-weight: 800;
}

.privacy_popup_desc {
    margin: 0;
    color: var(--gray_4);
    font-size: var(--fs_15);
    line-height: 1.65;
}

.privacy_popup_notice {
    margin-top: var(--m18) !important;
    color: var(--gray_5);
    font-size: var(--fs_14);
    line-height: 1.65;
}

/* Site Popup responsive */
@media (max-width: 767px) {
    .site_popup {
        padding: var(--p16);
    }

    .popup_box {
        max-height: 86vh;
        padding: var(--p28) var(--p22);
        border-radius: var(--br_25);
    }

    .popup_title,
    .popup_box h2 {
        margin-bottom: var(--m16);
        font-size: var(--fs_22);
    }

    .popup_scroll {
        max-height: 62vh;
        padding-right: 0;
        font-size: var(--fs_15);
    }

    .popup_close {
        top: calc(var(--h12) * -1);
        right: calc(var(--w12) * -1);
        width: var(--w38);
        height: var(--h38);
        padding: 0 0 var(--p2);
        font-size: var(--fs_24);
    }

    .privacy_popup_item {
        padding: var(--p14);
        border-radius: var(--br_15);
    }

    .privacy_popup_content {
        font-size: var(--fs_15);
    }

    .privacy_popup_subtitle {
        font-size: var(--fs_17);
    }

    .privacy_popup_term,
    .privacy_popup_desc {
        font-size: var(--fs_14);
    }
}