@charset "utf-8";
/* 가톨릭상조 GOLD 테마 v18 — 완전 재작성 */

:root {
  --ga:#B8960C; --gab:#C9A82A; --gal:#DFC060; --gad:#8A6E00;
  --n8:#3E2810; --n9:#1E1208;
  --text-h:#2C1A08; --text-b:#4A3420; --text-m:#8A6E52; --text-l:#B09A80;
  --border:#EDE4D8; --border-m:#DDD0BE;
  --bg:#FFFEF9; --bg-s:#FBF8F2; --bg-d:#F5EFE4;
  --shadow:0 4px 24px rgba(62,40,16,.07);
  --shadow-m:0 10px 40px rgba(62,40,16,.1);
}
*,:after,:before{box-sizing:border-box}
html{overflow-y:scroll;scroll-behavior:smooth}
body{margin:0;padding:0;font-size:16px;line-height:1.75;font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--text-b);overflow-x:hidden}
html,h1,h2,h3,h4,h5,h6,form,fieldset,img{margin:0;padding:0;border:0}
h1,h2,h3,h4,h5,h6{font-family:'Noto Serif KR',serif;line-height:1.35;color:var(--text-h)}
ul,dl,dt,dd{margin:0;padding:0;list-style:none}
p{margin:0;padding:0}
hr{display:none}
a{color:var(--text-b);text-decoration:none}
input,button,select,textarea{font-family:'Noto Sans KR',sans-serif;font-size:1em}
button{cursor:pointer}
.sound_only,.is-hidden{position:absolute;clip:rect(0 0 0 0);width:1px;height:1px;overflow:hidden}
img{max-width:100%;vertical-align:middle}
legend{position:absolute;font-size:0;line-height:0;text-indent:-9999em;overflow:hidden}
#hd_pop,.hd_pops,.hd_pops_footer,#hd_login_msg,#skip_to_container{display:none!important}
#gnb_all,#gnb_all_bg,.gnb_close_btn{display:none!important}
#hd,#wrapper,#ft{min-width:0}

/* ── HEADER ── */
/* ── 헤더 공통 ── */
#hd{position:sticky;top:0;z-index:500}
#hd_h1{position:absolute;font-size:0;overflow:hidden}
body.index_body{padding-top:0!important}

/* ── PC 헤더 ── */
#hd_pc{
  display:flex;align-items:center;
  height:100px;padding:0 56px;
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow);
  gap:0;
}
body.index_body #hd_pc{
  position:absolute;top:0;left:0;width:100%;
  background:rgba(255,254,249,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(184,150,12,.15);
  box-shadow:none;
  box-sizing:border-box;
}
#hd_pc.hd_fixed{
  position:fixed!important;top:0;left:0;width:100%;
  background:rgba(255,254,249,.97)!important;
  backdrop-filter:blur(16px)!important;
  border-bottom:1px solid var(--border)!important;
  box-shadow:var(--shadow)!important;
  height:80px;
}
#hd_pc.hd_fixed .gnb_1da{height:80px}
#hd_pc.hd_fixed .gnb_2dul{top:80px}

/* ── 모바일 헤더 ── */
#hd_mo{
  display:none;
  align-items:center;
  justify-content:space-between;
  height:56px;padding:0 14px;
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow);
}
#hd_mo.hd_fixed{
  position:fixed!important;top:0;left:0;width:100%;
  background:rgba(255,254,249,.97)!important;
  border-bottom:1px solid var(--border)!important;
  box-shadow:var(--shadow)!important;
  box-sizing:border-box;z-index:500;
}
body.index_body #hd_mo{
  position:absolute;top:0;left:0;width:100%;
  background:rgba(255,254,249,.88);
  backdrop-filter:blur(16px);
  box-sizing:border-box;
}
.mo_logo{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}
.mo_logo_img{width:32px;height:32px;object-fit:contain}
.mo_logo_text{font-family:'Noto Serif KR',serif;font-size:16px;font-weight:700;color:var(--text-h)}
.mo_right{display:flex;align-items:center;gap:0;flex-shrink:0}
.mo_tel{display:flex;align-items:center;gap:6px;font-family:'Noto Serif KR',serif;font-size:13px;font-weight:700;color:var(--text-h);text-decoration:none;padding-right:12px;margin-right:10px;border-right:1px solid var(--border-m);white-space:nowrap;line-height:1}
.mo_tel i{color:var(--ga);font-size:12px}
.mo_burger{background:none;border:0;font-size:22px;color:var(--text-h);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
#logo{flex-shrink:0;margin-right:0}
#logo a{display:flex;align-items:center;gap:14px;text-decoration:none}
.logo_img{width:58px;height:58px;object-fit:contain}
.logo_main{font-family:'Noto Serif KR',serif;font-size:26px;font-weight:700;color:var(--text-h);letter-spacing:1.5px}
/* GNB */
#gnb{flex:1;background:transparent;border:0;position:static;display:flex;justify-content:center}
#gnb>h2{position:absolute;font-size:0;overflow:hidden}
#gnb_1dul{display:flex;align-items:center;height:82px;margin:0;padding:0}
.gnb_1dli{position:relative;list-style:none;height:82px;display:flex;align-items:center}
.gnb_1da{display:flex;align-items:center;height:100px;padding:0 26px;font-family:'Noto Serif KR',serif;font-size:18px;font-weight:400;color:var(--text-h);text-decoration:none;transition:color .25s;position:relative}
.gnb_1da::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:2px;background:linear-gradient(90deg,var(--gad),var(--gab));transition:left .3s,right .3s}
.gnb_1dli:hover .gnb_1da{color:var(--ga)}
.gnb_1dli:hover .gnb_1da::after{left:26px;right:26px}
.gnb_2dul{position:absolute;top:100px;left:0;background:#fff;border-top:2px solid var(--ga);min-width:180px;z-index:200;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .22s;box-shadow:var(--shadow-m)}
.gnb_1dli:hover .gnb_2dul{opacity:1;visibility:visible;transform:translateY(0)}
.gnb_2dul_box{padding:6px 0}
.gnb_2dli{list-style:none}
.gnb_2da{display:block;padding:15px 26px;font-size:15px;color:var(--text-b);border-bottom:1px solid var(--border);transition:all .2s}
.gnb_2da:hover{background:var(--bg-d);color:var(--ga);padding-left:28px}
.gnb_1dli .bg{display:none}
/* 전화번호 */
.hd_tel{display:flex;flex-direction:column;align-items:flex-end;gap:2px;margin-right:20px;flex-shrink:0}
.hd_tel_label{font-size:10px;color:var(--ga);letter-spacing:.5px;font-weight:500}
.hd_tel_num{font-family:'Noto Serif KR',serif;font-size:28px;font-weight:700;color:var(--text-h);text-decoration:none;transition:color .25s;line-height:1.1}
.hd_tel_num:hover{color:var(--ga)}
/* 우측 */
.hd_right{display:flex;align-items:center;gap:12px}
.hd_login_wrap{position:relative}
.hd_login_icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-m);color:var(--text-m);text-decoration:none;transition:all .25s;font-size:18px;cursor:pointer;background:none}
.hd_login_icon:hover,.hd_login_icon.active{border-color:var(--ga);color:var(--ga);background:var(--bg-d)}
/* 로그인/회원가입 드롭다운 */
.hd_login_drop{position:absolute;top:calc(100% + 14px);right:0;width:300px;background:#fff;border:1px solid var(--border);box-shadow:0 12px 40px rgba(62,40,16,.14);z-index:600;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .25s}
.hd_login_drop.open{opacity:1;visibility:visible;transform:translateY(0)}
.hd_drop_inner{padding:24px}
.hd_drop_title{font-family:'Noto Serif KR',serif;font-size:16px;font-weight:700;color:var(--text-h);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--ga)}
.hd_drop_input{width:100%;padding:11px 14px;border:1px solid var(--border-m);font-size:14px;color:var(--text-b);background:#fff;box-sizing:border-box;margin-bottom:10px}
.hd_drop_input:focus{border-color:var(--ga);outline:none;box-shadow:0 0 0 3px rgba(184,150,12,.1)}
.hd_drop_login_btn{width:100%;padding:12px;background:var(--ga);color:#fff;font-size:14px;font-weight:700;border:0;cursor:pointer;letter-spacing:.5px;transition:background .2s;margin-bottom:12px}
.hd_drop_login_btn:hover{background:var(--gad)}
.hd_drop_divider{display:flex;align-items:center;gap:12px;margin-bottom:12px;color:var(--text-l);font-size:12px}
.hd_drop_divider::before,.hd_drop_divider::after{content:'';flex:1;height:1px;background:var(--border)}
.hd_drop_reg_btn{display:block;width:100%;padding:11px;text-align:center;border:1px solid var(--border-m);color:var(--text-m);font-size:14px;font-weight:600;transition:all .2s;box-sizing:border-box;text-decoration:none}
.hd_drop_reg_btn:hover{border-color:var(--ga);color:var(--ga);background:var(--bg-d)}
.hd_drop_links{display:flex;justify-content:center;gap:16px;margin-top:12px}
.hd_drop_links a{font-size:12px;color:var(--text-l);text-decoration:none;transition:color .2s}
.hd_drop_links a:hover{color:var(--ga)}
/* 로그인 상태 */
.hd_drop_member{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.hd_drop_member i{font-size:32px;color:var(--ga)}
.hd_drop_member strong{display:block;font-size:15px;color:var(--text-h)}
.hd_drop_member span{font-size:12px;color:var(--text-l)}
.hd_drop_logout{display:block;width:100%;padding:11px;text-align:center;background:var(--bg-d);border:1px solid var(--border-m);color:var(--text-m);font-size:13px;text-decoration:none;box-sizing:border-box;transition:all .2s}
.hd_drop_logout:hover{border-color:var(--ga);color:var(--ga)}
.mo_tel{display:none}
.gnb_menu_btn{display:none;background:transparent;border:0;color:var(--text-h);font-size:22px;padding:4px}

/* ── 모바일 오른쪽 드로어 ── */
#moBg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000}
#moBg.on{display:block}
#moDrawer{position:fixed;top:0;right:0;width:80vw;max-width:320px;height:100%;background:#fff;z-index:1001;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px rgba(0,0,0,.15);overflow:hidden}
#moDrawer.on{transform:translateX(0)}
.mod_head{display:flex;align-items:center;justify-content:space-between;padding:0 14px;height:52px;background:var(--n8);border-bottom:2px solid var(--ga);flex-shrink:0}
.mod_logo{font-family:'Noto Serif KR',serif;font-size:14px;font-weight:700;color:var(--gab)}
.mod_close{background:none;border:0;color:rgba(255,248,238,.5);font-size:20px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.mod_close:hover{color:var(--gab)}
.mod_login{padding:14px;border-bottom:1px solid #eee;background:#fafafa;flex-shrink:0}
.mod_member{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:var(--text-h)}
.mod_member i{font-size:26px;color:var(--ga)}
.mod_member b{display:block;font-size:14px;font-weight:700}
.mod_member span{font-size:11px;color:var(--text-l)}
.mod_inputs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px}
.mod_input{width:100%;padding:8px 10px;border:1px solid #ddd;font-size:12px;color:var(--text-b);background:#fff;box-sizing:border-box}
.mod_input:focus{border-color:var(--ga);outline:none}
.mod_gold_btn{display:block;width:100%;padding:9px;text-align:center;background:var(--ga);color:#fff;font-size:13px;font-weight:700;border:0;margin-bottom:6px}
.mod_out_btn{display:block;padding:8px;text-align:center;background:#fff;color:var(--text-m);font-size:13px;border:1px solid #ddd;text-decoration:none;box-sizing:border-box}
.mod_nav{flex:1;overflow-y:auto}
.mod_item{border-bottom:1px solid #f0f0f0}
.mod_link{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;font-size:14px;font-weight:600;color:var(--text-h);text-decoration:none}
.mod_arr{font-size:11px;color:#bbb;transition:transform .2s}
.mod_item.on .mod_arr{transform:rotate(90deg)}
.mod_sub{display:none;background:#f8f8f8;border-top:1px solid #eee}
.mod_item.on .mod_sub{display:block}
.mod_sub_a{display:block;padding:9px 28px;font-size:12px;color:#666;text-decoration:none;border-bottom:1px solid #eee}
.mod_ctas{display:grid;grid-template-columns:repeat(3,1fr);flex-shrink:0;border-top:1px solid #eee}
.mod_cta{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:12px 6px;text-decoration:none;border-right:1px solid #eee;color:var(--text-m)}
.mod_cta:last-child{border-right:0}
.mod_cta i,.mod_cta svg{font-size:20px}
.mod_cta div{text-align:center}
.mod_cta div small{display:block;font-size:10px;color:#999}
.mod_cta div b{display:block;font-size:11px;font-weight:700;color:var(--text-h)}
.mod_call i{color:#4caf50}
.mod_sms i{color:#2196f3}
.mod_kakao{background:#fee500}
.mod_kakao div small{color:#5a3a00}

/* ── 왼쪽 고정 사이드패널 ── */
#sidePanel{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:800;display:flex;align-items:center}
#sidePanel.sp_closed .sp_tab{border-color:transparent;border-left-color:var(--ga);background:rgba(255,253,245,.9)}
.sp_body{width:340px;background:#FFFDF6;border:1px solid var(--border-m);border-left:none;box-shadow:8px 0 40px rgba(62,40,16,.14);overflow:hidden;transition:width .35s cubic-bezier(.4,0,.2,1),opacity .35s}
.sp_body.collapsed{width:0!important;opacity:0;border-width:0}
.sp_inner{width:340px;box-sizing:border-box;overflow-y:auto;max-height:80vh;display:flex;flex-direction:column}
/* 패널 헤더 바 */
.sp_header{background:var(--n8);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.sp_header_title{font-family:'Noto Serif KR',serif;font-size:13px;font-weight:700;color:var(--gab);letter-spacing:1px}
.sp_header_sub{font-size:10px;color:rgba(255,248,238,.4);letter-spacing:1.5px;text-transform:uppercase}
.sp_close{background:none;border:0;color:rgba(255,248,238,.4);font-size:20px;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:color .2s}
.sp_close:hover{color:var(--gab)}
/* 패널 본문 */
.sp_content{padding:20px;flex:1}
.sp_badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg-d);border:1px solid var(--border);padding:5px 14px;font-size:11px;font-weight:700;color:var(--ga);letter-spacing:1.5px;margin-bottom:16px}
.sp_title{font-family:'Noto Serif KR',serif;font-size:22px;font-weight:700;color:var(--text-h);line-height:1.4;margin-bottom:10px}
.sp_desc{font-size:14px;color:var(--text-m);line-height:1.8;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.sp_list{list-style:none;padding:0;margin:0 0 16px}
.sp_list li{font-size:14px;color:var(--text-m);padding:7px 0 7px 20px;position:relative;border-bottom:1px solid var(--border)}
.sp_list li:last-child{border-bottom:0}
.sp_list li::before{content:'✓';position:absolute;left:0;color:var(--ga);font-size:11px;font-weight:700}
/* 무상품목 */
.sp_gifts_hd{font-size:9px;font-weight:700;color:var(--text-l);letter-spacing:2px;margin-bottom:10px}
.sp_gifts{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.sp_gift{text-align:center}
.sp_gift_img{aspect-ratio:1/1;background:var(--bg-d);overflow:hidden;margin-bottom:4px;border:1px solid var(--border)}
.sp_gift_img img{width:100%;height:100%;object-fit:cover}
.sp_gift span{font-size:9px;color:var(--text-m);line-height:1.3;display:block}
/* CTA */
.sp_btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--ga);color:#fff;font-size:15px;font-weight:700;padding:16px;text-decoration:none;transition:background .2s;flex-shrink:0}
.sp_btn:hover{background:var(--gad);color:#fff}
.sp_btn i{font-size:14px}
/* 탭 */
.sp_tab{width:28px;background:#FFFDF6;border:1px solid var(--border-m);border-left:4px solid var(--ga);cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:100px;transition:background .25s;flex-shrink:0;box-shadow:3px 0 10px rgba(62,40,16,.08)}
.sp_tab:hover{background:var(--bg-d)}
.sp_tab_text{writing-mode:vertical-rl;font-size:10px;color:var(--ga);letter-spacing:2px;padding:8px 0;font-weight:700}
/* ── WRAPPER / CONTAINER ── */
#wrapper{}
#container_wr{width:1300px;max-width:100%;margin:0 auto;padding:0 48px}
#container_wr:after{display:block;clear:both;content:""}
#container{float:left;width:940px;min-height:500px;margin:44px 0;font-size:1em}
#container:after{display:block;clear:both;content:""}
#aside{float:right;width:220px;margin:44px 0 44px 32px}

/* ── 게시판 페이지 full-width (aside 없음) ── */
body.bbs_page #container { float:none;width:100% }
/* ── 서브 페이지 (page/ 폴더) ── */
body.page_procedure,
body.page_about { overflow-x:visible }
body.page_procedure #container_title,
body.page_about #container_title { display:none }
body.page_procedure #wrapper,
body.page_about #wrapper { overflow:visible }
body.page_procedure #container_wr,
body.page_about #container_wr { width:100%;max-width:100%;padding:0;overflow:visible }
body.page_procedure #container,
body.page_about #container { width:100%;float:none;min-height:0;margin:0;overflow:visible }
body.page_procedure #aside,
body.page_about #aside { display:none }
body.bbs_page #aside { display:none!important }

/* ── SECTION 공통 ── */
.section_inner{width:100%;max-width:1200px;margin:0 auto;padding:0 48px;box-sizing:border-box}
.section_label{font-size:11px;font-weight:600;color:var(--ga);letter-spacing:3px;text-transform:uppercase;margin-bottom:12px}
.section_title{font-size:38px;font-weight:700;color:var(--text-h);margin-bottom:16px;line-height:1.25}
.section_desc{font-size:15px;color:var(--text-m);line-height:1.8;max-width:520px}
.section_header{margin-bottom:52px}

/* ── INDEX HERO SLIDER ── */
#main_slider{position:relative;height:100vh;min-height:600px;overflow:hidden}
.slide_item{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.slide_item.active{opacity:1}
.slide_bg{position:absolute;inset:0;background-size:cover;background-position:center}
.slide_overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(20,10,0,.72) 0%,rgba(20,10,0,.35) 100%)}
.slide_inner{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:center;padding:0 10%;max-width:900px}
.slide_eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px;opacity:0;transform:translateY(20px);transition:all .8s .3s}
.slide_item.active .slide_eyebrow{opacity:1;transform:translateY(0)}
.slide_eyebrow_line{width:40px;height:1px;background:var(--gab)}
.slide_eyebrow_text{font-size:11px;font-weight:600;letter-spacing:3px;color:var(--gab);text-transform:uppercase}
.slide_inner h2{font-size:52px;font-weight:700;color:#FFF8EE;line-height:1.15;letter-spacing:-.5px;margin-bottom:20px;opacity:0;transform:translateY(20px);transition:all .8s .5s}
.slide_item.active .slide_inner h2{opacity:1;transform:translateY(0)}
.slide_inner p{font-size:17px;color:rgba(255,248,238,.7);line-height:1.8;margin-bottom:40px;opacity:0;transform:translateY(20px);transition:all .8s .7s}
.slide_item.active .slide_inner p{opacity:1;transform:translateY(0)}
.slide_actions{display:flex;gap:16px;opacity:0;transform:translateY(20px);transition:all .8s .9s}
.slide_item.active .slide_actions{opacity:1;transform:translateY(0)}
.btn_primary{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;background:var(--ga);color:#fff;font-weight:700;font-size:15px;letter-spacing:.3px;transition:all .25s}
.btn_primary:hover{background:var(--gad);color:#fff;transform:translateY(-2px)}
.btn_outline{display:inline-flex;align-items:center;gap:10px;padding:15px 32px;background:transparent;color:#FFF8EE;border:1px solid rgba(255,248,238,.4);font-size:15px;transition:all .25s}
.btn_outline:hover{background:rgba(255,248,238,.08);border-color:rgba(255,248,238,.7)}
.slide_prev,.slide_next{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:48px;height:48px;background:rgba(255,248,238,.12);border:1px solid rgba(255,248,238,.2);color:#FFF8EE;font-size:26px;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center}
.slide_prev{left:32px}.slide_next{right:32px}
.slide_prev:hover,.slide_next:hover{background:rgba(184,150,12,.4);border-color:var(--ga)}
.slide_dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.slide_dot{width:8px;height:8px;border-radius:50%;background:rgba(255,248,238,.3);border:0;cursor:pointer;transition:background .3s}
.slide_dot.active{background:var(--gab);width:24px;border-radius:4px}

/* ── TICKER ── */
.ticker_wrap{background:var(--n8);padding:10px 0;overflow:hidden;position:relative;z-index:1}
.ticker_inner{display:flex;animation:ticker 30s linear infinite;white-space:nowrap}
.ticker_item{font-size:12px;color:rgba(255,248,238,.5);padding:0 40px;letter-spacing:.3px}
.ticker_sep{color:var(--ga);margin-right:10px}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── TRUST STATS ── */
.trust_section{padding:80px 0;background:var(--bg)}
.trust_grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust_item{text-align:center;padding:32px 24px;border-right:1px solid var(--border)}
.trust_item:last-child{border-right:none}
.trust_num{font-family:'Noto Serif KR',serif;font-size:48px;font-weight:700;color:var(--ga);line-height:1;margin-bottom:8px}
.trust_num span{font-size:48px}
.trust_label{font-size:13px;color:var(--text-l);letter-spacing:1px}

/* ── PRODUCTS ── */
.product_section{padding:96px 0;background:var(--bg-s)}
.product_grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product_card{background:#fff;border:1px solid var(--border);transition:all .3s;position:relative}
.product_card:hover{transform:translateY(-6px);box-shadow:var(--shadow-m);border-color:var(--ga)}
.product_card_head{padding:20px 24px 16px;background:var(--n8);color:#FFF8EE}
.product_badge{display:inline-flex;font-size:10px;font-weight:700;letter-spacing:1px;padding:3px 10px;margin-bottom:10px}
.badge_basic{background:rgba(184,150,12,.3);color:var(--gab)}
.badge_standard{background:rgba(184,150,12,.5);color:#FFF8EE}
.badge_premium{background:var(--ga);color:#fff}
.badge_vip{background:var(--gab);color:var(--n9)}
.product_name{font-size:18px;font-weight:700;margin-bottom:4px;color:#FFF8EE}
.product_sub{font-size:12px;color:rgba(255,248,238,.4);margin-bottom:0}
.product_card_body{padding:24px}
.product_price{display:flex;align-items:baseline;gap:4px;margin-bottom:20px}
.product_price_num{font-family:'Noto Serif KR',serif;font-size:36px;font-weight:700;color:var(--ga)}
.product_price_unit{font-size:14px;color:var(--text-l)}
.product_price_month{font-size:12px;color:var(--text-l);margin-left:4px}
.product_features{list-style:none;padding:0;margin:0 0 24px}
.product_features li{font-size:13px;color:var(--text-m);padding:7px 0 7px 18px;position:relative;border-bottom:1px solid var(--border)}
.product_features li:last-child{border-bottom:none}
.product_features li::before{content:'·';position:absolute;left:6px;color:var(--ga);font-weight:700}
.product_features li strong{color:var(--text-b);font-weight:600}
.product_btn{display:block;text-align:center;padding:12px;border:1px solid var(--ga);color:var(--ga);font-size:13px;font-weight:600;transition:all .25s}
.product_btn:hover{background:var(--ga);color:#fff}

/* ── FAITH SECTION ── */
.faith_section{padding:100px 0;background:var(--n8)}
.faith_grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.faith_text .section_label{color:var(--gal)}
.faith_text .section_title{color:#FFF8EE;font-size:40px}
.faith_text p{font-size:15px;color:rgba(255,248,238,.6);line-height:1.9;margin-bottom:28px}
.faith_quote{border-left:3px solid var(--ga);padding:20px 24px;background:rgba(184,150,12,.08);margin-bottom:32px}
.faith_quote p{font-family:'Noto Serif KR',serif;font-style:italic;font-size:16px;color:rgba(255,248,238,.8);margin-bottom:8px}
.faith_quote cite{font-size:12px;color:var(--gal);letter-spacing:1px}
.faith_cta{display:inline-flex;align-items:center;gap:10px;color:var(--gab);font-size:13px;font-weight:600;letter-spacing:.5px;text-decoration:none;transition:gap .25s}
.faith_cta:hover{gap:16px;color:var(--gal)}
.faith_features{display:grid;grid-template-columns:1fr;gap:20px}
.faith_feature{padding:24px;background:rgba(255,253,245,.06);border:1px solid rgba(184,150,12,.15);transition:all .3s}
.faith_feature:hover{background:rgba(184,150,12,.08);border-color:rgba(184,150,12,.35)}
.faith_feature_title{font-size:15px;font-weight:700;color:#FFF8EE;margin-bottom:8px}
.faith_feature_text{font-size:13px;color:rgba(255,248,238,.5);line-height:1.7}

/* ── SERVICES ── */
.service_section{padding:96px 0;background:var(--bg)}
.service_grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.service_card{padding:36px 32px;background:#fff;border:1px solid var(--border);transition:all .3s;position:relative;overflow:hidden}
.service_card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gad),var(--gab));transform:scaleX(0);transition:transform .3s}
.service_card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.service_card:hover::before{transform:scaleX(1)}
.service_icon{width:48px;height:48px;background:var(--bg-d);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--ga);margin-bottom:20px}
.service_title{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--text-h)}
.service_text{font-size:14px;color:var(--text-m);line-height:1.8;margin-bottom:20px}
.service_link{font-size:13px;color:var(--ga);font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* ── BOARD + CONTACT ── */
.board_contact_section{padding:80px 0;background:var(--bg-s)}
/* ── latest/notice 스킨 스타일 ── */
.lat_notice{background:transparent;border:none}
.lat_notice .lat_head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding:0;background:transparent}
.lat_notice .lat_title{display:flex;align-items:center;gap:8px;margin:0;font-family:'Noto Serif KR',serif;font-size:22px;font-weight:700;color:#2C1A08}
.lat_notice .lat_title i{color:#B8960C;font-size:.9em}
.lat_notice .lat_title a{color:inherit;text-decoration:none}
.lat_notice .lat_title a:hover{color:#B8960C}
.lat_notice .lat_more_link{display:inline-flex;align-items:center;gap:3px;font-size:.8em;color:#B09A80;text-decoration:none;font-weight:500}
.lat_notice .lat_more_link:hover{color:#B8960C}
.lat_notice .lat_list{margin:0;padding:0;list-style:none}
.lat_notice .lat_item{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #DDD0BE}
.lat_notice .lat_item:first-child{border-top:1px solid #DDD0BE}
.lat_notice .lat_link{flex:1;display:flex;align-items:center;gap:8px;padding:13px 0;text-decoration:none;min-width:0;overflow:hidden}
.lat_notice .lat_link:hover .lat_subject{color:#B8960C}
.lat_notice .lat_badge_notice{flex-shrink:0;display:inline-block;padding:2px 8px;background:#B8960C;color:#fff;font-size:.7em;font-weight:700;letter-spacing:.5px;line-height:1.6}
.lat_notice .lat_badge_new{flex-shrink:0;display:inline-block;padding:1px 5px;background:#3E2810;color:#C9A82A;font-size:.68em;font-weight:700;line-height:1.6}
.lat_notice .lat_lock{flex-shrink:0;color:#B09A80;font-size:.85em}
.lat_notice .lat_subject{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:14px;color:#4A3420;transition:color .2s}
.lat_notice .lat_subject.is_notice{font-weight:700;color:#2C1A08}
.lat_notice .lat_cmt{flex-shrink:0;display:inline-block;padding:0 5px;background:#F5EFE4;color:#B8960C;font-size:.75em;font-weight:700;border:1px solid #EDE4D8}
.lat_notice .lat_date{flex-shrink:0;font-size:.8em;color:#B09A80;white-space:nowrap}
.lat_notice .lat_empty{padding:32px 0;text-align:center;font-size:14px;color:#B09A80}
.board_contact_grid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.board_title_row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;border-bottom:2px solid var(--ga);padding-bottom:12px}
.board_title_row h3{font-size:18px;font-weight:700;color:var(--text-h)}
.board_more{font-size:12px;color:var(--text-l);letter-spacing:1px}
#bo_list_wrap{min-height:180px}
.contact_title{font-size:22px;font-weight:700;color:var(--text-h);margin-bottom:24px}
.contact_form{display:flex;flex-direction:column;gap:12px}
.contact_row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact_input{padding:12px 16px;border:1px solid var(--border-m);font-size:14px;color:var(--text-b);background:#fff;width:100%;box-sizing:border-box}
.contact_input:focus{border-color:var(--ga);outline:none;box-shadow:0 0 0 3px rgba(184,150,12,.1)}
.contact_select{padding:12px 16px;border:1px solid var(--border-m);font-size:14px;color:var(--text-b);background:#fff;width:100%;box-sizing:border-box;appearance:none}
.contact_textarea{padding:12px 16px;border:1px solid var(--border-m);font-size:14px;color:var(--text-b);background:#fff;width:100%;box-sizing:border-box;resize:none;height:100px}
.contact_textarea:focus{border-color:var(--ga);outline:none}
.contact_submit{padding:14px;background:var(--n8);color:#FFF8EE;font-size:14px;font-weight:700;border:0;letter-spacing:1px;cursor:pointer;transition:background .2s}
.contact_submit:hover{background:var(--n9)}

/* ── REVIEW SECTION — 웹진 갤러리형 ── */
/* ── REVIEW SECTION ── */
.review_section{padding:96px 0;background:#1A0F05;position:relative;overflow:hidden}
.review_section::before{content:'';position:absolute;inset:0;background-image:url('../img/slide2.png');background-size:cover;background-position:center;opacity:.07}
.review_inner{position:relative;z-index:1}
.review_header{text-align:center;margin-bottom:36px}
.review_more_btn{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:.85em;color:rgba(255,248,238,.45);text-decoration:none;border:1px solid rgba(184,150,12,.3);padding:6px 16px;transition:all .2s}
.review_more_btn:hover{color:#DFC060;border-color:rgba(184,150,12,.7)}
.review_title{color:#FFF8EE!important}
.review_desc{color:rgba(255,248,238,.4)!important;margin:0 auto}

/* ── 고객후기 카드 그리드 ── */
/* PC: featured(좌 1/3) + sub-grid(우 2/3 2×2) */
.rv_grid{display:grid;grid-template-columns:1fr 2fr;gap:16px;align-items:start}
.rv_grid_sub{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:16px;height:100%}

/* 카드 공통 */
.rv_card{overflow:hidden;background:rgba(255,253,245,.05);border:1px solid rgba(184,150,12,.15);transition:all .3s;display:flex;flex-direction:column;height:100%}
.rv_card:hover{border-color:rgba(184,150,12,.5);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.rv_card_link{display:flex;flex-direction:column;flex:1;text-decoration:none;color:inherit;height:100%}

/* 이미지 */
.rv_card_img{width:100%;overflow:hidden;background:rgba(184,150,12,.08);flex-shrink:0}
.rv_card_featured .rv_card_img{height:260px}
.rv_grid_sub .rv_card_img{height:150px}
.rv_card_img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;display:block}
.rv_card:hover .rv_card_img img{transform:scale(1.04)}
.rv_card_noimg{width:100%;display:flex;align-items:center;justify-content:center;font-size:2.5em;color:rgba(184,150,12,.3)}
.rv_card_featured .rv_card_noimg{height:260px}
.rv_grid_sub .rv_card_noimg{height:150px}

/* 본문 */
.rv_card_body{padding:18px 18px 16px;display:flex;flex-direction:column;flex:1}
.rv_card_num{font-size:9px;font-weight:700;color:rgba(184,150,12,.65);letter-spacing:2px;margin-bottom:8px;display:block}
.rv_card_title{font-family:'Noto Serif KR',serif;font-size:15px;font-weight:700;color:#FFF8EE;line-height:1.45;margin-bottom:10px}
.rv_card_featured .rv_card_title{font-size:18px;margin-bottom:10px}
.rv_card_desc{font-size:13px;color:rgba(255,248,238,.45);line-height:1.65;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.rv_grid_sub .rv_card_desc{display:none}
.rv_card_divider{width:28px;height:2px;background:#B8960C;margin-bottom:0;flex-shrink:0;opacity:.65}
.rv_card_footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid rgba(184,150,12,.15);margin-top:auto}
.rv_card_stars{font-size:11px;color:#B8960C;letter-spacing:.5px}
.rv_card_meta{display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(255,248,238,.45)}
.rv_card_sep{color:rgba(255,248,238,.2)}
.rv_empty{padding:40px;text-align:center;color:rgba(255,248,238,.3)}
/* ── CTA SECTION ── */
.cta_section{padding:80px 0;background:var(--bg)}
.cta_inner{display:grid;grid-template-columns:1fr auto;align-items:center;gap:40px}
.cta_text h2{font-size:28px;font-weight:700;color:var(--text-h);margin-bottom:8px}
.cta_text p{font-size:15px;color:var(--text-m)}
.cta_btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:var(--ga);color:#fff;font-size:15px;font-weight:700;letter-spacing:.3px;white-space:nowrap;transition:all .25s}
.cta_btn:hover{background:var(--gad);color:#fff;transform:translateY(-2px)}

/* ── FOOTER ── */
#ft{background:var(--n8)}
#ft h1{position:absolute;font-size:0;overflow:hidden}
#ft_wr{max-width:1200px;margin:0 auto;padding:64px 48px 0}
.footer_brand_wrap{margin-bottom:32px}
.ft_logo_link{display:inline-flex;align-items:center;gap:14px;margin-bottom:14px;text-decoration:none}
.ft_logo_cross{font-size:22px;color:var(--gab)}
.ft_logo_main{font-family:'Noto Serif KR',serif;font-size:20px;font-weight:700;color:rgba(255,254,249,.8);letter-spacing:1px}
.footer_brand_wrap>p{font-size:13px;color:rgba(255,254,249,.32);line-height:2;margin-bottom:14px}
.footer_contact_row{display:flex;align-items:baseline;gap:16px;margin-top:8px}
.footer_phone{font-family:'Noto Serif KR',serif;font-size:28px;font-weight:700;color:var(--gab)}
.footer_hours{font-size:12px;color:rgba(255,254,249,.3)}
.footer_bottom{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 0;border-top:1px solid rgba(255,254,249,.06);gap:24px}
.footer_copy{flex:1}
.footer_bottom p{font-size:12px;color:rgba(255,254,249,.25);line-height:1.9}
.footer_links{display:flex;gap:20px;flex-shrink:0}
.footer_links a{color:rgba(255,254,249,.2);font-size:12px;text-decoration:none;transition:color .2s}
.footer_links a:hover{color:var(--gab)}

/* ── TOP BTN ── */
#top_btn{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:var(--ga);color:#fff;border:0;font-size:22px;cursor:pointer;opacity:0;transition:opacity .3s;z-index:900;display:flex;align-items:center;justify-content:center}
#top_btn.top_show{opacity:1}

/* ── 유틸 ── */
.pc_only{display:block}.mo_only{display:none}
@media(min-width:769px){.mo_only{display:none!important}}

/* ============================================================
   RESPONSIVE 1024px
   ============================================================ */
@media(max-width:1024px){
  #hd_wrapper{padding:0 24px}
  .section_inner{padding:0 24px}
  #container_wr{padding:0 24px}
  .slide_inner{padding:0 6%;max-width:100%}
  .slide_inner h2{font-size:40px}
  .product_grid{grid-template-columns:repeat(2,1fr)}
  .faith_grid{grid-template-columns:1fr;gap:48px}
  .board_contact_grid{grid-template-columns:1fr;gap:48px}
  #ft_wr{padding:48px 24px 0}
  /* 게시판: 사이드바 숨기고 전체너비 */
  body.bbs_page #container { float:none;width:100% }
/* ── 서브 페이지 (page/ 폴더) ── */
body.page_procedure,
body.page_about { overflow-x:visible }
body.page_procedure #container_title,
body.page_about #container_title { display:none }
body.page_procedure #wrapper,
body.page_about #wrapper { overflow:visible }
body.page_procedure #container_wr,
body.page_about #container_wr { width:100%;max-width:100%;padding:0;overflow:visible }
body.page_procedure #container,
body.page_about #container { width:100%;float:none;min-height:0;margin:0;overflow:visible }
body.page_procedure #aside,
body.page_about #aside { display:none }
  body.bbs_page #aside { display:none!important }
}

/* ============================================================
   RESPONSIVE 768px (모바일)
   ============================================================ */
@media(max-width:768px){
  body{font-size:14px}
  #hd,#wrapper,#ft{min-width:0!important}

  /* ── 모바일: PC헤더 숨기고 모바일헤더만 표시 ── */
  #hd_pc{display:none!important}
  #hd_mo{display:flex!important}
  .mo_tel{display:flex!important}

  /* 섹션 공통 */
  .section_inner{padding:0 16px!important}
  .section_title{font-size:26px}
  .section_header{margin-bottom:32px}

  /* 슬라이더 */
  #main_slider{height:100svh;min-height:500px}
  .slide_inner{padding:0 20px}
  .slide_inner h2{font-size:32px}
  .slide_inner p{font-size:14px;margin-bottom:28px}
  .slide_actions{flex-direction:column;gap:10px;align-items:flex-start}
  .btn_primary,.btn_outline{padding:12px 24px;font-size:14px;width:100%;justify-content:center}
  .slide_prev{left:10px}.slide_next{right:10px}

  /* 신뢰 지표 */
  .trust_section{padding:48px 0}
  .trust_grid{grid-template-columns:repeat(2,1fr)}
  .trust_num{font-size:36px}
  .trust_num span{font-size:36px}

  /* 상품 */
  .product_section{padding:64px 0}
  .product_grid{grid-template-columns:1fr;gap:16px}

  /* 신앙 */
  .faith_section{padding:64px 0}
  .faith_text .section_title{font-size:28px}

  /* 서비스 */
  .service_section{padding:64px 0}
  .service_grid{grid-template-columns:1fr;gap:20px}

  /* 게시판/문의 */
  .board_contact_section{padding:48px 0}
  .lat_notice .lat_title{font-size:18px}
  .lat_review_list{grid-template-columns:repeat(2,1fr)}
  .board_contact_grid{grid-template-columns:1fr;gap:32px}
  .contact_row{grid-template-columns:1fr}

  /* 고객후기 */
  .review_section{padding:48px 0}
  .rv_grid{grid-template-columns:1fr;gap:12px}
  .rv_card_featured .rv_card_img{height:220px}
  .rv_card_featured .rv_card_noimg{height:220px}
  .rv_card_desc{display:-webkit-box!important;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .rv_grid_sub{grid-template-columns:1fr 1fr;gap:10px}
  .rv_grid_sub .rv_card_img{height:120px}
  .rv_grid_sub .rv_card_noimg{height:120px}
  .rv_grid_sub .rv_card_body{padding:12px}
  .rv_grid_sub .rv_card_title{font-size:12px;margin-bottom:6px}
  .rv_grid_sub .rv_card_stars{font-size:10px}
  .rv_grid_sub .rv_card_meta{font-size:10px;gap:3px}

  /* CTA */
  .cta_section{padding:48px 0}
  .cta_inner{grid-template-columns:1fr;gap:24px}
  .cta_btn{width:100%;justify-content:center}

  /* 푸터 */
  #ft_wr{padding:32px 16px 0}
  .footer_bottom{flex-direction:column;gap:12px;text-align:center}
  .footer_links{justify-content:center}

  /* 사이드패널 모바일 */
  #sidePanel{top:12vh;transform:none}
  .sp_body{width:72vw;max-width:280px;height:65vh;max-height:65vh;overflow:hidden}
  .sp_body.collapsed{width:0!important;height:0!important;max-height:0!important;opacity:0;border-width:0}
  .sp_inner{width:72vw;max-width:280px;height:65vh;max-height:65vh;overflow:hidden}
  .sp_header{padding:12px 14px}
  .sp_header_title{font-size:11px}
  .sp_content{padding:12px;overflow:hidden}
  .sp_badge{font-size:8px;padding:3px 8px;margin-bottom:8px}
  .sp_title{font-size:14px;margin-bottom:6px}
  .sp_desc{font-size:10px;margin-bottom:8px;padding-bottom:8px;line-height:1.5}
  .sp_list li{font-size:10px;padding:4px 0 4px 14px}
  .sp_gifts_hd{font-size:8px}
  .sp_gifts{gap:4px;margin-bottom:8px}
  .sp_gift span{font-size:7px}
  .sp_btn{font-size:11px;padding:10px}
  .sp_tab{width:22px;min-height:50px}
  .sp_tab_text{font-size:8px;letter-spacing:1px}
  /* 리뷰 모바일 — 2열 그리드 */

  .pc_only{display:none!important}
  .mo_only{display:block!important}
}

/* ============================================================
   RESPONSIVE 480px
   ============================================================ */
@media(max-width:480px){
  .lat_review_list{grid-template-columns:1fr;gap:8px}
  .lat_review_item{display:flex}
  .lat_review_link{display:flex;width:100%}
  .lat_thumb{flex-shrink:0;width:100px;aspect-ratio:auto;height:90px}
  .lat_review_body{flex:1;padding:10px 12px}
  .slide_inner h2{font-size:26px}
  .trust_num,.trust_num span{font-size:30px}
  .section_title{font-size:22px}
  .product_card_body{padding:16px}
}
