/* =========================================
   1. Global Variables & Reset
   ========================================= */
:root {
    --primary-color: #0066cc;       /* 기존 #06c 유지하되 표준화 */
    --accent-color: #03a9f4;        /* 버튼 색상 */
    --accent-hover: #0288d1;
    --text-main: #333333;
    --text-muted: #666666;
    --bg-light: #f8f9fa;
    --border-color: #e1e4e8;
    --code-bg: #f6f8fa;             /* 코드 블럭 배경색 */
    --shadow-soft: 0 4px 6px rgba(0, 0, 0, 0.05);
    --shadow-hover: 0 6px 12px rgba(0, 0, 0, 0.1);
}

body {
    /* 시스템 폰트 스택을 사용하여 더 깔끔하고 빠르게 렌더링 */
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    margin: 0;
    padding: 0;
    color: var(--text-main);
    line-height: 1.6;
    background-color: #fff;
}

/* 스크롤바 디자인 개선 - 더 얇고 모던하게 */
*::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

*::-webkit-scrollbar-thumb {
    border-radius: 4px;
    background: #ccc;
}

*::-webkit-scrollbar-thumb:hover {
    background: #bbb;
}

*::-webkit-scrollbar-track {
    background: transparent;
}

a {
    color: var(--primary-color);
    text-decoration: none;
    transition: color 0.2s;
}

a:hover {
    text-decoration: underline;
    color: #004080;
}

/* =========================================
   2. UI Elements (Buttons, Banner)
   ========================================= */
button {
    padding: 10px 24px;
    /* min-width: 300px; -> 너무 커서 제거, 필요시 컨텐츠에 맞게 늘어나도록 함 */
    border: none;
    border-radius: 6px; /* 과도한 20px에서 줄임 */
    font-size: 1rem;
    font-weight: 600;
    background-color: var(--accent-color);
    color: #ffffff;
    box-shadow: var(--shadow-soft);
    cursor: pointer;
    transition: all 0.2s ease;
}

button:hover {
    background-color: var(--accent-hover);
    box-shadow: var(--shadow-hover);
    transform: translateY(-1px); /* 살짝 떠오르는 효과 */
}

.topbanner {
    padding: 1rem;
    border-bottom: 1px solid rgba(0,0,0,0.1);
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    background-color: var(--primary-color);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.topbanner, .topbanner * {
    color: white;
}

.topbanner label {
    font-size: 1.25rem;
    font-weight: 600;
}

/* =========================================
   3. Navigation
   ========================================= */
.navmenu {
    padding: 0 10px 48px;
    background-color: #fff;
}

.navfolder {
    font-weight: 700;
    font-size: 1.1rem;
    text-align: center;
    margin: 1rem 0;
    padding: 0.75rem;
    background-color: var(--bg-light); /* 연한 회색으로 변경 */
    border-radius: 6px;
    color: var(--text-main);
}

.navgroup {
    font-size: 1rem;
    padding-left: 0.5rem;
    margin: 10px 0;
    font-weight: 600;
    color: var(--text-muted);
}

.navitem {
    /* width: 180px; -> 고정 너비 제거 (반응형 대응) */
    display: inline-block;
    margin: 2px 0;
    padding: 0; /* a 태그에 패딩을 줌 */
    border-radius: 4px;
    transition: background-color 0.2s;
}

.navitem a {
    display: block;
    padding: 6px 12px;
    color: var(--text-main);
    border-radius: 4px;
}

.navitem:hover {
    background-color: rgba(0, 0, 0, 0.05);
    text-decoration: none;
}

.navitem.active {
    background-color: #4682b4; /* steelblue */
}

.navitem.active a {
    color: #fff;
    font-weight: 500;
}

.navcontent {
    padding: 20px 40px;
}

.navfolderitems {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 5px; /* 아이템 간 간격 추가 */
}

/* 논리적 오류 수정: 내용이 많아지면 잘릴 수 있는 고정 높이 제거 */
.navfolderdemos, .navfolderdocs {
    height: auto; 
    min-height: 200px;
}

/* =========================================
   4. Syntax Highlighter (Modernized)
   ========================================= */
/* 기존의 베이지색/점선 스타일을 현대적인 GitHub/VSCode 스타일로 변경 */

.dp-highlighter {
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
    font-size: 13px;
    background-color: var(--code-bg);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    width: 100%; /* 99% -> 100% */
    box-sizing: border-box; /* 패딩 포함 계산 */
    overflow: auto;
    margin: 20px 0 !important;
    padding: 0;
    line-height: 1.5;
}

/* 상단 툴바 (Copy 버튼 등) */
.dp-highlighter .bar {
    padding-left: 0;
    background-color: transparent;
}

/* 코드 영역 리스트 */
.dp-highlighter ol {
    margin: 0 !important;
    padding: 10px 0 10px 50px !important; /* 라인 넘버 공간 확보 */
    color: var(--text-muted);
    background-color: transparent;
    border: none;
}

.dp-highlighter ol li,
.dp-highlighter .columns div {
    list-style: decimal;
    border-left: 3px solid transparent; /* 녹색 선 제거, 투명으로 유지 */
    background-color: transparent;
    color: #bbb; /* 라인 넘버 색상 연하게 */
    padding-left: 10px !important;
    margin: 0 !important;
}

/* 짝수 줄 배경색 제거 (현대적인 느낌을 위해) */
.dp-highlighter ol li.alt {
    background-color: transparent;
}

/* 코드 텍스트 본문 */
.dp-highlighter ol li span {
    color: #24292e; /* 기본 텍스트 검정 */
    font-family: inherit;
}

/* 호버 시 라인 강조 (선택 사항) */
.dp-highlighter ol li:hover {
    background-color: rgba(0,0,0,0.03);
    border-left-color: var(--accent-color);
}

/* 구문 강조 색상 (조금 더 선명하게 조정) */
.dp-highlighter .comment, .dp-highlighter .comments { color: #6a737d; font-style: italic; }
.dp-highlighter .string { color: #032f62; }
.dp-highlighter .keyword { color: #d73a49; font-weight: bold; }
.dp-highlighter .preprocessor { color: #6f42c1; }

/* Copy 버튼 위치 및 스타일 수정 (JS에서 생성되는 요소 대응) */
.dp-highlighter + div { 
    /* patch.js의 DPH_AddCopyBtn 함수가 생성하는 버튼에 대한 스타일 보정 */
    /* 필요하다면 여기에 z-index 등을 추가 */
}


/* =========================================
   5. General Content Styles (Bootstrap-like)
   ========================================= */
p {
    margin-bottom: 1rem;
}

code {
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
    font-size: 90%;
    padding: 0.2rem 0.4rem;
    color: #d63384; /* 인라인 코드 강조색 */
    background-color: rgba(27, 31, 35, 0.05);
    border-radius: 3px;
}

pre {
    background: #1e1e1e; /* 어두운 배경 */
    color: #f8f8f2;
    padding: 1rem;
    border-radius: 6px;
    overflow-x: auto;
}

/* Callout Box 디자인 개선 */
.callout {
    padding: 1.25rem;
    margin-bottom: 1.5rem;
    border: 1px solid #eee;
    border-left-width: 5px;
    border-radius: 4px;
    background-color: #fff;
}

.callout-warning {
    border-left-color: #ffc107;
    background-color: #fffbf2;
}

.callout-danger {
    border-left-color: #dc3545;
    background-color: #fff5f5;
}

.callout-title {
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
    display: block;
}

/* Sidebar Styling (Bootstrap Docs style) */
.hs-sidebar-link {
    color: #495057;
    padding: 0.5rem 1rem;
    display: block;
    border-radius: 4px;
}

.hs-sidebar-link:hover, 
.hs-sidebar-link.active {
    color: var(--accent-color);
    background-color: rgba(3, 169, 244, 0.1);
    text-decoration: none;
}

.hs-sidebar-heading {
    color: #888;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 1.5rem 0 0.5rem;
    padding: 0 1rem;
}

/* --- ESP32-CAM 수업 페이지 추가 스타일 --- */

.step-list li {
    margin-bottom: 15px;
    font-size: 1.05em;
}

.step-desc {
    display: block;
    font-size: 0.9em;
    color: #555;
    margin-top: 5px;
    margin-left: 5px;
}

.file-group {
    background-color: #f9f9f9;
    border: 1px solid #eee;
    padding: 10px;
    border-radius: 5px;
    margin-top: 5px;
}

.file-group a {
    display: block;
    margin: 5px 0;
    text-decoration: none;
    color: #007bff;
}

.file-group a:hover {
    text-decoration: underline;
}

/* 테이블 스타일 */
.wiring-table {
    border-collapse: collapse;
    width: 100%;
    margin-bottom: 20px;
    font-size: 0.95rem;
}
.wiring-table th, .wiring-table td {
    border: 1px solid #ddd;
    padding: 10px;
    text-align: center; /* 가운데 정렬 */
    vertical-align: middle;
}
.wiring-table th {
    background-color: #f2f2f2;
    font-weight: bold;
    color: #333;
}
.wiring-table tr:nth-child(even) {
    background-color: #f9f9f9;
}

/* =========================================
   6. ESP Web Tools Button Styling
   ========================================= */

/* 설치 버튼 컨테이너 */
esp-web-install-button {
    display: inline-block;
    margin-top: 10px;
}

/* Web Component 내부의 실제 버튼 스타일링 
   (쉐도우 돔 내부 요소 접근을 위해 ::part 사용)
*/
esp-web-install-button::part(button) {
    font-size: 1.2rem;            /* 글자 크기 키움 */
    padding: 12px 24px;           /* 버튼 크기 키움 */
    background-color: var(--primary-color); /* 파란색 배경 (#0066cc) */
    color: white;                 /* 글자색 흰색 */
    border-radius: 8px;           /* 둥근 모서리 */
    cursor: pointer;
    border: none;
    box-shadow: var(--shadow-soft);
    transition: all 0.2s ease;
    font-weight: 600;
    font-family: inherit;
}

/* 버튼 마우스 오버 효과 */
esp-web-install-button::part(button):hover {
    background-color: #004080;    /* 더 진한 파란색 */
    box-shadow: var(--shadow-hover);
    transform: translateY(-1px);  /* 살짝 떠오르는 효과 */
}

/* 버튼 클릭(활성화) 효과 */
esp-web-install-button::part(button):active {
    transform: translateY(0);
    box-shadow: none;
}
