﻿:root{
  --gnb-height: 94px;
  --top-banner-height: 50px;
  --float-gap: 44px;
  --subnav-z: 1000;
  --subnav-maxw: 746px;
  --banner-extra: 0px;
  --anchor-gap: 24px;
}
/* 임시 */
#s202603236558d61ff35a0 {display: none;}


/* =========================
   Base
========================= */
html,
body,
.doz_sys #wrap,
.doz_sys #container{
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--gnb-height) - 10px);
}

br.pc_only{
  display: block;
}

.doz_sys *{
  font-family: "Pretendard","Apple SD Gothic Neo","Malgun Gothic","Nanum Gothic","Noto Sans","sans-serif" !important;
}

.gnb-sticky-clone,
.gnb-sticky-clone *{
  font-family: "Pretendard","Apple SD Gothic Neo","Malgun Gothic","Nanum Gothic","Noto Sans","sans-serif" !important;
}

.inside{
  max-width: 1200px !important;
}

.doz_sys p{
  margin: 0;
  color: #585858;
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  letter-spacing: -0.32px;
  word-break: keep-all;
}

._text_wrap{
  overflow: hidden;
}

.bts,
.btb,
.btm,
.btl,
.fab{
  font-family: "Black Tie" !important;
}

/* =========================
   Top Banner
========================= */
.top-banner{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: var(--top-banner-height);
  padding: 8px 16px;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  background: #EEEEEE;
  z-index: 10030 !important;
}

.top-banner a{
  flex: 1;
  color: #585858;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.top-banner .close{
  flex: 0 0 auto;
  margin-left: 12px;
  display: flex;
  align-items: center;
  cursor: pointer;
}

.top-banner.is-hidden{
  display: none !important;
}

/* =========================
   Original GNB
========================= */
.doz_sys #s20260320b9bbf863ab46a{
  position: fixed !important;
  top: var(--top-banner-height);
  left: 0;
  width: 100%;
  background: #fff;
  z-index: 10020 !important;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.doz_sys #s20260320b9bbf863ab46a.gnb-origin-hidden{
  display: none !important;
  pointer-events: none !important;
}

/* =========================
   Sticky Clone GNB
========================= */
.gnb-sticky-clone{
  position: fixed !important;
  top: var(--top-banner-height) !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  display: block !important;
  background: #fff !important;
  z-index: 10025 !important;

  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;

  transition:
    opacity .22s ease,
    visibility 0s linear .22s !important;
}

.gnb-sticky-clone.is-visible{
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transition:
    opacity .22s ease !important;
}

.gnb-sticky-clone img,
.doz_sys #s20260320b9bbf863ab46a img{
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

/* =========================
   Custom GNB 내부 정렬
========================= */
.doz_sys #s20260320b9bbf863ab46a .button_wrap:not(.btn-group-justified):not(.btn-blocked),
.gnb-sticky-clone .button_wrap:not(.btn-group-justified):not(.btn-blocked),.doz_sys #w20260320a425c9f755894 .button_wrap{
  justify-content: flex-start!important;
  padding-left: 24px;
}

.doz_sys #s20260320b9bbf863ab46a .col-dz-2:nth-child(2) a,
.gnb-sticky-clone .col-dz-2:nth-child(2) a{
  padding: 13px 0 10px!important;
  font-weight: 400;
}

/* =========================
   Navigation / Common Buttons
========================= */
.doz_sys .nav li a,
.gnb-sticky-clone .nav li a{
  font-weight: 900;
  padding: 12px 0 5px;
}

.doz_sys .nav li:nth-child(4) a,
.gnb-sticky-clone .nav li:nth-child(4) a{
  padding-left: 60px;
  font-weight: 600;
  border-left: 1px solid #777;
}

.doz_sys .nav li:nth-child(5) a,
.gnb-sticky-clone .nav li:nth-child(5) a{
  margin-top: -4px;
  margin-left: 48px !important;
  padding: 8px 24px 6px;
  color: #fff !important;
  font-weight: 700;
  border-radius: 33px;
  background-image: linear-gradient(0deg,#B5CC34 0%,#83A80B 50%,#017C70 100%);
  background-position: 0% 100%;
  background-size: 100% 200%;
  transition: all .3s ease-out;
}

.doz_sys .nav li:nth-child(5) a:hover,
.gnb-sticky-clone .nav li:nth-child(5) a:hover{
  background-position: 0% 0%;
}

.doz_sys div[doz_type="text"].widget img{
  margin: 0;
}

.doz_sys a.btn,
.gnb-sticky-clone a.btn{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 9px 24px;
  font-size: 18px;
  font-weight: 700;
  line-height: 24px;
  border-radius: 50px;
}

a.btn_e0e8fd498efb0::after,
.doz_sys a.right::after,
.gnb-sticky-clone a.right::after{
  content: "";
  display: block;
  width: 28px;
  height: 28px;
  background: url("https://cdn.imweb.me/upload/S202208236d846984d8a18/380d49bfce501.png") no-repeat;
  background-size: cover;
}

.doz_sys a.btn.line,
.gnb-sticky-clone a.btn.line{
  background-color: transparent !important;
  border: 1px solid #fff !important;
  border-radius: 6px;
}

.doz_sys a.btn.line:hover,
.gnb-sticky-clone a.btn.line:hover{
  background-color: #fff !important;
  color: #000 !important;
}

.doz_sys a.btn.footer,
.gnb-sticky-clone a.btn.footer{
  margin: 24px 0;
  padding: 10px 32px;
  font-size: 14px;
  line-height: 24px;
}

.doz_sys a.btn.green,
.gnb-sticky-clone a.btn.green{
  color: #fff;
  background: linear-gradient(0deg,#017C70 0%,#83A80B 50%,#B5CC34 100%);
  background-position: 0% 0%;
  background-size: 100% 200%;
  border: none !important;
  transition: all .3s ease-out;
}

.doz_sys a.btn.green:hover,
.gnb-sticky-clone a.btn.green:hover{
  background-position: 0% 100%;
  color: #fff !important;
}

.doz_sys p.cr{
  font-size: 14px;
  line-height: 24px;
}

.modal-dialog{
  margin: 215px auto;
}

/* =========================
   Hero Common
========================= */
.hero{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  width: 1200px;
  margin: 0 auto;
}

.hero.right{
  padding-left: 782px;
}

.hero h2{
  margin: 0 0 24px !important;
  font-size: 48px;
  line-height: 56px;
  letter-spacing: -0.72px;
  font-weight: 900;
}

.hero h3{
  margin-bottom: 28px;
  font-size: 24px;
  line-height: 36px;
  font-weight: 900;
}

.hero p{
  margin-bottom: 12px !important;
  color: #fff;
  font-size: 20px;
  line-height: 36px;
}

.hero p strong,
.hero h2 strong{
  position: relative;
  color: #BFFF3F;
  font-weight: 900;
}

.hero p strong::before{
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  display: block;
  width: 100%;
  height: 12px;
  background-color: #005C53;
  z-index: -1;
}

.hero h2 strong::before{
  content: "";
  position: absolute;
  bottom: 12px;
  left: 0;
  display: block;
  width: 100%;
  height: 14px;
  background-color: #005C53;
  z-index: -1;
}

.hero .wcb{
  display: inline-flex;
  align-items: center;
  gap: 16px;
  padding: 8px 24px;
  font-size: 20px;
  line-height: 28px;
  color: #005C53;
  font-weight: 600;
  border-radius: 6px;
  background-color: rgba(255,255,255,.9);
}

.hero .wcb img{
  width: 25px;
  height: 20px;
}

.hero a.btn{
  display: inline-flex !important;
  margin: 24px 0 0;
  padding: 16px 32px !important;
  font-size: 22px;
  font-weight: 700;
}

.hero a.btn:hover{
  border: none !important;
  color: #fff !important;
}

#s2026032015e6834b254f3 .visual_section .header-content .text a.btn{
  display: inline-flex !important;
  margin: 24px 0;
  padding: 16px 32px !important;
  font-size: 22px;
  font-weight: 700;
}

#s2026032015e6834b254f3 .visual_section .header-content .text a.btn:hover{
  border: none !important;
  color: #fff !important;
}

#s202603230db86cd81003c{
  background-color: #000;
}

/* =========================
   Scroll Hero Reset
========================= */
#visual_s2026032015e6834b254f3{
  display: none !important;
}

#s2026032015e6834b254f3{
  padding: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
}

#s2026032015e6834b254f3 > .inside{
  width: 100% !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#s2026032015e6834b254f3 .doz_row,
#s2026032015e6834b254f3 [class*="col-dz"],
#s2026032015e6834b254f3 .widget,
#s2026032015e6834b254f3 .widget_data{
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* =========================
   Scroll Hero
========================= */
#hero-scroll-s2026032015e6834b254f3{
  --hero-header-offset: var(--top-banner-height);
  --hero-stage-height: calc(100vh - var(--hero-header-offset));
  --hero-max-width: 1200px;

  position: relative;
  width: 100vw;
  min-height: calc(100vh - var(--hero-header-offset));
  margin-left: calc(50% - 50vw);
  overflow: visible;

  background-color: #000;
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.48)),
    url('https://cdn.imweb.me/thumbnail/20260320/3b5aef7b88f2a.png');
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__sticky{
  position: sticky;
  top: var(--hero-header-offset);
  height: var(--hero-stage-height);
  min-height: calc(100vh - var(--hero-header-offset));
  overflow: hidden;
  background: transparent;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__viewport{
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: transparent;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide{
  --slide-y: 0%;
  --slide-o: 0;
  --slide-scale: 1.04;

  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  opacity: var(--slide-o);
  transform: translate3d(0, var(--slide-y), 0) scale(var(--slide-scale));
  transform-origin: center center;
  will-change: transform, opacity;
  pointer-events: none;
  z-index: 1;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide:first-child{
  --slide-y: 0%;
  --slide-o: 1;
  --slide-scale: 1;
  z-index: 2;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide.is-active{
  pointer-events: auto;
  z-index: 3;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__media{
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__bg{
  position: absolute;
  inset: 0;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  transform: scale(1.02);
  z-index: 0;
}

#hero-scroll-s2026032015e6834b254f3 .slide-1 .hero-vslide__bg{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.48)),
    url('https://cdn.imweb.me/thumbnail/20260320/3b5aef7b88f2a.png');
}

#hero-scroll-s2026032015e6834b254f3 .slide-2 .hero-vslide__bg{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.46)),
    url('https://cdn.imweb.me/thumbnail/20260320/9a5cce5656f19.png');
}

#hero-scroll-s2026032015e6834b254f3 .slide-3 .hero-vslide__bg{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.42)),
    url('https://cdn.imweb.me/thumbnail/20260320/989ed9353a904.png');
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__inner{
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
}

#hero-scroll-s2026032015e6834b254f3 .hero{
  width: min(var(--hero-max-width), calc(100% - 64px));
  max-width: 100%;
  min-height: 100%;
  position: relative;
  z-index: 2;
  justify-content: center;
}

#hero-scroll-s2026032015e6834b254f3 .hero.right > *{
  max-width: 418px;
}

#hero-scroll-s2026032015e6834b254f3 .hero .wcb{
  margin-bottom: 14px
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__ui{
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__progress{
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 3px;
  height: 160px;
  margin-left: -600px;
  background: rgba(255,255,255,.18);
  overflow: hidden;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__ui::before{
  content: "스크롤 해주세요";
  position: absolute;
  left: 50%;
  bottom: 108px;
  margin-left: -570px;
  display: block;
  font-size: 18px;
  font-weight: 400;
  color: rgba(255,255,255,.68);
  white-space: nowrap;
  pointer-events: none;
  animation: heroScrollFloat 2.2s ease-in-out infinite;
}

@keyframes heroScrollFloat{
  0%{
    transform: translateY(0);
    opacity: .55;
  }
  50%{
    transform: translateY(-10px);
    opacity: 1;
  }
  100%{
    transform: translateY(0);
    opacity: .55;
  }
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__progress > span{
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  transform-origin: bottom center;
  transform: scaleY(0);
  background: linear-gradient(180deg,#BFFF3F 0%, #83A80B 100%);
  border-radius: 999px;
}

/* =========================
   Scroll Hero Motion
========================= */
#hero-scroll-s2026032015e6834b254f3 .hero > *{
  opacity: 0;
  transform: translate3d(0, 28px, 0);
  filter: blur(6px);
  transition:
    opacity .9s ease,
    transform 1.1s cubic-bezier(.22,1,.36,1),
    filter .9s ease;
  will-change: transform, opacity, filter;
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide.is-entered .hero > *{
  opacity: 1;
  transform: translate3d(0, 0, 0);
  filter: blur(0);
}

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide:first-child .hero > *{
  opacity: 1;
  transform: translate3d(0, 0, 0);
  filter: blur(0);
}

#hero-scroll-s2026032015e6834b254f3 .hero > *:nth-child(1){ transition-delay: .05s; }
#hero-scroll-s2026032015e6834b254f3 .hero > *:nth-child(2){ transition-delay: .18s; }
#hero-scroll-s2026032015e6834b254f3 .hero > *:nth-child(3){ transition-delay: .31s; }
#hero-scroll-s2026032015e6834b254f3 .hero > *:nth-child(4){ transition-delay: .44s; }
#hero-scroll-s2026032015e6834b254f3 .hero > *:nth-child(5){ transition-delay: .57s; }

#hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide{
  transition: opacity .38s linear, transform .38s linear;
}

/* =========================
   Section: SSN / Process
========================= */
.doz_sys .ssn h2{
  margin: 0 0 48px;
  font-size: 32px;
  line-height: 48px;
  color: #005C53;
}

.doz_sys .ssn h2 span{
  font-weight: 500;
}

.doz_sys .ssn.cont{
  width: 1200px;
  margin: 0 auto;
}

.doz_sys ul.process{
  display: flex;
  justify-content: center;
  gap: 92px;
  margin: 0;
  padding: 0;
  text-align: center;
  list-style: none;
}

.doz_sys ul.process li{
  position: relative;
}

.doz_sys ul.process li::after{
  content: "";
  position: absolute;
  top: 99px;
  right: -80px;
  display: block;
  width: 72px;
  height: 3px;
  background-color: #83A80B;
}

.doz_sys ul.process li:last-child::after{
  content: none;
}

.doz_sys ul.process h3{
  margin: 24px 0 16px;
  font-size: 20px;
  line-height: 24px;
  color: #333;
}

.doz_sys ul.process .circle{
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 200px;
  height: 200px;
  border-radius: 100px;
  background-color: #EDF3D4;
}

.doz_sys ul.process span{
  display: flex;
  margin-top: -10px;
  margin-bottom: 40px;
  padding: 7px 14px;
  font-size: 16px;
  line-height: 18px;
  color: #005C53;
  border: 1px solid #005C53;
  background-color: #fff;
  box-shadow: 0 4px 0 0 #D8E4AB;
}

.doz_sys ul.process span strong{
  margin-left: 6px;
  font-weight: 800;
}

.doz_sys ul.process img{
  width: 80px;
  height: 80px;
}

/* =========================
   Section: ml60
========================= */
.doz_sys .ml60{
  position: relative;
  margin-top: 80px;
  margin-left: 60px;
}

.doz_sys .ml60 img{
  position: absolute;
  top: -80px;
  left: -60px;
}

.doz_sys .ml60 p{
  display: flex;
  flex-wrap: wrap;
  column-gap: 12px;
  width: 90%;
  font-size: 18px;
  line-height: 32px;
  word-break: keep-all;
}

.doz_sys .ml60 p span:nth-child(3){
  margin-right: 40%;
}

.doz_sys .ml60 p span.line::after{
  content: "|";
  padding-left: 12px;
  color: rgba(255,255,255,.4);
}

.doz_sys .ml60 span a{
  color: #fff;
  text-decoration: underline;
}

/* =========================
   Number Cards / Images
========================= */
#s202603236f4aa1cff6bb5 .widget.image>._img_box::after{
  content: "01";
  position: absolute;
  top: 32px;
  left: 32px;
  font-size: 24px;
  line-height: 24px;
  color: #005C53;
  font-weight: 900;
}

#s202603236f4aa1cff6bb5 .widget.image>div:not(._img_box){
  height: 74px;
  margin-top: 0;
  padding: 25px;
  text-align: center;
  background-color: #FFF;
}

#s202603236f4aa1cff6bb5 .widget.image>div:not(._img_box) h4{
  font-size: 20px;
  line-height: 24px;
  font-weight: 700;
}

#s202603236f4aa1cff6bb5 #w202603234db1bb69adab6 .widget.image>._img_box::after{
  content: "02";
}

#s202603236f4aa1cff6bb5 #w2026032369d3ae6850768 .widget.image>._img_box::after{
  content: "03";
}

#s202603236f4aa1cff6bb5 #w20260323d9dcc44b3428e .widget.image>._img_box::after{
  content: "04";
}

#s20250903cc12921d36b78 .text_bg_color{
  box-shadow: 0 4px 0 0 #FFF inset;
}

/* =========================
   Accordion
========================= */
.acd_row:first-child{
  border-top: 2px solid #9FC131;
}

.acd_row:last-child{
  border-bottom: 2px solid #9FC131;
}

.acd_row{
  border-bottom: 1px solid #9FC131;
}

.doz_sys #w2026032394c8e4dba9d54 .acd_heading{
  padding: 30px 20px;
}

.doz_sys #w2026032394c8e4dba9d54 .acd_collapse[aria-expanded="true"],
#w2026032394c8e4dba9d54 .acd_collapse{
  border: none !important;
}

.doz_sys #w2026032394c8e4dba9d54 .acd_body{
  margin-bottom: 32px;
  margin-left: 20px;
  padding: 0 32px;
  border-left: 18px solid #F3F7E1;
}

.doz_sys #w2026032394c8e4dba9d54 .acd_icon{
  margin-top: -18px;
}

.icon-plus:before{
  content: "";
  display: block;
  width: 36px;
  height: 36px;
  background: url('https://cdn.imweb.me/upload/S202208236d846984d8a18/89791c2b67f62.png');
  background-size: cover;
}

.icon-minus:before{
  content: "";
  display: block;
  width: 36px;
  height: 36px;
  background: url('https://cdn.imweb.me/upload/S202208236d846984d8a18/49a1bb0ed59a5.png');
  background-size: cover;
}

/* =========================
   Wbox
========================= */
.doz_sys .wbox{
  padding: 12px 28px;
  margin-right: 86px;
  background-color: rgba(255,255,255,.7);
}

.doz_sys .wbox.alt{
  margin-right: 0;
  margin-left: 50px;
  background-image: linear-gradient(
    91deg,
    rgba(153,153,153,.7) -1.5%,
    rgba(255,255,255,.2) 10.56%
  ) !important;
}

/* =========================
   Slide
========================= */
#w20260323bcdf788af8e39 .container_border .item_gallary .item_container{
  width: 1000px;
  margin: 0 auto;
}

#w20260323bcdf788af8e39 .type_slide .item_gallary .item_container{
  display: flex;
  flex-direction: row;
}

#w20260323bcdf788af8e39 .type_slide .item_gallary .item_container .img_wrap{
  flex: 1;
  height: 308px !important;
  min-height: unset !important;
}

#w20260323bcdf788af8e39 .type_slide .item_gallary .item_container .text_wrap{
  flex: 1;
}

#w20260323bcdf788af8e39 .type_slide .owl-controls .owl-next:before,
#w20260323bcdf788af8e39 .type_slide .owl-controls .owl-prev:before{
  width: 40px;
  height: 64px;
}

#w20260323bcdf788af8e39 .type_slide .owl-controls .owl-prev:before{
  content: "";
  background: url('https://cdn.imweb.me/upload/S202208236d846984d8a18/fcd5b3cf1acd1.png');
  background-size: cover;
}

#w20260323bcdf788af8e39 .type_slide .owl-controls .owl-next:before{
  content: "";
  background: url('https://cdn.imweb.me/upload/S202208236d846984d8a18/c5411f3fa9d3e.png');
  background-size: cover;
}

#w20260323bcdf788af8e39 .type_slide.owl-theme.slide_02 .owl-dots{
  bottom: -36px;
}

.doz_sys .paging_type_big_dot .owl-dots .owl-dot span{
  width: 12px !important;
  height: 12px !important;
  margin: 12px 6px !important;
}

#w20260323bcdf788af8e39 .slide_02 .item_gallary .text_wrap .title{
  font-weight: 700;
}

#w20260323bcdf788af8e39 .slide_02 .item_gallary .text_wrap .title .body{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-weight: 400;
}

#w20260323bcdf788af8e39 .slide_02 .item_gallary .text_wrap .title .body strong{
  display: inline-flex;
  margin: 16px 0 24px;
  padding: 8px 16px;
  font-size: 18px;
  color: #fff;
  border-radius: 32px;
  background-color: #9FC131;
}
  .hero h3 span {
    display: block;
    font-weight: 400;
    margin-top: 16px;
  }

/* =========================
   Floating Banner
========================= */
.float{
  position: fixed;
  top: 188px;
  right: 40px;
  width: 187px;
  height: 238px;
  z-index: 10010 !important;
  transition: top .25s ease, opacity .4s ease, transform .4s ease;
  opacity: 0;
  transform: translateY(40px);
  pointer-events: none;
}

.float.is-visible{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.float a{
  display: block;
  transition: transform .3s ease, filter .3s ease;
}

.float a:hover{
  transform: translateY(-5px);
  filter: drop-shadow(0 4px 8px rgba(0,0,0,.15));
}

.float img,
.float picture img{
  width: 100%;
  height: 100%;
}

/* =========================
   Responsive
========================= */
@media (max-width:1024px){
  :root{
    --gnb-height: 55px;
    --top-banner-height: 42px;
    --home-w: 50px;
    --home-left: 3%;
    --gap: 3%;
    --home-gap-mult: 2;
    --anchor-gap: 16px;
  }

  br.pc_only{
    display: none;
  }

  .inside{
    max-width: 100% !important;
  }

  .top-banner{
    height: var(--top-banner-height);
    font-size: 14px;
  }

  .nav_mobile{
    position: fixed;
    top: 42px;
    left: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 55px;
    padding: 0 15px;
    background: #fff;
    border-bottom: 1px solid #D9D9D9;
    z-index: 9999;
  }

  .nav_mobile h1{
    width: 125px;
    height: 30px;
    margin: 0 !important;
  }

  .nav_mobile h1 a,
  .nav_mobile a.menu{
    display: flex;
    height: 30px;
  }

  .nav_mobile h1 a img{
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
  }

  .doz_sys .nav_mobile a.donation.sm{
    display: inline-flex;
    margin-left: auto;
    margin-right: 15px;
    padding: 4px 16px;
    color: #fff;
    border-radius: 30px;
    background: linear-gradient(0deg,#017C70 -188.64%,#83A80B 2.27%,#D9E651 193.18%);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: all .3s ease-in;
  }

  .nav_mobile .gohome{
    position: absolute;
    top: 18px;
    left: 152px;
    font-size: 13px;
    color: #78A22F;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all .2s ease-out;
  }

  .nav,
  .nav h1{
    display: none;
  }

  .nav ul{
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .nav ul li{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 120px;
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #D9D9D9;
  }

  .doz_sys .nav ul li a{
    margin: 0;
    padding: 0;
    font-size: 20px;
    line-height: 1.6;
    font-weight: 600;
    color: #555555;
  }

  .doz_sys .nav ul li.bg-green{
    display: flex;
    gap: 16px;
    height: 90px;
    padding: 0 24px;
    background-color: #EDF3D4;
  }

  .doz_sys .nav ul li.bg-green a{
    flex: 1;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 8px 24px;
    font-size: 18px;
    color: #78A22F;
    border: 1px solid #83A80B;
    border-radius: 33px;
    background-color: #fff;
  }

  .doz_sys .nav ul li.bg-green a.donation{
    color: #fff;
    border: 0;
    background: linear-gradient(0deg,#017C70 -188.64%,#83A80B 2.27%,#D9E651 193.18%);
  }

  .menu .icon-close{
    display: none;
  }

  .doz_sys .nav li:nth-child(4) a{
    padding-left: 0;
    font-weight: 600;
    border-left: 0;
  }

  .nav_mskim{
    position: absolute;
    top: 55px;
    display: flex;
    width: 100%;
    border-bottom: 1px solid #D9D9D9;
    z-index: 9997;
  }

  .nav_mskim a{
    position: relative;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 42px;
    font-size: 14px;
    background-color: #F5F5F5;
    border-right: 1px solid #D9D9D9;
  }

  .nav_mskim a:last-child{
    color: #78A22F;
    font-weight: bold;
    border-right: 0;
  }
  .doz_sys .ssn.cont {
    width:100%;
  }
  #sf-wrap .sf-list,
  #sf-wrap {width:100%;}
  .doz_sys h2{
    margin: 80px 0 12px;
    line-height: 1.2;
  }

  .doz_sys h3{
    margin: 24px 0 12px;
    font-size: 20px;
    line-height: 1.4;
    word-break: keep-all;
  }

  .doz_sys p{
    font-size: 14px;
    line-height: 20px;
  }

  .doz_sys a.btn{
    padding: 8px 24px;
    font-size: 16px;
    line-height: 24px;
  }

  .doz_sys .ml60{
    width: 100%;
    margin-top: 58px;
    margin-left: 38px;
  }

  .doz_sys .ml60 img{
    top: -58px;
    left: -38px;
    width: 160px;
  }

  .doz_sys .ml60 p span.line:first-child{
    margin-right: 30%;
  }

  .doz_sys .ml60 p span.line:first-child:after{
    content: none;
  }

  .doz_sys .ml60 p span:nth-child(3){
    margin-right: 20px;
  }

  .doz_sys .ml60 p:nth-child(2){
    font-size: 14px;
    line-height: 28px;
  }

  .doz_sys .ml60 p.cr{
    font-size: 13px;
  }

  .modal{
    top: 100px;
  }

  .hero{
    width: calc(100% - 40px);
  }

  .hero.right{
    padding-left: 0;
    align-items: flex-start;
  }

  .hero.right > *{
    max-width: 100%;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero{
    width: calc(100% - 40px);
    justify-content: flex-end;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero.right > *{
    max-width: 100%;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__progress{
    left: 18px;
    bottom: 0;
    height: 120px;
    margin-left: 0;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__ui::before{
    left: 36px;
    bottom: 132px;
    margin-left: 0;
    font-size: 14px;
  }
}

@media (max-width:767px){
  #s2026033144e2b2ae323b5 {display: none;}
  :root{
    --gnb-height: 64px;
  }

  .doz_sys #s20260320b9bbf863ab46a,
  .gnb-sticky-clone{
    display: none !important;
  }

  .float{
    top: auto !important;
    bottom: 10px;
    left: 50%;
    right: auto;
    transform: translateX(-50%) translateY(40px);
    width: 90%;
    height: auto;
    transition: opacity .4s ease, transform .4s ease;
  }
  .float.is-visible{
    transform: translateX(-50%) translateY(0);
  }
  .float picture,
  .float picture img{
    width: 100%;
    height: auto;
  }
  .floating{
    position: fixed;
    top: 136px;
    right: 50%;
    z-index: 999;
    margin-right: -860px;
    width: 90%;
  }

  .floating a img{
    transform: translateY(0);
    transition: all ease-out .4s;
  }

  #hero-scroll-s2026032015e6834b254f3 .slide-1 .hero-vslide__bg{
    background-position: center center;
    background-image:
      url('https://cdn.imweb.me/upload/S202208236d846984d8a18/97bcd42479194.png');
  }
  #hero-scroll-s2026032015e6834b254f3 .slide-2 .hero-vslide__bg{
    background-position: center center;
    background-image:
      url('https://cdn.imweb.me/upload/S202208236d846984d8a18/2bdb523815369.png');
  }
  #hero-scroll-s2026032015e6834b254f3 .slide-3 .hero-vslide__bg{
    background-position: center center;
    background-image:
      url('https://cdn.imweb.me/upload/S202208236d846984d8a18/df13678235e38.png');
  }
  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide.is-entered .hero .btn.green.big{
    display: none !important;
  }

  /* 모바일: sticky scroll 해제 → 슬라이드 세로 나열 */
  #hero-scroll-s2026032015e6834b254f3{
    height: auto !important;
    min-height: 0 !important;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__sticky{
    position: relative !important;
    top: 0 !important;
    height: auto !important;
    min-height: 0 !important;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__viewport{
    height: auto !important;
    overflow: visible !important;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide{
    align-items: flex-end;
    position: relative !important;
    inset: auto !important;
    min-height: 0 !important;
    aspect-ratio: 201 / 180 !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
  }
  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__slide.slide-1 {
    aspect-ratio: 201 / 220 !important;
  }
  #hero-scroll-s2026032015e6834b254f3 .hero{
    width: calc(100% - 64px);
  }
  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__inner{
    padding-bottom: 36px;
  }

  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__progress,
  #hero-scroll-s2026032015e6834b254f3 .hero-vslide__ui::before{
    display: none;
  }

  .hero h2{
    font-size: 22px;
    line-height: 32px;
    letter-spacing: -1px;
  }
  .hero h2 strong::before {
    bottom:3px;
  }
  .hero h3{
    font-size: 16px;
    line-height: 24px;
    word-break: keep-all;
    margin-bottom: 24px;
  }
  .hero p strong::before {
    bottom:3px;
    height: 8px;
  }
  .hero h3 span {
    display: block;
    font-weight: 400;
    margin-top: 8px;
  }
  .hero p{
    font-size: 15px;
    line-height: 23px;
  }

  .hero .wcb{
    font-size: 15px;
    line-height: 24px;
    padding: 8px 16px;
    gap: 10px;
    background-color: rgba(0, 0, 0, .5);
    color:#D9E651;
    margin-bottom: 8px!important;
  }

  .hero a.btn{
    font-size: 18px;
    padding: 14px 24px !important;
  }

  .ssn h2{
    font-size: 24px !important;
    text-align: center;
  }

  /* Process 2x2 */
  .doz_sys ul.process{
    flex-wrap: wrap;
    gap: 56px 48px;
    justify-content: center;
  }

  .doz_sys ul.process li{
    display: flex;
    flex-direction: column;
    align-items: center;
    width: calc(50% - 24px);
  }

  .doz_sys ul.process .circle{
    width: 130px;
    height: 130px;
    border-radius: 65px;
  }

  .doz_sys ul.process img{
    width: 60px;
    height: 60px;
  }

  .doz_sys ul.process h3{
    font-size: 16px;
    line-height: 20px;
    margin: 16px 0 12px;
  }

  .doz_sys ul.process span{
    font-size: 13px;
    padding: 5px 10px;
    margin-bottom: 20px;
  }
  
  .doz_sys ul.process li::after{
    top: 65px;
    right: -40px;
    width: 32px;
    height: 2px;
  }

  .doz_sys ul.process li:nth-child(2)::after{
    content: none;
  }

  #w20260323144b89112aed9 .ssn h2{
    margin-bottom: 16px !important;
  }

  #s202603236f4aa1cff6bb5 .inside > .doz_row + .doz_row{
    margin: 0 !important;
  }

  #s202603236f4aa1cff6bb5 .inside > .doz_row + .doz_row .col-dz{
    padding-left: 8px;
    padding-right: 8px;
  }

  #s202603236f4aa1cff6bb5 .inside > .doz_row + .doz_row .col-dz .widget{
    margin-top: 8px;
    margin-bottom: 8px;
  }

  #s202603236f4aa1cff6bb5 .widget.image > ._img_box::after{
    top: 16px;
    left: 16px;
    font-size: 16px;
  }

  #s202603236f4aa1cff6bb5 .widget.image > div:not(._img_box){
    padding: 14px;
    height: unset;
  }

  #s202603236f4aa1cff6bb5 .widget.image > div:not(._img_box) h4{
    font-size: 16px;
    line-height: 24px;
    word-break: keep-all;
  }

  .doz_sys #w2026032394c8e4dba9d54 .acd_heading{
    padding: 20px 12px;
  }

  #w2026032394c8e4dba9d54 .acd_title{
    font-size: 15px;
  }

  #w2026032394c8e4dba9d54 .acd_title .table-cell{
    word-break: keep-all;
  }

  #w2026032394c8e4dba9d54 .acd_icon{
    margin-top: -16px;
  }

  .icon-minus:before,
  .icon-plus:before{
    width: 32px;
    height: 32px;
  }

  #w2026032394c8e4dba9d54 .acd_body .comment-block .btn-gruop-wrap .tools{
    float: right;
  }

  .doz_sys #w2026032394c8e4dba9d54 .acd_body{
    margin-left: 12px;
    border-left-width: 6px;
    padding-left: 16px;
    padding-right: 5px;
  }
  .doz_sys #w2026032394c8e4dba9d54 .acd_body p {
    margin-bottom: 12px;
  }
  .doz_sys #w2026032394c8e4dba9d54 .acd_title a > div.category {
    width: 30%;
  }
  .doz_sys #w2026032394c8e4dba9d54 .acd_title a > div.number,
  .doz_sys #w2026032394c8e4dba9d54 .acd_title a > div.notice_icon {
    width: 30px;
    word-break: keep-all;
  }
  #w2026032394c8e4dba9d54 .acd_row.interlock_etc_board .tabled,
  #w2026032394c8e4dba9d54 .acd_row.interlock_etc_board .tabled > div {
    display: block;
    width: 100%;
  }
  #w2026032394c8e4dba9d54 .acd_row.interlock_etc_board .tabled > div.prod_star,
  #w2026032394c8e4dba9d54 .acd_row.interlock_etc_board .tabled > div.prod_title {
    line-height: 20px;
    width: 100%;
  }
  #w2026032394c8e4dba9d54 .acd_row.interlock_etc_board .tabled > div {
    padding-left: 0;
  }
  #w2026032394c8e4dba9d54 .dropdown {
    float: right;
  }
  #w2026032394c8e4dba9d54 ul.dropdown-menu {
    width: auto;
    padding: 8px 0;
    margin: 2px 0 0;
    border: 1px solid rgba(0,0,0,.15);
    position: absolute;

  }
  #w2026032394c8e4dba9d54 ul.dropdown-menu > li {
    display: block;
    width: 100%;
    text-align: left;
    padding: 8px 0;
    margin: 2px 0 0;
  }
  .mobile_right .dropdown-toggle i:before{
    font-family: 'simple-line-icons' !important;
  }

  #w2026032394c8e4dba9d54 ul.dropdown-menu > li > a{
    padding: 8px 16px;
  }

  .doz_sys #s202603230db86cd81003c{
    padding: 0 !important;
    aspect-ratio: 1 / 1;
    margin-bottom: 360px;
  }

  .doz_sys #s202603230db86cd81003c .section_bg{
    background-size: cover;
    background-position: 48% 50% !important;
  }

  .doz_sys #s202603230db86cd81003c .inside{
    position: relative;
    height: 100%;
  }

  .doz_sys #s202603230db86cd81003c .inside .doz_row:nth-child(2),
  .doz_sys #s202603230db86cd81003c .inside .col-dz-8{
    display: none;
  }

  .doz_sys #s202603230db86cd81003c .inside .doz_row:first-child{
    position: absolute;
    bottom: -130px;
    width: calc(100% - 30px);
  }

  .doz_sys #s202603230db86cd81003c .inside .doz_row:last-child{
    position: absolute;
    bottom: -212px;
    width: calc(100% - 30px);
  }

  .doz_sys #s202603230db86cd81003c .wbox{
    width: 100%;
    text-align: center;
    margin: 0;
    padding: 0;
  }

  .doz_sys #s202603230db86cd81003c .wbox.alt{
    background-image: unset !important;
  }

  .doz_sys #s202603230db86cd81003c .wbox p{
    font-size: 18px !important;
    line-height: 28px !important;
  }
}

@media (max-width:360px){
  .doz_sys .nav ul li.bg-green a{
    font-size: 16px;
  }
}

#sf-wrap * {
  box-sizing: border-box;
  font-family: 'Pretendard', 'Apple SD Gothic Neo', 'Malgun Gothic', sans-serif;
}
#sf-wrap button, #sf-wrap select, #sf-wrap input {
  font-family: inherit;
}

/* ── 최상위 래퍼 ── */
#sf-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0 40px;
  color: #222;
}

/* ── 본문 레이아웃 ── */
#sf-wrap .sf-body {
  display: flex;
  gap: 32px;
  align-items: flex-start;
}

/* ── 지도 영역 ── */
#sf-wrap .sf-map {
  flex: 0 0 auto;
  width: 268px;
}
#sf-wrap .sf-count {
  font-size: 16px;
  font-weight: 900;
  color: #78A22F;
  margin: 12px 0 40px;
}
#sf-wrap #sf-map-wrap {
  width: 268px;
  position: relative;
  cursor: pointer;
}
#sf-wrap #sf-map-wrap svg {
  width: 100%;
  height: auto;
  display: block;
}
/* 오버레이 SVG */
#sf-wrap #sf-map-wrap .sf-map-overlay {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  overflow: visible;
}
/* 지도 기본 path 색 - 라이트 그린-그레이 */
#sf-wrap #sf-map-wrap svg path[data-region] {
  fill: transparent;
  transition: fill 0.2s;
  cursor: pointer;
}
#sf-wrap #sf-map-wrap svg path[data-region]:hover {
  fill: rgba(131,168,11,0.55);
}
#sf-wrap #sf-map-wrap svg path[data-region].sf-map-active {
  fill: rgba(131,168,11,0.65);
}
/* 지역명 툴팁 */
#sf-map-tooltip {
  display: none;
  position: absolute;
  background: rgba(26,75,46,0.92);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  font-family: 'Pretendard', 'Apple SD Gothic Neo', 'Malgun Gothic', sans-serif;
  padding: 4px 9px;
  border-radius: 5px;
  pointer-events: none;
  white-space: nowrap;
  z-index: 10;
  transform: translate(-50%, -100%);
  margin-top: -6px;
}

/* ── 목록 영역 ── */
#sf-wrap .sf-list {
  flex: 1 1 0;
  min-width: 0;
}

/* ── 필터 ── */
#sf-wrap .sf-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
  align-items: center;
}
#sf-wrap .sf-filters select {
  height: 44px;
  padding: 0 36px 0 14px;
  border: 1.5px solid #C8D0C2;
  border-radius: 6px;
  font-size: 14px;
  color: #333;
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2378A22F' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
  min-width: 130px;
}
#sf-wrap .sf-filters select:focus {
  outline: none;
  border-color: #78A22F;
}
#sf-wrap .sf-filters input[type="text"] {
  height: 44px;
  padding: 0 14px;
  border: 1.5px solid #C8D0C2;
  border-radius: 6px;
  font-size: 14px;
  color: #333;
  flex: 1;
  min-width: 140px;
}
#sf-wrap .sf-filters input[type="text"]::placeholder {
  color: #AAB0A8;
}
#sf-wrap .sf-filters input[type="text"]:focus {
  outline: none;
  border-color: #78A22F;
}
#sf-wrap .sf-filters button {
  height: 44px;
  padding: 0 24px;
  background: #78A22F;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}
#sf-wrap .sf-filters button:hover {
  background: #5E821F;
}

/* ── 테이블 ── */
#sf-wrap .sf-table-wrap {
  overflow-x: auto;
}
#sf-wrap table {
  width: 100%;
  border-collapse: collapse;
  font-size: 16px;
}
#sf-wrap thead th {
  padding: 10px 12px;
  border-bottom: 2px solid #2E5C1F;
  color: #333;
  font-weight: 600;
  text-align: left;
  white-space: nowrap;
}
#sf-wrap tbody tr {
  border-bottom: 1px solid #EAEDE8;
  transition: background 0.1s;
}
#sf-wrap tbody tr:hover {
  background: #F4F8F1;
}
#sf-wrap tbody td {
  padding: 6px 12px;
  vertical-align: middle;
  color: #333;
  line-height: 1.5;
}
#sf-wrap td.sf-name {
  font-weight: 500;
  min-width: 140px;
}
#sf-wrap td.sf-type {
  color: #78A22F;
  font-weight: 600;
  white-space: nowrap;
  min-width: 80px;
}
#sf-wrap td.sf-addr {
  color: #555;
  min-width: 180px;
}
#sf-wrap td.sf-contact {
  text-align: center;
  width: 50px;
}
#sf-wrap .sf-contact-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: none;
  cursor: pointer;
  padding: 0;
  border-radius: 50%;
  transition: background 0.15s;
}
#sf-wrap .sf-contact-btn:hover {
  background: #EDF4E6;
}
#sf-wrap .sf-contact-btn svg {
  width: 25px;
  height: 20px;
}

/* ── 로딩 / 빈 상태 ── */
#sf-wrap .sf-status {
  text-align: center;
  padding: 48px 0;
  color: #888;
  font-size: 15px;
}
#sf-wrap .sf-spinner {
  display: inline-block;
  width: 22px;
  height: 22px;
  border: 3px solid #DDE6D8;
  border-top-color: #78A22F;
  border-radius: 50%;
  animation: sf-spin 0.7s linear infinite;
  margin-bottom: 12px;
}
@keyframes sf-spin { to { transform: rotate(360deg); } }

/* ── 페이지네이션 ── */
#sf-wrap .sf-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  margin-top: 24px;
  flex-wrap: wrap;
}
#sf-wrap .sf-page-btn {
  min-width: 36px;
  height: 36px;
  padding: 0 8px;
  border: 1.5px solid #D4DDD0;
  background: #fff;
  color: #333;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
#sf-wrap .sf-page-btn:hover:not(:disabled) {
  border-color: #78A22F;
  color: #78A22F;
}
#sf-wrap .sf-page-btn.active {
  background: #4A7C2F;
  border-color: #4A7C2F;
  color: #fff;
  font-weight: 700;
}
#sf-wrap .sf-page-btn:disabled {
  opacity: 0.35;
  cursor: default;
}

/* ── 팝업 오버레이 ── */
#sf-popup {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,0.45);
  align-items: center;
  justify-content: center;
}
#sf-popup.open {
  display: flex;
}
#sf-popup .sf-popup-box {
  background: #fff;
  border-radius: 14px;
  padding: 36px 32px 28px;
  max-width: 400px;
  width: 90%;
  position: relative;
  box-shadow: 0 8px 40px rgba(0,0,0,0.18);
  animation: sf-popup-in 0.22s ease;
}
@keyframes sf-popup-in {
  from { transform: scale(0.92); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}
#sf-popup .sf-popup-close {
  position: absolute;
  top: 16px;
  right: 18px;
  border: none;
  background: none;
  font-size: 20px;
  color: #888;
  cursor: pointer;
  line-height: 1;
  padding: 4px;
}
#sf-popup .sf-popup-close:hover { color: #333; }
#sf-popup .sf-popup-store {
  font-size: 18px;
  font-weight: 700;
  color: #1B5E45;
  margin-bottom: 6px;
  line-height: 1.4;
}
#sf-popup .sf-popup-type {
  font-size: 13px;
  color: #78A22F;
  font-weight: 600;
  margin-bottom: 18px;
}
#sf-popup .sf-popup-section {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 14px;
}
#sf-popup .sf-popup-icon {
  flex: 0 0 20px;
  margin-top: 2px;
  color: #78A22F;
}
#sf-popup .sf-popup-text {
  font-size: 14px;
  color: #444;
  line-height: 1.6;
  word-break: break-all;
}
#sf-popup a.sf-popup-link {
  color: #4A7C2F;
  text-decoration: underline;
  word-break: break-all;
}
#sf-popup a.sf-popup-link:hover { color: #2E5C1F; }
#sf-popup .sf-popup-divider {
  border: none;
  border-top: 1px solid #EAEDE8;
  margin: 18px 0;
}

/* ── 반응형 ── */
@media (max-width: 767px) {
  #sf-wrap .sf-body {
    flex-direction: column;
    gap: 20px;
  }
  #sf-wrap .sf-map {
    width: 100%;
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: center;
  }
  #sf-wrap #sf-map-wrap {
    width: 160px;
    flex: 0 0 160px;
  }
  #sf-wrap .sf-count {
    position: absolute;
    top:0;
    left:0;
    margin-bottom: 0;
  }
  #sf-wrap .sf-filters {
    flex-direction: column;
    align-items: stretch;
  }
  #sf-wrap .sf-filters select,
  #sf-wrap .sf-filters button {
    width: 100%;
  }
  #sf-wrap .sf-filters input[type="text"] {
    width:100%;
    padding:12px 14px;
  }
  #sf-wrap table,
  #sf-wrap tbody td {font-size: 15px;}
  #sf-wrap thead th:nth-child(1) {width:58%;}
  #sf-wrap thead th:nth-child(4) {width:66px;}
  #sf-wrap thead th:nth-child(3) { display: none; }
  #sf-wrap tbody td:nth-child(3) { display: none; }
}