/* Syntax Highlighting for Code Blocks */

/* Base code block styling - Solarized Dark inspired */
.codehilite {
    background-color: #073642;
    border: 1px solid #586e75;
    border-radius: 8px;
    padding: 1.5rem;
    margin: 1.5rem 0;
    overflow-x: auto;
    font-family: 'Fira Code', 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    font-size: 0.9rem;
    line-height: 1.5;
    position: relative;
    color: #839496;
}

.codehilite pre {
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
    overflow: visible;
}

.codehilite code {
    background: transparent;
    padding: 0;
    border-radius: 0;
    font-size: inherit;
}

/* Line numbers */
.codehilite .linenos {
    background-color: #002b36;
    color: #586e75;
    padding-right: 1rem;
    margin-right: 1rem;
    border-right: 1px solid #586e75;
    user-select: none;
}

/* Language label */
.codehilite::before {
    content: attr(data-lang);
    position: absolute;
    top: 0.5rem;
    right: 1rem;
    background: #6c757d;
    color: white;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 500;
}

/* Pygments syntax highlighting styles - Solarized Dark theme */
.codehilite .hll { background-color: #073642 }
.codehilite .c { color: #586e75; font-style: italic } /* Comment */
.codehilite .err { color: #dc322f; background-color: #073642 } /* Error */
.codehilite .k { color: #859900; font-weight: bold } /* Keyword */
.codehilite .o { color: #93a1a1 } /* Operator */
.codehilite .ch { color: #586e75; font-style: italic } /* Comment.Hashbang */
.codehilite .cm { color: #586e75; font-style: italic } /* Comment.Multiline */
.codehilite .cp { color: #cb4b16; font-weight: bold } /* Comment.Preproc */
.codehilite .cpf { color: #268bd2 } /* Comment.PreprocFile */
.codehilite .c1 { color: #586e75; font-style: italic } /* Comment.Single */
.codehilite .cs { color: #586e75; font-weight: bold; font-style: italic } /* Comment.Special */
.codehilite .gd { color: #dc322f; background-color: #073642 } /* Generic.Deleted */
.codehilite .ge { font-style: italic } /* Generic.Emph */
.codehilite .gr { color: #dc322f } /* Generic.Error */
.codehilite .gh { color: #268bd2; font-weight: bold } /* Generic.Heading */
.codehilite .gi { color: #859900; background-color: #073642 } /* Generic.Inserted */
.codehilite .go { color: #586e75 } /* Generic.Output */
.codehilite .gp { color: #586e75 } /* Generic.Prompt */
.codehilite .gs { font-weight: bold } /* Generic.Strong */
.codehilite .gu { color: #6c71c4; font-weight: bold } /* Generic.Subheading */
.codehilite .gt { color: #dc322f } /* Generic.Traceback */
.codehilite .kc { color: #b58900; font-weight: bold } /* Keyword.Constant */
.codehilite .kd { color: #859900; font-weight: bold } /* Keyword.Declaration */
.codehilite .kn { color: #859900; font-weight: bold } /* Keyword.Namespace */
.codehilite .kp { color: #859900; font-weight: bold } /* Keyword.Pseudo */
.codehilite .kr { color: #859900; font-weight: bold } /* Keyword.Reserved */
.codehilite .kt { color: #859900; font-weight: bold } /* Keyword.Type */
.codehilite .m { color: #2aa198 } /* Literal.Number */
.codehilite .s { color: #2aa198 } /* Literal.String */
.codehilite .na { color: #93a1a1 } /* Name.Attribute */
.codehilite .nb { color: #268bd2 } /* Name.Builtin */
.codehilite .nc { color: #268bd2; font-weight: bold } /* Name.Class */
.codehilite .no { color: #b58900 } /* Name.Constant */
.codehilite .nd { color: #268bd2; font-weight: bold } /* Name.Decorator */
.codehilite .ni { color: #cb4b16 } /* Name.Entity */
.codehilite .ne { color: #dc322f; font-weight: bold } /* Name.Exception */
.codehilite .nf { color: #268bd2; font-weight: bold } /* Name.Function */
.codehilite .nl { color: #93a1a1; font-weight: bold } /* Name.Label */
.codehilite .nn { color: #93a1a1 } /* Name.Namespace */
.codehilite .nt { color: #268bd2 } /* Name.Tag */
.codehilite .nv { color: #cb4b16 } /* Name.Variable */
.codehilite .ow { color: #859900; font-weight: bold } /* Operator.Word */
.codehilite .w { color: #586e75 } /* Text.Whitespace */
.codehilite .mb { color: #2aa198 } /* Literal.Number.Bin */
.codehilite .mf { color: #2aa198 } /* Literal.Number.Float */
.codehilite .mh { color: #2aa198 } /* Literal.Number.Hex */
.codehilite .mi { color: #2aa198 } /* Literal.Number.Integer */
.codehilite .mo { color: #2aa198 } /* Literal.Number.Oct */
.codehilite .sa { color: #2aa198 } /* Literal.String.Affix */
.codehilite .sb { color: #2aa198 } /* Literal.String.Backtick */
.codehilite .sc { color: #2aa198 } /* Literal.String.Char */
.codehilite .dl { color: #2aa198 } /* Literal.String.Delimiter */
.codehilite .sd { color: #2aa198 } /* Literal.String.Doc */
.codehilite .s2 { color: #2aa198 } /* Literal.String.Double */
.codehilite .se { color: #cb4b16 } /* Literal.String.Escape */
.codehilite .sh { color: #2aa198 } /* Literal.String.Heredoc */
.codehilite .si { color: #cb4b16 } /* Literal.String.Interpol */
.codehilite .sx { color: #2aa198 } /* Literal.String.Other */
.codehilite .sr { color: #2aa198 } /* Literal.String.Regex */
.codehilite .s1 { color: #2aa198 } /* Literal.String.Single */
.codehilite .ss { color: #2aa198 } /* Literal.String.Symbol */
.codehilite .bp { color: #268bd2 } /* Name.Builtin.Pseudo */
.codehilite .fm { color: #268bd2; font-weight: bold } /* Name.Function.Magic */
.codehilite .vc { color: #cb4b16 } /* Name.Variable.Class */
.codehilite .vg { color: #cb4b16 } /* Name.Variable.Global */
.codehilite .vi { color: #cb4b16 } /* Name.Variable.Instance */
.codehilite .vm { color: #cb4b16 } /* Name.Variable.Magic */
.codehilite .il { color: #2aa198 } /* Literal.Number.Integer.Long */

/* Dark mode support */
@media (prefers-color-scheme: dark) {
    .codehilite {
        background-color: #0d1117;
        border-color: #30363d;
        color: #e6edf3;
    }

    .codehilite .linenos {
        background-color: #21262d;
        color: #7d8590;
        border-right-color: #30363d;
    }

    .codehilite .c { color: #8b949e } /* Comment */
    .codehilite .k { color: #ff7b72 } /* Keyword */
    .codehilite .o { color: #ff7b72 } /* Operator */
    .codehilite .s { color: #a5d6ff } /* String */
    .codehilite .na { color: #79c0ff } /* Name.Attribute */
    .codehilite .nb { color: #79c0ff } /* Name.Builtin */
    .codehilite .nc { color: #ffa657 } /* Name.Class */
    .codehilite .nf { color: #d2a8ff } /* Name.Function */
    .codehilite .nt { color: #7ee787 } /* Name.Tag */
    .codehilite .nv { color: #ffa657 } /* Name.Variable */
    .codehilite .m { color: #79c0ff } /* Number */
}

/* Copy button for code blocks */
.codehilite-wrapper {
    position: relative;
}

.codehilite-copy {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    background: #6c757d;
    color: white;
    border: none;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s;
}

.codehilite-wrapper:hover .codehilite-copy {
    opacity: 1;
}

.codehilite-copy:hover {
    background: #495057;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .codehilite {
        padding: 1rem;
        margin: 1rem 0;
        font-size: 0.8rem;
    }
    
    .codehilite .linenos {
        padding-right: 0.5rem;
        margin-right: 0.5rem;
    }
}
