         /* ======================================== */
         /* ======== 공통 레이아웃 시작 부분==========  */
         /* ======================================== */


/* 1. 여기에 추가: 스크롤바가 생겨도 화면이 밀리지 않게 공간 확보 */
html { 
    scrollbar-gutter: stable; 
}

/* 2. 기본 배경은 흰색으로 설정 (세로 스크롤 허용) */
body { 
    margin: 0; 
    padding: 0;
    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; 
         width: calc(100% - 17px);  /* 스크롤바가 들어갈 자리를 확실히 비워줍니다 */
         z-index: 1000; 
         transition: height 0.3s ease; /* 부드러운 높이 변화 */
         pointer-events: auto; /* 마우스 이벤트 허용 */
         }

/* 4. 마우스를 올리면 드롭다운 메뉴가 보일만큼 높이를 늘림 */
.header-frame:hover { height: 400vh; }

/* 5. 푸터 프레임: 하단 흰 줄 제거 및 밀착 */
.footer-frame { 
    flex-shrink: 0;   /* 푸터가 본문에 밀려 찌그러지지 않게 방지 */
    margin-top: auto; /* 본문이 짧아도 강제로 최하단에 위치시킴 */
    width: 100%; 
    height: 80px; 
    border: none; 
    display: block; 
    vertical-align: top; 
    background: #1a1a1a; }



         /* ======================================== */
         /* ======== 상단 탭 수정부분 작성 위치 시작 부분==========  */
         /* ======================================== */


/* 프로젝트 상단 내비게이션 스타일 */
.about_via-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: 176px;        /* 버튼의 동일한 가로 너비 */
  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;
}


         /* ======================================== */
         /* ======== 본문 수정부분 작성 위치 시작 부분==========  */
         /* ======================================== */



/* 본문 전체 영역 */
.about-main {
    flex: 1 0 auto; /* ★핵심: 남는 모든 공간을 이 영역이 차지하여 푸터를 바닥으로 밀어냄 */
    width: 100%;  /* 위쪽 여백은 네비게이션 높이에 맞춰 조절하세요 */
    display: flex;
    justify-content: center;
    padding-top: 5px; 
    padding-bottom: 50px; 
    position: relative; 
    z-index: 1;
    background: #fff;
}    


/* 컨테이너 레이아웃 */
.philosophy-wrapper {
    max-width: 1300px;
    width: 90%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 60px;
}

.philosophy-image { flex: 1; }
.philosophy-image img {
    width: 100%;
    max-width: 500px;
    height: auto;
    display: block;
    filter: grayscale(100%); /* 흑백 필터 */
}

.philosophy-content { flex: 1.2; text-align: left; }
.philosophy-content .category {
    font-size: 13px; font-weight: 800; color: #bbb;
    letter-spacing: 0.2em; margin-bottom: 15px; display: block;
}

/* 타이틀 스타일: 강조되지 않은 글자는 연하게 처리 */
.philosophy-content .title {
    font-size: 52px; line-height: 1.2; font-weight: 800;
    color: rgba(0, 0, 0, 0.15); 
    margin-bottom: 30px;
}

/* V, I, A 강조색 (진한 녹색) */
.philosophy-content .highlight { color: #0a4a44; }

.philosophy-content .description { max-width: 700px; }
.philosophy-content .description p {
    font-size: 15px; line-height: 1.8; color: #666;
    margin-bottom: 20px; word-break: keep-all;
}


         /* ======================================== */
         /* ======== 반응형 대응 시작 부분==========  */
         /* ======================================== */


@media (max-width: 1024px) {
    .about-main {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0px 10px 10px 10px !important; 
        margin: 0 !important;
        box-sizing: border-box !important;
        gap: 5px !important;
    }

    .philosophy-wrapper { 
        flex-direction: column; 
        gap: 20px; 
    }
    .philosophy-image, .philosophy-content {
        flex: none;
        width: 90%;
    }

    .philosophy-content {
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .philosophy-content .title { 
        font-size: 32px; 
        margin-bottom: 10px;
    }

    .philosophy-content .description {
        max-width: 100%;
    }

    .philosophy-content .description p { 
        font-size: 14px; 
        line-height: 1.6;
    }

    /* 프로젝트 상단 내비게이션 스타일 */ 
    .about_via-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;        
    }

}
