/* 기본 리셋 및 전체 폰트 설정 */
* {
  margin: 0; padding: 0; box-sizing: border-box;
}

body {
  font-family: 'Noto Sans KR', sans-serif;

  color: #333333;
  line-height: 1.6;
}

.container {
  max-width: 1200px; /* 모든 콘텐츠 영역의 최대 너비 통일 (XL 기준) */
  width: 100%;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

a {
  text-decoration: none;
  color: inherit;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* 공통 버튼 스타일 */
.btn {
  display: inline-block;
  background-color: #d84141;
  color: white;
  padding: 12px 25px;
  border-radius: 25px;
  font-weight: 500;
  transition: background-color 0.3s ease;
}
.btn:hover {
  background-color: #b25468;
}



/* 퀵 메뉴 섹션 */
#quick-menu {
  background-color: #fff;
  padding: 50px 0; /* XL 기준 패딩 */
  margin-bottom: 60px;
}
.quick-menu-grid {
  display: flex;
  justify-content: space-between; /* XL에서는 양 끝 정렬 */
  max-width: 1000px; /* XL 기준 최대 너비 */
  margin: 0 auto;
  gap: 20px; /* XL 기준 간격 */
  flex-wrap: wrap; /* 모든 화면에서 랩핑 허용 (6개/3개 패턴을 위해) */
}
.quick-menu-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1 1 calc(16.66% - 16.66px); /* XL/LG 기준 6개 아이템 균등 배치 (100%/6 - gap) */
  padding: 15px 0;
  color: #333333;
  transition: color 0.3s ease, transform 0.2s ease;
}
.quick-menu-item:hover {
  color: #d84141;
  transform: translateY(-5px);
}

.quick-menu-item img {
  width: 60px; /* XL 기준 아이콘 크기 */
  height: 60px;
  margin-bottom: 10px;
  transition: transform 0.2s ease;
}

.quick-menu-item span {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.3;
  white-space: nowrap;
}


/* LG (Large / 992px - 1199px) */
@media (min-width: 992px) and (max-width: 1199px) {

  /* Quick Menu - LG에서도 6개 1줄 유지, 간격만 조금 줄임 */
  .quick-menu-grid {
    gap: 15px;
    max-width: 960px;
  }
  .quick-menu-item {
    flex: 1 1 calc(16.66% - 12.5px); /* 100%/6 - gap */
  }
  #quick-menu .quick-menu-item img {
    width: 55px;
    height: 55px;
  }
}

/* MD (Medium / 768px - 991px), SM (Small / 576px - 767px), XS (Extra Small / 575px 이하) */
/* ★★★ 멍하니님 요청 반영: 991px 이하 모든 모바일/태블릿 구간에서 퀵 메뉴는 3개씩 2줄로만 배치 ★★★ */
@media (max-width: 991px) {


  #quick-menu {
    padding: 40px 0;
  }
  .quick-menu-grid {
    flex-wrap: wrap; /* 랩핑 허용 */
    justify-content: center;
    max-width: 720px; /* 3개씩 배치 위한 최대 너비, 768px~991px에 맞춤 */
    gap: 20px 15px; /* 세로/가로 간격 */
  }
  .quick-menu-item {
    flex: 0 0 calc(33.33% - 10px); /* 3개씩 배치 (100%/3 - gap). (15px * 2) / 3 = 10px */
    max-width: calc(33.33% - 10px); /* 크기 오차 방지 */
    padding: 12px 0;
  }
  #quick-menu .quick-menu-item img {
    width: 50px;
    height: 50px;
  }
  #quick-menu .quick-menu-item span {
    font-size: 0.95rem;
  }
}

/* SM (Small / 576px - 767px) */
@media (max-width: 767px) {
  .container {
    padding: 0 15px;
  }


  #quick-menu {
    padding: 30px 0;
  }
  .quick-menu-grid {
    max-width: 540px; /* 3개씩 배치 위한 최대 너비 */
    gap: 15px 10px;
  }
  .quick-menu-item {
    flex: 0 0 calc(33.33% - 6.66px); /* 3개씩 2줄로 배열 (100%/3 - gap). (10px * 2) / 3 = 6.66px */
    max-width: calc(33.33% - 6.66px);
    padding: 10px 0;
  }
  #quick-menu .quick-menu-item img {
    width: 45px;
    height: 45px;
  }
  #quick-menu .quick-menu-item span {
    font-size: 0.9rem;
  }
}

/* XS (Extra Small / 575px 이하) */
@media (max-width: 575px) {
  .container {
    padding: 0 10px;
  }


  #quick-menu {
    padding: 25px 0;
    margin-bottom: 40px;
  }
  .quick-menu-grid {
    justify-content: center;
    gap: 10px 8px; /* 세로/가로 간격 */
    max-width: 300px; /* 3개씩 배치 위한 최대 너비 */
  }
  .quick-menu-item {
    flex: 0 0 calc(33.33% - 5.33px); /* 3개씩 2줄로 배열 (100%/3 - gap). (8px * 2) / 3 = 5.33px */
    max-width: calc(33.33% - 5.33px);
    padding: 8px 0;
  }
  #quick-menu .quick-menu-item img {
    width: 40px;
    height: 40px;
    margin-bottom: 5px;
  }
  #quick-menu .quick-menu-item span {
    font-size: 0.85rem;
  }
}

/* ★★★ LG (Large / 992px - 1199px)보다 작을 때 슬라이드 버튼 크기 조절 추가 ★★★ */
@media (max-width: 1199px) {
  .prev-btn, .next-btn {
    width: 35px;
    height: 35px;
    font-size: 1.5rem;
  }
}
