/* 网站全局样式 */
:root {
  --primary-color: #3b82f6;
  --secondary-color: #64748b;
  --accent-color: #8b5cf6;
  --dark-color: #1e293b;
  --light-color: #f1f5f9;
}

/* 滚动条样式 */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: #a1a1a1;
}

/* 暗色模式滚动条 */
.dark ::-webkit-scrollbar-track {
  background: #1f2937;
}

.dark ::-webkit-scrollbar-thumb {
  background: #374151;
}

.dark ::-webkit-scrollbar-thumb:hover {
  background: #4b5563;
}

/* 页面过渡动画 */
.page-content {
  transition: all 0.3s ease-in-out;
}

/* 侧边栏相关样式补充 */
.sidebar-item {
  position: relative;
}

.sidebar-item-active::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background-color: var(--primary-color);
  border-radius: 0 4px 4px 0;
}

/* 侧边栏响应式调整 */
@media (max-width: 1023px) {
  #sidebar {
    transform: translateX(-100%);
    position: fixed !important;
    z-index: 50 !important;
    height: 100vh !important;
  }

  #sidebar.open {
    transform: translateX(0);
  }

  main {
    margin-left: 0 !important;
  }
}

/* 加载动画 */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in {
  animation: fadeIn 0.5s ease-in-out;
}

/* Ping 动画 - 用于404页面装饰 */
@keyframes ping {
  0%,
  100% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.5);
    opacity: 0;
  }
}

.animate-ping {
  animation: ping 2s cubic-bezier(0, 0, 0.2, 1) infinite;
}

/* 404页面元素进入动画 */
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.slide-up {
  animation: slideUp 0.7s ease-out;
}

/* 404页面背景数字动画 */
@keyframes pulse {
  0%,
  100% {
    opacity: 0.05;
  }
  50% {
    opacity: 0.08;
  }
}

.pulse-slow {
  animation: pulse 4s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* 按钮交互效果 */
.contact-button {
  /* 移除暗色模式切换时的过渡效果 */
}

.contact-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  /* 保留悬停效果但不影响暗色模式切换 */
  transition: all 0.2s ease-in-out;
}

/* 响应式调整 */
@media (max-width: 768px) {
  .contact-button {
    padding: 3px;
  }

  .contact-button i {
    font-size: 1.2rem;
  }

  .contact-button span {
    display: none;
  }
}

/* 打印样式 */
@media print {
  #sidebar,
  #top-nav,
  #dark-mode-toggle,
  #mobile-menu-button,
  #sidebar-overlay {
    display: none !important;
  }

  .lg\:ml-64 {
    margin-left: 0 !important;
  }
}

/* 防止过度滚动效果 */
html,
body {
  overscroll-behavior: none;
  overflow-x: hidden;
}

/* 主要内容容器也应用同样的限制 */
main {
  overscroll-behavior: none;
}

/* 活跃日历样式优化 */
#calendar-grid {
  display: grid;
  gap: 1px;
  max-width: 100%;
  overflow: hidden;
  justify-content: start;
}

/* 代码块标题栏样式 */
.code-block-with-title {
  margin: 1.5rem 0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1),
    0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

.code-block-title-bar {
  background-color: #1f2937;
  color: white;
  padding: 0.375rem 1rem;
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}

.code-block-language {
  font-family: "Consolas", "Monaco", "Courier New", monospace;
  font-weight: 600;
  text-transform: uppercase;
}

.code-block-copy-button {
  background: none;
  border: none;
  color: #d1d5db;
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 0.25rem;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}

.code-block-copy-button:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: white;
}

.code-block-copy-button:focus {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
}

/* 暗色模式下的代码块标题栏样式 */
.dark .code-block-title-bar {
  background-color: #111827;
}

.dark .code-block-copy-button {
  color: #9ca3af;
}

.dark .code-block-copy-button:hover {
  background-color: rgba(255, 255, 255, 0.05);
  color: white;
}

/* 响应式调整日历单元格大小 */
@media (max-width: 768px) {
  #calendar-grid {
    transform: scaleX(calc(100vw / 636px)); /* 按比例缩放以适应屏幕宽度 */
    transform-origin: left center;
  }
}

/* 隐藏行内代码中的反引号 */
.prose code::before,
.prose code::after {
  content: "" !important;
}

/* 为行内代码添加适当的背景色和样式 */
.prose code {
  background-color: rgba(107, 114, 128, 0.1);
  padding: 0.2em 0.4em;
  border-radius: 0.375rem;
  font-family: "Consolas", "Monaco", "Courier New", monospace;
  font-size: 0.875em;
}

/* 暗色模式下的行内代码样式 */
.dark .prose code {
  background-color: rgba(156, 163, 175, 0.1);
}

/* 代码块样式 - 亮色模式 */
.prose pre {
  background-color: #f8f9fa !important;
  border: 1px solid #e9ecef !important;
  border-radius: 0.5rem !important;
  padding: 1rem !important;
  overflow-x: auto !important;
}

/* 代码块标题栏样式 - 亮色模式 */
.code-block-title-bar {
  background-color: #f1f3f5 !important;
  color: #212529 !important;
  border-bottom: 1px solid #e9ecef !important;
}

/* 代码块样式 - 暗色模式 */
.dark .prose pre {
  background-color: #1e293b !important;
  border: 1px solid #334155 !important;
}

/* 代码块标题栏样式 - 暗色模式 */
.dark .code-block-title-bar {
  background-color: #111827 !important;
  color: #f3f4f6 !important;
  border-bottom: 1px solid #334155 !important;
}

/* 更完整的代码语法高亮样式 - 亮色模式 */
.chroma {
  color: #212529 !important; /* 设置代码块基础文本颜色 */
}

.chroma .k {
  color: #007020;
  font-weight: bold;
} /* Keyword */
.chroma .kc {
  color: #007020;
  font-weight: bold;
} /* Keyword.Constant */
.chroma .kd {
  color: #007020;
  font-weight: bold;
} /* Keyword.Declaration */
.chroma .kn {
  color: #007020;
  font-weight: bold;
} /* Keyword.Namespace */
.chroma .kp {
  color: #007020;
} /* Keyword.Pseudo */
.chroma .kr {
  color: #007020;
  font-weight: bold;
} /* Keyword.Reserved */
.chroma .kt {
  color: #902000;
} /* Keyword.Type */
.chroma .s {
  color: #4070a0;
} /* String */
.chroma .sc {
  color: #4070a0;
} /* String.Char */
.chroma .sd {
  color: #4070a0;
  font-style: italic;
} /* String.Doc */
.chroma .s2 {
  color: #4070a0;
} /* String.Double */
.chroma .se {
  color: #4070a0;
  font-weight: bold;
} /* String.Escape */
.chroma .sh {
  color: #4070a0;
} /* String.Heredoc */
.chroma .si {
  color: #70a0d0;
  font-style: italic;
} /* String.Interpol */
.chroma .sx {
  color: #c65d09;
} /* String.Other */
.chroma .sr {
  color: #235388;
} /* String.Regex */
.chroma .s1 {
  color: #4070a0;
} /* String.Single */
.chroma .ss {
  color: #517918;
} /* String.Symbol */
.chroma .m {
  color: #40a070;
} /* Number */
.chroma .mb {
  color: #40a070;
} /* Number.Bin */
.chroma .mf {
  color: #40a070;
} /* Number.Float */
.chroma .mh {
  color: #40a070;
} /* Number.Hex */
.chroma .mi {
  color: #40a070;
} /* Number.Integer */
.chroma .il {
  color: #40a070;
} /* Number.Integer.Long */
.chroma .mo {
  color: #40a070;
} /* Number.Oct */
.chroma .o {
  color: #666666;
} /* Operator */
.chroma .ow {
  color: #007020;
  font-weight: bold;
} /* Operator.Word */
.chroma .p {
  color: #666666;
} /* Punctuation */
.chroma .c {
  color: #60a0b0;
  font-style: italic;
} /* Comment */
.chroma .ch {
  color: #60a0b0;
  font-style: italic;
} /* Comment.Hashbang */
.chroma .cm {
  color: #60a0b0;
  font-style: italic;
} /* Comment.Multiline */
.chroma .c1 {
  color: #60a0b0;
  font-style: italic;
} /* Comment.Single */
.chroma .cs {
  color: #60a0b0;
  background-color: #fff0f0;
} /* Comment.Special */
.chroma .gd {
  color: #a00000;
} /* Generic.Deleted */
.chroma .ge {
  font-style: italic;
} /* Generic.Emph */
.chroma .gr {
  color: #ff0000;
} /* Generic.Error */
.chroma .gh {
  color: #000080;
  font-weight: bold;
} /* Generic.Heading */
.chroma .gi {
  color: #00a000;
} /* Generic.Inserted */
.chroma .go {
  color: #888888;
} /* Generic.Output */
.chroma .gp {
  color: #c65d09;
  font-weight: bold;
} /* Generic.Prompt */
.chroma .gs {
  font-weight: bold;
} /* Generic.Strong */
.chroma .gu {
  color: #800080;
  font-weight: bold;
} /* Generic.Subheading */
.chroma .gt {
  color: #0044dd;
} /* Generic.Traceback */
.chroma .na {
  color: #008080;
} /* Name.Attribute */
.chroma .nb {
  color: #0086b3;
} /* Name.Builtin */
.chroma .nc {
  color: #445588;
  font-weight: bold;
} /* Name.Class */
.chroma .no {
  color: #008080;
} /* Name.Constant */
.chroma .nd {
  color: #3c5d5d;
  font-weight: bold;
} /* Name.Decorator */
.chroma .ni {
  color: #800080;
} /* Name.Entity */
.chroma .ne {
  color: #990000;
  font-weight: bold;
} /* Name.Exception */
.chroma .nf {
  color: #990000;
  font-weight: bold;
} /* Name.Function */
.chroma .nl {
  color: #990000;
  font-weight: bold;
} /* Name.Label */
.chroma .nn {
  color: #555555;
} /* Name.Namespace */
.chroma .nt {
  color: #000080;
  font-weight: bold;
} /* Name.Tag */
.chroma .nv {
  color: #008080;
} /* Name.Variable */
.chroma .vc {
  color: #008080;
} /* Name.Variable.Class */
.chroma .vg {
  color: #008080;
} /* Name.Variable.Global */
.chroma .vi {
  color: #008080;
} /* Name.Variable.Instance */
.chroma .vm {
  color: #008080;
} /* Name.Variable.Magic */
.chroma .w {
  color: #bbbbbb;
} /* Text.Whitespace */

/* 暗色模式下的语法高亮样式 */
.dark .chroma {
  color: #e2e8f0 !important; /* 设置暗色模式代码块基础文本颜色 */
}

.dark .chroma .k {
  color: #c586c0;
  font-weight: bold;
} /* Keyword */
.dark .chroma .kc {
  color: #c586c0;
  font-weight: bold;
} /* Keyword.Constant */
.dark .chroma .kd {
  color: #c586c0;
  font-weight: bold;
} /* Keyword.Declaration */
.dark .chroma .kn {
  color: #c586c0;
  font-weight: bold;
} /* Keyword.Namespace */
.dark .chroma .kp {
  color: #c586c0;
} /* Keyword.Pseudo */
.dark .chroma .kr {
  color: #c586c0;
  font-weight: bold;
} /* Keyword.Reserved */
.dark .chroma .kt {
  color: #569cd6;
} /* Keyword.Type */
.dark .chroma .s {
  color: #ce9178;
} /* String */
.dark .chroma .sc {
  color: #ce9178;
} /* String.Char */
.dark .chroma .sd {
  color: #ce9178;
  font-style: italic;
} /* String.Doc */
.dark .chroma .s2 {
  color: #ce9178;
} /* String.Double */
.dark .chroma .se {
  color: #ce9178;
  font-weight: bold;
} /* String.Escape */
.dark .chroma .sh {
  color: #ce9178;
} /* String.Heredoc */
.dark .chroma .si {
  color: #ce9178;
  font-style: italic;
} /* String.Interpol */
.dark .chroma .sx {
  color: #ce9178;
} /* String.Other */
.dark .chroma .sr {
  color: #ce9178;
} /* String.Regex */
.dark .chroma .s1 {
  color: #ce9178;
} /* String.Single */
.dark .chroma .ss {
  color: #ce9178;
} /* String.Symbol */
.dark .chroma .m {
  color: #b5cea8;
} /* Number */
.dark .chroma .mb {
  color: #b5cea8;
} /* Number.Bin */
.dark .chroma .mf {
  color: #b5cea8;
} /* Number.Float */
.dark .chroma .mh {
  color: #b5cea8;
} /* Number.Hex */
.dark .chroma .mi {
  color: #b5cea8;
} /* Number.Integer */
.dark .chroma .il {
  color: #b5cea8;
} /* Number.Integer.Long */
.dark .chroma .mo {
  color: #b5cea8;
} /* Number.Oct */
.dark .chroma .o {
  color: #d4d4d4;
} /* Operator */
.dark .chroma .ow {
  color: #c586c0;
  font-weight: bold;
} /* Operator.Word */
.dark .chroma .p {
  color: #d4d4d4;
} /* Punctuation */
.dark .chroma .c {
  color: #6a9955;
  font-style: italic;
} /* Comment */
.dark .chroma .ch {
  color: #6a9955;
  font-style: italic;
} /* Comment.Hashbang */
.dark .chroma .cm {
  color: #6a9955;
  font-style: italic;
} /* Comment.Multiline */
.dark .chroma .c1 {
  color: #6a9955;
  font-style: italic;
} /* Comment.Single */
.dark .chroma .cs {
  color: #6a9955;
} /* Comment.Special */
.dark .chroma .gd {
  color: #ff0000;
} /* Generic.Deleted */
.dark .chroma .ge {
  font-style: italic;
} /* Generic.Emph */
.dark .chroma .gr {
  color: #ff0000;
} /* Generic.Error */
.dark .chroma .gh {
  color: #d4d4d4;
  font-weight: bold;
} /* Generic.Heading */
.dark .chroma .gi {
  color: #00ff00;
} /* Generic.Inserted */
.dark .chroma .go {
  color: #808080;
} /* Generic.Output */
.dark .chroma .gp {
  color: #d4d4d4;
  font-weight: bold;
} /* Generic.Prompt */
.dark .chroma .gs {
  font-weight: bold;
} /* Generic.Strong */
.dark .chroma .gu {
  color: #d4d4d4;
  font-weight: bold;
} /* Generic.Subheading */
.dark .chroma .gt {
  color: #00ffff;
} /* Generic.Traceback */
.dark .chroma .na {
  color: #9cdcfe;
} /* Name.Attribute */
.dark .chroma .nb {
  color: #569cd6;
} /* Name.Builtin */
.dark .chroma .nc {
  color: #4ec9b0;
  font-weight: bold;
} /* Name.Class */
.dark .chroma .no {
  color: #4ec9b0;
} /* Name.Constant */
.dark .chroma .nd {
  color: #dcdcaa;
  font-weight: bold;
} /* Name.Decorator */
.dark .chroma .ni {
  color: #d16969;
} /* Name.Entity */
.dark .chroma .ne {
  color: #c586c0;
  font-weight: bold;
} /* Name.Exception */
.dark .chroma .nf {
  color: #dcdcaa;
  font-weight: bold;
} /* Name.Function */
.dark .chroma .nl {
  color: #dcdcaa;
  font-weight: bold;
} /* Name.Label */
.dark .chroma .nn {
  color: #4ec9b0;
} /* Name.Namespace */
.dark .chroma .nt {
  color: #569cd6;
  font-weight: bold;
} /* Name.Tag */
.dark .chroma .nv {
  color: #9cdcfe;
} /* Name.Variable */
.dark .chroma .vc {
  color: #9cdcfe;
} /* Name.Variable.Class */
.dark .chroma .vg {
  color: #9cdcfe;
} /* Name.Variable.Global */
.dark .chroma .vi {
  color: #9cdcfe;
} /* Name.Variable.Instance */
.dark .chroma .vm {
  color: #9cdcfe;
} /* Name.Variable.Magic */
.dark .chroma .w {
  color: #808080;
} /* Text.Whitespace */

.chroma .ln {
  margin-right: 0.5rem !important;
  padding-right: 0.5rem !important;
  border-right: 1px solid #dee2e6 !important;
  color: #6c757d !important;
  display: inline-block;
  text-align: right;
  width: 2rem;
}

.dark .chroma .ln {
  border-right: 1px solid #374151 !important;
  color: #9ca3af !important;
}

/* 修复代码块和标题栏之间的间距问题 */
.code-block-title-bar {
  margin-bottom: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.prose pre {
  margin-top: 0 !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
