
       .test {

       }
       html {
      scroll-behavior: smooth;
    }

    footer {background:#111;color:#fff;text-align:center;padding:1.5rem;font-size:0.9rem;}
  
  #thankYouMessage {
  display: none;
  text-align: center;
}

  @media(max-width:768px){
    body {
    }
  }
  form {
    display: flex;
    /* justify-content: center; */
    align-items: center;

  }
  form .form {
    width: 100%;
    
  }


  @media(min-width:768px){
    form {
      padding-left: 100px;
      padding-right: 100px;
    }
  }

  @media(max-width:768px){
    form {
      padding-left: 10px;
      padding-right: 10px;
      /* background-color: #007bff; */
    }
    form .form {
      width: 100%;
    }
  }




  .agree {
    /* background-color: #28a745; */
    padding: 10px;

  }
  .agree label {
    display: flex;
    align-content: center;
    align-items: center;
    text-align: center;

  }

  .checkbox {
    width: 20px;
    height: 20px;
  }
  


    /* [자세히] 링크 스타일 */
.agre-link {
  color: #007BFF;
  cursor: pointer;
  font-weight: bold;
}
.agre-link:hover {
  text-decoration: underline;
}

/* 팝업 배경 */
.popup-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.6);
  display: none; /* 기본은 숨김 */
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

/* 팝업 박스 */
.popup-content {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  width: 90%;
  max-width: 500px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.25);
  animation: popupFadeIn 0.3s ease;
  position: relative;
}

/* 닫기 버튼 */
.popup-close {
  position: absolute;
  top: -10px;
  right: 20px;
  font-size: 45px;
  cursor: pointer;
  color: #666;
  transition: color 0.2s;
}
.popup-close:hover {
  color: #e94560;
}

/* 팝업 타이틀 */
.popup-title {
  text-align: center;
  margin-bottom: 0rem;
  font-size: 1.2rem;
  font-weight: bold;
  color: #333;
}

/* 텍스트 */
.terms-text p:first-child {
    margin-top: 30px;
}
.terms-text p {
  margin: 0.5rem 0;

  color: #444;
  line-height: 1.5;
}

/* 팝업 등장 애니메이션 */
@keyframes popupFadeIn {
  from { transform: translateY(-20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}


#ident {
  margin-top: 30px;
}

#agreePopu .strView {
  font-size: 14px; 
  color: #555;
}

footer {
  margin-top: 20px;
}



.submitBtnLayer {
  margin-top: 10px;
  text-align: center;
}

#thankYouMessage {
  display: none;
  text-align: center;
}


  :root {
    --primary: #1a1a2e;
    --secondary: #f9f9f9;
    --accent: #e94560;
    --text: #2e2e2e;
    --max-width: 1200px;
  }
  * {box-sizing:border-box;margin:0;padding:0;}

  .mt-10 {
    margin-top: 10px;
  }

  .mt-20 {
    margin-top: 20px;
  }

  .mt-30 {
    margin-top: 30px;
  }


  .btnLink {
    padding: 10px;
    background-color: aliceblue;
    border: solid 0.1px antiquewhite;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1);
    cursor: pointer;
    border-radius: 15px;
  }
  .btnLink a { 
    font-size: 20px;
  }

  body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    background: #f9f9f9;
    background-color: whitesmoke;
  }
  /* header {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 20px;
    background: #fff;
    border-bottom: 1px solid #ddd;
  } */
  .logo {
    font-size: 24px;
    font-weight: bold;
    color: #2c3eeb;
  }
  header h1 {
    margin: 0;
  }

  @media(min-width:768px){
    header h1 {
      font-size: 34px;
    }
  }

  @media(max-width:768px){
    header h1 {
      font-size: 24px;
    }
  }


  .search-box input {
    padding: 6px 10px;
    border: 1px solid #ccc;
    border-radius: 20px;
  }

  /* 메뉴 */
  .nav {

    background: #fff;
    border-bottom: 1px solid #ddd;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch; /* iOS에서 부드러운 터치 */
    scrollbar-width: none; /* Firefox 스크롤바 숨김 */
    cursor: grab;
  }
  .nav:active {
    cursor: grabbing;
  }
  .nav::-webkit-scrollbar {
    display: none; /* 크롬/사파리 스크롤바 숨김 */
  }
  .nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: inline-flex;
  }
  .nav li {
    flex: 0 0 auto;
  }
  .nav a {
    display: block;
    padding: 12px 18px;
    text-decoration: none;
    color: #333;
    font-weight: 500;
  }
  .nav a.active {
    color: #2c3eeb;
    border-bottom: 3px solid #2c3eeb;
  }

  /* 청약현황 */
  .status-box {
    display: flex;
    gap: 15px;
    padding: 15px;
    background: #fff;
    flex-wrap: wrap;

    margin-top: 30px;
  }
  .status-item {
    flex: 1;
    min-width: 150px;
    text-align: center;
    background: #f3f1ff;
    padding: 15px;
    border-radius: 12px;
    font-size: 15px;
  }
  .status-item span {
    font-weight: bold;
    color: #2c3eeb;
  }

  /* 뉴스 */
  .news-section {
    padding: 15px;
  }
  .news-grid {
    display: grid;
    grid-template-columns: 1fr 3fr;
    gap: 50px;
  }
  .news-main img {
    width: 100%;
    border-radius: 8px;
  }
  .news-main h3 {
    margin: 10px 0;
    font-size: 18px;
  }
  .news-list article {
    display: flex;
    margin-bottom: 15px;
    gap: 10px;
  }
  .news-list img {
    width: 100px;
    height: 70px;
    object-fit: cover;
    border-radius: 6px;
  }
  .news-list h4 {
    font-size: 20px;
    margin: 0;
    color: #333;
  }

  @media(min-width:768px){
    section {
      /* max-width: 1340px; */
    }
    
  }

  @media(max-width:768px){

  }


  /* 반응형 */
  @media (max-width: 768px) {

    section {
        max-width: 100% !important;
    }
    .card {
        padding-bottom: 20px;
    }

    .news-grid {
      grid-template-columns: 1fr;
    }
    .news-list img {
      width: 80px;
      height: 60px;
    }

    .card-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(100%, 1fr));
      gap: 60px;
    }

  }

  @media(min-width:768px){
    .nav {
      display: flex;
      justify-content: center;
    }

    section {
     
      background-color: whitesmoke;
      padding: 0px 50px;
      margin: auto;
    }
  }

  @media(max-width:768px){
    section {
      padding: 0px 10px;
      margin: auto;
    }
  }


  body {
    font-family: 'Noto Sans KR', sans-serif;
    margin: 0;
    padding: 0;
    background: #fff;
  }
  /* .carousel {
    width: 90%;
    margin: 30px auto;
  }
  .card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    transition: transform .3s;
  } */

  .carousel {
    width: 90%;
    margin: 30px auto;
    padding: 0 10px; /* 캐러셀 전체 여백 */
  }


  @media(min-width:768px){
    .card {
      /* width: 380px !important; */
    }
  }

  @media(max-width:768px){
    .card {
      width: 100% !important;
    }
  }


  .card {
    text-align: center;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    transition: transform .3s;
    /* margin: 0 10px;  */
    /* 아이템 간격 */
  }

  .card:hover {
    transform: translateY(-5px);
  }
  .card img {
    /* width: 100%;
    height: 180px;
    object-fit: cover; */
    /* width: 100%; */
    /* height: 180px; */
    object-fit: contain;
  }
  .card-body {
    padding: 15px;
    min-height: 320px;
    /* max-height: 320px; */
  }
  .card-body h3 {
    font-size: 18px;
    margin: 0 0 8px;
  }
  .card-body p {
    font-size: 14px;
    margin: 0 0 6px;
    color: #555;
  }
  .price {
    font-weight: bold;
    margin: 10px 0;
    font-size: 15px;
    color: #222;
  }
  .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
  }
  .tag {
    /* background: #f1f1f1;
    border-radius: 8px;
    padding: 4px 8px;
    font-size: 12px;
    color: #333; */
  
    background: #f1f1f1;
    border-radius: 8px;
    padding: 4px 8px;
    font-size: 14px;
    color: #333;
    margin-top: 10px;
    font-weight: 500;

  }

  


  .slick-prev, .slick-next {
    z-index: 10;
    width: 40px;
    height: 40px;
  }
  .slick-prev:before, .slick-next:before {
    font-size: 40px;
    color: #000;
  }
  @media (max-width: 768px) {
    .card img {
      /* height: 150px; */
    }
  }

  @media(min-width:768px){

  }

  @media(max-width:768px){
    .banners img {
      width: 100%;
    }

    #aptfind {
      display: none;
    }
  }


/* 예약접수 리스트 스타일 */
.updateList-section {
  width: 90%;
  max-width: 400px;
  background: rgba(255,255,255,0.95);
  border: 1px solid #ddd;
  border-radius: 10px;
  padding: 10px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  z-index: 9999;
  overflow: hidden;
  font-size: 14px;
  margin-top: 50px;
}
@media (max-width: 768px) {
  
  .updateList-section {
    height: 130px;
    overflow: hidden;
    font-size: 18px;
  }
  .updateList-list {
    overflow: hidden;
    height: 130px;
  }
}
.updateList-section h2 {
  margin: 0 0 5px;
  font-size: 16px;
  text-align: center;
  color: #2c3eeb;
}


  /* .carousel .card-body {
    padding-bottom: 140px;
  } */

  @media(min-width:768px){

    .carousel {
      max-width: 1200px;
      margin-top: 50px;
    }
    .carousel .card {
      min-height: 300px;
      /* padding-bottom: 20px; */
      margin-bottom: 20px;
    }

    .slick-next {
      margin-right: -20px;
    }
    .slick-prev {
      margin-left: -20px;
    }

    .eventShow {
      width: 400px;
      height: 400px;
    }
  }

  @media (max-width: 768px) {
    .eventShow {
      width: 100%;
    }
  }

  .envents {
    background-color: #4d4b4b;
    font-size: 20px;
    color: whitesmoke;
    font-weight: 900;
    text-align: center;
    padding: 20px;
  }




  .event-section .section-title {
    border-left: 6px solid #818181;
    padding-left: 20px;
  }


  body {
    font-family: 'Noto Sans KR', sans-serif;
    margin: 0;
    padding: 0;
    background: #fafafa;
    color: #333;
  }

  .container {
    max-width: 1200px;
    margin: 0 auto;

  }

  .banners {
    margin-top: 10px;
    text-align: center;
  }
  
  @media(max-width:768px){
    .container {
    }
    .news {
      margin-top:  10px !important;
    }
  }
  @media(min-width:768px){
    .container {
      max-width: 1200px;
      /* padding: 40px 20px; */
    }
  }
  .section {
    max-width: 1340px;
  }

  h2.section-title {
    font-size: 1.6rem;
    margin-bottom: 20px;
    font-weight: 700;
    border-left: 6px solid #818181;
    padding-left: 12px;
    color: #222;
  }

  .card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 40px;
  }
  .card-grid-event {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 40px;
  }
  .card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 3px 8px rgba(0,0,0,0.1);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    /* cursor: pointer; */
  }

  .card:hover {
    transform: translateY(-6px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.15);
  }

  /* .card img {
    width: 100%;
    height: 230px;
    object-fit: cover;
    display: block;
  } */
  .card img {
    /* width: 100%;
    height: 230px; */
    object-fit: contain;
    display: block;
  }

  .card-event img {
    width: 100%;
    /* height: 230px; */
    object-fit: cover;
    display: block;
  }
  .card-body {
    padding: 16px;
  }

  .card-body .location {
    font-size: 0.85rem;
    color: #666;
    margin-bottom: 6px;
  }

  .card-body .title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #222;
    line-height: 1.4;
  }

  .news {
    margin-top: 50px;
  }

  .card-info-ready {
      position: relative;
  }
  .card-info-ready > span {
      position: absolute;
      top: 30px;
      right: 20px;
      background-color: rgb(52, 119, 243);
      padding: 5px 15px;
      border-radius: 1300px;
      color: whitesmoke;
      font-weight: 900;
  }

  .card-info-active {
      position: relative;
  }
  .card-info-active > span {
      position: absolute;
      top: 10px;
      right: 20px;
      background-color: rgba(172, 255, 47, 0.783);
      padding: 5px 15px;
      border-radius: 1300px;
      font-weight: 900;
      color: rgb(59, 59, 59);
    
  }

  .card-body {
      position: relative;
      /* background-color: #ccc; */
      min-height: 100px;

      padding-bottom: 40px;
  }

  .card .more {
    text-align: center;
    padding-top: 30px;
  }
  .card .more > span {
    padding: 10px 20px;
    background-color: #4CAF50; /* 버튼 배경색 */
    color: white; /* 버튼 글자색 */
    border: none; /* 버튼 테두리 제거 */
    border-radius: 5px; /* 버튼 모서리 둥글게 */
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2); /* 그림자 효과 */
    cursor: pointer; /* 마우스 커서 모양 변경 */
  }

  /* 마우스를 올렸을 때 그림자를 더 진하게 하거나 변화시키는 예시 */
  .card .more > span:hover {
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.5);
  }

/* 반응형 */
  @media (max-width: 768px) {
  .card-body {
      padding-bottom: 20px;
  }
  }






@media(min-width:768px){
}
@media(max-width:768px){
}

  @media(min-width:768px){
    .side_menus ul{
      
      list-style: none;
      margin: 0;
      padding: 0;
    }

    .side_menus ul li{
      /* padding: 10px 20px; */
    }

    .side_menus ul .divider{
      /* padding: 10px 20px; */
      padding: 10px 20px;
      font-size: 19px;
      /* border: solid 1px; */
    }

    .side_menus ul .menuItem{
      padding: 10px 10px;
    }


    .side_menus {
      position: fixed;
      bottom: 300px;
      right: 20px;
      /* transform: translateX(-50%); */
      /* width: 90%; */
      max-width: 600px;
      background: rgba(255, 255, 255, 0.95);
      /* border: 1px solid #ddd; */
      border-radius: 10px;
      padding: 10px;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
      z-index: 9999;
      overflow: hidden;
      font-size: 17px;
      /* min-height: 200px; */
    }

    .side_menus > div {
      text-align: center;
    }
  }
  @media(max-width:768px){
    .nav-toggle {
      display: none !important;
    }
    .side_menus > div {
      text-align: center;
    }
    .side_menus ul{
      
      list-style: none;
      margin: 0;
      padding: 0;
    }

    .side_menus ul li{
      /* padding: 10px 20px; */
      text-decoration: none;
    }

    .side_menus ul .divider{
      /* padding: 10px 20px; */
      text-align: center;
      padding: 5px 10px;
      font-size: 14px;
      /* border: solid 1px; */
    }

    .side_menus ul .menuItem{
      padding: 10px 10px;
    }


    .side_menus {
      position: fixed;
      bottom: 310px;
      right: 20px;
      /* transform: translateX(-50%); */
      /* width: 90%; */
      max-width: 600px;
      background: rgba(255, 255, 255, 0.95);
      /* border: 1px solid #ddd; */
      border-radius: 10px;
      /* padding: 10px; */
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
      z-index: 9999;
      overflow: hidden;
      font-size: 15px;
      /* min-height: 200px; */
      width: 80px !important;
    }

  }

  .action-floating a {
    background-color: blueviolet !important;
  }

    @media(min-width:768px){

    /* 플로팅 버튼 그룹 */
    .action-floating {
      position:fixed;
      right:20px;
      /* bottom:140px; */
      bottom:70px;
      display:flex;
      flex-direction:column;
      gap:14px;
      z-index:10;
    }

      .action-floating a {
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        width:100px;
        height:100px;
        font-size:18px;
        font-weight:700;
        border-radius:50%;
        color:#fff;
        text-decoration:none;
        text-align:center;
        line-height:1.2;
        color:#fff;
        box-shadow:0 4px 8px rgba(0,0,0,0.15);
        transition:transform 0.3s;
        animation: pulse-sequence 10s infinite;
        background:var(--accent);
        /* animation:pulse 2s infinite; */
        /* transition:transform 0.3s; */
      }

      .action-floating i {
        font-size:30px;
        /* margin-bottom:4px; */
        padding: 3px;
      }
    }


    @media(max-width:768px){

          /* 플로팅 버튼 그룹 */
      .action-floating {
        position:fixed;
        right:20px;
        /* bottom:95px; */
        bottom:150px;
        display:flex;
        flex-direction:column;
        gap:14px;
        z-index:999;
      }

      .action-floating a {
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        width:60px;
        height:60px;
        font-size:12px;
        font-weight:500;
        border-radius:50%;
        color:#fff;
        text-decoration:none;
        text-align:center;
        line-height:1.2;
        color:#fff;
        box-shadow:0 4px 8px rgba(0,0,0,0.15);
        transition:transform 0.3s;
        animation: pulse-sequence 10s infinite;
        background:var(--accent);
        /* animation:pulse 2s infinite; */
        /* transition:transform 0.3s; */
      }

      .action-floating i {
        font-size:16px;
        margin-bottom:4px;
      }
    }



/* 예약접수 리스트 스타일 */
.reservation-section {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  padding: 10px;
  z-index: 9999;
  overflow: hidden;
  border-radius: 30px;
  background-color: white !important;

}

.reservation-section h2 {
  margin: 0 0 5px;
  text-align: center;
  color: #2c3eeb;
}

@media(min-width:768px){
  .reservation-section {
    bottom: 10px;
    width: 90%;
    max-width: 470px;
    padding: 10px;
    font-size: 26px;
    background-color: white !important;
  }
  .reservation-section h2 {
    font-size: 26px;
  }
}

@media(max-width:768px){
  .reservation-section {
    bottom: 10px;
    width: 90%;
    max-width: 450px;
    padding: 5px;
    font-size: 17px;
    background-color: white !important;
  }
  .reservation-section h2 {
    font-size: 20px;
  }
}

@media(min-width:768px){
  .reservation-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 120px;
    overflow: hidden;
    position: relative;
    font-size: 20px;
    text-align: center;
  }

  .reservation-list li {
    padding: 5px 0;
    border-bottom: 1px solid #eee;
    white-space: nowrap;
  }
}

@media(max-width:768px){
  .reservation-list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 70px;
  overflow: hidden;
  position: relative;
  font-size: 15px;
  text-align: center;
  }

  .reservation-list li {
    padding: 5px 0;
    border-bottom: 1px solid #eee;
    white-space: nowrap;
  }
}




@media(min-width:768px){
  .marketing {
    width: 700px !important;
  }
}

@media(max-width:768px){

}



#contact .form-fild {
  width: 100%;
}

#contact .form-fild:nth-child(2) {
  margin-top: 20px;
}

#contact div input {
  margin-top: 10px;
}

@media(min-width:768px){

}

@media(max-width:768px){
  #contact .form-fild {
    width: 100%;
  }

  #contact .form-fild:nth-child(2) {
    margin-top: 0px !important;
  }
}


      /* Contact */ 
    .contact {
      background:var(--secondary);
      /* margin-top: 40px; */
    }
    .contact h2 {
      text-align:center;
      font-size:1.2rem;
      color:var(--primary);
    }
    form {
      max-width:600px;
      margin:auto;
      display:flex;
      flex-direction:column;
      gap:1rem;
    }
    input, textarea {
      padding:0.9rem;
      border:1px solid #ccc;
      border-radius:10px;
      font-size:1rem;
    }
    button {background:var(--accent);color:#fff;padding:0.9rem;border:none;border-radius:50px;cursor:pointer;transition:background 0.3s;font-size:1rem;}
    button:hover {background:#d63447;}


    @media(min-width:768px){
      .contact {
        padding-top: 100px;
      }
    }

    @media(max-width:768px){



      .form-fild {
        display: flex;
        align-items: center;
      }
      .form-fild label { 
        width: 70px;
      }
      .form-fild span { 
        display: none;
      }
    .contact h2 {
      padding-top: 80px;
      }

          form {
      gap:0.2rem;
    }
    }
