| @reference "./tailwind.css"; |
|
|
| @font-face { |
| font-family: 'Inter'; |
| src: url('/assets/fonts/Inter-Variable.ttf'); |
| font-display: swap; |
| } |
|
|
| @font-face { |
| font-family: 'Archivo'; |
| src: url('/assets/fonts/Archivo-Variable.ttf'); |
| font-display: swap; |
| } |
|
|
| @font-face { |
| font-family: 'Mona Sans'; |
| src: url('/assets/fonts/Mona-Sans.woff2'); |
| font-display: swap; |
| } |
|
|
| @font-face { |
| font-family: 'InstrumentSerif'; |
| src: url('/assets/fonts/InstrumentSerif-Regular.ttf'); |
| font-display: swap; |
| } |
|
|
| @font-face { |
| font-family: 'Vazirmatn'; |
| src: url('/assets/fonts/Vazirmatn-Variable.ttf'); |
| font-display: swap; |
| } |
|
|
| |
| :root { |
| --app-text-scale: 1; |
| } |
|
|
| html { |
| word-break: break-word; |
| |
| font-size: calc(1rem * var(--app-text-scale, 1)); |
| } |
|
|
| #sidebar-chat-item { |
| |
| min-height: calc(32px * var(--app-text-scale, 1)); |
| padding-inline: calc(11px * var(--app-text-scale, 1)); |
| padding-block: calc(6px * var(--app-text-scale, 1)); |
| } |
|
|
| #sidebar-chat-item div[dir='auto'] { |
| |
| height: calc(20px * var(--app-text-scale, 1)); |
| line-height: calc(20px * var(--app-text-scale, 1)); |
| } |
|
|
| #sidebar-chat-item input { |
| |
| min-height: calc(20px * var(--app-text-scale, 1)); |
| } |
|
|
| code { |
| |
| overflow-x: auto; |
| width: auto; |
| } |
|
|
| .editor-selection { |
| background: rgba(180, 213, 255, 0.5); |
| border-radius: 2px; |
| } |
|
|
| .font-secondary { |
| font-family: 'InstrumentSerif', sans-serif; |
| } |
|
|
| .marked a { |
| @apply underline; |
| } |
|
|
| math { |
| margin-top: 1rem; |
| } |
|
|
| .hljs { |
| @apply rounded-lg; |
| } |
|
|
| input::placeholder { |
| direction: auto; |
| } |
|
|
| textarea::placeholder { |
| direction: auto; |
| } |
|
|
| .input-prose { |
| @apply prose dark:prose-invert prose-headings:font-semibold prose-hr:my-4 prose-hr:border-gray-50 prose-hr:dark:border-gray-850 prose-p:my-1 prose-img:my-1 prose-headings:my-2 prose-pre:my-0 prose-table:my-1 prose-blockquote:my-0 prose-ul:my-1 prose-ol:my-1 prose-li:my-0.5 whitespace-pre-line; |
| } |
|
|
| .input-prose-sm { |
| @apply prose dark:prose-invert prose-headings:font-medium prose-h1:text-2xl prose-h2:text-xl prose-h3:text-lg prose-hr:my-4 prose-hr:border-gray-50 prose-hr:dark:border-gray-850 prose-p:my-1 prose-img:my-1 prose-headings:my-2 prose-pre:my-0 prose-table:my-1 prose-blockquote:my-0 prose-ul:my-1 prose-ol:my-1 prose-li:my-1 whitespace-pre-line text-sm; |
| } |
|
|
| .markdown-prose { |
| @apply prose dark:prose-invert prose-blockquote:border-s-gray-100 prose-blockquote:dark:border-gray-800 prose-blockquote:border-s-2 prose-blockquote:not-italic prose-blockquote:font-normal prose-headings:font-semibold prose-hr:my-4 prose-hr:border-gray-50 prose-hr:dark:border-gray-850 prose-p:my-0 prose-img:my-1 prose-headings:my-1 prose-pre:my-0 prose-table:my-0 prose-blockquote:my-0 prose-ul:-my-0 prose-ol:-my-0 prose-li:-my-0 whitespace-pre-line; |
| } |
|
|
| .markdown-prose-sm { |
| @apply text-sm prose dark:prose-invert prose-blockquote:border-s-gray-100 prose-blockquote:dark:border-gray-800 prose-blockquote:border-s-2 prose-blockquote:not-italic prose-blockquote:font-normal prose-headings:font-semibold prose-hr:my-2 prose-hr:border-gray-50 prose-hr:dark:border-gray-850 prose-p:my-0 prose-img:my-1 prose-headings:my-1 prose-pre:my-0 prose-table:my-0 prose-blockquote:my-0 prose-ul:-my-0 prose-ol:-my-0 prose-li:-my-0 whitespace-pre-line; |
| } |
|
|
| .markdown-prose-xs { |
| @apply text-xs prose dark:prose-invert prose-blockquote:border-s-gray-100 prose-blockquote:dark:border-gray-800 prose-blockquote:border-s-2 prose-blockquote:not-italic prose-blockquote:font-normal prose-headings:font-semibold prose-hr:my-0.5 prose-hr:border-gray-50 prose-hr:dark:border-gray-850 prose-p:my-0 prose-img:my-1 prose-headings:my-1 prose-pre:my-0 prose-table:my-0 prose-blockquote:my-0 prose-ul:-my-0 prose-ol:-my-0 prose-li:-my-0 whitespace-pre-line; |
| } |
|
|
| .markdown a { |
| @apply underline; |
| } |
|
|
| .font-primary { |
| font-family: 'Archivo', 'Vazirmatn', sans-serif; |
| } |
|
|
| .drag-region { |
| -webkit-app-region: drag; |
| } |
|
|
| .drag-region a, |
| .drag-region button { |
| -webkit-app-region: no-drag; |
| } |
|
|
| .no-drag-region { |
| -webkit-app-region: no-drag; |
| } |
|
|
| li p { |
| display: inline; |
| } |
|
|
| ::-webkit-scrollbar-thumb { |
| --tw-border-opacity: 1; |
| background-color: rgba(215, 215, 215, 0.6); |
| border-color: rgba(255, 255, 255, var(--tw-border-opacity)); |
| border-radius: 9999px; |
| border-width: 1px; |
| } |
|
|
| |
| .dark ::-webkit-scrollbar-thumb { |
| background-color: rgba(67, 67, 67, 0.6); |
| border-color: rgba(0, 0, 0, var(--tw-border-opacity)); |
| } |
|
|
| ::-webkit-scrollbar { |
| height: 0.45rem; |
| width: 0.45rem; |
| } |
|
|
| ::-webkit-scrollbar-track { |
| background-color: transparent; |
| border-radius: 9999px; |
| } |
|
|
| select { |
| background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E"); |
| background-position: right 0rem center; |
| background-repeat: no-repeat; |
| background-size: 1.5em 1.5em; |
| -webkit-print-color-adjust: exact; |
| print-color-adjust: exact; |
| |
| |
| -moz-appearance: none; |
| |
| -webkit-appearance: none; |
| } |
|
|
| .dark select:not([class*='bg-transparent']) { |
| @apply bg-gray-900 text-gray-300; |
| } |
|
|
| .dark select option { |
| @apply bg-gray-850 text-white; |
| } |
|
|
| @keyframes shimmer { |
| 0% { |
| background-position: 200% 0; |
| } |
| 100% { |
| background-position: -200% 0; |
| } |
| } |
|
|
| .shimmer { |
| background: linear-gradient(90deg, #9a9b9e 25%, #2a2929 50%, #9a9b9e 75%); |
| background-size: 200% 100%; |
| background-clip: text; |
| -webkit-background-clip: text; |
| -webkit-text-fill-color: transparent; |
| animation: shimmer 4s linear infinite; |
| color: #818286; |
| } |
|
|
| :global(.dark) .shimmer { |
| background: linear-gradient(90deg, #818286 25%, #eae5e5 50%, #818286 75%); |
| background-size: 200% 100%; |
| background-clip: text; |
| -webkit-background-clip: text; |
| -webkit-text-fill-color: transparent; |
| animation: shimmer 4s linear infinite; |
| color: #a1a3a7; |
| } |
|
|
| @keyframes smoothFadeIn { |
| 0% { |
| opacity: 0; |
| transform: translateY(-10px); |
| } |
| 100% { |
| opacity: 1; |
| transform: translateY(0); |
| } |
| } |
|
|
| .status-description { |
| animation: smoothFadeIn 0.2s forwards; |
| } |
|
|
| .katex-mathml { |
| display: none; |
| } |
|
|
| .scrollbar-hidden:active::-webkit-scrollbar-thumb, |
| .scrollbar-hidden:focus::-webkit-scrollbar-thumb, |
| .scrollbar-hidden:hover::-webkit-scrollbar-thumb { |
| visibility: visible; |
| } |
| .scrollbar-hidden::-webkit-scrollbar-thumb { |
| visibility: hidden; |
| } |
|
|
| .scrollbar-hidden::-webkit-scrollbar-corner { |
| display: none; |
| } |
|
|
| .scrollbar-none::-webkit-scrollbar { |
| display: none; |
| } |
|
|
| .scrollbar-none::-webkit-scrollbar-corner { |
| display: none; |
| } |
|
|
| .scrollbar-none { |
| -ms-overflow-style: none; |
| scrollbar-width: none; |
| } |
|
|
| input::-webkit-outer-spin-button, |
| input::-webkit-inner-spin-button { |
| |
| -webkit-appearance: none; |
| margin: 0; |
| } |
|
|
| input[type='number'] { |
| -moz-appearance: textfield; |
| } |
|
|
| .katex-display { |
| @apply overflow-y-hidden overflow-x-auto max-w-full; |
| } |
|
|
| .katex-display::-webkit-scrollbar { |
| height: 0.4rem; |
| width: 0.4rem; |
| } |
|
|
| .katex-display:active::-webkit-scrollbar-thumb, |
| .katex-display:focus::-webkit-scrollbar-thumb, |
| .katex-display:hover::-webkit-scrollbar-thumb { |
| visibility: visible; |
| } |
| .katex-display::-webkit-scrollbar-thumb { |
| visibility: hidden; |
| } |
|
|
| .katex-display::-webkit-scrollbar-corner { |
| display: none; |
| } |
|
|
| .cm-editor { |
| height: 100%; |
| width: 100%; |
| } |
|
|
| .cm-scroller:active::-webkit-scrollbar-thumb, |
| .cm-scroller:focus::-webkit-scrollbar-thumb, |
| .cm-scroller:hover::-webkit-scrollbar-thumb { |
| visibility: visible; |
| } |
|
|
| .cm-scroller::-webkit-scrollbar-thumb { |
| visibility: hidden; |
| } |
|
|
| .cm-scroller::-webkit-scrollbar-corner { |
| display: none; |
| } |
|
|
| .cm-editor.cm-focused { |
| outline: none; |
| } |
|
|
| .cm-gutters { |
| @apply !bg-white dark:!bg-black !border-none; |
| } |
|
|
| .cm-editor { |
| @apply bg-white dark:bg-black; |
| } |
|
|
| .tippy-box[data-theme~='dark'] { |
| @apply rounded-lg bg-gray-950 text-xs border border-gray-900 shadow-xl; |
| } |
|
|
| .password { |
| -webkit-text-security: disc; |
| } |
|
|
| .codespan { |
| color: #eb5757; |
| border-width: 0px; |
| padding: 3px 8px; |
| font-size: 0.8em; |
| font-weight: 600; |
| @apply rounded-md dark:bg-gray-800 bg-gray-100 mx-0.5; |
| } |
|
|
| .svelte-flow { |
| background-color: transparent !important; |
| } |
|
|
| .svelte-flow__edge > path { |
| stroke-width: 0.5; |
| } |
|
|
| .svelte-flow__edge.animated > path { |
| stroke-width: 2; |
| @apply stroke-gray-600 dark:stroke-gray-500; |
| } |
|
|
| .bg-gray-950-90 { |
| background-color: rgba(var(--color-gray-950, #0d0d0d), 0.9); |
| } |
|
|
| .ProseMirror { |
| @apply h-full min-h-fit max-h-full whitespace-pre-wrap; |
| } |
|
|
| .ProseMirror:focus { |
| outline: none; |
| } |
|
|
| .ProseMirror p.is-editor-empty:first-child::before { |
| content: attr(data-placeholder); |
| float: left; |
| |
| |
| color: #676767; |
| pointer-events: none; |
|
|
| @apply line-clamp-1 absolute; |
| } |
|
|
| .tiptap ul[data-type='taskList'] { |
| list-style: none; |
| margin-left: 0; |
| padding: 0; |
|
|
| li { |
| align-items: start; |
| display: flex; |
|
|
| > label { |
| flex: 0 0 auto; |
| margin-right: 0.5rem; |
| margin-top: 0.2rem; |
| user-select: none; |
| display: flex; |
| } |
|
|
| > div { |
| flex: 1 1 auto; |
|
|
| align-items: center; |
| } |
| } |
|
|
| |
|
|
| li[data-checked='true'] { |
| > div { |
| opacity: 0.5; |
| text-decoration: line-through; |
| } |
| } |
|
|
| input[type='checkbox'] { |
| cursor: pointer; |
| } |
|
|
| ul[data-type='taskList'] { |
| margin: 0; |
| } |
|
|
| |
| ul:not([data-type='taskList']) { |
| list-style: disc; |
| padding-left: 1rem; |
|
|
| li { |
| align-items: initial; |
| display: list-item; |
|
|
| label { |
| flex: initial; |
| margin-right: initial; |
| margin-top: initial; |
| user-select: initial; |
| display: initial; |
| } |
|
|
| div { |
| flex: initial; |
| align-items: initial; |
| } |
| } |
| } |
| } |
|
|
| .mention { |
| border-radius: 0.4rem; |
| box-decoration-break: clone; |
| padding: 0.1rem 0.3rem; |
| @apply text-sky-800 dark:text-sky-200 bg-sky-300/15 dark:bg-sky-500/15; |
| } |
|
|
| .mention::after { |
| content: '\200B'; |
| } |
|
|
| .tiptap .suggestion { |
| border-radius: 0.4rem; |
| box-decoration-break: clone; |
| padding: 0.1rem 0.3rem; |
| @apply text-sky-800 dark:text-sky-200 bg-sky-300/15 dark:bg-sky-500/15; |
| } |
|
|
| .tiptap .suggestion::after { |
| content: '\200B'; |
| } |
|
|
| .tiptap .suggestion.is-empty::after { |
| content: '\00A0'; |
| border-bottom: 1px dotted rgba(31, 41, 55, 0.12); |
| } |
|
|
| .input-prose .tiptap ul[data-type='taskList'] { |
| list-style: none; |
| margin-left: 0; |
| padding: 0; |
|
|
| li { |
| align-items: start; |
| display: flex; |
|
|
| > label { |
| flex: 0 0 auto; |
| margin-right: 0.5rem; |
| margin-top: 0.4rem; |
| user-select: none; |
| display: flex; |
| } |
|
|
| > div { |
| flex: 1 1 auto; |
|
|
| align-items: center; |
| } |
| } |
|
|
| |
|
|
| li[data-checked='true'] { |
| > div { |
| opacity: 0.5; |
| text-decoration: line-through; |
| } |
| } |
|
|
| input[type='checkbox'] { |
| cursor: pointer; |
| } |
|
|
| ul[data-type='taskList'] { |
| margin: 0; |
| } |
|
|
| |
| ul:not([data-type='taskList']) { |
| list-style: disc; |
| padding-left: 1rem; |
|
|
| li { |
| align-items: initial; |
| display: list-item; |
|
|
| label { |
| flex: initial; |
| margin-right: initial; |
| margin-top: initial; |
| user-select: initial; |
| display: initial; |
| } |
|
|
| div { |
| flex: initial; |
| align-items: initial; |
| } |
| } |
| } |
| } |
|
|
| @media (prefers-color-scheme: dark) { |
| .ProseMirror p.is-editor-empty:first-child::before { |
| color: #757575; |
| } |
| } |
|
|
| .ai-autocompletion::after { |
| color: #a0a0a0; |
|
|
| content: attr(data-suggestion); |
| pointer-events: none; |
| } |
|
|
| .tiptap pre > code { |
| border-radius: 0.4rem; |
| font-size: 0.85rem; |
| padding: 0.25em 0.3em; |
|
|
| @apply dark:bg-gray-800 bg-gray-50; |
| } |
|
|
| .tiptap pre { |
| border-radius: 0.5rem; |
| font-family: 'JetBrainsMono', monospace; |
| margin: 1.5rem 0; |
| padding: 0.75rem 1rem; |
|
|
| @apply dark:bg-gray-800 bg-gray-50; |
| } |
|
|
| .tiptap p code { |
| color: #eb5757; |
| border-width: 0px; |
| padding: 3px 8px; |
| font-size: 0.8em; |
| font-weight: 600; |
| @apply rounded-md dark:bg-gray-800 bg-gray-50 mx-0.5; |
| } |
|
|
| |
| .hljs-comment, |
| .hljs-quote { |
| color: #616161; |
| } |
|
|
| .hljs-variable, |
| .hljs-template-variable, |
| .hljs-attribute, |
| .hljs-tag, |
| .hljs-regexp, |
| .hljs-link, |
| .hljs-name, |
| .hljs-selector-id, |
| .hljs-selector-class { |
| color: #f98181; |
| } |
|
|
| .hljs-number, |
| .hljs-meta, |
| .hljs-built_in, |
| .hljs-builtin-name, |
| .hljs-literal, |
| .hljs-type, |
| .hljs-params { |
| color: #fbbc88; |
| } |
|
|
| .hljs-string, |
| .hljs-symbol, |
| .hljs-bullet { |
| color: #b9f18d; |
| } |
|
|
| .hljs-title, |
| .hljs-section { |
| color: #faf594; |
| } |
|
|
| .hljs-keyword, |
| .hljs-selector-tag { |
| color: #70cff8; |
| } |
|
|
| .hljs-emphasis { |
| font-style: italic; |
| } |
|
|
| .hljs-strong { |
| font-weight: 700; |
| } |
|
|
| |
| .tiptap table { |
| @apply w-full text-sm text-start text-gray-500 dark:text-gray-400 max-w-full; |
| } |
|
|
| .tiptap thead { |
| @apply text-xs text-gray-700 uppercase bg-gray-50 dark:bg-gray-850 dark:text-gray-400 border-none; |
| } |
|
|
| .tiptap th, |
| .tiptap td { |
| @apply px-3 py-1.5 border border-gray-100/30 dark:border-gray-850/30; |
| } |
|
|
| .tiptap th { |
| @apply cursor-pointer text-start text-xs text-gray-700 dark:text-gray-400 font-semibold uppercase bg-gray-50 dark:bg-gray-850; |
| } |
|
|
| .tiptap td { |
| @apply text-gray-900 dark:text-white w-max; |
| } |
|
|
| .tiptap tr { |
| @apply bg-white dark:bg-gray-900 dark:border-gray-850 text-xs; |
| } |
|
|
| .tippy-box[data-theme~='transparent'] { |
| @apply bg-transparent p-0 m-0; |
| } |
|
|
| |
| .ProseMirror > .ProseMirror-yjs-cursor:first-child { |
| margin-top: 16px; |
| } |
| |
| .ProseMirror-yjs-cursor { |
| position: relative; |
| margin-left: -1px; |
| margin-right: -1px; |
| border-left: 1px solid black; |
| border-right: 1px solid black; |
| border-color: orange; |
| word-break: normal; |
| pointer-events: none; |
| } |
| |
| .ProseMirror-yjs-cursor > div { |
| position: absolute; |
| top: -1.05em; |
| left: -1px; |
| font-size: 13px; |
| background-color: rgb(250, 129, 0); |
| user-select: none; |
| color: white; |
| padding-left: 2px; |
| padding-right: 2px; |
| white-space: nowrap; |
| } |
|
|
| body { |
| background: #fff; |
| color: #000; |
| } |
|
|
| .dark body { |
| background: #171717; |
| color: #eee; |
| } |
|
|
| |
| .pm-li--with-handle { |
| position: relative; |
| margin-left: 12px; |
| } |
|
|
| .tiptap ul[data-type='taskList'] .pm-list-drag-handle { |
| margin-left: 0px; |
| } |
|
|
| |
| .pm-list-drag-handle { |
| position: absolute; |
| left: -36px; |
| top: 1px; |
| width: 18px; |
| height: 18px; |
| display: inline-flex; |
| align-items: center; |
| justify-content: center; |
| font-size: 12px; |
| line-height: 1; |
| border-radius: 4px; |
| cursor: grab; |
| user-select: none; |
| opacity: 0.35; |
| transition: |
| opacity 120ms ease, |
| background 120ms ease; |
| } |
|
|
| .tiptap ul[data-type='taskList'] .pm-list-drag-handle { |
| left: -16px; |
| } |
|
|
| .pm-list-drag-handle:active { |
| cursor: grabbing; |
| } |
| .pm-li--with-handle:hover > .pm-list-drag-handle { |
| opacity: 1; |
| } |
| .pm-list-drag-handle:hover { |
| background: rgba(0, 0, 0, 0.06); |
| } |
|
|
| :root { |
| --pm-accent: color-mix(in oklab, Highlight 70%, transparent); |
| --pm-fill-target: color-mix(in oklab, Highlight 26%, transparent); |
| --pm-fill-ancestor: color-mix(in oklab, Highlight 16%, transparent); |
| } |
|
|
| .pm-li-drop-before, |
| .pm-li-drop-after, |
| .pm-li-drop-into, |
| .pm-li-drop-outdent { |
| position: relative; |
| } |
|
|
| |
| .pm-li-drop-before::before, |
| .pm-li-drop-after::after { |
| content: ''; |
| position: absolute; |
| left: 0; |
| right: 0; |
| height: 3px; |
| background: var(--pm-accent); |
| pointer-events: none; |
| } |
| .pm-li-drop-before::before { |
| top: -2px; |
| } |
| .pm-li-drop-after::after { |
| bottom: -2px; |
| } |
|
|
| .pm-li-drop-before, |
| .pm-li-drop-after, |
| .pm-li-drop-into, |
| .pm-li-drop-outdent { |
| background: var(--pm-fill-target); |
| border-radius: 6px; |
| } |
|
|
| .pm-li-drop-outdent::before { |
| content: ''; |
| position: absolute; |
| inset-block: 0; |
| inset-inline-start: 0; |
| width: 3px; |
| background: color-mix(in oklab, Highlight 35%, transparent); |
| } |
|
|
| .pm-li--with-handle:has(.pm-li-drop-before), |
| .pm-li--with-handle:has(.pm-li-drop-after), |
| .pm-li--with-handle:has(.pm-li-drop-into), |
| .pm-li--with-handle:has(.pm-li-drop-outdent) { |
| background: var(--pm-fill-ancestor); |
| border-radius: 6px; |
| } |
|
|
| .pm-li-drop-before, |
| .pm-li-drop-after, |
| .pm-li-drop-into, |
| .pm-li-drop-outdent { |
| position: relative; |
| z-index: 0; |
| } |
|
|
| #note-content-container .ProseMirror { |
| padding-bottom: 2rem; |
| } |
|
|