Skip to content
Nibiru docsv0.9.2

Components

Buttons, cards, callouts, hero — copy-paste ready.

Stable Reading time ~ 3 min Edit on GitHub

A black-on-cream rectangle. Editorial. No gradient, no glow.

<a class="atelier-button atelier-button--primary" href="/en/start/installation/">
<span>Read the docs</span>
<span class="atelier-button__arrow" aria-hidden="true">→</span>
</a>
.atelier-button {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.7rem 1.2rem;
font-family: var(--nibiru-font-text);
font-variation-settings: var(--nibiru-fv-body-bold);
font-size: 0.92rem;
letter-spacing: var(--nibiru-tracking-body);
border-radius: var(--nibiru-radius-md);
text-decoration: none;
transition: transform 200ms var(--nibiru-ease-out),
box-shadow 200ms var(--nibiru-ease-out);
}
.atelier-button--primary {
background: var(--nibiru-ink);
color: var(--nibiru-paper);
border: 1px solid var(--nibiru-ink);
box-shadow: 0 1px 0 rgba(31, 27, 46, 0.4);
}
.atelier-button--primary:hover {
transform: translateY(-1px);
box-shadow: 0 8px 24px -8px rgba(31, 27, 46, 0.5);
}
.atelier-button .atelier-button__arrow {
transition: transform 240ms var(--nibiru-ease-out);
}
.atelier-button:hover .atelier-button__arrow {
transform: translateX(3px);
}
.atelier-button--ghost {
background: transparent;
color: var(--nibiru-ink);
border: 1px solid var(--nibiru-ink-faint);
}
.atelier-button--ghost:hover {
border-color: var(--nibiru-iris);
color: var(--nibiru-iris-deep);
}

Flat, paper-tinted. Hover lifts 2px and brightens the border.

<article class="card">
<h3 class="card-title">MMVC architecture</h3>
<p>Modules wrap MVC with traits, plugins, interfaces and settings.</p>
</article>
.card {
background: var(--nibiru-mist);
border: 1px solid rgba(31, 27, 46, 0.10);
border-radius: var(--nibiru-radius-lg);
padding: 1.6rem 1.5rem;
transition: transform 240ms var(--nibiru-ease-out),
border-color 240ms,
box-shadow 240ms;
}
.card:hover {
transform: translateY(-2px);
border-color: var(--nibiru-iris);
box-shadow: 0 18px 40px -20px rgba(94, 84, 140, 0.35);
}
.card-title {
font-family: var(--nibiru-font-display);
font-variation-settings: var(--nibiru-fv-display-medium);
font-size: 1.05rem;
letter-spacing: -0.018em;
color: var(--nibiru-ink);
margin: 0 0 0.5rem;
}
.card p {
color: var(--nibiru-ink-soft);
font-size: 0.92rem;
line-height: 1.6;
margin: 0;
}

A single-pixel violet rule on the left. No box. No icon.

<aside class="callout callout--note">
<span class="callout__title">Note</span>
<p>Browse <code>/start/quick-start/</code> for a five-minute first build.</p>
</aside>
.callout {
background: var(--nibiru-mist);
border: 0;
border-left: 2px solid var(--nibiru-iris);
padding: 1rem 1.2rem 1rem 1.4rem;
border-radius: 0;
margin: 1.6rem 0;
}
.callout--tip { border-left-color: var(--nibiru-aurum); }
.callout--caution { border-left-color: var(--nibiru-aurum); }
.callout--danger { border-left-color: var(--nibiru-rose); }
.callout__title {
font-family: var(--nibiru-font-text);
font-variation-settings: var(--nibiru-fv-label);
text-transform: uppercase;
letter-spacing: var(--nibiru-tracking-label);
font-size: 0.72rem;
color: var(--nibiru-ink-faint);
display: block;
margin-bottom: 0.45rem;
}

No box. A coloured underline tint that stays out of the way.

:not(pre) > code {
font-family: var(--nibiru-font-mono);
font-size: 0.86em;
background: linear-gradient(to top,
rgba(124, 112, 171, 0.16) 35%,
transparent 35%);
color: var(--nibiru-iris-deep);
padding: 0 0.18em;
border-radius: 2px;
}

Asymmetric two-column grid. Big editorial number behind the copy. The brand mark anchors the right side and breathes once every 18 seconds.

<section class="atelier-hero">
<span class="atelier-hero__number" aria-hidden="true">01</span>
<div class="atelier-hero__grid">
<div>
<p class="atelier-hero__eyebrow">Modular MMVC PHP framework</p>
<h1 class="atelier-hero__title">
Create.<br>Invent.<br><em>Impress.</em>
</h1>
<p class="atelier-hero__lede">
Nibiru is a modular PHP framework for builders who ship.
</p>
<div class="atelier-hero__cta">
<a class="atelier-button atelier-button--primary" href="/en/start/installation/">
Read the docs <span aria-hidden="true">→</span>
</a>
</div>
</div>
<div class="atelier-hero__art" aria-hidden="true">
<img class="atelier-hero__mark" src="/img/nibiru-logo.png" alt="">
</div>
</div>
</section>

The full styles live in src/styles/nibiru.css.

A 52px paper-coloured circle in the bottom-right. The lotus mark inside rotates on hover. No pulse. No glow.

<button id="oracle-launcher" type="button" aria-label="Open Oracle"></button>
#oracle-launcher {
position: fixed;
bottom: 1.4rem; right: 1.4rem;
width: 52px; height: 52px; border-radius: 50%;
border: 1px solid rgba(31, 27, 46, 0.18);
background: var(--nibiru-paper);
box-shadow: 0 6px 24px -10px rgba(31, 27, 46, 0.35),
0 1px 2px rgba(31, 27, 46, 0.08);
cursor: pointer;
transition: transform 220ms var(--nibiru-ease-out),
box-shadow 220ms,
border-color 220ms;
display: flex; align-items: center; justify-content: center;
}
#oracle-launcher::before {
content: '';
width: 26px; height: 26px;
background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 2 C 9 8, 9 16, 12 22 C 15 16, 15 8, 12 2 Z' fill='%237c70ab'/><path d='M2 12 C 8 9, 16 9, 22 12 C 16 15, 8 15, 2 12 Z' fill='%237db7dc'/></svg>");
background-size: contain;
transition: transform 400ms var(--nibiru-ease-out);
}
#oracle-launcher:hover {
transform: translateY(-2px);
border-color: var(--nibiru-iris);
}
#oracle-launcher:hover::before {
transform: rotate(60deg);
}