/* Syntax Highlighting - Dracula theme adapted for golang.com.br */
/* Generated with: hugo gen chromastyles --style=dracula, then customized */

/* Wrapper */
.highlight {
    margin: 24px 0;
    border-radius: var(--radius-md, 12px);
    overflow: hidden;
    border: 1px solid var(--border-color, #30363D);
}

.highlight pre {
    margin: 0;
    padding: 20px 24px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.highlight code {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.875rem;
    line-height: 1.7;
    tab-size: 4;
}

/* Scrollbar styling for code blocks */
.highlight pre::-webkit-scrollbar {
    height: 6px;
}

.highlight pre::-webkit-scrollbar-track {
    background: transparent;
}

.highlight pre::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
    border-radius: 3px;
}

.highlight pre::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* Chroma token colors - Dracula */
/* Background */         .bg { color:#f8f8f2; background-color:#161B22; }
/* PreWrapper */         .chroma { color:#f8f8f2; background-color:#161B22; }
/* Other */              .chroma .x {  }
/* Error */              .chroma .err {  }
/* CodeLine */           .chroma .cl {  }
/* LineLink */           .chroma .lnlinks { outline:none; text-decoration:none; color:inherit; }
/* LineTableTD */        .chroma .lntd { vertical-align:top; padding:0; margin:0; border:0; }
/* LineTable */          .chroma .lntable { border-spacing:0; padding:0; margin:0; border:0; width:100%; }
/* LineHighlight */      .chroma .hl { background-color:#2D333B; }
/* LineNumbersTable */   .chroma .lnt { white-space:pre; -webkit-user-select:none; user-select:none; margin-right:0.4em; padding:0 0.8em 0 0.4em; color:#484F58; }
/* LineNumbers */        .chroma .ln { white-space:pre; -webkit-user-select:none; user-select:none; margin-right:0.4em; padding:0 0.8em 0 0.4em; color:#484F58; }
/* Line */               .chroma .line { display:flex; }

/* Keywords - pink */
/* Keyword */            .chroma .k { color:#ff79c6; }
/* KeywordConstant */    .chroma .kc { color:#ff79c6; }
/* KeywordDeclaration */ .chroma .kd { color:#8be9fd; font-style:italic; }
/* KeywordNamespace */   .chroma .kn { color:#ff79c6; }
/* KeywordPseudo */      .chroma .kp { color:#ff79c6; }
/* KeywordReserved */    .chroma .kr { color:#ff79c6; }
/* KeywordType */        .chroma .kt { color:#8be9fd; }

/* Names - green */
/* Name */               .chroma .n {  }
/* NameAttribute */      .chroma .na { color:#50fa7b; }
/* NameBuiltin */        .chroma .nb { color:#8be9fd; font-style:italic; }
/* NameBuiltinPseudo */  .chroma .bp {  }
/* NameClass */          .chroma .nc { color:#50fa7b; }
/* NameConstant */       .chroma .no {  }
/* NameDecorator */      .chroma .nd {  }
/* NameEntity */         .chroma .ni {  }
/* NameException */      .chroma .ne {  }
/* NameFunction */       .chroma .nf { color:#50fa7b; }
/* NameFunctionMagic */  .chroma .fm {  }
/* NameLabel */          .chroma .nl { color:#8be9fd; font-style:italic; }
/* NameNamespace */      .chroma .nn {  }
/* NameOther */          .chroma .nx {  }
/* NameProperty */       .chroma .py {  }
/* NameTag */            .chroma .nt { color:#ff79c6; }
/* NameVariable */       .chroma .nv { color:#8be9fd; font-style:italic; }
/* NameVariableClass */  .chroma .vc { color:#8be9fd; font-style:italic; }
/* NameVariableGlobal */ .chroma .vg { color:#8be9fd; font-style:italic; }
/* NameVariableInst */   .chroma .vi { color:#8be9fd; font-style:italic; }
/* NameVariableMagic */  .chroma .vm {  }

/* Strings - yellow */
/* Literal */            .chroma .l {  }
/* LiteralDate */        .chroma .ld {  }
/* LiteralString */      .chroma .s { color:#f1fa8c; }
/* LiteralStringAffix */ .chroma .sa { color:#f1fa8c; }
/* LiteralStringBack */  .chroma .sb { color:#f1fa8c; }
/* LiteralStringChar */  .chroma .sc { color:#f1fa8c; }
/* LiteralStringDelim */ .chroma .dl { color:#f1fa8c; }
/* LiteralStringDoc */   .chroma .sd { color:#f1fa8c; }
/* LiteralStringDbl */   .chroma .s2 { color:#f1fa8c; }
/* LiteralStringEsc */   .chroma .se { color:#f1fa8c; }
/* LiteralStringHere */  .chroma .sh { color:#f1fa8c; }
/* LiteralStringInterp */.chroma .si { color:#f1fa8c; }
/* LiteralStringOther */ .chroma .sx { color:#f1fa8c; }
/* LiteralStringRegex */ .chroma .sr { color:#f1fa8c; }
/* LiteralStringSingle */.chroma .s1 { color:#f1fa8c; }
/* LiteralStringSymbol */.chroma .ss { color:#f1fa8c; }

/* Numbers - purple */
/* LiteralNumber */      .chroma .m { color:#bd93f9; }
/* LiteralNumberBin */   .chroma .mb { color:#bd93f9; }
/* LiteralNumberFloat */ .chroma .mf { color:#bd93f9; }
/* LiteralNumberHex */   .chroma .mh { color:#bd93f9; }
/* LiteralNumberInt */   .chroma .mi { color:#bd93f9; }
/* LiteralNumberIntLong*/.chroma .il { color:#bd93f9; }
/* LiteralNumberOct */   .chroma .mo { color:#bd93f9; }

/* Operators - pink */
/* Operator */           .chroma .o { color:#ff79c6; }
/* OperatorWord */       .chroma .ow { color:#ff79c6; }

/* Punctuation */        .chroma .p {  }

/* Comments - muted */
/* Comment */            .chroma .c { color:#6272a4; }
/* CommentHashbang */    .chroma .ch { color:#6272a4; }
/* CommentMultiline */   .chroma .cm { color:#6272a4; }
/* CommentSingle */      .chroma .c1 { color:#6272a4; }
/* CommentSpecial */     .chroma .cs { color:#6272a4; }
/* CommentPreproc */     .chroma .cp { color:#ff79c6; }
/* CommentPreprocFile */ .chroma .cpf { color:#ff79c6; }

/* Generic */
/* Generic */            .chroma .g {  }
/* GenericDeleted */     .chroma .gd { color:#f55; }
/* GenericEmph */        .chroma .ge { text-decoration:underline; }
/* GenericError */       .chroma .gr {  }
/* GenericHeading */     .chroma .gh { font-weight:bold; }
/* GenericInserted */    .chroma .gi { color:#50fa7b; font-weight:bold; }
/* GenericOutput */      .chroma .go { color:#44475a; }
/* GenericPrompt */      .chroma .gp {  }
/* GenericStrong */      .chroma .gs {  }
/* GenericSubheading */  .chroma .gu { font-weight:bold; }
/* GenericTraceback */   .chroma .gt {  }
/* GenericUnderline */   .chroma .gl { text-decoration:underline; }
/* TextWhitespace */     .chroma .w {  }

/* ===== Context-specific overrides ===== */

/* Blog/tutorial content */
.blog-post-content .highlight,
.content-card .highlight,
.page-content .highlight {
    margin: 24px 0;
}

/* Homepage code card - remove double border/radius when highlight is inside */
.code-card .highlight {
    margin: 0;
    border: none;
    border-radius: 0;
}

.code-card .highlight pre {
    padding: 24px;
}

/* Cheatsheet */
.cheat-card .highlight {
    margin: 0;
    border: none;
    border-radius: 0;
}

.cheat-card .highlight pre {
    padding: 1rem;
    font-size: 0.85rem;
}

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

.copy-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 6px;
    color: #8B949E;
    font-size: 0.75rem;
    font-family: 'Inter', sans-serif;
    cursor: pointer;
    transition: all 0.2s;
    opacity: 0;
    z-index: 1;
}

.highlight:hover .copy-btn,
.highlight-wrapper:hover .copy-btn {
    opacity: 1;
}

.copy-btn:hover {
    background: rgba(255, 255, 255, 0.2);
    color: #F0F6FC;
}

.copy-btn.copied {
    background: rgba(80, 250, 123, 0.2);
    border-color: rgba(80, 250, 123, 0.3);
    color: #50fa7b;
}

/* Inline code (not in highlight blocks) */
:not(pre) > code {
    padding: 2px 6px;
    background: var(--bg-tertiary, #21262D);
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.9em;
    color: #e6edf3;
}

/* Responsive */
@media (max-width: 768px) {
    .highlight pre {
        padding: 16px;
    }

    .highlight code {
        font-size: 0.8rem;
    }
}
