@charset "utf-8";

:root {    
    --rem: 1em;
    --container: var(--container-xl);
}

/* =======================================================
    common
======================================================= */
body { font-family: 'Pretendard', sans-serif; font-size: 1em; line-height: 1.4; letter-spacing: -0.02em; color: #191919; --swiper-theme-color: var(--primary); }

* { scrollbar-width: thin; scrollbar-color: #aaa #fff; }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: #fff; }
::-webkit-scrollbar-thumb { background: #aaa; border-radius: var(--radius-full); }

img { pointer-events: none; }
.main { margin-top: 5em; padding: 6em 0; }

/* =======================================================
    layout
======================================================= */
/* header */
.hd { top: 0; left: 0; width: 100%; z-index: var(--z-sticky); position: fixed; }
.hd small { display: block; }
.hd_wrap { position: relative; z-index: 5; border-bottom: 1px solid #ddd; transition: var(--ts-md); background-color: #fff; }
.hd_con { height: 5em; display: flex; align-items: center; }
.hd_logo a { display: block; }
.hd_logo img { max-height: 3.5em; }

.hd_gnb { font-size: 1.125em; margin: 0 auto; }
.hd_gnb_list { display: flex; justify-content: flex-start; align-items: center; gap: 3em }
.hd_gnb_item { position: relative; padding: 1em 0; }
.hd_gnb_sub { position: absolute; left: 50%; top: 100%; white-space: nowrap; transform: translateX(-50%); text-align: center; background-color: #fff; color: #a9a9a9; padding: 0.3em 0.6em; border-radius: var(--radius-md); box-shadow: var(--shadow-md); pointer-events: none; opacity: 0; transition: var(--ts-sm); }
.hd_gnb_sub a { padding: 0.5em; font-weight: 500; line-height: 1; display: block; font-size: 0.8125em; }
.hd_gnb_sub a:hover { color: var(--primary); }
.hd_gnb_item:hover .hd_gnb_sub { pointer-events: auto; opacity: 1; margin-top: -0.5em; }

.hd_gnb_btn { width: 1.5em; aspect-ratio: 1/0.75; position: relative; background-color: transparent; border: 0; margin-left: 1em; }
.hd_gnb_btn .bar { display: inline-block; width: 100%; height: 2px; background-color: currentColor; position: absolute; left: 50%; transform: translateX(-50%); -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; margin-top: -1px; transition: var(--ts-md); }
.hd_gnb_btn .bar-1 { top: 0; }
.hd_gnb_btn .bar-2 { top: 50%; width: 130%; }
.hd_gnb_btn .bar-3 { top: 100%; }
.hd_gnb_btn.is-close .bar { top: 50%; }
.hd_gnb_btn.is-close .bar-1 { transform: translateX(-50%) rotate(-45deg); }
.hd_gnb_btn.is-close .bar-2 { width: 0; margin-left: 0; }
.hd_gnb_btn.is-close .bar-3 { transform: translateX(-50%) rotate(45deg); }

.hd_search_btn i { font-size: 1.5em; }


.hd_anb_item > a { font-size: 1.125em; font-weight: 600; display: block; }
.hd_anb_sub { padding: 1em 0; font-weight: 300; }
.hd_anb_sub li { margin-bottom: 0.75em; }
.hd_anb_sub li a { opacity: 0.6; }
.hd_anb_sub li:hover a { opacity: 1; }

/* footer */
.ft { background-color: #1E1E1E; color: #fff; padding: 2em 0 3em; }
.ft_con { display: flex; flex-direction: column; gap: 0.75em; }
.ft_box { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1em; }
.ft_logo img { filter: brightness(0) invert(1) opacity(0.6); }
.ft_info { line-height: 1.5; }
.ft .divider { margin: -0.25em 0.5em 0; vertical-align: middle; }

/* floating */
.floating { position: fixed; right: 3%; bottom: 5%; display: flex; flex-direction: column; gap: 1em; z-index: 999; }
.floating a { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 6em; aspect-ratio: 1/1; border: 1px solid #eee; background-color: #fff; border-radius: var(--radius-full); line-height: 1; box-shadow: var(--shadow-sm); }
.floating a i { font-size: 2.5em; opacity: 0.8; }
.floating a span { font-size: 0.875em; margin-top: 0.5em; }
.floating a:hover { background-color: var(--primary); color: #fff; border-color: transparent; }
.floating a:hover i { opacity: 1; }

/* =======================================================
    content
======================================================= */
.sub .ctt_admin { display: none; }

.sub .page_title { text-align: center; margin-bottom: 3em; }
.sub .page_title h2 { font-size: 3em; line-height: 1.2; font-weight: 700; text-transform: uppercase; }
.sub .page_title p { font-size: 1.125em; margin-top: 0.5em; }

/* about us */
.about .page_title { text-align: left; margin-bottom: 2em; }
.about_img { -webkit-border-radius: 1.5rem;-moz-border-radius: 1.5rem;border-radius: 1.5rem; overflow: hidden; margin-bottom: 2em; }
.about_img img { width: 100%; }
.about_box { display: flex; justify-content: space-between; align-items: flex-start; gap: 3em; }
.about_tit,
.about_txt { flex: 1 1 40%; }
.about_tit h3 { font-size: 2em; font-weight: 700; }
.about_asset { width: 100%; margin-top: 2em; }
.about_txt { font-size: 1.125em; line-height: 1.6; }
.about_txt p { margin-bottom: 0.75em; }
.about_txt h5 { text-align: right; font-weight: 600; padding-top: 0.5em; }

/* history */
.history_list { background: url(../img/history_bg.png) no-repeat center/contain; }
.history_item { width: calc(50% + 1em); display: flex; align-items: flex-start; gap: 2em; position: relative; margin-bottom: 10em; }
.history_item:last-child { margin-bottom: 0; }
.history_arrow { position: absolute; top: 3em; height: 9em; }
.history_line { text-align: center; }
.history_marker { width: 2em; aspect-ratio: 1/1; background-color: rgba(var(--primary-rgb),0.12); -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; padding: 0.55em; }
.history_marker .point { background-color: var(--primary); -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; width: 100%; height: 100%; display: block; }
.history_txt h4 { font-size: 1.5em; line-height: 1.2; font-weight: 700; }
.history_item:nth-child(even) h4::after,
.history_item:nth-child(odd) h4::before { content:""; width: 0.25em; height: 0.25em; display: inline-block; background-color: var(--primary); -webkit-border-radius: 5em;-moz-border-radius: 5em;border-radius: 5em; vertical-align: middle; margin-top: -0.2em; }
.history_txt p { font-size: 1.0625em; margin-top: 0.25em; }
.history_item:nth-child(odd) { margin-left: auto; }
.history_item:nth-child(odd) h4::before { margin-right: 0.4em; }
.history_item:nth-child(odd) .history_arrow { left: 0.65em; }
.history_item:nth-child(even) { flex-direction: row-reverse; margin-right: auto; text-align: right; }
.history_item:nth-child(even) h4::after { margin-left: 0.4em; }
.history_item:nth-child(even) .history_arrow { right: 0.65em; }

/* directions */
.directions_map { width: 100%; aspect-ratio: 1/0.38; -webkit-border-radius: 1.5em;-moz-border-radius: 1.5em;border-radius: 1.5em; overflow: hidden; margin-bottom: 2em; }
.directions_map #map { width: 100%; height: 100%; }
.directions_list { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5em; }
.directions_list li { background-color: #f3f3f3; -webkit-border-radius: 1.25em;-moz-border-radius: 1.25em;border-radius: 1.25em; padding: 1.5em 2em; display: flex; justify-content: flex-start; align-items: center; gap: 1.25em; }
.directions_list img { max-width: 20%; }
.directions_list h5 { font-weight: 700; font-size: 1.125em; }
.directions_list h5::before { content:""; width: 0.35em; height: 0.35em; display: inline-block; -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; background-color: var(--primary); vertical-align: middle; margin-top: -0.2em; margin-right: 0.5em; }
.directions_list p { font-weight: 500; font-size: 1.125em; margin-top: 0.25em; }

/* balance */
.balance_txt { background-color: #f9f9f9; border-radius: 1em; padding: 2em 3.5em; }
.balance_txt h3 { font-size: 1.75em; font-weight: 700; display: flex; justify-content: flex-start; align-items: center; gap: 0.5em; }
.balance_txt h3 b { font-size: 0.75em; font-weight: 600; background-color: var(--primary); color: #fff; -webkit-border-radius: 9999px;-moz-border-radius: 9999px;border-radius: 9999px; aspect-ratio: 1/1; width: 1.75em; display: inline-flex; justify-content: center; align-items: center; }
.balance_txt p { margin-top: 1em; line-height: 1.6; }
.balance_img { display: grid; grid-template-columns: repeat(2,1fr); gap: 3em; margin: 2.5em 0; }
.balance_img img { aspect-ratio: 1/0.58; border-radius: 1em; width: 100%; }
.balance_list { margin-top: 2em; display: grid; grid-template-columns: repeat(4,1fr); gap: 2em 2em; }
.balance_list img { width: 100%; }

/* meter */
.meter_item { display: flex; align-items: center; gap: 6em; margin-bottom: 3em; }
.meter_item:last-child { margin-bottom: 0; }
.meter_item:nth-child(odd) {  }
.meter_item:nth-child(even) { flex-direction: row-reverse; }
.meter_img { width: 50%; border-radius: 1.25em; overflow: hidden; }
.meter_img img { width: 100%; }
.meter_txt h4 { font-size: 1.875em; font-weight: 700; }
.meter_txt h4::before { content:""; width: 0.3em; height: 0.3em; display: inline-block; -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; background-color: var(--primary); vertical-align: middle; margin-top: -0.2em; margin-right: 0.5em; }
.meter_txt p { font-size: 1.0625em; line-height: 1.6; margin-top: 0.75em; }
.meter_flex { margin: 4em 0; display: flex; justify-content: space-between; }
.meter_seven { width: 45%; }
.meter_seven h4 { font-size: 2em; font-weight: 700; }
.meter_seven h4 small { font-size: 0.625em; }
.meter_seven li { display: flex; justify-content: flex-start; align-items: center; background-color: rgba(var(--primary-rgb),0.03); padding: 0.5em; -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; gap: 1em; margin-top: 1em; font-size: 1.125em; }
.meter_seven span { display: inline-flex; justify-content: center; align-items: center; width: 2.5em; aspect-ratio: 1/1; background-color: #fff; -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; }
.meter_cert { width: 45%; border: 1px solid #ddd; display: flex; justify-content: center; align-items: center; }
.meter_box { background-color: #F7F7F7; padding: 1.5em; border-radius: 1.25em; text-align: center; font-size: 1.125em; }
.meter_box h5 { font-weight: 700; }
.meter_box h5 i { font-size: 1.5em; font-weight: 400; margin-right: 0.25em; vertical-align: middle; }
.meter_swiper { margin-top: 4em; padding-bottom: 1.5em !important; }
.meter_swiper img { max-width: 80%; }
.meter_swiper .swiper-slide { aspect-ratio: 1/1; display: flex; height: auto; border: 1px solid #ddd; justify-content: center; align-items: center; }
.meter_swiper .swiper-pagination-progressbar { top: auto !important; bottom: 0 !important; }

/* pipette */
.pipette_con { display: flex; justify-content: space-between; align-items: center; gap: 4em; }
.pipette_con.reverse { flex-direction: row-reverse; margin-top: 4em; }
.pipette_con .pipette_img { aspect-ratio: 1/0.7; width: 47%; overflow: hidden; -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; }
.pipette_con .pipette_img img { width: 100%; height: 100%; object-fit: cover; }
.pipette_con .pipette_txt h5 { font-size: 2.25em; font-weight: 700; }
.pipette_con .pipette_txt p { line-height: 1.6; margin-top: 1em; }
.pipette_info { margin: 3em 0; text-align: center; padding: 1.5em; -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; background-color: rgba(var(--primary-rgb),0.04); font-size: 1.125em; }
.pipette_list { display: grid; grid-template-columns: repeat(3,1fr); gap: 3em; }
.pipette_list .pipette_item { -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; overflow: hidden; background-color: #F9F9F9; }
.pipette_list .pipette_img img { width: 100%; }
.pipette_list .pipette_txt { text-align: center; padding: 1.5em; display: flex; align-items: center; justify-content: center; flex-direction: column; }
.pipette_list .pipette_txt b { font-size: 1.125em; border-bottom: 2px solid currentColor; }
.pipette_list .pipette_txt h5 { font-size: 1.25em; font-weight: 700; margin: 0.75em 0 0.5em; }
.pipette_list .pipette_txt p { font-size: 0.875em; color: #4c4c4c; }
.pipette_cert { position: relative; text-align: center; margin-top: 6em; }
.pipette_cert .pipette_img { max-width: 360px; width: 25%; }
.pipette_cert .pipette_txt { position: absolute; width: 80%; height: 70%; left: 10%; top: 5%; text-align: left; display: flex; flex-wrap: wrap; align-items: center; }
.pipette_cert .pipette_txt li { width: 50%; display: flex; align-items: center; gap: 1em; }
.pipette_cert .pipette_txt .box { background-color: #F6F6F6; max-width: 230px; border-radius: 999px; padding: 1.25em 2em; }
.pipette_cert .pipette_txt .line { flex-grow:1; height: 1px; background-color: #bbb; display: inline-block; position: relative; }
.pipette_cert .pipette_txt .line::before { content:""; width: 0.4em; height: 0.4em; background-color: #bbb; -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; display: inline-block; vertical-align: top; margin-top: -0.15em; position: absolute; }
.pipette_cert .pipette_txt h5 { font-size: 1.0625em; font-weight: 600; color: var(--primary); }
.pipette_cert .pipette_txt p { font-size: 0.9375em; line-height: 1.3; }
.pipette_cert .pipette_txt li:nth-child(odd) { padding-right: 18%; }
.pipette_cert .pipette_txt li:nth-child(even) { padding-left: 18%; flex-direction: row-reverse; }
.pipette_cert .pipette_txt li:nth-child(odd) .line::before { right: 0; }
.pipette_cert .pipette_txt li:nth-child(even) .line::before { left: 0; }

/* =======================================================
    board
======================================================= */
.tab { display: flex; justify-content: center; align-items: center; }
.tab .tab_list { display: flex; justify-content: center; background-color: #F6F6F6; border-radius: 9999px; padding: 0.5em; }

/* delivery */
.delivery .gallery .post_item { -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; overflow: hidden; border: 1px solid #ddd; }
.delivery .gallery .post_txt { margin-top: 0; padding: 1.5em 1.875em; }
.delivery .gallery .post_desc { color: #9E9E9E; margin-bottom: 0; font-size: 0.9375em; margin-top: 0.5em; }
.delivery .gallery .post_desc .ellipsis { -webkit-line-clamp: 2; }
.delivery .gallery .post_meta { display: none; }

/* inquiry */
.inquiry .tab_item:first-child { display: none; }
.inquiry .post_btns.is-user.is-list { justify-content: center; width: 100%; margin-bottom: 2.5em; }
.inquiry .post_btns.is-user.is-list .btn { font-size: 1.125em; -webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px; padding: 0.875em 1.25em; min-width: 13em; margin-right: 0; }

/* product
.product:has(#fwrite) { --container: var(--container-sm); }
.product:has(.detail_box) { --container: 720px; }
.product .frm_wrap,
.product .detail { position: relative; }
.product .frm_label { display: block; margin-bottom: 0.5em; }
.product .post_desc { display: none; }
.product .btn_add,
.product .btn_remove { position: absolute; right: 0; top: 0; padding: 0.5em 1em; font-size: 0.875em; }
.product .detail { margin-bottom: 3em; }
.product .detail_box { margin-bottom: 3em; display: flex; text-align: center; gap: 1em 2em; }
.product .detail_box h4 { font-size: 1.375em; font-weight: 800; margin-bottom: 0.5em; }
.product .detail_box p { font-size: 0.875em; line-height: 1.5; word-break: keep-all; }
.product .detail_box br { display: none;  }
.product .detail_img { width: 100%; }
.product .detail_img img { width: 100% !important; height: auto !important; margin-bottom: 0; }
.product .detail_box.type-a { flex-direction: column; align-items: center; }
.product .detail_box.type-a .detail_txt { background-color: #f5f5f5; -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; padding: 1.5em 1.25em; }
.product .detail_box.type-b { flex-direction: row; text-align: left; align-items: center; }
.product .detail_box.type-c { display: grid; grid-template-columns: repeat(2,1fr) }
.product .detail_box.type-c .detail_set { display: flex; flex-direction: column; }
.product .detail_box.type-c .detail_img { margin-bottom: 1em; }
.product .detail_box.type-c .detail_txt h4 { color: var(--primary); }
.product .detail_box.type-d { display: grid; grid-template-columns: repeat(3,1fr) }
.product .detail_box.type-d .detail_set { display: flex; flex-direction: column; }
.product .detail_box.type-d .detail_img { margin-bottom: 1em; }
.product .detail_box.type-d .detail_txt h4 { color: var(--primary); }

.editor:has(#fwrite) { --container: var(--container-sm); }
.editor .view { max-width: 658px; margin: auto; }
.editor .post_desc { display: none; }
.editor .post_content * { font-family: inherit !important; }
.editor .post_content b { font-weight: 800; }
.editor .post_content td { padding-right: 2em; }
.editor .post_content td:last-child { padding-right: 0; }
.editor .post_content img { max-width: 100%; vertical-align: top; }
*/

/* 제품 목록 */
.product_wrap { display: flex; gap: 2em; align-items: flex-start; position: relative; }

.product_filter { width: 320px; border: 1px solid #ddd; padding: 1em; border-radius: 1em; flex-shrink: 0; position: sticky; top: 6.5em; }
.product_search { width: 100%; border: 1px solid #ddd; -webkit-border-radius: 0.5em;-moz-border-radius: 0.5em;border-radius: 0.5em; display: flex; justify-content: flex-start; }
.product_search .search_input,
.product_search .search_btn { padding: 0.875em 1em; border: 0; }
.product_search .search_input { width: calc(100% - 2.875em); border-radius: 0.5em 0 0 0.5em; }
.product_search .search_btn { flex-shrink: 0; width: 2.875em; border-radius: 0 0.5em 0.5em 0; }
.product_tab .tab_item { border-bottom: 1px solid #eee; }
.product_tab .tab_item a { padding: 1.25em 1em; display: block; line-height: 1; position: relative; }
.product_tab .tab_item a::after { font-size: 1.5em; content:"\ea6e"; position: absolute; right: 0.75em; top: 50%; transform: translateY(-50%); font-family: 'remixicon' !important; }
.product_tab .tab_item:hover,
.product_tab .tab_item.is-active { color: var(--primary); }

.product_content { flex-grow: 1; }
.product_content .post_list { grid-template-columns: repeat(3,1fr); gap: 1em 1em; }
.product_content .post_thumb a { border: 1px solid #ddd; -webkit-border-radius: 1em;-moz-border-radius: 1em;border-radius: 1em; overflow: hidden; }
.product_content .post_subject { text-align: center; }
.product_content .post_desc,
.product_content .post_meta { display: none; }

/* 제품작성 */
.product:has(#fwrite) { --container: var(--container-sm); }
.product .frm_wrap, .product .detail { position: relative; }
.product .detail { margin-bottom: 3em; }
.product .btn_add, .product .btn_remove { position: absolute; right: 0; top: 0; padding: 0.5em 1em; font-size: 0.875em; }

/* 제품상세 */
.product_view { display: flex; flex-direction: row-reverse; align-items: flex-start; gap: 5%; }

.product_overview { max-width: 640px; width: 45%; flex-shrink: 0; position: sticky; top: 7em; }
.product_overview h3 { display: flex; justify-content: space-between; align-items: flex-end; }
.product_overview h3 b { font-size: 2.25em; line-height: 1.2; font-weight: 700; }
.product_overview .data_btn { font-size: 1em; font-weight: 500; color: #777; border: 1px solid #ddd; padding: 0.5em 0.875em; }
.product_overview hr { margin: 0.75em 0; background-color: #ddd; height: 1px; }
.product_overview .detail_link { display: flex; gap: 0.5em; }
.product_overview .detail_link li { flex: 1 1 20%; color: #666; }
.product_overview .detail_link .btn { border: 1px solid #ddd; border-radius: 0.5em; display: flex; padding: 0.75em; }
.product_overview .detail_link li:hover .btn { border-color: var(--primary); color: var(--primary); }
.product_overview .detail_link li.active .btn { background-color: var(--primary); border-color: var(--primary); color: #fff; }

.product_overview .detail_video { margin-top: 1em; padding-top: 56%; position: relative; }
.product_overview .detail_video iframe { width: 100%; height: 100%; position: absolute; left: 0; top: 0; }

.product_overview .data_tab { overflow-x: auto; padding: 1em 1.5em; background-color: #F9F9F9; border-radius: 1em; margin: 1em 0;}
.product_overview .data_tab ul { display: flex; gap: 2em; }
.product_overview .data_tab li { font-weight: 500; color: #A6A6A6; cursor: pointer; }
.product_overview .data_tab li.is-active { color: var(--primary); }
.product_overview .data_con { overflow-y: scroll; height: 18em; }
.product_overview .data_con li { display: none; }
.product_overview .data_con li.is-active { display: block; }
.product_overview .data_con table { font-size: 0.875em; }
.product_overview .data_con th,
.product_overview .data_con td { border: 1px solid #ddd; padding: 0.75em 1em; }
.product_overview .data_con th { width: 35%; background-color: #F9F9F9; text-align: left; }

.product_detail { flex-grow: 1; display: flex; flex-direction: column; gap: 4em; text-align: center; }
.product_detail .product_big img { width: 100%; height: auto; }
.product_detail .product_tit h3 { font-size: 1.875em; font-weight: 700; }
.product_detail .product_tit p { font-size: 0.9375em; margin-top: 0.5em; }
.product_detail .detail_box { --gap: 1.5em; }
.product_detail .detail_txt { padding: 1.5em; }
.product_detail .detail_txt h4 { font-size: 1.375em; font-weight: 700; line-height: 1.2; }
.product_detail .detail_txt p { font-size: 0.9375em; line-height: 1.5; word-break: keep-all; margin-top: 1em; }
/*.product_detail .detail_txt br { display: none; }*/
.product_detail .detail_img { width: 100%; }
.product_detail .detail_img img { width: 100% !important; height: auto !important; margin-bottom: 0; }

.product_detail .type-a .detail_txt { background-color: #F5F5F5; padding: 2em 1.5em; }
.product_detail .type-b .detail_set { display: flex; align-items: center; gap: var(--gap); }
.product_detail .type-b .detail_txt,
.product_detail .type-b .detail_img { width: 50%; }
.product_detail .type-b .detail_txt { text-align: left; }
.product_detail .type-c { display: flex; gap: var(--gap); }
.product_detail .type-c .detail_set { flex: 1 1 40%; }
.product_detail .type-c .detail_txt h4 { color: var(--primary); }
.product_detail .type-d { display: flex; }
.product_detail .type-d .detail_set { flex: 1 1 30%; border: 1px solid #ddd; }
.product_detail .type-d .detail_img { border-bottom: 1px solid #ddd; }
.product_detail .type-d h4 { color: var(--primary); }
.product_detail .type-e .detail_txt { background-color: #F5F5F5; padding: 2em 1.5em; }
.product_detail .type-f .detail_txt { background-color: #F5F5F5; padding: 2em 1.5em; }
.product_detail .type-f h4 { color: var(--primary); }
.product_detail .type-g .detail_set { display: flex; align-items: center; gap: var(--gap); flex-direction: row-reverse; }
.product_detail .type-g .detail_txt,
.product_detail .type-g .detail_img { width: 50%; }
.product_detail .type-g .detail_txt { text-align: left; }
.product_detail .type-h { display: flex; border-top: 1px solid #000; border-bottom: 1px solid #ddd; }
.product_detail .type-h .detail_set { flex: 1 1 40%; border-right: 1px solid #ddd; }
.product_detail .type-h .detail_set:last-child { border-right: 0; }
.product_detail .type-h .detail_txt { padding: 0; }
.product_detail .type-h h4 { background-color: #F5F5F5; border-bottom: 1px solid #ddd; padding: 0.75em; font-size: 1.25em; }
.product_detail .type-h p { padding: 1em; margin: 0; }

/* =======================================================
    index
======================================================= */
.hd.idx .hd_wrap { background-color: transparent; border: 0; }

.idx { padding: 0; margin-top: 0; }
.idx .more { font-size: 1.125em; }
.idx .more i { margin-left: 0.25em; background-color: #f2f2f2; font-size: 1.125em; border-radius: var(--radius-full); width: 1.5em; aspect-ratio: 1/1; display: inline-flex; justify-content: center; align-items: center; transition: var(--ts-sm); }
.idx .more:hover i { background-color: var(--primary); color: #fff; }

.idx_title { margin-bottom: 3em; position: relative; }
.idx_title h2 { font-size: 3em; font-weight: 700; line-height: 1.2; }
.idx_title p { font-size: 1.125em; font-weight: 500; margin-top: 0.5em; }
.idx_title .more { position: absolute; bottom: 0; right: 0; }

.idx_visual { background: url(/img/idx_visual_bg.png) no-repeat center/cover; }
.idx_visual .visual_con { height: calc(var(--vh)*100); display: flex; justify-content: space-between; align-items: center; }
.idx_visual .visual_txt h4 { font-size: 1.75em; font-weight: 600; text-transform: uppercase; }
.idx_visual .visual_txt h2 { font-size: 3.5em; line-height: 1.2; font-weight: 700; margin: 0.25em 0 0.5em; }
.idx_visual .visual_txt p { font-size: 1.5em; }
.idx_visual .visual_img img { width: 100%; }
.idx_visual .visual_nav { display: inline-flex; justify-content: flex-start; align-items: center; gap: 1.25em; margin-top: 3em; }
.idx_visual .visual_nav .swiper-paging { display: flex; gap: 1em; }
.idx_visual .visual_nav .swiper-page { font-weight: 700; color: #aaa; cursor: pointer; }
.idx_visual .visual_nav .swiper-page.is-active { color: #191919; }
.idx_visual .visual_nav .swiper-btn { cursor: pointer; }
.idx_visual .visual_nav .swiper-btn i { font-size: 1.375em; }
.idx_visual .visual_swiper { width: 40%; }
.idx_visual .visual_swiper .swiper-slide { height: auto; display: flex; align-items: center; justify-content: center; }

.idx_product { padding: 8em 0; overflow: hidden; position: relative; }
.idx_product .product_bg { width: 100%; position: absolute; left: 0; bottom: 5%; overflow: hidden; }
.idx_product .product_bg .swiper-wrapper { transition-timing-function: linear; }
.idx_product .product_bg .swiper-slide { width: auto; padding-right: 2em; }
.idx_product .product_bg .swiper-slide img { max-width: 100%; }

.idx_product .product_con { display: flex; gap: 2em; }
.idx_product .product_cate { width: 30%; max-width: 380px; position: relative; z-index: 5; }
.idx_product .product_cate ul { border-radius: var(--radius-xl) 0 var(--radius-xl) 0; overflow: hidden; box-shadow: 0 0 1em rgba(0,0,0,0.1); }
.idx_product .product_cate li:not(:last-child) { border-bottom: 1px solid #ddd; }
.idx_product .product_cate li a { display: flex; justify-content: space-between; align-items: center; font-size: 1.625em; padding: 1.5em 2.5em; background-color: #f4f4f4; color: #686868; cursor: pointer; }
.idx_product .product_cate li span { white-space: nowrap; }
.idx_product .product_cate li img { width: 2em; }
.idx_product .product_cate li.is-active a,
.idx_product .product_cate li a:hover { color: #fff; background-color: var(--primary); }
.idx_product .product_cate li.is-active a img,
.idx_product .product_cate li a:hover img { filter: brightness(0) invert(1); }
.idx_product .product_cate .product_more { font-size: 1.5em; border-radius: var(--radius-full); display: flex; justify-content: center; align-items: center; padding: 0.875em; margin-top: 1em; background-color: rgba(255,255,255,0.1); backdrop-filter: blur(0.3em); box-shadow: 0 0 1em rgba(0,0,0,0.1); color: #686868; }
.idx_product .product_cate .product_more:hover { color: var(--primary); }

.idx_product .product_swiper { max-width: calc(100% - 380px - 32px); padding: 1.25em; padding-bottom: 3em; }
.idx_product .product_box { border-radius: var(--radius-xl) 0 var(--radius-xl) 0; overflow: hidden; box-shadow: 0 0 1em rgba(0,0,0,0.1); background-color: #fff; padding: 2.5em; display: block; }
.idx_product .product_thumb { width: 100%; aspect-ratio: 1/1.25; }
.idx_product .product_thumb img { width: 100%; height: 100%; object-fit: contain; }
.idx_product .product_desc b { font-size: 1.125em; font-weight: 700; }
.idx_product .product_desc h5 { font-size: 1.5em; font-weight: 700; margin: 0.25em 0 0.5em; }
.idx_product .swiper-pagination {  }

.idx_cs { padding: 8em 0; text-align: center; }
.idx_cs .cs_list { display: flex; border-radius: var(--radius-lg); overflow: hidden; color: #fff; position: relative; background: url(/img/idx_cs_bg_01.png) no-repeat center/cover; }
.idx_cs .cs_list li { flex: 1 1 20%; }
.idx_cs .cs_list li::before { content:""; width: 100%; height: 100%; position: absolute; left: 0; top: 0; opacity: 0; transition: var(--ts-sm); }
.idx_cs .cs_list li:nth-child(1)::before { background: url(/img/idx_cs_bg_01.png) no-repeat center/cover; }
.idx_cs .cs_list li:nth-child(3)::before { background: url(/img/idx_cs_bg_02.png) no-repeat center/cover; }
.idx_cs .cs_list li:nth-child(5)::before { background: url(/img/idx_cs_bg_03.png) no-repeat center/cover; }
.idx_cs .cs_list li:nth-child(7)::before { background: url(/img/idx_cs_bg_04.png) no-repeat center/cover; }
.idx_cs .cs_list .divider { height: auto; margin: 1.5em 0; flex: 0 0 1px; position: relative; z-index: 3; }
.idx_cs .cs_link { height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; aspect-ratio: 1/1.3; opacity: 0.4; position: relative; z-index: 3; }
.idx_cs .cs_txt { position: relative; padding-bottom: 4.5em; margin-top: 4.5em; transition: var(--ts-sm); }
.idx_cs .cs_txt h5 { font-size: 1.75em; font-weight: 600; }
.idx_cs .cs_txt p { font-size: 1.125em; margin-top: 0.25em; }
.idx_cs .cs_icon { width: 3em; aspect-ratio: 1/1; background-color: var(--primary); color: #fff; display: inline-flex; justify-content: center; align-items:center; border-radius: var(--radius-full); pointer-events: none; transition: var(--ts-sm); position: absolute; bottom: 0; left: 50%; margin-left: -1.5em; opacity: 0; }

.idx_cs .cs_list li:hover .cs_link { opacity: 1; }
.idx_cs .cs_list li:hover .cs_txt { margin-top: 0; }
.idx_cs .cs_list li:hover .cs_icon { opacity: 1; pointer-events: auto; }
.idx_cs .cs_list li:nth-child(1):hover::before { opacity: 1; }
.idx_cs .cs_list li:nth-child(3):hover::before { opacity: 1; }
.idx_cs .cs_list li:nth-child(5):hover::before { opacity: 1; }
.idx_cs .cs_list li:nth-child(7):hover::before { opacity: 1; }

.idx_delivery { padding: 8em 0; }
.idx_delivery .delivery_box { display: block; border-radius: var(--radius-md); overflow: hidden; border: 1px solid #ddd; }
.idx_delivery .delivery_thumb { width: 100%; aspect-ratio: 1/0.9; }
.idx_delivery .delivery_thumb img { width: 100%; height: 100%; object-fit: cover; }
.idx_delivery .delivery_desc { padding: 1.5em 2em; }
.idx_delivery .delivery_desc h5 { font-size: 1.25em; font-weight: 600; }
.idx_delivery .delivery_desc p { font-size: 0.9375em; color: #999; margin-top: 0.5em; }
.idx_delivery .delivery_desc p span { -webkit-line-clamp: 2; }
.idx_delivery .swiper-scrollbar { position: static !important; margin-top: 1em; }
.idx_delivery .swiper-scrollbar-drag { background-color: var(--primary); }