6.7 KB
raw
:root {
/* Warm-dark biohacker palette */
--bg: #0e0d0a;
--bg-deep: #090806;
--surface: #13120e;
--surface-2: #18160f;
--border: rgba(221, 215, 205, 0.06);
--border-green: rgba(107, 158, 120, 0.2);
--border-green-hover: rgba(107, 158, 120, 0.35);
--text: #ddd7cd;
--text-bright: #ede8e0;
--text-muted: #a09890;
--text-dim: #665f56;
--green: #6b9e78;
--green-bright: #7db88c;
--green-hi: #95cca2;
--green-dim: rgba(107, 158, 120, 0.12);
--green-glow: rgba(107, 158, 120, 0.3);
--amber: #c9a84c;
--amber-bright: #ddc06a;
--amber-dim: rgba(201, 168, 76, 0.1);
--terracotta: #c47055;
--terracotta-bright: #e38871;
--terracotta-dim: rgba(196, 112, 85, 0.1);
/* Legacy tokens kept so any missed reference still resolves to the new palette */
--color-one: var(--bg);
--color-two: var(--surface);
--color-three: var(--green);
--color-four: var(--green-bright);
--color-five: var(--amber);
--radius: 3px;
--radius-lg: 6px;
--breakpoint-desktop-max: 1023.99px;
--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", "SF Mono",
Menlo, Consolas, ui-monospace, monospace;
}
* {
box-sizing: border-box;
}
html,
body {
padding: 0;
margin: 0;
}
body {
font-family: var(--font-mono);
color: var(--text);
background-color: var(--bg);
min-height: 100vh;
width: 100%;
overflow-x: hidden;
font-size: 15px;
line-height: 1.6;
letter-spacing: 0.01em;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
/* Subtle grid background for that operator-console feel */
background-image:
radial-gradient(
circle at 15% 10%,
rgba(107, 158, 120, 0.04) 0%,
transparent 45%
),
radial-gradient(
circle at 85% 85%,
rgba(201, 168, 76, 0.025) 0%,
transparent 50%
),
linear-gradient(rgba(107, 158, 120, 0.015) 1px, transparent 1px),
linear-gradient(90deg, rgba(107, 158, 120, 0.015) 1px, transparent 1px);
background-size: auto, auto, 40px 40px, 40px 40px;
background-position: 0 0, 0 0, -1px -1px, -1px -1px;
background-attachment: fixed;
}
input,
button,
select,
textarea {
font-family: var(--font-mono);
color: inherit;
}
a {
color: var(--green-bright);
text-decoration: none;
transition: color 200ms ease;
}
a:hover {
color: var(--green-hi);
}
:focus {
outline: none;
}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
outline: 1px solid var(--green);
outline-offset: 2px;
box-shadow: 0 0 0 3px var(--green-dim);
}
::selection {
background: var(--green-dim);
color: var(--green-hi);
}
.page-transition {
opacity: 0;
position: absolute;
top: 0;
left: 0;
right: 0;
}
.page-transition-appear,
.page-transition-enter {
opacity: 0;
}
.page-transition-appear-active,
.page-transition-enter-active {
opacity: 1;
transition-delay: 250ms;
transition-duration: 250ms;
transition-property: opacity;
}
.page-transition-appear-done,
.page-transition-enter-done {
opacity: 1;
}
.page-transition-exit {
opacity: 1;
}
.page-transition-exit-active {
opacity: 0;
transition-duration: 250ms;
transition-property: opacity;
}
.fade-appear,
.fade-enter {
opacity: 0;
transform: translateX(-40px);
}
.fade-appear-active,
.fade-enter-active {
opacity: 1;
transform: translateX(0);
transition-duration: 250ms;
transition-property: opacity, transform;
}
.fade-exit {
opacity: 1;
transform: translateX(0);
}
.fade-exit-active {
opacity: 0;
transform: translateX(40px);
transition-duration: 250ms;
transition-property: opacity, transform;
transition-delay: 0ms !important;
}
/* Toastify overrides so it matches the dark warm palette */
.Toastify__toast {
font-family: var(--font-mono) !important;
font-size: 0.85rem !important;
border-radius: var(--radius) !important;
background: var(--surface) !important;
color: var(--text) !important;
border: 1px solid var(--border-green);
box-shadow: 0 6px 24px rgba(0, 0, 0, 0.45);
}
.Toastify__toast--success {
border-left: 3px solid var(--green);
}
.Toastify__toast--error {
border-left: 3px solid var(--terracotta);
}
.Toastify__progress-bar--success {
background: var(--green) !important;
}
.Toastify__progress-bar--error {
background: var(--terracotta) !important;
}
/* ----- Shared page primitives (used by log, summary, about) ----- */
/* Outer page grid: fixed sidebar + fluid main + right gutter.
All content pages use this for consistent horizontal alignment. */
.page-grid {
display: grid;
grid-template-columns: 60px minmax(0, 1fr) 60px;
width: 100%;
min-height: 100vh;
}
@media (max-width: 1023.99px) {
.page-grid {
grid-template-columns: 0 minmax(0, 1fr) 0;
}
}
.page-main {
grid-column: 2;
width: 100%;
max-width: 1100px;
justify-self: start;
padding: 52px 40px 120px;
box-sizing: border-box;
}
@media (max-width: 1023.99px) {
.page-main {
padding: 32px 20px 120px;
}
}
/* Page title bar: uppercase green with glow + hairline underline.
Use on every content page's top to signal location. */
.page-title {
font-weight: 700;
text-transform: uppercase;
font-size: 1.8em;
letter-spacing: 0.22em;
color: var(--green-bright);
text-shadow: 0 0 16px var(--green-glow);
margin: 0 0 1.5rem;
padding-bottom: 0.8rem;
border-bottom: 1px solid var(--border);
}
@media (max-width: 1023.99px) {
.page-title {
font-size: 1.3em;
}
}
/* Section label: small uppercase tracked label used above chart / section */
.section-label {
font-size: 0.72em;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.22em;
color: var(--text-muted);
margin: 2rem 0 0.75rem;
}
.section-label:first-child {
margin-top: 0;
}
/* Empty state: consistent centered message used when a page has no data.
Positioned to fill the viewport so it renders identically across pages. */
.empty-state {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 16px;
text-align: center;
padding: 20px;
pointer-events: none;
}
.empty-state > * {
pointer-events: auto;
}
.empty-state-title {
font-weight: 500;
font-size: 1.15em;
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--text-muted);
margin: 0;
padding-bottom: 14px;
position: relative;
}
.empty-state-title::after {
content: "";
position: absolute;
width: 80px;
left: 50%;
transform: translateX(-50%);
bottom: 0;
height: 1px;
background: linear-gradient(
90deg,
transparent,
var(--green) 50%,
transparent
);
}
.empty-state-hint {
font-size: 0.78em;
color: var(--text-dim);
letter-spacing: 0.06em;
max-width: 320px;
line-height: 1.6;
}
@media (max-width: 1023.99px) {
.empty-state-title {
font-size: 0.9em;
}
}