Minimalist CSS Framework
No JavaScript. Raw CSS.
Download drop-in CSS (minified)
Download CSS classes (minified)
- https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.min.css
- https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.css
- https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.drop-in.css
- https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.drop-in.min.css
- https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.classes.css
- https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.classes.min.css
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.min.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.drop-in.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.drop-in.min.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.classes.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/kaufmann-dev/PurusCss/css/purus.classes.min.css">- Developed alongside modern-normalize, which means every normalization is included
- Customize using CSS variables
- Responsive and mobile-friendly
- Clean, beautiful typography
- Forms, tables, buttons and navigation
.container { width: 100%; margin: 0 auto; max-width: 768px; padding: 0 16px 16px; }
.container-fluid { width: 100%; margin: 0 auto; padding: 0 16px 16px; }
.fill-vertical-space { flex: 1 0 auto; }
.active { background-color: var(--primary-darker); cursor: not-allowed; }
.important { background-color: var(--primary-darker); }
.outline-none { outline: 0; }.h-25 { height: 25%; }
.h-50 { height: 50%; }
.h-75 { height: 75%; }
.h-100 { height: 100%; }
.h-auto { height: auto; }
.h-content { height: fit-content; }
.w-25 { width: 25%; }
.w-50 { width: 50%; }
.w-75 { width: 75%; }
.w-100 { width: 100%; }
.w-auto { width: auto; }
.w-content { width: fit-content; }.p { padding: var(--padding); }
.px { padding-left: var(--padding); padding-right: var(--padding); }
.py { padding-top: var(--padding); padding-bottom: var(--padding); }
.pl { padding-left: var(--padding); }
.pr { padding-right: var(--padding); }
.pt { padding-top: var(--padding); }
.pb { padding-bottom: var(--padding); }
.p-nav { padding: var(--padding) var(--padding) calc(var(--padding) - 5px) var(--padding); }
.p-lg { padding: var(--padding-lg); }
.px-lg { padding-left: var(--padding-lg); padding-right: var(--padding-lg); }
.py-lg { padding-top: var(--padding-lg); padding-bottom: var(--padding-lg); }
.pl-lg { padding-left: var(--padding-lg); }
.pr-lg { padding-right: var(--padding-lg); }
.pt-lg { padding-top: var(--padding-lg); }
.pb-lg { padding-bottom: var(--padding-lg); }
.p-nav-lg { padding: var(--padding-lg) var(--padding-lg) calc(var(--padding-lg) - 5px) var(--padding-lg); }
.p-none { padding: 0; }.m { margin: var(--margin); }
.mx { margin-left: var(--margin); margin-right: var(--margin); }
.my { margin-top: var(--margin); margin-bottom: var(--margin); }
.ml { margin-left: var(--margin); }
.mr { margin-right: var(--margin); }
.mt { margin-top: var(--margin); }
.mb { margin-bottom: var(--margin); }
.m-lg { margin: var(--margin-lg); }
.mx-lg { margin-left: var(--margin-lg); margin-right: var(--margin-lg); }
.my-lg { margin-top: var(--margin-lg); margin-bottom: var(--margin-lg); }
.ml-lg { margin-left: var(--margin-lg); }
.mr-lg { margin-right: var(--margin-lg); }
.mt-lg { margin-top: var(--margin-lg); }
.mb-lg { margin-bottom: var(--margin-lg); }
.m-none { margin: 0; }
.m-auto { margin: auto; }.color-grey-border { color: var(--grey-border); }
.color-grey-text { color: var(--grey-text); }
.color-white { color: var(--white); }
.color-white-darker { color: var(--white-darker); }
.color-white-darkest { color: var(--white-darkest); }
.color-black { color: var(--black); }
.color-primary-outline { color: var(--primary-outline); }
.color-primary-faded { color: var(--primary-faded); }
.color-primary { color: var(--primary); }
.color-primary-darker { color: var(--primary-darker); }
.color-primary-darkest { color: var(--primary-darkest); }
.color-error { color: var(--error); }.bg-grey-border { background-color: var(--grey-border); }
.bg-grey-text { background-color: var(--grey-text); }
.bg-white { background-color: var(--white); }
.bg-white-darker { background-color: var(--white-darker); }
.bg-white-darkest { background-color: var(--white-darkest); }
.bg-black { background-color: var(--black); }
.bg-primary-outline { background-color: var(--primary-outline); }
.bg-primary-faded { background-color: var(--primary-faded); }
.bg-primary { background-color: var(--primary); }
.bg-primary-darker { background-color: var(--primary-darker); }
.bg-primary-darkest { background-color: var(--primary-darkest); }
.bg-error { background-color: var(--error); }.visible { visibility: visible; }
.invisible { visibility: hidden; }.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }.align-baseline { vertical-align: baseline; }
.align-top { vertical-align: top; }
.align-middle { vertical-align: middle; }
.align-bottom { vertical-align: bottom; }
.align-text-bottom { vertical-align: text-bottom; }
.align-text-top { vertical-align: text-top; }.shadow-sm { box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); }
.shadow { box-shadow: 0 1px 3px 0 rgba(0,0,0,0.1),0 1px 2px 0 rgba(0,0,0,0.06); }
.shadow-md { box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06); }
.shadow-lg { box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05); }
.shadow-xl { box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04); }
.shadow-2xl { box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); }
.shadow-inner { box-shadow: inset 0 2px 4px 0 rgba(0,0,0,0.06); }.border { border: 1px solid var(--grey-border); }
.border-top { border-top: 1px solid var(--grey-border); }
.border-bottom { border-bottom: 1px solid var(--grey-border); }
.border-y { border-top: 1px solid var(--grey-border); border-bottom: 1px solid var(--grey-border); }
.border-right { border-right: 1px solid var(--grey-border); }
.border-left { border-left: 1px solid var(--grey-border); }
.border-x { border-right: 1px solid var(--grey-border); border-left: 1px solid var(--grey-border); }
.border-none { border: 0; }
.border-solid { border-style: solid; }
.border-dashe { border-style: dashed; }
.border-dotted { border-style: dotted; }
.border-double { border-style: double; }.rounded-none { border-radius: 0px; }
.rounded-sm { border-radius: 0.125rem; }
.rounded { border-radius: 0.25rem; }
.rounded-md { border-radius: 0.375rem; }
.rounded-lg { border-radius: 0.5rem; }
.rounded-xl { border-radius: 0.75rem; }
.rounded-2xl { border-radius: 1rem; }
.rounded-3xl { border-radius: 1.5rem; }
.rounded-full { border-radius: 9999px; }.float-none { float: none; }
.float-left { float: left; }
.float-right { float: right; }.opacity-0 { opacity: 0; }
.opacity-5 { opacity: 0.05; }
.opacity-10 { opacity: 0.1; }
.opacity-20 { opacity: 0.2; }
.opacity-25 { opacity: 0.25; }
.opacity-30 { opacity: 0.3; }
.opacity-40 { opacity: 0.4; }
.opacity-50 { opacity: 0.5; }
.opacity-60 { opacity: 0.6; }
.opacity-70 { opacity: 0.7; }
.opacity-75 { opacity: 0.75; }
.opacity-80 { opacity: 0.8; }
.opacity-90 { opacity: 0.9; }
.opacity-95 { opacity: 0.95; }
.opacity-100 { opacity: 1; }.position-static { position: static; }
.position-relative { position: relative; }
.position-absolute { position: absolute; }
.position-sticky { position: sticky; }
.position-fixed { position: fixed; }.all-0 { left: 0; right: 0; bottom: 0; top: 0; }
.all-10 { left: 10px; right: 10px; bottom: 10px; top: 10px; }
.x-0 { left: 0; right: 0; }
.x-10 { left: 10px; right: 10px; }
.y-0 { bottom: 0; top: 0; }
.y-10 { bottom: 10px; top: 10px; }
.bottom-0 { bottom: 0; }
.bottom-10 { bottom: 10px; }
.top-0 { top: 0; }
.top-10 { top: 10px; }
.left-0 { left: 0; }
.left-10 { left: 10px; }
.right-0 { right: 0; }
.right-10 { right: 10px; }.d-none { display: none; }
.d-inline { display: inline; }
.d-block { display: block; }
.d-contents { display: contents; }
.d-list-item { display: list-item; }
.d-inline-block { display: inline-block; }
.d-inline-table { display: inline-table; }
.d-table { display: table; }
.d-table-cell { display: table-cell; }
.d-table-column { display: table-column; }
.d-table-column-group { display: table-column-group; }
.d-table-footer-group { display: table-footer-group; }
.d-table-header-group { display: table-header-group; }
.d-table-row { display: table-row; }
.d-table-row-group { display: table-row-group; }
.d-flex { display: flex; }
.d-inline-flex { display: inline-flex; }
.d-grid { display: grid; }
.d-inline-grid { display: inline-grid; }
.d-ruby { display: ruby; }
.d-ruby-base { display: ruby-base; }
.d-ruby-text { display: ruby-text; }
.d-ruby-base-container { display: ruby-base-container; }
.d-ruby-text-container { display: ruby-text-container; }
.d-run-in { display: run-in; }
.d-inherit { display: inherit; }
.d-initial { display: initial; }
.d-unset { display: unset; }In Purus CSS, several predefined variables exist. This is in order to make it easier for you to customize these values. All variables have a default value. To change these values, simply define variables with the same name in a custom CSS file. This will override the old values. Make sure to load your custom CSS after Purus CSS! The following predefined variables exist:
| Name | CSS Name | Value |
|---|---|---|
| grey-border | var(--grey-border) | #d1d1d1 |
| grey-text | var(--grey-text) | #7d7d7d |
| white | var(--white) | #ffffff |
| white-darker | var(--white-darker) | #f9f9f9 |
| white-darkest | var(--white-darkest) | #f3f3f3 |
| black | var(--black) | #000000 |
| primary-outline | var(--primary-outline) | rgba(0, 123, 255, .35) |
| primary-faded | var(--primary-faded) | #5c95f4 |
| primary | var(--primary) | #4285f4 |
| primary-darker | var(--primary-darker) | #3c78dc |
| primary-darkest | var(--primary-darkest) | #2766cf |
| error | var(--error) | #f43022 |
| padding | var(--padding) | 5px |
| margin | var(--margin) | 5px |
| padding-lg | var(--padding-lg) | 10px |
| margin-lg | var(--margin-lg) | 10px |
As an example, let's try to override white with #f9f9f9:
:root {
--white: #f9f9f9;
}Calling var(--white) will now return the value #f9f9f9.