---
name: soneta-ui-style
description: "System projektowy (design system) Soneta / enova365 do budowania aplikacji webowych i stron internetowych wizualnie spójnych z enova365 ERP. Zawiera pełne specyfikacje: palety kolorów (motywy jasny/ciemny), typografię, layout, komponenty UI (przyciski, formularze, tabele, sidebar, header, kafelki, modale), system odstępów, cienie, ikony SVG, animacje i responsywność. Używaj tego skilla ZAWSZE gdy użytkownik: (1) prosi o zaprojektowanie, zbudowanie lub ostylowanie strony/aplikacji webowej w stylu Soneta lub enova365; (2) wspomina 'styl enova', 'styl Soneta', 'design system enova365', 'UI enova'; (3) chce stworzyć dashboard, formularz, stronę logowania lub panel administracyjny w estetyce enova365; (4) prosi o landing page, stronę firmową lub aplikację z zielonym motywem enterprise w stylu Soneta; (5) pyta o kolory, czcionki, komponenty lub wzorce UI platformy enova365/Soneta. Skill działa z każdym stosem technologicznym (HTML/CSS, React, Vue, Tailwind, itp.)."
---
# Soneta / enova365 — Design System
Ten skill opisuje reguły projektowania interfejsów użytkownika wizualnie spójnych z aplikacją enova365 ERP firmy Soneta. Stosuj te reguły budując strony internetowe, dashboardy, formularze i aplikacje webowe w estetyce Soneta.
## Zasady przewodnie
1. **Szmaragdowa zieleń jako kolor wiodący** — `#016E46` dominuje w headerze, sidebarze (motyw jasny), przyciskach akcji, stanach focus i linkach
2. **Enterprise minimalizm** — czysty, profesjonalny interfejs bez ozdobników, nacisk na czytelność danych
3. **Wysoka gęstość informacji** — kompaktowe wiersze (`30-36px`), pola blisko siebie, minimalne marginesy
4. **Płaski design z subtelnymi cieniami** — brak skeuomorfizmu, delikatne bordery i cienie
5. **Hierarchia przez wagę czcionki, nie rozmiar** — różnice wynikają z `font-weight` (400 vs 600), a nie drastycznych zmian rozmiaru
6. **Dwa motywy: jasny i ciemny** — oba używają tego samego systemu zmiennych CSS
7. **Spójność stanów** — każdy komponent definiuje 6 stanów: default, hover, focus, pressed, selected, disabled
---
## 1. Kolory
### 1.1 Brand (wspólne)
| Token | Wartość | Użycie |
|-------|---------|--------|
| `--brand_500` | `#016E46` | Kolor główny — header, focus, linki |
| `--brand_600` | `#015436` | Brand ciemny |
| `--brand_700` | `#01422A` | Brand najciemniejszy |
| `--brand_300` | `#3A8E6F` | Brand jasny |
| `--brand_200` | `#02E391` | Brand najjaśniejszy |
| Akcent cyjan | `#31e2b8` | Logo — turkusowy |
| Akcent błękitny | `#6acbf3` | Logo — jasny niebieski |
### 1.2 Motyw jasny (White)
| Przeznaczenie | Kolor |
|---------------|-------|
| Tło główne (content area) | `rgb(230, 231, 231)` — jasnoszare, wydziela białe karty |
| Tło headera | `#016E46` — szmaragdowy |
| Tło sidebara | `#003320` — bardzo ciemna zieleń, **ciemniejszy niż header** |
| Sidebar hover | `rgba(0, 70, 38)` |
| Sidebar selected | `rgba(0, 88, 48)` |
| Tekst sidebara | `#FFFFFF` |
| Tło surface/karty | `#FFFFFF` |
| Tło sekcji | `#F5F5F5` – `#FAFAFA` |
| Tekst podstawowy | `#212121` – `#333333` |
| Tekst drugorzędny | `#757575` – `#A3A3A3` |
| Tekst etykiet | `#616161` |
| Obramowanie inputów | `#BDBDBD` – `#E0E0E0` |
| Obramowanie focus | `#016E46` |
| Wiersz zaznaczony | `rgba(46, 125, 50, 0.08)` |
| Wiersz hover | `rgba(0, 0, 0, 0.04)` |
| Separator | `#E0E0E0` |
### 1.3 Motyw ciemny (Black)
| Przeznaczenie | Kolor |
|---------------|-------|
| Tło główne | `#1E1E1E` – `#212121` |
| Tło headera | `#1B5E20` – `#0D3B14` — ciemnozielony |
| Tło sidebara | `#262626` — **grafitowy, nie zielony** |
| Tło surface/karty | `#2A2A2A` – `#303030` |
| Tekst podstawowy | `#E0E0E0` – `#F0F0F0` |
| Tekst drugorzędny | `#A3A3A3` |
| Tekst etykiet | `#BDBDBD` |
| Obramowanie inputów | `#424242` – `#555555` |
| Obramowanie focus | `#016E46` — identyczny jak w jasnym |
| Wiersz zaznaczony | `rgba(46, 125, 50, 0.15)` |
| Wiersz hover | `rgba(255, 255, 255, 0.05)` |
| Separator | `#424242` |
| Overlay modal | `rgba(0, 0, 0, 0.7)` |
### 1.4 Kolory semantyczne
| Przeznaczenie | Kolor |
|---------------|-------|
| Success / Primary action | `#2E7D32` — przyciski "Zapisz" |
| Danger | `#C62828` – `#D32F2F` — przyciski "Zamknij" |
| Warning | `#F57C00` |
| Info | `#1976D2` |
| Link | `#016E46` |
| Disabled | `#A3A3A3` z opacity |
### 1.5 Paleta neutralna (z PaletteBase.css)
Wartości w formacie RGB (bez `rgb()`):
| Token | Wartość | HEX |
|-------|---------|-----|
| `--neutral_0` | `255, 255, 255` | `#FFFFFF` |
| `--neutral_100` | `245, 245, 245` | `#F5F5F5` |
| `--neutral_200` | `229, 229, 229` | `#E5E5E5` |
| `--neutral_300` | `212, 212, 212` | `#D4D4D4` |
| `--neutral_500` | `109, 115, 113` | `#6D7371` |
| `--neutral_700` | `77, 81, 80` | `#4D5150` |
| `--neutral_800` | `38, 38, 38` | `#262626` |
| `--neutral_850` | `33, 33, 33` | `#212121` |
| `--neutral_900` | `23, 23, 23` | `#171717` |
Semantyczne: `--red_600: #DC2626`, `--green_400: #10C200`, `--blue_500: #3B82F6`, `--orange_500: #F97316`, `--yellow_400: #F3D930`, `--emerald_400: #139041`.
---
## 2. Typografia
### Czcionki
| Przeznaczenie | Czcionka | Fallback |
|---------------|----------|----------|
| Główna (`--primaryFont`) | `"FiraSans"` | `Arial, sans-serif` |
| Alternatywna (`--tertiaryFont`) | `"ROBOTO"` | `sans-serif` |
| Nagłówki | `"SourceSansSemiBold"` | `Arial, sans-serif` |
| Branding/logo | `"Lato"` | `sans-serif` |
| Monospace | `Consolas` | `"Courier New", monospace` |
Gdy nie możesz załadować czcionek Soneta, użyj `"Roboto", "Segoe UI", Arial, sans-serif` jako bezpiecznego zamiennika.
### Rozmiary
| Przeznaczenie | Rozmiar |
|---------------|---------|
| Captions | `10px` – `11px` |
| Etykiety pól | `12px` (`--font_size_label: 9pt`) |
| Tekst w inputach | `13px` – `14px` |
| Body (podstawowy) | `14px` |
| Nagłówki sekcji | `14px` – `16px` + `font-weight: 600` |
| Tytuł formularza | `16px` – `18px` |
| Duże nagłówki | `20px` – `24px` |
| Logo / ekran logowania | `24px` – `32px` |
### Grubości
| Styl | Wartość | Użycie |
|------|---------|--------|
| Light | `300` | Delikatne teksty |
| Regular | `400` | Domyślna |
| Medium | `500` | Przyciski |
| Semi-bold | `600` | Nagłówki sekcji, aktywne menu |
| Bold | `700` | Tytuły |
### Wysokość linii
Body: `18-20px`, wiersze tabeli: `20-24px`, inputy: `24-26px`, nagłówki: `28-32px`.
### Letter-spacing
Normalny tekst: `0–0.1px`, etykiety: `0.15–0.25px`, przyciski uppercase: `0.6–2px`.
---
## 3. Layout
### Struktura główna
```
┌──────────────────────────────────────────────────────┐
│ HEADER BAR (~48-56px) │
│ [Logo] [Search] [Ikony] [Avatar] │
├──────────┬───────────────────────────────────────────┤
│ │ BREADCRUMB (~32px) │
│ ├───────────────────────────────────────────┤
│ SIDEBAR │ TOOLBAR + TABS (~44-48px) │
│ (250px) ├───────────────────────────────────────────┤
│ │ │
│ Drzewo │ CONTENT AREA │
│ nawigacji│ (Formularz / Lista / Dashboard) │
│ │ │
├──────────┴───────────────────────────────────────────┤
│ STATUS BAR (opcjonalnie) │
└──────────────────────────────────────────────────────┘
```
### Wymiary
| Element | Wymiar |
|---------|--------|
| Header bar | `48px` – `56px` |
| Sidebar rozwinięty | `240px` – `260px` |
| Sidebar zwinięty | `48px` – `56px` |
| Breadcrumb | `28px` – `32px` |
| Toolbar | `40px` – `48px` |
| Status bar | `24px` – `28px` |
| Min width | `1024px` |
### System layoutu
- **Flexbox** dominuje — `flex-direction: row` dla sidebar+content, `column` dla sekcji
- **Grid** sporadycznie — dashboard kafelków
- `justify-content: space-between` w toolbarze
- `align-items: center` praktycznie wszędzie
---
## 4. Komponenty UI
### 4.1 Przyciski
| Wariant | Tło | Tekst | Border | Użycie |
|---------|-----|-------|--------|--------|
| **Primary** | `#2E7D32` | `#FFF` | brak | "Zapisz", "Zaloguj" |
| **Secondary** | przezroczyste | inherit | `1px solid` szary | "Czynności" |
| **Tertiary** | przezroczyste | inherit | brak | Ikony toolbar |
| **Danger** | `#C62828` | `#FFF` | brak | "Zamknij" |
Wymiary: height `32-38px` (standard) / `40-44px` (duży), padding `6px 12px` / `8px 16px` / `10px 20px`, border-radius `4-6px`, font `13-14px` weight `500-600`, gap ikona+tekst `6-8px`.
Stany: hover — lekkie rozjaśnienie; focus — `box-shadow: inset 0 0 3px 1px #016E46`; pressed — przyciemnienie; disabled — opacity `0.5-0.6`.
```css
/* Przykład: przycisk Primary */
.btn-primary {
background-color: #2E7D32;
color: #FFFFFF;
border: none;
border-radius: 4px;
padding: 6px 16px;
font-size: 14px;
font-weight: 500;
cursor: pointer;
transition: background-color 0.2s ease;
}
.btn-primary:hover { filter: brightness(1.1); }
.btn-primary:focus { box-shadow: inset 0 0 3px 1px #016E46; }
.btn-primary:disabled { opacity: 0.5; cursor: default; }
```
### 4.2 Pola formularza
| Właściwość | Jasny | Ciemny |
|------------|-------|--------|
| Tło | `#FFFFFF` | `#2A2A2A` |
| Tekst | `#212121` | `#E0E0E0` |
| Border | `1px solid #BDBDBD` | `1px solid #555555` |
| Border-radius | `4px` | `4px` |
| Wysokość | `30-32px` | `30-32px` |
| Padding | `4px 8px` | `4px 8px` |
| Font-size | `13-14px` | `13-14px` |
Focus: border `#016E46` + opcjonalnie `box-shadow: inset 0 0 3px 1px #016E46`. Error: czerwony shadow. Warning: pomarańczowy shadow. Disabled: tło `#F5F5F5` / `#1A1A1A`.
**Etykiety**: font `12px`, kolor `#757575` (jasny) / `#BDBDBD` (ciemny), weight `400`.
**Układ formularza**: siatka 2-4 kolumn, etykieta po lewej (~100-140px stała szerokość), input `flex: 1`, gap między wierszami `8-12px`, sekcje oddzielone nagłówkami z marginesem `16-24px`.
### 4.3 Checkbox
Rozmiar `16-18px`, border-radius `2-3px`, checked: zielone tło `#2E7D32` z białym checkmarkiem.
### 4.4 Tabele / Listy
**Nagłówek**: tło `#F5F5F5` (jasny) / `#2A2A2A` (ciemny), tekst `#616161` / `#BDBDBD`, font `12-13px` weight `600`, padding `8px 12px`.
**Wiersze**: tło naprzemienne `#FFF` / `#FAFAFA` (jasny), `#1E1E1E` / `#252525` (ciemny), height `30-36px`, padding `4-6px 12px`, font `13-14px`. Hover: `rgba(0,0,0,0.04)` / `rgba(255,255,255,0.05)`. Selected: zielony tint `rgba(46,125,50,0.08)` / `0.15`.
### 4.5 Zakładki (Tabs)
Styl **outline**: padding `6px 12px`, border `1px solid szary`, border-radius `4px`, font `13px`, aktywna — zielone tło lub zielony border, gap `4-6px`.
Styl **page tabs**: przylegające (`gap: 0`), aktywna — wyróżnione tło + pogrubiony tekst.
### 4.6 Header Bar
- Tło: `#016E46` (jasny) / `#1B5E20` (ciemny)
- Wysokość: `48-56px`, padding: `0 16px`
- Logo: ZAWSZE osadzać poniższe oficjalne SVG inline (nie wymyślać własnego logo!):
```html
```
- Search: **białe tło**, ciemny tekst, ikona lupy, border-radius `4px`
- Ikony: białe SVG `20-24px`
- Avatar: kółko `32-36px`, zielone tło + biały inicjał
- Shadow: `0 2px 4px rgba(0,0,0,0.1)` na dole
### 4.7 Sidebar
**Motyw jasny**: tło `#003320` (ciemniejsza zieleń niż header), biały tekst, białe ikony SVG `16-18px`. **Motyw ciemny**: tło `#262626` (grafitowy), jasnoszary tekst.
Kształt: border-radius `8-12px`, margin `4-6px` (góra/lewo/dół) — pływający panel z zaokrąglonymi rogami.
Struktura: (1) pasek sterowania "Zwiń"/"Odepnij", (2) pole wyszukiwania, (3) drzewo nawigacji z chevronami.
Hover: `rgba(255,255,255,0.08)` (jasny) / `0.05` (ciemny). Aktywny: `rgba(255,255,255,0.12)` + pogrubienie. Padding elementu: `8px 16px`, wcięcie podpoziomów: `+16-20px`.
### 4.8 Breadcrumb
Wysokość `28-32px`, font `12px`, kolor `#757575` (linki), ostatni segment `#212121` (nie-link), separator `>` kolor `#BDBDBD` z `margin: 0 4px`, ikona Home SVG `14-16px`, padding `4px 16px`.
### 4.9 Modal / Dialog
| Właściwość | Jasny | Ciemny |
|------------|-------|--------|
| Overlay | `rgba(0,0,0,0.5)` | `rgba(0,0,0,0.7)` |
| Tło | `#FFFFFF` | `#2A2A2A` |
| Border-radius | `8-12px` | `8-12px` |
| Shadow | `0 4px 20px rgba(0,0,0,0.25)` | `…0.5)` |
| Padding | `20-25px` | `20-25px` |
| Szerokość | `400-600px` | `400-600px` |
### 4.10 Dropdown / Menu kontekstowe
Tło białe/ciemne, border `1px solid #E0E0E0` / `#424242`, border-radius `8px`, shadow `0 4px 12px rgba(0,0,0,0.15)` / `0.4`, padding elementu `8px 16px`, font `13-14px`, ikony kolorowe `16-20px` po lewej.
### 4.11 Ekran logowania
Dwuczęściowy layout ~50/50: lewa — zdjęcie/branding z logo, prawa — formularz logowania wycentrowany w pionie. Logo "enova365" z akcentami kolorystycznymi. Hasło: "System ERP dla ambitnego biznesu" `22px` kursywa. Przycisk "Zaloguj": zielony, pełna szerokość, `40px` height. Footer: "by Soneta ®".
### 4.12 Dashboard — Kafelki (Tiles)
Tło content area: `rgb(230, 231, 231)` (jasny) — wydziela białe kafelki.
**Kafelek**: width `352px`, min-height `80px`, border-radius `12px`, tło białe/ciemne, **border-left `4px solid [kolor_modułu]`** — kolorowy akcent, shadow `0 0 10px 1px rgba(229,229,229)`, padding `10px 16px`.
**Układ wewnętrzny kafelka**: `display: flex; align-items: center; gap: 10px` — ikona po lewej, tekst (tytuł + opis) po prawej. Ikona jest wycentrowana w pionie względem bloku tekstowego.
**Ikona w kafelku**: rozmiar `20px` × `20px`, kolor = kolor modułu (taki sam jak border-left). Ikona to czyste SVG liniowe (outline) — same kontury, **bez koła/okręgu za ikoną**, bez żadnego tła pod ikoną. Ikona renderowana bezpośrednio na białym tle kafelka.
Katalog `SvgResources/` tego skilla zawiera ~370 gotowych ikon SVG enova365. Każda ikona ma `viewBox="0 0 160 160"` i używa `fill` na elementach `` (cienkie kształty dające efekt liniowy). Aby użyć ikony w kafelku, skopiuj zawartość pliku SVG, ustaw `width="20" height="20"` i nadaj kolor modułu przez atrybut `fill` na elemencie `