/* ===== Reset / Base ===== */
* { box-sizing: border-box; }
header { width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; margin: 0; padding: 0; }
img { max-width: 100%; height: auto; display: block; }

/* ===== Top line ===== */
.top-line{
  width:100%;
  border-bottom: 1px solid #e9e9e9;
  background:#fff;
}
.top_gnb{
  max-width: 1200px;
  margin: 0 auto;
  padding: 6px 16px;
  display:flex;
  justify-content:flex-end;
  gap: 14px;
  flex-wrap: wrap;
}
.top_gnb a{
  font-size: 13px;
  padding: 6px 4px;
  display:inline-block;
  color:#333;
}

/* ===== Navbar ===== */
.navbar{
  position: relative;
  width: 100%;
  background:#fff;
  border-bottom: 1px solid #e9e9e9;

  /* layout */
  max-width: 1200px;
  margin: 0 auto;
  padding: 12px 16px;

  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 16px;
}

/* Logo */
.logo{
  display:flex;
  align-items:center;
  gap: 8px;
}
.logo img{
  height: 44px;      /* PC 기본 로고 높이 */
  width: auto;
}

/* Menu Toggle (hamburger) */
.menu-toggle{
  display:none;               /* PC에서는 숨김 */
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  user-select: none;
  padding: 6px 10px;
  border: 1px solid #e9e9e9;
  border-radius: 8px;
}

/* Nav menu (PC 기본) */
.nav-menu{
  display:flex;
  align-items:center;
  gap: 22px;
}

/* 1depth */
.nav-menu > li{
  position: relative;
}
.nav-menu > li > a{
  display:inline-block;
  padding: 12px 6px;
  font-size: 15px;
  color:#111;
  white-space: nowrap;
}

/* Sub menu (dropdown) */
.sub-menu{
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 180px;
  background:#fff;
  border: 1px solid #e9e9e9;
  border-radius: 10px;
  padding: 8px 0;
  box-shadow: 0 10px 24px rgba(0,0,0,0.08);
  display:none;
  z-index: 999;
}
.sub-menu li a{
  display:block;
  padding: 10px 14px;
  font-size: 14px;
  color:#222;
}

/* PC hover dropdown */
@media (hover: hover) and (pointer: fine){
  .nav-menu > li:hover > .sub-menu{
    display:block;
  }
  .nav-menu > li > a:hover{
    color:#0a58ca;
  }
  .sub-menu li a:hover{
    background:#f6f6f6;
  }
}

/* ===== Mobile / Tablet ===== */
@media (max-width: 992px){
  /* 상단 링크 줄바꿈 대비 */
  .top_gnb{
    justify-content: flex-end;   /* ← center → flex-end 로 변경 */
    text-align: right;
  }

  .navbar{
    max-width: 100%; position: relative;   /* 기준점 */
  }

  /* 로고 */
  .logo{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
  
  .logo img{ height: 56px; }

  /* 햄버거 표시 */
  .menu-toggle{ display:block; }

  /* 기본 상태: 메뉴 숨김 */
  .nav-menu{
    display:none;
    position:absolute;
    left: 0;
    right: 0;
    top: calc(100% + 1px);
    background:#fff;
    border-bottom: 1px solid #e9e9e9;
    padding: 10px 16px;
    flex-direction: column;
    gap: 0;
    z-index: 999;
  }

  /* 모바일: 1depth 클릭 영역 크게 */
  .nav-menu > li > a{
    width: 100%;
    padding: 14px 8px;
    border-top: 1px solid #f0f0f0;
    font-size: 16px;
  }

  /* 모바일: 서브메뉴는 기본 숨김 + static으로 아래에 붙임 */
  .sub-menu{
    position: static;
    border: 0;
    box-shadow: none;
    border-radius: 0;
    padding: 0 0 8px 0;
    display:none;
    min-width: 0;
  }
  .sub-menu li a{
    padding: 12px 14px;
    font-size: 14px;
    background:#fafafa;
    border-top: 1px solid #f0f0f0;
  }

  /*
    모바일에서 "탭"으로 서브메뉴 열기 (CSS 한계 버전)
    - li 내부에 포커스가 들어오면(:focus-within) sub-menu 표시
    - 1depth 링크를 탭하면 포커스가 걸리면서 열림
    - 다만 두 번째 탭에서 링크 이동될 수 있어 UX가 애매할 수 있음
  */
  .nav-menu > li:focus-within > .sub-menu{
    display:block;
  }

  /* 메뉴 오픈 클래스가 붙으면 표시 */
  .nav-menu.is-open{
    display:flex;
  }
}

/* 아주 작은 화면 */
@media (max-width: 420px){
  .top_gnb a{ font-size: 12px; }
  .menu-toggle{ font-size: 24px; }
}


/* =========================
   Main Center + Responsive
   ========================= */

/* main 전체를 가운데 정렬 + 최대폭 제한 */
main{
  max-width: 1200px;      /* 사이트 본문 폭 */
  margin: 0 auto;         /* 가운데 정렬 */
  padding: 24px 16px;     /* 좌우 여백 (모바일 최적화) */
}

/* 공통 컨테이너도 main 폭에 맞춤 */
main .container{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* 섹션 간격 */
main section{
  margin: 28px 0;
}

/* =========================
   Banner
   ========================= */

.banner-section{
  width: 100%;
}

.banner-slider{
  width: 100%;
  overflow: hidden;
  border-radius: 14px;
}

.banner-slider .slide img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* =========================
   Schedule Section
   ========================= */

.schedule-section{
  width: 100%;
}

.schedule-section .title{
  display: block;
  text-align: center;
  font-weight: 700;
  font-size: 26px;
  margin-bottom: 10px;
}

.schedule-section .month{
  display: block;
  text-align: left;     /* 달은 좌측 정렬 */
  font-weight: 700;
  margin-top: 16px;
  background-color: blue;
}

.schedule-section .event{
  display: block;
  text-align: center;   /* 일정은 중앙 정렬 */
  padding: 6px 0;
}

/* =========================
   Mobile Optimization
   ========================= */

@media (max-width: 992px){
  main{
    max-width: 100%;
    padding: 18px 14px;
  }

  main section{
    margin: 18px 0;
  }

  .schedule-section .title{
    font-size: 18px;
  }

  .schedule-section .month{
    margin-top: 12px;
  }

  .banner-slider{
    border-radius: 12px;
  }
}

@media (max-width: 420px){
  main{
    padding: 14px 12px;
  }

  .schedule-section .title{
    font-size: 17px;
  }

  .schedule-section .event{
    font-size: 14px;
  }
}