Greenville Triumph · 2026

Build dashboards that look on brand the first time.

The Triumph design system for staff dashboards and ops tools. Link two files, use the tokens, and a data-dense page comes out brand-correct and screen-tuned.

tokens.css components.css Two files. Zero hardcoded hex.
match-day-revenue.html live
Revenue MTD
$284,610
12.4% vs prior
Tickets sold
8,142
6.1% vs prior
STH base
1,210
93% renewed

Revenue by channel

On track
Stone Stadium94%
GE Vernova Park71%
00 · Start here

Two links and you inherit the whole brand.

Fonts (Fabiola + Inter), the full palette, the type scale, spacing, and every component arrive through these two stylesheets. Then clone starter.html and edit content, not layout.

<!-- dark-mode lock (meta + first style block) -->
<meta name="color-scheme" content="only dark">
<meta name="supported-color-schemes" content="dark">
<meta name="darkreader-lock">
<meta name="theme-color" content="#14181f">
<style>:root,html,body{background:#14181f!important;color:#f2fafa!important;color-scheme:only dark;}</style>

<!-- tokens first, then components; all three fonts ride along -->
<link rel="stylesheet" href="https://design.greenvilletriumph.club/tokens.css">
<link rel="stylesheet" href="https://design.greenvilletriumph.club/components.css">

The four rules that keep it on brand

  • Use var(--token-name) in CSS. Never hardcode a hex, rgba, or oklch value.
  • Fabiola is the hero only (.h-display, once per page). Every other heading is Inter.
  • Pick one accent per layout: Electric Lime or Light Green, not both.
  • Labels are --text-label, nothing renders below --text-xs, and font-size only ever takes a --text-* token.
Open starter.html Read agents.md View tokens.css
01 · Color

Seven brand colors. Never an eighth.

The whole system is built from these. Every surface, border, and accent is one of them or a derived tint. Click a swatch to copy its hex.

Brand palette
Greenville Blue#002855PMS 295 C · deep band
Triumph Green#61a631PMS 369 C · primary accent
Light Green#97d700PMS 375 C · lime accent
Electric Lime#69b3e7PMS 292 C · sky accent
Morning Mist#d2e6e5PMS 5455 C · soft text
Upstate Fog#f2fafaPMS 7541 C · primary text
Deep Night#020022PMS Black 6 C · canvas
Surface elevation

Depth without leaving the palette. Deep Night lifted toward Upstate Fog gives a calm slate ladder, so cards read as layers instead of a flat wall of saturated navy. Greenville Blue is reserved for one deep emphasis band.

bg--color-bg
surface-1band
surface-2card
surface-3raised
surface-4overlay
Contrast (engineering note, not Brandpad)
PairingPreviewRatioGrade
Upstate Fog on slate canvasBody text16.8AAA
Morning Mist on slate canvasSoft text13.7AAA
Electric Lime on slate canvasAccent text7.8AAA
Triumph Green on slate canvasAccent text5.9AA
Greenville Blue on Upstate FogText on light13.8AAA
Triumph Green on Upstate FogAvoid this2.83FAIL

On light surfaces, body text is Greenville Blue or Deep Night, never Triumph Green.

02 · Typography

One Fabiola moment. Inter does the work.

Brandpad assigns Fabiola Capitals to its headings. On a data-dense screen that fights the data, and any weight above 400 synthetic-bolds the single-weight file into mush. So Fabiola is restricted to one hero (.h-display, rendered at the real Brandpad spec) and every working heading is Inter at a genuine heavy cut weight.

.h-displayFabiola Capitals · 400 · the hero only · --text-display
Together we triumph
h1Inter · 800 · page title
Match-day snapshot
h2Inter · 800 · section title
Revenue by channel
h3Inter · 700 · card / subsection
Season ticket holders
h4Inter · 700 · label heading
Per-section availability
subheaderJetBrains Mono · 700 · --text-lg · heads a content group
Per-section availability
ledeInter · 300 · large intro only
A light weight reads elegant at large sizes and weak at small ones, so 300 stays big.
bodyInter · 400 · default
Body copy is Inter Regular at 400 for legibility on the dark canvas. This is a deliberate dashboard choice; Brandpad ships marketing body at 300.
labelJetBrains Mono · 600 · --text-label · also h6, .section-number, .kpi-label
01 · Tickets sold
kickerJetBrains Mono · 700 · accent · ONE per page
Greenville Triumph · 2026
statJetBrains Mono · 800 · tabular · --text-4xl
18,472
The label law
Do
  • Every uppercase mono label is --text-label · 600 · --track-label · muted. Eyebrows, section numbers, KPI and stat labels, table headers, nav links: one spec, no exceptions.
  • --text-xs is the absolute floor. Footnotes, deltas, badges, dense cells sit there; nothing sits below it.
  • Subheaders are headings: .subsection-label at --text-lg minimum.
  • One featured kicker per page may take .eyebrow-accent.
Don't
  • Type a raw rem or px font-size. Size only via --text-* tokens.
  • Re-shrink a registry label in page CSS. A local 0.65rem clone of .kpi-label is the canonical sin.
  • Type a literal letter-spacing on a label; the --track-* tokens are the only values.
  • Put the accent on wayfinding. Green means interactive or live.
03 · Layout & spacing

Fill the screen, keep the rhythm.

Three container widths and drop-in grids so a dashboard uses the monitor instead of stranding a skinny column in the middle. A single fluid spacing scale keeps the vertical rhythm consistent everywhere.

Containers
.container
1200px

Reading width. Prose, single-column docs.

.container-wide
1440px

Dashboard width. KPI rows, charts, multi-column data.

.container-full
100%

Full bleed with gutters. Dense tables, seat maps.

Grids

Responsive by default, collapse to one column on narrow screens.

grid-4
grid-4
grid-4
grid-4
col-8 (chart)
col-4 (rail)
Spacing scale
--space-xs
--space-sm
--space-md
--space-lg
--space-xl
--space-section
04 · Components

The controls, brand-correct out of the box.

Sharp edges, lift on hover (never scale), one accent per layout. Everything below is a class in components.css.

Buttons
Inputs
Toggle & segmented
Tabs
Chips
Badges, pills & deltas
Sold out In Review Live On track 12.4% 3.1%
States & feedback
No matches found
Try widening the date range.
Snapshot failed
The API returned 502. Retry in a minute.
updated 2m ago updated 26m ago updated 3h ago
Saved
Board updated. Shown in place here; live, toasts stack bottom-right via .toast-stack.
05 · Data display

Numbers, the way Triumph reads them.

Tabular mono figures, accent-keyed KPIs, dense tables with totals, and Chart.js wired to the palette through the tok() helper.

KPI tiles
Revenue
$2.41M
12% vs last season
Tickets sold
18,472
8% vs last season
Avg order
$128
2% vs last season
Sell-through
94.2%
flat vs last season

Tickets by channel

Cumulative sales

live
Executive scoreboard
Greenville Triumph

2026 Season Ticketing

As of Jun 4, 2026 · 5 played · 14 to go
Total revenue
$499,086
tickets + parking, season to date
Tickets distributed
26,354
admissions, season to date
Season ticket members
874
$344,349 in season plans
Home sell-through
94.2%
20,217 of 21,460 seats
Title-card hero

For pages that ARE the event (matchday guides, one-pagers): the Main lockup, a quiet Inter kicker, the fixture in poster Fabiola, and an info rail where Light Green marks the one live fact. The scale boundary is hard: poster Fabiola belongs to title-card pages only; data dashboards keep .h-display at the calibrated size.

Greenville Triumph

Match 9 of 17 · 2026 USL League One

Triumph vs Knoxville
Kickoff7:00 PM
VenueGE Vernova Park
Gates5:30 PM
Capacity3,842
Stat band
Matches
17
2026 home slate
Capacity
3,842
GE Vernova Park
STH base
1,210
renewals + new
Sell-through
94.2%
season to date
Data table
MatchOpponentSoldHeldOpenStatus
5/9Lexington SC3,84200Sold out
6/3Charlotte Independence3,104220518On sale
6/21One Knoxville2,4881801,174Slow
7/11Chattanooga Red Wolves3,610120112Near sellout
Total13,0445201,804
06 · Dashboard demo

A real page, assembled only from this system.

No bespoke CSS. Every block above, composed the way a live Triumph dashboard composes them. This is the bar a page hits on the first try.

Tickets · Season 2026 updated 2m ago
Revenue
$2.41M
Sold
18,472
STH
1,210
Sell-through
94.2%

Weekly sales

Top reps

Sam$612K
Brandon$548K
Owen$410K

Brand-correct, screen-tuned, every time.

07 · Logos

Three lockups, three backgrounds.

Pick the lockup for the space and the variant for the background. Never recolor, stretch, rotate, or add effects.

Main
Main color
Main · ColorPNG
Main on light
Main · On lightPNG
Main on dark
Main · On darkPNG
Simplified
Simplified color
Simplified · ColorPNG
Simplified on light
Simplified · On lightPNG
Simplified on dark
Simplified · On darkPNG
Wordmark
Wordmark color
Wordmark · ColorPNG
Wordmark on light
Wordmark · On lightPNG
Wordmark on dark
Wordmark · On darkPNG
Elements
Brand pattern
PatternPNG
Brand shape
ShapePNG
08 · Voice

Clear, inclusive, never corporate.

Together we triumph

Soccer connects people across cultures, languages, and backgrounds, creating community, opportunity, and a sense of home.

Do
  • Lead with clarity. Do not overcomplicate.
  • Stay inclusive. Speak to belonging.
  • Say "Greenville Triumph" in everyday copy.
Avoid
  • Corporate or detached tone.
  • Aggressive or exclusionary language.
  • "GVL Triumph", or any em dash.
09 · Anti-patterns

The drift that makes a page look off.

Do
  • Reference tokens by name: var(--color-accent).
  • Lift on hover with translateY and a border tint.
  • Flat surfaces from the elevation ladder.
  • Fabiola weight 400, hero only.
  • One accent per layout.
  • Tabular-nums on every figures column.
Don't
  • Hardcode hex, rgba, or oklch.
  • Scale on hover, or pulse scroll arrows.
  • Gradient page or section backgrounds.
  • Fabiola on h2/h3, or any weight above 400.
  • Pair Electric Lime with Light Green.
  • Use yellow as a decorative accent.
10 · Ship checklist

Before a dashboard goes out.

11 · Token reference

The names, copy-paste ready.

The most-used tokens as raw values. The full set lives in tokens.css.

/* canvas + elevation */
--color-bg: #14181f;
--color-surface-2: #22262e;  --color-surface-3: #2d3039;
/* text */
--color-text: #f2fafa;  --color-text-soft: #d2e6e5;
/* accents (one per layout) */
--color-accent: #61a631;  --color-blue: #69b3e7;  --color-pop: #97d700;
/* type + layout */
--font-display: Fabiola Capitals;
--font-sans: Inter;  --font-mono: JetBrains Mono;
--text-label: clamp(0.84rem, 0.80rem + 0.20vw, 0.95rem);
--track-label: 0.08em;  --track-kicker: 0.12em;
--content-wide: 1440px;  --space-section: clamp(2.75rem, 2rem + 3vw, 5rem);
/* Chart.js: canvas cannot read vars, use the helper */
const tok = n => getComputedStyle(document.documentElement).getPropertyValue(n).trim();