/* ==============================================
   mfarm-site.css — 마늘먹인 의령메추리농장 공통
   GNB / Footer / Quick Menu / TOP Button
   ============================================== */

/* ---------- CSS 변수 ---------- */
:root {
  --color-bg: #ffffff;
  --color-text: #2b2b2b;
  --color-text-dark: #111111;
  --color-text-gray: #4a4a4a;
  --color-text-inactive: #444444;
  --color-primary: #6b4a2b;
  --color-second: #535353;
  --color-cart-badge: #4b5b3a;
  --color-tab-border: #ededed;
  --color-tab-icon-bg: #f5f5f5;
  --color-footer-bg: #2b2b2b;
  --color-footer-text: rgba(255, 255, 255, 0.6);
  --color-footer-dim: rgba(255, 255, 255, 0.4);
  --color-footer-sep: rgba(255, 255, 255, 0.3);
  --color-phone-yellow: #f4c542;
  --color-cs-box: rgba(0, 0, 0, 0.5);
  --color-line:#CAB49F;
  --color-tr-line:#E8DDD5;

  --font-base: 'Pretendard', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', sans-serif;

  --max-width: 1490px;
  --content-padding: 0;
  --content-padding-md: 40px;
  --content-padding-sm: 20px;

  --gnb-height: 167px;

  --duration-fast: 0.2s;
  --duration-base: 0.3s;
  --duration-slow: 0.45s;
  --easing: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---------- HTML / Body ---------- */
html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-base);
  color: var(--color-text);
  background-color: var(--color-bg);
  line-height: 1.5;
  overflow-x: hidden;
  padding:0;
}

/* 그누보드 기본 min-width 제거 */
#hd, #wrapper, #ft { min-width: 0; }

/* 그누보드 default.css의 #container float/min-height 완전 무력화
   (빈 span#container가 930×500px float 박스로 히어로를 밀어내는 문제 방지) */
span#container {
  position: absolute !important;
  float: none !important;
  width: 0 !important;
  min-height: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* 커스텀 페이지: 그누보드 #container float 완전 해제 */
.mfarm-main,
.about-main,
.garlic-main { float: none !important; width: 100% !important; max-width: 100%; }

/* 그누보드 로그인 상태 메세지 숨김 (GNB에 통합) */
#hd_login_msg { display: none; }

/* ---------- 전역 요소 기본값 ---------- */
/* default.css의 Malgun Gothic 오버라이드 */
h1, h2, h3, h4, h5, h6,
input, textarea, select, button {
  font-family: var(--font-base);
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; }
img { display: block; max-width: 100%; }


/* ========================================
   GNB
   ======================================== */

.gnb {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-tab-border);
  /* 스크롤 감지 슬라이드 트랜지션 */
  transition:
    transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
    background-color 0.3s ease,
    border-color 0.3s ease;
  will-change: transform;
}

/* 히어로 상단 투명 상태 */
.gnb.is-transparent {
  background: transparent;
  border-bottom-color: transparent;
}

.gnb.is-header-hidden {
  transform: translateY(-100%);
}

/* 상품 상세 sticky 요소 재배치 */
body.is-gnb-hidden .goods__tabs { top: 0; }
body.is-gnb-hidden .goods__info { top: 20px; }

.gnb__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 10px var(--content-padding);
  gap: 40px;
}

.gnb__logo {
  flex-shrink: 0;
  transition: opacity var(--duration-fast) var(--easing);
}
.gnb__logo:hover,
.gnb__logo:focus-visible { opacity: 0.8; }
.gnb__logo img { width: 140px; height: auto; }

.gnb__nav {
  flex: 1;
  display: flex;
  justify-content: center;
}

.gnb__menu-wrap { position: relative; }

.gnb__menu {
  display: flex;
  align-items: center;
  gap: 80px;
  padding: 20px 80px;
  border-radius: 60px;
  background: transparent;
  position: relative;
  z-index: 2;
}

.gnb__menu-li { position: relative; }

.gnb__menu-item {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text);
  padding: 16px 0;
  position: relative;
  white-space: nowrap;
  transition: color var(--duration-fast) var(--easing);
}

.gnb__menu-item:hover,
.gnb__menu-item:focus-visible,
.gnb__menu-li.is-open .gnb__menu-item { color: var(--color-primary); }

.gnb__menu-item--active { color: var(--color-primary); }

/* 드롭다운 */
.gnb__dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  background: var(--color-cart-badge);
  border-radius: 20px;
  padding: 20px;
  min-width: 140px;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  z-index: 300;
  transition:
    opacity    0.22s var(--easing),
    transform  0.22s var(--easing),
    visibility 0s linear 0.22s;
}

.gnb__menu-li.is-open .gnb__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
  transition:
    opacity    0.22s var(--easing),
    transform  0.22s var(--easing),
    visibility 0s linear 0s;
}

.gnb__dropdown-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  list-style: none;
}

.gnb__dropdown-item {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  white-space: nowrap;
  padding: 4px 8px;
  border-radius: 8px;
  transition: background-color var(--duration-fast) var(--easing);
}

.gnb__dropdown-item:hover,
.gnb__dropdown-item:focus-visible { background: rgba(255, 255, 255, 0.18); }

.gnb__dropdown-item:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.6);
  outline-offset: 2px;
}

.gnb__overlay { display: none; }

.gnb__util {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
}

.gnb__util-btn {
  position: relative;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition:
    background-color var(--duration-fast) var(--easing),
    transform var(--duration-fast) var(--easing);
}

.gnb__util-btn:hover,
.gnb__util-btn:focus-visible {
  background-color: #f5f5f5;
  transform: translateY(-1px);
}

.gnb__util-btn:active { transform: translateY(0); }

.gnb__cart-count {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 40px;
  background: var(--color-cart-badge);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  pointer-events: none;
}

/* ========================================
   GNB 관리자 아이콘 (super admin 전용)
   ======================================== */

.gnb-admin-link {
  position: relative;
  color: #aaa;
  transition:
    background-color var(--duration-fast) var(--easing),
    transform var(--duration-fast) var(--easing),
    color var(--duration-fast) var(--easing);
}

.gnb-admin-link__icon {
  width: 22px;
  height: 22px;
  display: block;
  flex-shrink: 0;
  transition:
    color var(--duration-fast) var(--easing),
    transform 0.3s var(--easing);
}

.gnb-admin-link:hover,
.gnb-admin-link:focus-visible {
  color: var(--color-primary);
}

.gnb-admin-link:hover .gnb-admin-link__icon,
.gnb-admin-link:focus-visible .gnb-admin-link__icon {
  transform: scale(1.05) rotate(30deg);
}

.gnb-admin-link__tooltip {
  position: absolute;
  bottom: calc(100% + 6px);
  right: 0;
  background: rgba(40, 30, 20, 0.88);
  color: #fff;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  padding: 4px 8px;
  border-radius: 4px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.15s, transform 0.15s;
  letter-spacing: 0;
}

.gnb-admin-link__tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  right: 10px;
  border: 4px solid transparent;
  border-top-color: rgba(40, 30, 20, 0.88);
}

.gnb-admin-link:hover .gnb-admin-link__tooltip,
.gnb-admin-link:focus-visible .gnb-admin-link__tooltip {
  opacity: 1;
  transform: translateY(0);
}


/* ========================================
   GNB 쇼핑몰 관리자 아이콘 (super admin 전용)
   ======================================== */

.gnb-shop-admin-link {
  position: relative;
  color: #aaa;
  transition:
    background-color var(--duration-fast) var(--easing),
    transform var(--duration-fast) var(--easing),
    color var(--duration-fast) var(--easing);
}

.gnb-shop-admin-link__icon {
  width: 22px;
  height: 22px;
  display: block;
  flex-shrink: 0;
  transition:
    color var(--duration-fast) var(--easing),
    transform 0.3s var(--easing);
}

.gnb-shop-admin-link:hover,
.gnb-shop-admin-link:focus-visible {
  color: var(--color-primary);
}

.gnb-shop-admin-link:hover .gnb-shop-admin-link__icon,
.gnb-shop-admin-link:focus-visible .gnb-shop-admin-link__icon {
  transform: scale(1.05) rotateY(180deg);
}

.gnb-shop-admin-link__tooltip {
  position: absolute;
  bottom: calc(100% + 6px);
  right: 0;
  background: rgba(40, 30, 20, 0.88);
  color: #fff;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  padding: 4px 8px;
  border-radius: 4px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.15s, transform 0.15s;
  letter-spacing: 0;
}

.gnb-shop-admin-link__tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  right: 10px;
  border: 4px solid transparent;
  border-top-color: rgba(40, 30, 20, 0.88);
}

.gnb-shop-admin-link:hover .gnb-shop-admin-link__tooltip,
.gnb-shop-admin-link:focus-visible .gnb-shop-admin-link__tooltip {
  opacity: 1;
  transform: translateY(0);
}


@media (max-width: 768px) {
  .gnb__util{gap: 2px;}
  .gnb-admin-link__tooltip { right: auto; left: 50%; transform: translateX(-50%) translateY(4px); }
  .gnb-admin-link__tooltip::after { right: auto; left: calc(50% - 4px); }
  .gnb-admin-link:hover .gnb-admin-link__tooltip,
  .gnb-admin-link:focus-visible .gnb-admin-link__tooltip { transform: translateX(-50%) translateY(0); }
  
  .gnb-shop-admin-link__tooltip { right: auto; left: 50%; transform: translateX(-50%) translateY(4px); }
  .gnb-shop-admin-link__tooltip::after { right: auto; left: calc(50% - 4px); }
  .gnb-shop-admin-link:hover .gnb-shop-admin-link__tooltip,
  .gnb-shop-admin-link:focus-visible .gnb-shop-admin-link__tooltip { transform: translateX(-50%) translateY(0); }
}


/* ========================================
   GNB 공지 배너 (메인 페이지)
   ======================================== */

.gnb__notice {
  background: #4B5B3A;
  padding: 11px var(--content-padding);
  overflow: hidden;
}

.gnb__notice-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.gnb__notice-text {
  font-size: 15px;
  font-weight: 500;
  color: #ffffff;
  line-height: 1;
  letter-spacing: -0.01em;
}

a.gnb__notice-text:hover { text-decoration: underline; }

.gnb__notice-close {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.6);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  padding: 0;
  line-height: 1;
  transition: color 0.15s ease;
}

.gnb__notice-close:hover { color: rgba(255, 255, 255, 0.9); }

@media (max-width: 768px) {
  .gnb__notice { padding: 10px var(--content-padding-sm); }
  .gnb__notice-text { font-size: 13px; }
  .gnb__notice-close { font-size: 12px; }
}


/* ========================================
   Footer
   ======================================== */

.site-footer {
  background: var(--color-footer-bg);
  padding: 80px var(--content-padding);
  display: flex;
  flex-direction: column;
  align-items: center;
  clear: both; /* float 이후 정상 위치 보장 */
}

.footer-inner {
  max-width: var(--max-width);
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 50px;
}

.footer-content {
  display: flex;
  gap: 50px;
  align-items: flex-start;
}

.footer-logo {
  width: 154px;
  height: auto;
  flex-shrink: 0;
}

.footer-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.footer-links {
  display: flex;
  align-items: center;
  gap: 15px;
  flex-wrap: wrap;
}

.footer-link {
  font-size: 16px;
  font-weight: 400;
  color: var(--color-bg);
  letter-spacing: -0.025em;
  line-height: 1;
  transition: opacity var(--duration-fast) var(--easing);
  position: relative;
}

.footer-link::after {
  content: '';
  position: absolute;
  right: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 12px;
  background: var(--color-footer-sep);
}

.footer-link:last-child::after { display: none; }

.footer-link:hover,
.footer-link:focus-visible { opacity: 0.8; }

.footer-address {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.footer-address p {
  font-size: 14px;
  font-weight: 400;
  color: var(--color-footer-text);
  line-height: 1.8;
  letter-spacing: -0.0286em;
}

.footer-copyright {
  font-size: 14px;
  font-weight: 400;
  color: var(--color-footer-dim);
  letter-spacing: -0.0286em;
}

.footer-cs {
  background: var(--color-cs-box);
  border-radius: 10px;
  padding: 40px 50px;
  display: flex;
  gap: 50px;
  flex-shrink: 0;
  min-height: 244px;
  align-items: flex-start;
}

.footer-cs__item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.footer-cs__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-bg);
  text-transform: uppercase;
  line-height: 1.3;
  margin-bottom: 4px;
}

.footer-cs__phones,
.footer-cs__account {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.footer-cs__phone,
.footer-cs__bank {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-phone-yellow);
  line-height: 1.3;
}

.footer-cs__depositor {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-bg);
  line-height: 1.3;
}

.footer-cs__hours,
.footer-cs__note {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-footer-text);
  line-height: 1.35;
  letter-spacing: -0.0286em;
  margin-top: 8px;
}


/* ========================================
   Quick Menu + TOP Button
   ======================================== */

.quick-menu-wrap {
  position: fixed;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 800;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.btn-scroll-top {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: #fff;
  color: #2B2B2B;
  border: 1px solid #E0E0E0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition:
    opacity      0.25s ease,
    transform    0.25s ease,
    visibility   0s linear 0.25s,
    background   0.15s ease,
    color        0.15s ease,
    border-color 0.15s ease,
    box-shadow   0.15s ease;
}

.btn-scroll-top.btn-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition:
    opacity      0.25s ease,
    transform    0.25s ease,
    visibility   0s linear 0s,
    background   0.15s ease,
    color        0.15s ease,
    border-color 0.15s ease,
    box-shadow   0.15s ease;
}

.btn-scroll-top:hover {
  background: #6B4A2B;
  color: #fff;
  border-color: #6B4A2B;
  box-shadow: 0 6px 16px rgba(107, 74, 43, 0.3);
}

.btn-scroll-top:active { transform: translateY(1px); }

.btn-scroll-top:focus-visible {
  outline: 2px solid #6B4A2B;
  outline-offset: 3px;
}

.btn-scroll-top__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
}

.quick-menu {
  width: 76px;
  background: #fff;
  border-radius: 999px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 8px 0;
}

.quick-menu__item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 14px 0;
  text-decoration: none;
  color: #2B2B2B;
  transition: color 0.3s ease, transform 0.3s ease;
}

.quick-menu__item + .quick-menu__item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 14px;
  right: 14px;
  height: 1px;
  background: #EBEBEB;
}

.quick-menu__item:hover {
  color: #635447;
  transform: scale(1.05);
}

.quick-menu__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}

.quick-menu__icon img { width: 28px; height: 28px; display: block; }

.quick-menu__text {
  font-size: 11px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  letter-spacing: -0.02em;
  white-space: nowrap;
}


/* ========================================
   Responsive
   ======================================== */

.gnb__aside-logo img{
    max-width:110px;
}

@media (max-width: 1600px) {
  :root { --content-padding: 60px; }
}

@media (max-width: 1280px) {
  :root { --content-padding: var(--content-padding-md); }

  .gnb__menu { gap: 40px; padding: 20px 40px; }

  .quick-menu-wrap { right: 16px; }
  .quick-menu { width: 66px; }
  .quick-menu__item { padding: 12px 0; gap: 5px; }
  .quick-menu__icon,
  .quick-menu__icon img { width: 24px; height: 24px; }
  .quick-menu__text { font-size: 10px; }
  
  .gnb__inner {
      padding: 10px var(--content-padding);
  }
}

@media (max-width: 1024px) {
  .gnb__nav { display: none; }
  .gnb__dropdown { display: none; }
    .gnb__logo img { width: 120px; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .footer-cs { width: 100%; }
  .gnb__inner {
      padding: 10px var(--content-padding);
  }
}

@media (max-width: 768px) {
  :root {
    --content-padding: var(--content-padding-sm);
    --gnb-height: 72px;
  }

  .gnb__inner { padding: 5px var(--content-padding-sm); }
  .gnb__logo img { width: 90px; }

  .site-footer { padding: 40px var(--content-padding-sm); }
  .footer-content { flex-direction: column; gap: 20px; }
  .footer-cs { flex-direction: column; gap: 24px; padding: 24px; min-height: auto; }

  .quick-menu-wrap {
    right: 16px;
    bottom: 160px;
    top: auto;
    transform: none;
    gap: 0;
  }
  .quick-menu { display: none; }
  .btn-scroll-top { width: 60px; height: 60px; }
  .mfarm-section-head{
        margin-bottom:10px !important;
  }
  
    .mobile-scroll-wrap{
        width:100% !important;
        white-space:nowrap;
        overflow-x:auto !important;
        -webkit-overflow-scrolling: touch;
    }
    .mobile-scroll-wrap .tbl_head03 thead th {
        padding: 20px 0;
        border-top: 2px solid #959da6;
        border-bottom: 1px solid #d3d3d3;
        color: #383838;
        font-size: 0.85em;
        text-align: center;
        letter-spacing: -0.1em;
    }
    .mobile-scroll-wrap .fr-fic.fr-dib{
        min-width:768px;
    }
}

/* ---------- 모션 비선호 ---------- */
@media (prefers-reduced-motion: reduce) {
  .gnb,
  .goods__tabs,
  .goods__info { transition: none !important; }

  .btn-scroll-top,
  .btn-scroll-top.btn-visible { transition: none !important; }
}




/* ==================================================
   GNB Aside Menu (풀스크린 & 모바일 메뉴) 2026-06-17
   ================================================ */
.gnb__aside {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 900;
    background: rgba(255, 255, 255, 0.98);
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--duration-base) var(--easing), visibility var(--duration-base);
}

/* 활성화 상태 */
.gnb__aside.is-open {
    opacity: 1;
    visibility: visible;
}

.gnb__aside-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 40px var(--content-padding-md);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.gnb__aside-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 30px;
    border-bottom: 1px solid var(--color-tab-border);
}

.gnb__aside-close {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-dark);
    transition: transform var(--duration-fast) ease;
}
.gnb__aside-close:hover { transform: rotate(90deg); }

.gnb__aside-nav {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow-y: auto;
}

/* [PC/테블릿 이상] 1024px 초과 - 풀스크린 가로 배열 스타일 */
@media (min-width: 1025px) {
    .gnb__aside-menu {
        display: flex;
        justify-content: center;
        gap: 100px;
        width: 100%;
    }
    .gnb__aside-item {
        font-size: 28px;
        font-weight: 700;
        color: var(--color-text-dark);
        display: block;
        margin-bottom: 24px;
    }
    .gnb__aside-sub {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
    .gnb__aside-sub a {
        font-size: 18px;
        color: var(--color-text-gray);
        transition: color var(--duration-fast) ease;
    }
    .gnb__aside-sub a:hover { color: var(--color-primary); }
}

/* [모바일] 1024px 이하 - 우측 서랍식 슬라이드 스타일 */
@media (max-width: 1024px) {
    .gnb__aside {
        background: rgba(0, 0, 0, 0.5);
    }
    .gnb__aside-inner {
        position: absolute;
        top: 0;
        right: 0;
        width: 80%;
        max-width: 400px;
        background: #fff;
        box-shadow: -4px 0 20px rgba(0,0,0,0.15);
        transform: translateX(100%);
        transition: transform var(--duration-base) var(--easing);
        padding: 20px var(--content-padding-sm);
    }
    .gnb__aside.is-open .gnb__aside-inner {
        transform: translateX(0);
    }
    .gnb__aside-nav {
        align-items: flex-start;
        justify-content: flex-start;
        padding-top: 30px;
    }
    .gnb__aside-menu {
        width: 100%;
        display: flex;
        flex-direction: column;
        gap:0px; /* 갭 주지 말것 */
    }
    .gnb__aside-item {
        --arrow-box:30px;
        font-size: 20px;
        font-weight: 700;
        padding: 0.5em var(--arrow-box) 0.5em 0;;
        display: flex;
        justify-content: space-between;
        align-items: center;
        border-bottom: 1px solid #dedede;
        position:relative;
    }
    
    .gnb__aside-item:after{
        content:'';
        width:var(--arrow-box);
        height:var(--arrow-box);
        display:block;
        position:absolute;
        right:0px;
        top:50%;
        transform:translateY(-50%);
        background-image:url(/img/mfarm/chevron-down-outline.svg);
        background-size:24px;
        background-repeat:no-repeat;
        background-position:center center;
        transform-origin: center center;
        transition:all 0.35s;
        opacity:0.15;
    }
    
    .gnb__aside-li.is-active .gnb__aside-item:after{
        transform:translateY(-50%) rotate(-180deg);
        transition:all 0.35s;        
        opacity:0.45;
    }
    
    /* 모바일 서브메뉴 토글용 */
    .gnb__aside-sub {
        display: none;
        background: #fcfcfc;
        padding: 10px 15px;
    }
    .gnb__aside-sub li a {
        display: block;
        padding: 8px 0;
        font-size: 16px;
        color: var(--color-text-gray);
    }
    .gnb__aside-li.is-active .gnb__aside-sub {
        display: block;
    }
}

/* 스크롤 잠금용 전역 클래스 */
body.is-layer-open { overflow: hidden !important; }

@media(max-width:640px){
    html,body{
        font-size:14px;
    }
    #sit_qa_wbtn a{
        font-size:1em !important;
    }
}