newechoes/src/styles/articles.css

365 lines
8.2 KiB
CSS
Raw Normal View History

@import "./articles-table.css";
@import "./articles-mermaid.css";
@import "./articles-code.css";
2025-04-25 18:25:05 +08:00
2025-03-03 21:16:16 +08:00
/* 增强列表样式 */
.prose ul {
list-style-type: disc;
margin-top: 1.25em;
margin-bottom: 1.25em;
padding-left: 1.625em;
}
.prose ul li {
margin-top: 0.5em;
margin-bottom: 0.5em;
padding-left: 0.375em;
}
.prose ul li::marker {
color: #6b7280;
}
.prose ul li ul {
margin-top: 0.5em;
margin-bottom: 0.5em;
}
.prose ol {
list-style-type: decimal;
margin-top: 1.25em;
margin-bottom: 1.25em;
padding-left: 1.625em;
}
.prose ol li {
margin-top: 0.5em;
margin-bottom: 0.5em;
padding-left: 0.375em;
}
.prose ol li::marker {
color: #6b7280;
}
/* 标题样式 */
.prose h1 {
font-size: 2.25rem;
font-weight: 700;
margin-top: 2.5rem;
margin-bottom: 1.5rem;
color: var(--color-secondary-900);
border-bottom: 1px solid var(--color-secondary-200);
padding-bottom: 0.5rem;
position: relative;
}
.prose h1::after {
content: "";
position: absolute;
bottom: -1px;
left: 0;
width: 100px;
height: 3px;
background: linear-gradient(to right, var(--color-primary-600), var(--color-primary-400));
border-radius: 3px;
}
.prose h2 {
font-size: 1.875rem;
font-weight: 700;
margin-top: 2rem;
margin-bottom: 1.25rem;
color: var(--color-secondary-900);
border-bottom: 1px solid var(--color-secondary-200);
padding-bottom: 0.25rem;
position: relative;
}
.prose h2::after {
content: "";
position: absolute;
bottom: -1px;
left: 0;
width: 75px;
height: 2px;
background: linear-gradient(to right, var(--color-primary-500), var(--color-primary-300));
border-radius: 2px;
}
.prose h3 {
font-size: 1.5rem;
font-weight: 600;
margin-top: 1.75rem;
margin-bottom: 1rem;
color: var(--color-secondary-900);
position: relative;
padding-left: 1rem;
}
.prose h3::before {
content: "";
position: absolute;
left: 0;
top: 0.25em;
height: 1em;
width: 4px;
background: linear-gradient(to bottom, var(--color-primary-500), var(--color-primary-300));
border-radius: 2px;
}
.prose h4 {
font-size: 1.25rem;
font-weight: 600;
margin-top: 1.5rem;
margin-bottom: 0.75rem;
color: var(--color-secondary-900);
}
.prose h5 {
font-size: 1.125rem;
font-weight: 600;
margin-top: 1.25rem;
margin-bottom: 0.75rem;
color: var(--color-secondary-900);
}
.prose h6 {
font-size: 1rem;
font-weight: 600;
margin-top: 1.25rem;
margin-bottom: 0.75rem;
color: var(--color-secondary-700);
}
/* 标题锚点样式 */
.prose h1 .anchor,
.prose h2 .anchor,
.prose h3 .anchor,
.prose h4 .anchor,
.prose h5 .anchor,
.prose h6 .anchor {
visibility: hidden;
margin-left: 0.5rem;
color: #a0aec0;
text-decoration: none;
}
.prose h1:hover .anchor,
.prose h2:hover .anchor,
.prose h3:hover .anchor,
.prose h4:hover .anchor,
.prose h5:hover .anchor,
.prose h6:hover .anchor {
visibility: visible;
}
/* 暗色模式 */
[data-theme="dark"] .prose {
color: var(--color-secondary-300);
}
[data-theme="dark"] .prose h1,
[data-theme="dark"] .prose h2,
[data-theme="dark"] .prose h3,
[data-theme="dark"] .prose h4,
[data-theme="dark"] .prose h5 {
color: var(--color-secondary-100);
}
[data-theme="dark"] .prose h6 {
color: var(--color-secondary-300);
}
2025-03-08 18:16:42 +08:00
/* 引用样式 */
.prose blockquote {
margin: 1.5em 0;
padding: 1em 1.5em;
border-left: 4px solid var(--color-primary-500);
background-color: var(--color-gray-100);
border-radius: 0.5rem;
font-style: italic;
color: var(--color-secondary-700);
}
.prose blockquote p {
margin: 0;
}
.prose blockquote p + p {
margin-top: 1em;
}
/* 链接样式 */
.prose a {
color: var(--color-primary-600);
text-decoration: none;
border-bottom: 1px solid var(--color-primary-300);
transition: all 0.2s ease;
}
.prose a:hover {
color: var(--color-primary-800);
border-bottom-color: var(--color-primary-600);
}
/* 暗色模式适配 */
[data-theme="dark"] .prose blockquote {
background-color: var(--color-dark-surface);
border-left-color: var(--color-primary-400);
color: var(--color-secondary-300);
}
[data-theme="dark"] .prose a {
color: var(--color-primary-400);
border-bottom-color: var(--color-primary-600);
}
[data-theme="dark"] .prose a:hover {
color: var(--color-primary-300);
border-bottom-color: var(--color-primary-400);
}
/* 响应式样式 */
2025-03-08 18:16:42 +08:00
@media (max-width: 640px) {
/* 移除所有表格相关样式 */
2025-03-08 18:16:42 +08:00
}
/* 收纳内容样式 */
.details-content {
margin-left: 1.5em;
padding: 1em;
background-color: var(--color-gray-100);
border-left: 4px solid var(--color-primary-500);
margin-bottom: 1em;
border-radius: 0.5rem;
}
[data-theme="dark"] .details-content {
background-color: var(--color-dark-surface);
border-left-color: var(--color-primary-400);
}
/* 收纳标题样式 */
.prose details {
margin: 1.5em 0;
border-radius: 0.5rem;
border: 1px solid var(--color-secondary-200);
background-color: var(--color-gray-50);
transition: all 0.2s ease;
overflow: hidden;
}
/* 添加 details 内部内容的内边距 */
.prose details > *:not(summary) {
padding: 1.5em;
margin: 0;
}
.prose details > p,
.prose details > ul,
.prose details > ol,
.prose details > div {
margin-top: 0;
margin-bottom: 1em;
}
.prose details > *:last-child {
margin-bottom: 0;
}
2025-03-08 18:16:42 +08:00
.prose details summary {
padding: 1em;
cursor: pointer;
position: relative;
font-weight: 500;
color: var(--color-secondary-900);
list-style: none;
display: flex;
align-items: center;
gap: 0.75em;
transition: all 0.2s ease;
background: linear-gradient(to right, var(--color-primary-50), var(--color-gray-50));
border-left: 4px solid var(--color-primary-100);
}
.prose details summary::-webkit-details-marker {
display: none;
}
.prose details summary::before {
content: "";
width: 20px;
height: 20px;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234b6bff'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5l7 7-7 7'%3E%3C/path%3E%3C/svg%3E");
background-size: contain;
background-repeat: no-repeat;
transition: transform 0.3s ease;
flex-shrink: 0;
}
.prose details[open] summary {
border-left: 4px solid var(--color-primary-500);
background: linear-gradient(to right, var(--color-primary-100), var(--color-gray-50));
border-bottom: 1px solid var(--color-secondary-200);
}
.prose details[open] summary::before {
transform: rotate(90deg);
}
.prose details summary:hover {
background: linear-gradient(to right, var(--color-primary-100), var(--color-gray-100));
color: var(--color-primary-700);
}
.prose details > blockquote {
margin: 0;
padding: 1.5em;
border-radius: 0;
border-left: 4px solid var(--color-primary-500);
background: linear-gradient(to right, var(--color-primary-50/50), var(--color-gray-50));
}
.prose details > blockquote p:first-child {
margin-top: 0;
}
.prose details > blockquote p:last-child {
margin-bottom: 0;
}
/* 暗色模式适配 */
[data-theme="dark"] .prose details {
2025-03-03 21:16:16 +08:00
border-color: var(--color-dark-border);
2025-03-08 18:16:42 +08:00
background-color: var(--color-dark-surface);
}
[data-theme="dark"] .prose details summary {
color: var(--color-secondary-100);
background: linear-gradient(to right, var(--color-dark-surface), var(--color-dark-card));
border-left-color: var(--color-primary-800);
}
[data-theme="dark"] .prose details[open] summary {
border-bottom-color: var(--color-dark-border);
}
[data-theme="dark"] .prose details summary::before {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23839dff'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5l7 7-7 7'%3E%3C/path%3E%3C/svg%3E");
}
[data-theme="dark"] .prose details[open] summary {
background: linear-gradient(to right, var(--color-dark-card), var(--color-dark-surface));
border-left-color: var(--color-primary-400);
}
[data-theme="dark"] .prose details summary:hover {
background: linear-gradient(to right, var(--color-primary-900/30), var(--color-dark-card));
color: var(--color-primary-400);
}
[data-theme="dark"] .prose details > blockquote {
background: linear-gradient(to right, var(--color-primary-900/10), var(--color-dark-surface));
border-left-color: var(--color-primary-400);
}