2026-05-08 16:07:14 +03:00
|
|
|
/*
|
|
|
|
|
* Глобальные стили Лидерра. Tailwind удалён в фазе 2 (CLAUDE.md §5 п.2 запрет).
|
|
|
|
|
* Палитра Forest и токены — через Vuetify theme в resources/js/plugins/vuetify.ts.
|
|
|
|
|
* Шрифты Inter (UI) и JetBrains Mono (numerics) подключаются здесь.
|
|
|
|
|
*/
|
2026-05-08 09:37:16 +03:00
|
|
|
|
2026-05-08 16:07:14 +03:00
|
|
|
@import url('https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,400;14..32,500;14..32,600;14..32,700&family=JetBrains+Mono:wght@400;500;600&display=swap');
|
2026-05-08 09:37:16 +03:00
|
|
|
|
2026-05-08 16:07:14 +03:00
|
|
|
:root {
|
|
|
|
|
--liderra-page-bg: #f6f3ec; /* warm ivory, BRANDBOOK_v2 §3 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
html,
|
|
|
|
|
body {
|
|
|
|
|
margin: 0;
|
|
|
|
|
padding: 0;
|
|
|
|
|
font-family: 'Inter', ui-sans-serif, system-ui, sans-serif;
|
|
|
|
|
background: var(--liderra-page-bg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* tnum для всех численных значений в .numeric (для финансов и счётчиков). */
|
|
|
|
|
.numeric {
|
|
|
|
|
font-family: 'JetBrains Mono', ui-monospace, monospace;
|
|
|
|
|
font-feature-settings: 'tnum' 1;
|
2026-05-08 09:37:16 +03:00
|
|
|
}
|
2026-05-12 22:09:48 +03:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* A11y override: Vuetify .v-messages helper-text + .v-field-label opacity
|
|
|
|
|
* (~0.52 default) рендерится ≈#7a7a7a/#767471 → contrast 4.20-4.29 fails
|
|
|
|
|
* WCAG 2.1 AA 4.5:1. Q.DEFER.002 fix (12.05.2026 audit): локально bump до 0.7
|
|
|
|
|
* → rendered ≈#595959 → 7.9:1+.
|
|
|
|
|
*/
|
|
|
|
|
.v-messages,
|
|
|
|
|
.v-field-label {
|
|
|
|
|
--v-medium-emphasis-opacity: 0.7;
|
|
|
|
|
}
|
2026-05-14 10:07:35 +03:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* A11y rescan 2026-05-14: Vuetify tonal-variant default text color produces
|
|
|
|
|
* 2.0-4.4:1 contrast on ivory page background (#f6f3ec) — below WCAG 2.1 AA
|
|
|
|
|
* 4.5:1 threshold. Pa11y rescan flagged across /billing /admin/billing
|
|
|
|
|
* /admin/incidents /admin/system. Fix: darken text color inside .v-alert and
|
|
|
|
|
* .v-chip tonal variants; also darken .text-warning utility used in count
|
|
|
|
|
* badges (text-h6 text-warning «5» on ivory was 2.03:1).
|
|
|
|
|
*/
|
|
|
|
|
.v-alert--variant-tonal .v-alert__content,
|
|
|
|
|
.v-alert--variant-tonal .v-alert__content strong,
|
|
|
|
|
.v-alert--variant-tonal .v-alert__content code {
|
|
|
|
|
color: #0a0700;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.v-chip--variant-tonal.bg-success .v-chip__content,
|
|
|
|
|
.v-chip--variant-tonal.text-success .v-chip__content {
|
|
|
|
|
/* deep forest green, ≥4.5:1 on tonal pale-success bg */
|
|
|
|
|
color: #1f5e3a;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.v-chip--variant-tonal.bg-warning .v-chip__content,
|
|
|
|
|
.v-chip--variant-tonal.text-warning .v-chip__content {
|
|
|
|
|
/* dark amber, ≥4.5:1 on tonal pale-warning bg + on ivory page bg */
|
|
|
|
|
color: #6a4504;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* .text-warning is used both inside chips (covered above) and standalone
|
|
|
|
|
* (text-h6 count badges on ivory background). Vuetify defines the utility as
|
|
|
|
|
* `.v-theme--liderraForest .text-warning { color: rgb(var(--v-theme-warning)) !important }`
|
|
|
|
|
* which has specificity 0,2,0 + !important — plain `.text-warning !important`
|
|
|
|
|
* (0,1,0) loses on specificity even with !important. Match Vuetify's selector
|
|
|
|
|
* exactly so our override wins on cascade-order (loaded after Vuetify CSS).
|
|
|
|
|
*/
|
|
|
|
|
.v-theme--liderraForest .text-warning,
|
|
|
|
|
.v-theme--liderraForest.text-warning,
|
|
|
|
|
.text-warning {
|
|
|
|
|
color: #6a4504 !important;
|
|
|
|
|
}
|