customization-guide > CSS Structure and Styling Guide
CSS Structure and Styling Guide
Notionpresso provides a flexible and extensible CSS structure. This section explains the CSS variable system, key styling points, and the principles of indent application.
CSS Variable System
Notionpresso uses CSS variables to define global styles. This allows for easy theme changes and overall style adjustments.
The main CSS variables are as follows:
.notion {
--notion-font: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
"Segoe UI", Helvetica, "Apple Color Emoji", Arial, sans-serif,
"Segoe UI Emoji", "Segoe UI Symbol";
--notion-max-width: 720px;
--notion-header-height: 45px;
--notion-indent: 27px;
/* Color variables */
--fg-color: rgb(55, 53, 47);
--fg-color-0: rgba(55, 53, 47, 0.09);
--fg-color-1: rgba(55, 53, 47, 0.16);
--fg-color-2: rgba(55, 53, 47, 0.4);
--fg-color-3: rgba(55, 53, 47, 0.6);
--fg-color-4: #000;
--fg-color-5: rgb(233, 233, 231);
--fg-color-6: rgba(55, 53, 47, 0.8);
--fg-color-icon: var(--fg-color);
--bg-color: #fff;
--bg-color-0: rgba(135, 131, 120, 0.15);
--bg-color-1: rgb(247, 246, 243);
--bg-color-2: rgba(135, 131, 120, 0.15);
--select-color-0: rgb(46, 170, 220);
--select-color-1: rgba(35, 131, 226, 0.28);
--select-color-2: #d9eff8;
}
You can easily change the overall style by redefining these variables.
Key Styling Points
-
Class Naming Convention: All classes start with
notion-
. This prevents style conflicts.Example:
.notion-block
,.notion-h1
,.notion-toggle
-
Block Level Styles: The
notion-block
class is applied to all block-level elements..notion-block { display: block; }
-
Color Application: Colors are applied through CSS variables.
.notion-text { color: var(--fg-color); }
-
Responsive Design: The
--notion-max-width
variable is used to implement responsive layouts..notion-body { width: 100%; max-width: var(--notion-max-width); margin: 0 auto; }
Indent Application Principle
Notionpresso implements indentation through a recursive structure. This is handled in CSS as follows:
.notion-block > .notion-block {
margin-left: var(--notion-indent);
}
.notion-block > .notion-display-contents > .notion-block {
margin-left: var(--notion-indent);
}
This CSS rule automatically applies indentation to nested blocks. You can easily adjust the degree of indentation by modifying the --notion-indent
variable.
Dark Mode and Custom Themes
Notionpresso supports dark mode by default. Dark mode is implemented as follows:
[data-theme="dark"] .notion {
--fg-color: rgba(255, 255, 255, 0.9);
--bg-color: #2f3437;
/* Other dark mode related variables... */
}
Also, you can easily apply custom themes. You can apply the desired theme using the data-theme
attribute:
<Notion data-theme="custom">{/* Notion content */}</Notion>
And you can define styles in CSS as follows:
.notion[data-theme="custom"] {
--fg-color: #333;
--bg-color: #f4f4f4;
/* Other custom theme related variables... */
}
Using this method, you can easily override default styles by utilizing selector priority.
Style Customization Examples
-
Changing Global Font:
.notion[data-theme="custom"] { --notion-font: "Roboto", sans-serif; }
-
Changing Heading Styles:
.notion[data-theme="custom"] .notion-h1 { font-size: 2.5em; color: var(--select-color-0); border-bottom: 2px solid var(--fg-color-1); }
-
Adjusting Indentation:
.notion[data-theme="custom"] { --notion-indent: 20px; }
-
Implementing Dark Mode:
[data-theme="dark"] .notion[data-theme="custom"] { --fg-color: rgba(255, 255, 255, 0.9); --bg-color: #2f3437; /* Adjust other color variables appropriately */ }
By following this CSS structure and styling guide, you can implement consistent and easily maintainable styles using Notionpresso. Furthermore, detailed customization is possible as needed.