/**
 * MD2HTML Code Highlighting CSS - v1.0.0
 * 코드 구문 강조를 위한 스타일시트
 */

/* 기본 하이라이팅 테마 */
.md2html-code-block {
    background: #f8f8f8;
    border: 1px solid #e1e1e8;
    border-radius: 6px;
    padding: 16px;
    overflow-x: auto;
    font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
    font-size: 14px;
    line-height: 1.4;
    color: #333;
}

/* 언어별 스타일 */
.md2html-code-block code {
    background: none;
    padding: 0;
    border: none;
    font-size: inherit;
    color: inherit;
}

/* JavaScript/TypeScript */
.md2html-code-block .language-javascript,
.md2html-code-block .language-js,
.md2html-code-block .language-typescript,
.md2html-code-block .language-ts {
    color: #333;
}

/* Python */
.md2html-code-block .language-python,
.md2html-code-block .language-py {
    color: #333;
}

/* HTML */
.md2html-code-block .language-html,
.md2html-code-block .language-markup {
    color: #333;
}

/* CSS */
.md2html-code-block .language-css {
    color: #333;
}

/* PHP */
.md2html-code-block .language-php {
    color: #333;
}

/* JSON */
.md2html-code-block .language-json {
    color: #333;
}

/* SQL */
.md2html-code-block .language-sql {
    color: #333;
}

/* Shell/Bash */
.md2html-code-block .language-bash,
.md2html-code-block .language-shell {
    color: #333;
    background: #2d3748;
}

.md2html-code-block .language-bash code,
.md2html-code-block .language-shell code {
    color: #e2e8f0;
}

/* 다크 테마 */
@media (prefers-color-scheme: dark) {
    .md2html-code-block {
        background: #1a1a1a;
        border-color: #404040;
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-javascript,
    .md2html-code-block .language-js,
    .md2html-code-block .language-typescript,
    .md2html-code-block .language-ts {
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-python,
    .md2html-code-block .language-py {
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-html,
    .md2html-code-block .language-markup {
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-css {
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-php {
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-json {
        color: #e0e0e0;
    }
    
    .md2html-code-block .language-sql {
        color: #e0e0e0;
    }
}

/* 코드 블록 복사 버튼 */
.md2html-code-block {
    position: relative;
}

.md2html-code-block::before {
    content: attr(data-language);
    position: absolute;
    top: 8px;
    right: 8px;
    background: rgba(0, 0, 0, 0.1);
    color: #666;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 12px;
    font-weight: normal;
    text-transform: uppercase;
    pointer-events: none;
}

/* 라인 번호 (확장 기능) */
.md2html-code-block.line-numbers {
    padding-left: 3em;
}

.md2html-code-block.line-numbers::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 2.5em;
    background: rgba(0, 0, 0, 0.05);
    border-right: 1px solid rgba(0, 0, 0, 0.1);
}

/* 하이라이팅된 라인 (확장 기능) */
.md2html-code-block .highlight-line {
    background: rgba(255, 255, 0, 0.1);
    display: block;
    margin: 0 -16px;
    padding: 0 16px;
}

/* 인라인 코드 하이라이팅 */
.md2html-inline-code {
    background: #f1f3f4;
    border: 1px solid #e1e1e8;
    border-radius: 3px;
    padding: 2px 4px;
    font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
    font-size: 85%;
    color: #d73a49;
}

@media (prefers-color-scheme: dark) {
    .md2html-inline-code {
        background: #2d3748;
        border-color: #4a5568;
        color: #f56565;
    }
}

/* 스크롤바 개선 */
.md2html-code-block::-webkit-scrollbar {
    height: 8px;
}

.md2html-code-block::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.md2html-code-block::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 4px;
}

.md2html-code-block::-webkit-scrollbar-thumb:hover {
    background: #a8a8a8;
}

/* 반응형 스타일 */
@media (max-width: 768px) {
    .md2html-code-block {
        font-size: 12px;
        padding: 12px;
    }
    
    .md2html-code-block::before {
        font-size: 10px;
        top: 6px;
        right: 6px;
    }
}

/* 프린트 스타일 */
@media print {
    .md2html-code-block {
        background: white;
        border: 1px solid #000;
        color: #000;
        font-size: 10pt;
        page-break-inside: avoid;
    }
    
    .md2html-code-block::before {
        display: none;
    }
    
    .md2html-inline-code {
        background: #f5f5f5;
        border: 1px solid #ddd;
        color: #000;
    }
}