Skip to content

Instantly share code, notes, and snippets.

@sreetamdas
Created June 9, 2021 07:04
Show Gist options
  • Save sreetamdas/2c13d70d68ba6f19c17601d03c17f467 to your computer and use it in GitHub Desktop.
Save sreetamdas/2c13d70d68ba6f19c17601d03c17f467 to your computer and use it in GitHub Desktop.
Fork of obsidian theme by bencodezen, with slightly modified font family
/*------------- --------------------*/
/* Typography */
/*------------- --------------------*/
/*-----------------------------*/
/* Colors */
/*-----------------------------*/
/*-------------------------------------*/
/* CSS Variables */
/*-------------------------------------*/
:root {
--font-size-normal: 16px;
--font-size-code: 14px;
--font-size-side-dock: 12px;
--font-size-side-dock-title: 14px;
--font-size-status-bar: 12px;
--font-size-h1: 32px;
--font-size-h2: 28px;
--font-size-h3: 24px;
--font-size-h4: 20px;
--font-size-h5: 18px;
--font-size-h6: 16px;
--font-family-editor: "Iosevka", "Source Code Pro", monospace;
--font-family-preview: "Avenir", "Avenir Next", sans-serif;
--font-family-preview-heading: "Avenir", "Avenir Next", sans-serif;
}
.theme-light,
.theme-dark {
--background-primary: #011628;
--background-primary-alt: #011c32;
--background-secondary: #011c32;
--background-secondary-alt: #02223c;
--background-accent: #f8f8f2;
--background-modifier-border: #f8f8f2;
--background-modifier-form-field: rgba(0, 0, 0, 0.2);
--background-modifier-form-field-highlighted: rgba(0, 0, 0, 0.5);
--background-modifier-box-shadow: rgba(0, 0, 0, 0.3);
--background-modifier-success: #50fa7b;
/*no sure*/
--background-modifier-error: #3d0000;
/*no sure*/
--background-modifier-error-rgb: 61, 0, 0;
--background-modifier-error-hover: #470000;
--background-modifier-cover: rgba(0, 0, 0, 0.6);
--text-accent: #ffeb95;
--text-accent-hover: #8be9fd;
--text-normal: #f8f8f2;
--text-muted: #f8f8f2;
--text-faint: #7fdbca;
--text-highlight-bg: rgba(160, 163, 0, 0.8);
--text-error: #ff79c6;
--text-error-hover: #ff79c6;
--text-selection: #6272a4;
/* Chromium precess this color with alpha channel */
--text-on-accent: #bd93f9;
--interactive-normal: #ffb86c;
--interactive-hover: #ff5555;
--interactive-accent: #ffeb95;
--interactive-accent-rgb: 123, 108, 217;
--interactive-accent-hover: #ff5555;
--scrollbar-active-thumb-bg: #282a36;
--scrollbar-bg: #282a36;
--scrollbar-thumb-bg: #282a36;
--text-title-h1: #ff79c6;
--text-title-h2: #82aaff;
--text-title-h3: #c5e478;
--text-title-h4: #ffb86c;
--text-title-h5: #50fa7b;
--text-title-h6: #8be9fd;
--inline-code: #bd93f9;
--code-block: #8be9fd;
--pre-code: #44475a;
--blockquote-border: #ffb86c;
--vim-cursor: #ff5555;
--border-color: #2b2727;
/*also like transparent*/
}
/*-------------------------------------*/
/* Search the following lines */
/* to jump to specific section */
/*-------------------------------------*/
/* resize-handle and borders */
/* tags */
/* link */
/* Cursor */
/* basic format in EDITOR and PREVIEW */
/* Headings - EDITOR and PREVIEW */
/* Code block in Preview */
/* Code block in Editor */
/* Brackets */
/* Blockquote */
/* table */
/* Checkbox */
/* html in editor */
/* popover */
/* Side panel */
/* internal embedded link in preview */
/* graph view */
/* settings */
/* Hide side bar */
/* width of content */
/* note header bar for non-andy mode */
/* andy mode activated in light mode */
/* at a rule line before ul list *
/* Hide Scrollbar (recommend for mac) */
/*-------------------------------------*/
/***************************************/
/* resize-handle and borders */
/***************************************/
/*vertical resize-handle*/
.workspace-split.mod-vertical > * > .workspace-leaf-resize-handle,
.workspace-split.mod-left-split > .workspace-leaf-resize-handle,
.workspace-split.mod-right-split > .workspace-leaf-resize-handle {
width: 1px !important;
background-color: var(--border-color);
}
/*horizontal resize-handle*/
.workspace-split.mod-horizontal > * > .workspace-leaf-resize-handle {
height: 1px !important;
background-color: var(--border-color);
}
/*workspace ribbon when collapsed*/
.workspace-ribbon.is-collapsed {
background-color: var(--background-primary-alt);
}
/*the vertical split*/
.workspace-split.mod-root .workspace-split.mod-vertical .workspace-leaf-content,
.workspace-split.mod-vertical > .workspace-split,
.workspace-split.mod-vertical > .workspace-leaf,
.workspace-tabs {
padding-right: 0px;
}
/*status-bar*/
.status-bar {
font-size: var(--font-size-status-bar);
background-color: var(--background-secondary-alt);
border-top: 0px;
}
.document-search-container {
border-top: 0px;
border-right: 0px;
z-index: inherit;
}
.workspace-ribbon.mod-left.is-collapsed {
border-right: 1px solid var(--border-color);
}
.workspace-ribbon.mod-right.is-collapsed {
border-left: 1px solid var(--border-color);
}
/*************************************/
/* tags */
/*************************************/
/* Tag hover in preview */
a.tag:hover {
color: var(--text-accent) !important;
}
/* Tag Color in editor and preview*/
.cm-hashtag,
a.tag {
color: var(--text-accent-hover) !important;
text-decoration: none !important;
font-style: normal !important;
}
/*********************************/
/* link */
/*********************************/
/* link */
a,
.internal-link,
.cm-hmd-internal-link,
.cm-link,
.cm-formatting-link,
.cm-url {
text-decoration: none !important;
}
/* the url string in editor */
.cm-s-obsidian span.cm-string {
color: var(--text-accent-hover) !important;
}
/* make external links italics to differentiate */
a:not(.internal-link) {
font-style: italic;
}
/*footnote*/
.cm-s-obsidian pre.HyperMD-footnote span.cm-hmd-footnote,
.cm-s-obsidian span.cm-footref {
color: var(--text-accent) !important;
}
/***************************************/
/* Cursor */
/***************************************/
/* Cursor color and opacity */
.cm-fat-cursor .CodeMirror-cursor,
.cm-animate-fat-cursor {
width: 0.5em;
background: var(--vim-cursor);
opacity: 60% !important;
}
/**************************************/
/* basic format in EDITOR and PREVIEW */
/**************************************/
/* font for everything outside of editor/preview panes */
.app-container {
font-family: var(--font-family-preview);
}
/* set the text selection color for preview mode */
::selection {
background-color: var(--text-selection);
}
/* normal text outside of headings and code of editor */
.cm-s-obsidian,
.mod-single-child .cm-s-obsidian {
font-family: var(--font-family-editor);
font-size: var(--font-size-normal);
}
.cm-hmd-frontmatter {
font-family: var(--font-family-editor) !important;
}
.cm-comment.cm-hmd-frontmatter {
font-weight: bold;
}
/* bold in preview and editor */
strong,
.cm-strong {
font-weight: 600;
color: #50fa7b;
}
/* emphasis in preview and editor */
em,
.cm-em {
color: var(--text-muted);
font-style: italic;
}
/* strikethrough in preview and editor */
s,
.cm-strikethrough {
color: var(--text-muted);
}
/* list in editor */
.cm-s-obsidian span.cm-formatting-list {
color: var(--text-normal) !important;
}
/* horizontal line in preview */
.markdown-preview-view hr {
background-color: var(--text-faint) !important;
}
/* embedded images */
img {
display: block;
margin-left: auto;
margin-right: auto;
}
/* img hover zoom out img*/
img:hover {
transform: scale(1.04);
transition: transform 0.25s ease-in-out 0s;
}
.community-theme img:hover {
transform: none;
}
/***************************************/
/* Code block in Preview */
/***************************************/
/* code blocks in preview */
pre code {
font-family: var(--font-family-editor) !important;
font-size: var(--font-size-code) !important;
padding: 6px !important;
line-height: normal;
display: block;
color: var(--code-block) !important;
}
/* padding of code blocks in preview */
.markdown-preview-view pre {
padding: 0px !important;
}
/* font-size of in-line block for preview */
.markdown-preview-view code {
font-size: var(--font-size-code);
}
/* remove the shadow that typically affect light mode */
.theme-dark code[class*="language-"],
.theme-dark pre[class*="language-"],
.theme-light code[class*="language-"],
.theme-light pre[class*="language-"] {
text-shadow: none !important;
color: var(--text-faint) !important;
background-color: var(--pre-code);
}
/***************************************/
/* Brackets */
/***************************************/
.cm-s-obsidian span.cm-formatting-link {
color: var(--text-accent) !important;
}
/***************************************/
/* Blockquote */
/***************************************/
/* for editor */
.cm-quote {
color: var(--text-normal) !important;
font-style: italic;
}
/* for preview */
.markdown-preview-view blockquote {
background-color: var(--pre-code);
border: 0px solid;
border-color: var(--blockquote-border) !important;
border-left-width: 4px !important;
border-radius: 0 8px 8px 0;
line-height: 1.5em;
margin: 30px 0px;
font-style: italic;
}
/***************************************/
/* table */
/***************************************/
th {
font-weight: 800 !important;
}
.markdown-preview-view th {
font-weight: 800;
background-color: var(--background-secondary) !important;
}
thead {
border-bottom: 3px solid var(--background-modifier-border);
}
.table {
padding: 4px;
line-height: normal;
display: block;
border-top-left-radius: 4px;
border-top-right-radius: 4px;
border-bottom-right-radius: 4px;
border-bottom-left-radius: 4px;
}
/***************************************/
/* popover */
/***************************************/
.popover {
border: 1px solid var(--border-color);
background-color: var(--background-secondary);
}
/***************************************/
/* Side panel */
/***************************************/
/* search result in backlink or file search */
.search-result-file-title {
font-size: 15px;
}
.search-result-file-matches,
.search-empty-state {
font-size: var(--font-size-side-dock);
}
/*decrease the spacing between result items*/
.search-result-file-title,
.search-result-file-match {
padding: 0px 10px;
}
.nav-file-title,
.nav-folder-title {
border-bottom-left-radius: 0 !important;
border-bottom-right-radius: 0 !important;
border-top-left-radius: 0 !important;
border-top-right-radius: 0 !important;
}
/*backlink pane*/
.workspace-leaf-content[data-type="backlink"] .view-content {
background-color: var(--background-secondary);
}
.workspace-leaf-content[data-type="tag"] .tag-pane-tag-count,
.workspace-leaf-content[data-type="tag"] .tag-pane-tag-text {
font-size: var(--font-size-side-dock);
}
.workspace-leaf-content[data-type="backlink"] .search-result-file-matches {
font-size: var(--font-size-side-dock);
}
/***************************************/
/* internal embedded link in preview */
/***************************************/
/* Naked Embeds */
.markdown-embed-title {
display: none;
}
.markdown-preview-view .markdown-embed-content > :first-child {
margin-top: 0;
}
.markdown-preview-view .markdown-embed-content > :last-child {
margin-bottom: 0;
}
/*remove the following two line, you will get border and scroll*/
.markdown-preview-view .markdown-embed {
border: none;
padding: 0;
margin: 0;
}
.markdown-preview-view .markdown-embed-content {
max-height: unset;
background-color: var(--background-secondary);
}
/* the link on the top right corner*/
.markdown-embed-link {
color: var(--text-faint) !important;
}
.markdown-embed-link:hover {
color: var(--text-accent) !important;
}
/***************************************/
/* graph view */
/***************************************/
.graph-view.color-circle,
.graph-view.color-fill-highlight,
.graph-view.color-line-highlight {
color: var(--text-accent) !important;
}
.graph-view.color-text {
color: var(--text-normal) !important;
}
.graph-view.color-line {
color: #6272a4;
}
.graph-view.color-fill {
color: var(--text-muted);
}
.workspace-leaf-content[data-type="graph"] .view-content {
background-color: var(--background-primary);
}
/***************************************/
/* settings */
/***************************************/
.modal.mod-settings button:not(.mod-cta):hover {
background-color: var(--interactive-accent-hover);
}
/***************************************/
/* Hide side bar */
/***************************************/
.workspace-ribbon:not(:hover) .workspace-ribbon-collapse-btn,
.workspace-ribbon:not(:hover) .side-dock-actions,
.workspace-ribbon:not(:hover) .side-dock-settings {
display: none;
transition: all 300ms ease-in-out;
}
.workspace-ribbon:not(:hover) {
width: 0px;
transition: all 300ms ease-in-out;
}
.workspace-split.mod-left-split {
margin-left: 0px;
}
.workspace-split.mod-right-split {
margin-right: 0px;
}
/***************************************/
/* width of content */
/***************************************/
.markdown-source-view.is-readable-line-width .CodeMirror {
max-width: 900px;
margin-left: auto;
margin-right: auto;
}
.markdown-preview-view.is-readable-line-width .markdown-preview-section {
max-width: 900px;
margin-left: auto;
margin-right: auto;
}
/* shift sticky position, so titles will stack up to the left */
/* This will currently stack to a maximum of 10 before resetting */
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-8) {
left: calc(var(--sticky-left) * 0);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-7) {
left: calc(var(--sticky-left) * 1);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-6) {
left: calc(var(--sticky-left) * 2);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-5) {
left: calc(var(--sticky-left) * 3);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-4) {
left: calc(var(--sticky-left) * 4);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-3) {
left: calc(var(--sticky-left) * 5);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-2) {
left: calc(var(--sticky-left) * 6);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n-1) {
left: calc(var(--sticky-left) * 7);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n + 0) {
left: calc(var(--sticky-left) * 8);
}
.theme-light .mod-root.workspace-split.mod-vertical > div:nth-child(10n + 1) {
left: calc(var(--sticky-left) * 9);
}
/* now it's time for the fancy vertical titles */
/* first we'll add a bit of gap for the title to sit inside of */
.theme-light .workspace-leaf-content {
padding-left: var(--sticky-left);
position: relative;
}
/* this is where the magic happens */
.theme-light .view-header {
writing-mode: vertical-lr;
border-right: 1px solid var(--border-color);
border-left: 0px !important;
border-top: none;
border-bottom: none;
height: auto;
width: 36px;
position: absolute;
left: 0;
top: 0;
bottom: 0;
background-color: var(--background-primary) !important;
}
/* fix the long-title-obscuring shadows */
.theme-light .view-header-title-container:after {
width: 100%;
height: 30px;
top: unset;
bottom: 0;
background: linear-gradient(
to bottom,
transparent,
var(--background-primary)
) !important;
}
/* unset the title container height and swap padding */
.theme-light .view-header-title-container {
height: unset;
padding-left: unset;
padding-top: 5px;
}
/* active titles have different border colours */
.theme-light .workspace-leaf.mod-active .view-header {
background-color: var(--background-secondary-alt) !important;
border-right: 3px solid var(--interactive-accent) !important;
border-left: 0px;
border-bottom: none;
}
/* swap the padding/margin around for the header and actions icons */
.theme-light .view-header-icon,
.theme-light .view-actions {
padding: 10px 5px;
}
.theme-light .view-action {
margin: 8px 0;
}
/* get rid of the gap left by the now-missing horizontal title */
.theme-light .view-content {
height: 100%;
}
/* make the fake drop target overlay have a background so you can see it. */
/* TODO: figure out how the fake target overlay works so we can put the title back, too */
.theme-light .workspace-fake-target-overlay {
background-color: var(--background-primary);
}
/*preview padding too small*/
.theme-light .markdown-preview-view,
.theme-light .mod-single-child .markdown-preview-view {
font-family: var(--font-family-editor);
font-size: var(--font-size-normal);
padding-top: 5px;
padding-left: 4% !important;
padding-right: 2% !important;
}
/***************************************/
/* at a rule line before ul list */
/***************************************/
ul ul {
position: relative;
}
ul ul::before {
content: "";
border-left: 1px solid var(--border-color);
position: absolute;
}
ul ul::before {
left: -1em;
top: 0;
bottom: 0;
}
/***************************************/
/* Code block in Editor */
/***************************************/
/* in-line block for editor */
.cm-s-obsidian span.cm-inline-code,
.cm-s-obsidian span.cm-inline-code.cm-hmd-indented-code,
.cm-s-obsidian
span.cm-inline-code:not(.cm-formatting):not(.cm-hmd-indented-code) {
background-color: var(--pre-code-bg);
color: var(--inline-code) !important;
bottom: 0px !important;
}
/* Editor CodeBlock TEXT Appearance */
.cm-s-obsidian pre.HyperMD-codeblock {
font-family: var(--font-family-editor) !important;
font-size: var(--font-size-code) !important;
padding: 1px !important;
display: block;
color: var(--code-block) !important;
font-weight: 500;
text-indent: 0px !important;
}
/*remove the border of codeblock in editor */
.HyperMD-codeblock-bg {
border: 0px !important;
}
/*an active line highlight in vim normal mode
.cm-fat-cursor .CodeMirror-activeline .CodeMirror-linebackground{
background-color: var(--text-selection) !important;
} */
/* in-line block for preview */
code {
color: var(--inline-code) !important;
bottom: 0px !important;
}
/* graph css */
.theme-dark .graph-view.color-arrow {
color: #50fa7b;
}
.theme-dark .graph-view.color-fill-tag {
color: #ffb86c;
}
.theme-dark .graph-view.color-fill-attachment {
color: #ff5555;
}
.theme-dark .graph-view.color-fill-unresolved {
color: #6272a4;
}
.search-result-collapse-indicator {
position: absolute;
left: 0;
top: -3px;
color: var(--text-faint);
transition: transform 100ms ease-in-out;
padding: 0px !important;
}
body {
font-size: var(--font-size-normal);
}
.nav-file-title,
.nav-folder-title {
border: 1px solid transparent;
border-radius: 3px;
cursor: pointer;
color: var(--text-muted);
font-size: 0.85rem;
line-height: 20px;
padding: 1px 20px 0 26px;
position: relative;
white-space: nowrap;
width: max-content;
min-width: 100%;
}
.markdown-preview-view .list-collapse-indicator {
margin-left: -60px;
padding-left: 8px;
}
/* rule line when there are checkboxes*/
ul .task-list-item ul::before {
left: 0.15em !important;
}
/***************************************/
/* Checkbox */
/***************************************/
.markdown-preview-view .task-list-item-checkbox {
-webkit-appearance: none;
top: 0.2em !important;
right: 8px;
box-sizing: border-box;
position: relative;
width: 1rem;
height: 1rem;
margin: 0;
box-shadow: 0 0 0.1em var(--text-muted);
}
.markdown-preview-view .task-list-item-checkbox:checked::before {
content: "✓";
position: absolute;
left: -1px;
top: -3px;
color: var(--text-accent);
font-size: 1rem;
line-height: 1.25rem;
width: 1.2rem;
text-align: center;
text-shadow: 0 0 0.1rem var(--text-accent);
}
.markdown-preview-view ul > li.task-list-item.is-checked {
text-decoration: none;
}
.checkbox-container {
background-color: var(--background-primary);
}
/**************************************/
/* note header bar for non-andy mode */
/* activated in dark mode */
/**************************************/
/* header */
.theme-dark .view-header {
background-color: var(--background-primary) !important;
border-top: 1px solid var(--border-color) !important;
border-bottom: 1px solid var(--border-color) !important;
}
.theme-dark .view-header-title-container:after {
background: linear-gradient(
to bottom,
transparent,
var(--background-primary)
) !important;
}
.theme-dark .workspace-leaf.mod-active .view-header {
background-color: var(--background-primary-alt) !important;
border-top: 0px !important;
border-bottom: 3px solid var(--interactive-accent) !important;
}
.workspace-leaf.mod-active .view-header-title-container:after {
background: linear-gradient(
to bottom,
transparent,
var(--background-secondary-alt)
) !important;
}
.workspace-leaf.mod-active .view-header-title,
.workspace-leaf.mod-active .view-header-icon {
color: var(--background-modifier-border);
}
.view-header-title,
.view-header-icon,
.view-action {
color: var(--text-faint);
}
.cm-header-1 {
font-family: var(--font-family-editor);
font-weight: 500;
font-size: var(--font-size-h1);
color: var(--text-title-h1);
}
.cm-header-2 {
font-family: var(--font-family-editor);
font-weight: 500;
font-size: var(--font-size-h2);
color: var(--text-title-h2);
}
.cm-header-3 {
font-family: var(--font-family-editor);
font-weight: 500;
font-size: var(--font-size-h3);
color: var(--text-title-h3);
}
.cm-header-4 {
font-family: var(--font-family-editor);
font-weight: 500;
font-size: var(--font-size-h4);
color: var(--text-title-h4);
}
.cm-header-5 {
font-family: var(--font-family-editor);
font-weight: 500;
font-size: var(--font-size-h5);
color: var(--text-title-h5);
}
.cm-header-6 {
font-family: var(--font-family-editor);
font-weight: 500;
font-size: var(--font-size-h6);
color: var(--text-title-h6);
}
.markdown-preview-view h1 {
font-family: var(--font-family-preview-heading);
font-size: var(--font-size-h1);
color: var(--text-title-h1);
}
.markdown-preview-view h2 {
font-family: var(--font-family-preview-heading);
font-size: var(--font-size-h2);
color: var(--text-title-h2);
}
.markdown-preview-view h3 {
font-family: var(--font-family-preview-heading);
font-size: var(--font-size-h3);
color: var(--text-title-h3);
}
.markdown-preview-view h4 {
font-family: var(--font-family-preview-heading);
font-size: var(--font-size-h4);
color: var(--text-title-h4);
}
.markdown-preview-view h5 {
font-family: var(--font-family-preview-heading);
font-size: var(--font-size-h5);
color: var(--text-title-h5);
}
.markdown-preview-view h6 {
font-family: var(--font-family-preview-heading);
font-size: var(--font-size-h6);
color: var(--text-title-h6);
}
.markdown-preview-view h1 {
font-weight: 900;
}
.markdown-preview-view h2 {
font-weight: 800;
}
.markdown-preview-view h3 {
font-weight: 700;
}
.markdown-preview-view h4 {
font-weight: 600;
}
.markdown-preview-view h5,
.markdown-preview-view h6 {
font-weight: 500;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment