/* ===== CODE BLOCKS COMPONENT ===== */
/* For displaying syntax-highlighted code in blog articles */

:root {
  --code-bg: #1e1e2e;
  --code-fg: #cdd6f4;
}

.code-block {
  background: var(--code-bg);
  border-radius: 10px;
  padding: 1.5rem 1.8rem;
  margin: 1.5rem 0 2rem;
  overflow-x: auto;
  position: relative;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

.code-block::before {
  content: attr(data-lang);
  position: absolute;
  top: 0.6rem;
  right: 1rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(205, 214, 244, 0.3);
}

.code-block pre {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.78rem;
  line-height: 1.7;
  color: var(--code-fg);
  white-space: pre;
  margin: 0;
}

/* Syntax highlighting colors (Catppuccin-inspired) */
.code-block .kw { color: #cba6f7; }  /* Keywords - purple */
.code-block .ty { color: #89b4fa; }  /* Types - blue */
.code-block .fn { color: #a6e3a1; }  /* Functions - green */
.code-block .str { color: #f9e2af; } /* Strings - yellow */
.code-block .cm { color: #6c7086; font-style: italic; } /* Comments - muted */
.code-block .op { color: #89dceb; }  /* Operators - cyan */
.code-block .num { color: #fab387; } /* Numbers - orange */
.code-block .param { color: #f38ba8; } /* Parameters - pink */

/* Inline code */
code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.88em;
  background: rgba(0, 0, 0, 0.05);
  padding: 0.2em 0.4em;
  border-radius: 3px;
  color: #c44b2b;
}

/* Copy button (optional enhancement) */
.code-block-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.code-block-lang {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(205, 214, 244, 0.5);
}

.code-copy-btn {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--code-fg);
  padding: 0.3rem 0.7rem;
  border-radius: 4px;
  font-size: 0.7rem;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: 'Source Sans 3', sans-serif;
}

.code-copy-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.3);
}

.code-copy-btn.copied {
  background: #a6e3a1;
  color: #1e1e2e;
  border-color: #a6e3a1;
}

/* Scrollbar for code blocks */
.code-block::-webkit-scrollbar {
  height: 8px;
}

.code-block::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 4px;
}

.code-block::-webkit-scrollbar-thumb {
  background: rgba(205, 214, 244, 0.3);
  border-radius: 4px;
}

.code-block::-webkit-scrollbar-thumb:hover {
  background: rgba(205, 214, 244, 0.5);
}

/* Responsive */
@media (max-width: 768px) {
  .code-block {
    padding: 1rem 1.2rem;
    margin: 1rem 0 1.5rem;
  }

  .code-block pre {
    font-size: 0.75rem;
  }
}
