         /* ======================================== */
         /* ======== 공통 레이아웃 시작 부분==========  */
         /* ======================================== */


/* 1. 여기에 추가: 스크롤바가 생겨도 화면이 밀리지 않게 공간 확보 */
html { 
    scrollbar-gutter: stable; 
}

/* 2. 기본 배경은 흰색으로 설정 (세로 스크롤 허용) */
body { 
    margin: 0; 
    padding: 0;

    height: auto !important; 
    min-height: 100vh; 

    background: #fff; 

    /* 우측에 브라우저 기본 스크롤바가 생기도록 설정 */
    overflow-y: auto !important; 
    overflow-x: hidden;
    
    /* 요소들을 위에서 아래로 수직 배치 */
    display: flex;
    flex-direction: column;
}

/* 3. 헤더 프레임: 메뉴 드롭다운과 모바일 사이드바를 위해 높이 확보 */
 .header-frame { 
         width: 100%; 
         height: 100px; /* 기본 높이 */
         border: none; 
         position: fixed; 
         top: 0; 
         left: 0; 
         z-index: 1000; 
         transition: height 0.3s ease; /* 부드러운 높이 변화 */
         pointer-events: auto; /* 마우스 이벤트 허용 */
         }

/* 4. 마우스를 올리면 드롭다운 메뉴가 보일만큼 높이를 늘림 */
.header-frame:hover { height: 400vh; }

/* 5. 푸터 프레임: 하단 흰 줄 제거 및 밀착 */
.footer-frame { 
    width: 100%; 
    height: 80px; 
    border: none; 
    display: block; 
    vertical-align: top; 
    background: #1a1a1a; }



         /* ======================================== */
         /* ======== 본문 수정부분 작성 위치 시작 부분==========  */
         /* ======================================== */


.project-frame {
    width: 100%;
    border: none;
    display: block;
    
    /* 헤더가 fixed이므로 그만큼 상단 여백을 주어 가려지지 않게 함 */
    margin-top: 5px; 

    
    /* 푸터를 아래로 밀어내는 역할 */
    flex: 1 0 auto; 
    
    /* [중요] iframe 내부에는 절대 스크롤바가 생기지 않도록 차단 */
    overflow: hidden !important; 
    
    /* 초기 로드 시 너무 짧아 보이지 않게 최소 높이 지정 */
    min-height: 600px; 
    
    /* 스크립트(postMessage)가 이 height 값을 직접 변경합니다. */
    height: auto; 
}


/* 프로젝트 상단 내비게이션 스타일 */
.project-nav {
  display: flex;
  flex-direction: column; /* 세로(위-아래) 방향으로 배치 */
  align-items: center;    /* 전체 요소를 가로 중앙 정렬 */
  justify-content: center;
  padding: 0px 0;
  margin-top: 105px; 
  margin-bottom: 20px;
}

.nav-title {
  font-size: 35px;
  font-weight: 800;
  letter-spacing: 1px;
  color: #0a4a44;
  margin-bottom: 20px;   /* 제목과 아래 탭 사이의 간격 */
  text-align: center;    /* 텍스트 중앙 정렬 */
}

.nav-tabs {
  display: flex;
  gap: 10px; /* 항목 사이 공간을 띄움 (원하는 만큼 조절 가능) */
  flex: 1;
  justify-content: center; /* 중앙 배치 */
}

.tab-item {
  text-decoration: none;
  color: #333;
  font-weight: 700;
  font-size: 14px;
  
  /* 박스 크기를 동일하게 설정 */
  width: 130px;        /* 버튼의 동일한 가로 너비 */
  height: 40px;        /* 버튼의 동일한 세로 높이 */
  display: flex;       /* 중앙 정렬을 위해 flex 사용 */
  align-items: center;
  justify-content: center;
  
  transition: all 0.3s ease;
  border: 1px solid #ddd;
  background-color: #fff;
  letter-spacing: 0.5px;
}

/* ALL 및 활성화된 탭 스타일 */
.tab-item.active {
  background-color: #0a4a44 !important; /* 비아건축 로고 색상 */
  color: #fff !important;
  border-color: #0a4a44 !important;
}

.tab-item:hover:not(.active) {
  border-color: #0a4a44; /* 호버 시 테두리만 로고 색상으로 */
  color: #0a4a44;
}


         /* ======================================== */
         /* ======== 반응형 대응 시작 부분==========  */
         /* ======================================== */

@media (max-width: 1024px) {
  .project-frame { 
    /* 기존 140px에서 100px 정도로 축소 (헤더 높이에 맞춰 조정) */
    margin-top: 0px; 
    padding-top: 0px; 
  }

    .project-nav {
        flex-direction: column;
        gap: 5px;
        margin-top: 70px;
        padding-left: 10px;
        padding-right: 10px;
    }
    .nav-title {
        font-size: 25px;
        margin-top: 5px;
        margin-bottom: 5px;
   }
    .nav-tabs {
        width: 100%;
        display: flex;         /* flexbox 활성화 확인 */
        flex-wrap: nowrap;     /* 한 줄로 가득 채우려면 nowrap, 줄바꿈 허용시 wrap */
        gap: 3px;
        padding: 0;            /* 불필요한 패딩 제거 */
    }

    .tab-item {
        flex: 1;               /* 핵심: 자식 요소가 너비를 균등하게 나눠 가짐 */
        min-width: 0;          /* 텍스트가 길어질 경우 대비 */
        text-align: center;    /* 텍스트 중앙 정렬 */
        font-size: 12px;
        height: 30px;        
    }

}

@media (max-width: 640px) {
    .project-frame {
        padding-left: 10px;
        padding-right: 10px;
    }

}
