{"id":485395,"date":"2026-06-29T07:36:43","date_gmt":"2026-06-29T07:36:43","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=485395"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=485395","title":{"rendered":"\u0412\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441\u0442\u0430\u0442\u0435\u0439\u043d\u043e\u0433\u043e \u0441\u0430\u0439\u0442\u0430: \u0442\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u043a\u0430, \u0446\u0432\u0435\u0442 \u0438 \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438-\u0441\u043b\u043e\u0439"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u0412\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441\u0442\u0430\u0442\u0435\u0439\u043d\u043e\u0433\u043e \u0441\u0430\u0439\u0442\u0430 \u0441\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u0437 \u0441\u043e\u0442\u0435\u043d \u043c\u0435\u043b\u043a\u0438\u0445 \u0440\u0435\u0448\u0435\u043d\u0438\u0439 \u2014 \u043e\u0442 \u043e\u0441\u0438 GRAD \u0432 \u0448\u0440\u0438\u0444\u0442\u0435 \u0434\u043e \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u0438\u044f \u043c\u043e\u0434\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043e\u043a\u043d\u0430. \u041a\u0430\u0436\u0434\u043e\u0435 \u0442\u0430\u043a\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043b\u0438\u0431\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435, \u043b\u0438\u0431\u043e \u0432\u043e\u0440\u0443\u0435\u0442 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0443 \u0442\u0435\u043a\u0441\u0442\u0430.<\/p>\n<h3>\u041f\u043e\u0447\u0435\u043c\u0443 \u043e\u0434\u0438\u043d \u0448\u0440\u0438\u0444\u0442\u043e\u0432\u043e\u0439 \u0444\u0430\u0439\u043b \u0437\u0430\u043c\u0435\u043d\u044f\u0435\u0442 \u0446\u0435\u043b\u043e\u0435 \u0441\u0435\u043c\u0435\u0439\u0441\u0442\u0432\u043e \u043d\u0430\u0447\u0435\u0440\u0442\u0430\u043d\u0438\u0439<\/h3>\n<p>\u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043e\u0431\u044b\u0447\u043d\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0434\u0432\u0443\u043c\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438: \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0448\u0440\u0438\u0444\u0442\u0430 \u0438 \u043c\u0435\u0436\u0441\u0442\u0440\u043e\u0447\u043d\u044b\u043c \u0438\u043d\u0442\u0435\u0440\u0432\u0430\u043b\u043e\u043c. \u0422\u0430\u043a\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0442\u043e\u0447\u043a\u043e\u0439 \u0432\u0445\u043e\u0434\u0430, \u043d\u043e \u043d\u0435 \u0440\u0430\u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0448\u0440\u0438\u0444\u0442\u043e\u0432\u044b\u0445 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0439.<\/p>\n<p>\u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0439 \u0448\u0440\u0438\u0444\u0442 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u043d\u0435 \u043d\u0430\u0431\u043e\u0440 \u0441\u0442\u0430\u0442\u0438\u0447\u043d\u044b\u0445 \u043d\u0430\u0447\u0435\u0440\u0442\u0430\u043d\u0438\u0439, \u0430 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u043e\u0435 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432. Inter Variable, \u043a \u043f\u0440\u0438\u043c\u0435\u0440\u0443, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u043e\u0441\u044c wght \u0434\u043b\u044f \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0432\u0435\u0441\u043e\u043c \u043e\u0442 100 \u0434\u043e 900 \u0438 \u043e\u0441\u044c opsz \u0434\u043b\u044f \u043e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u0442 \u0444\u043e\u0440\u043c\u0443 \u0433\u043b\u0438\u0444\u043e\u0432 \u043f\u043e\u0434 \u043a\u0435\u0433\u043b\u044c. \u041d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0448\u0440\u0438\u0444\u0442\u043e\u0432\u044b\u0435 \u0441\u0435\u043c\u0435\u0439\u0441\u0442\u0432\u0430 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442 \u043e\u0441\u044c GRAD \u2014 grade, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043c\u0435\u043d\u044f\u0435\u0442 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0443\u044e \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u044c \u0441\u0438\u043c\u0432\u043e\u043b\u0430 \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0435\u0433\u043e \u0448\u0438\u0440\u0438\u043d\u044b. \u0421\u0432\u044f\u0437\u043a\u0430 \u044d\u0442\u0438\u0445 \u043e\u0441\u0435\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0442\u043e\u0447\u043d\u043e \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0442\u044c \u0442\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u043a\u0443 \u043f\u043e\u0434 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0435 \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u043d\u0435 \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u044b \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043d\u0430\u0447\u0435\u0440\u0442\u0430\u043d\u0438\u044f.<\/p>\n<pre><code class=\"css\">body {  font-family: 'Inter Variable', sans-serif;  font-variation-settings: 'wght' 400, 'opsz' 32;}h1 {  font-variation-settings: 'wght' 750, 'opsz' 72, 'GRAD' 0;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435 \u0431\u0443\u043a\u0432\u044b \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u0436\u0438\u0440\u043d\u0435\u0435 \u0438\u0437-\u0437\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 irradiation \u2014 \u0441\u0432\u0435\u0442\u043b\u043e\u0435 \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u00ab\u0440\u0430\u0441\u043f\u043b\u044b\u0432\u0430\u0435\u0442\u0441\u044f\u00bb \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0444\u043e\u043d\u0430. \u041e\u0441\u044c <code>GRAD<\/code> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043a\u043e\u043c\u043f\u0435\u043d\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u043e \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0438 \u0433\u043b\u0438\u0444\u043e\u0432:<\/p>\n<pre><code class=\"css\">@media (prefers-color-scheme: dark) {  body { font-variation-settings: 'wght' 400, 'opsz' 32, 'GRAD' -25; }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>Fluid-\u0448\u043a\u0430\u043b\u0430 \u0432\u043c\u0435\u0441\u0442\u043e \u0431\u0440\u0435\u0439\u043a\u043f\u043e\u0438\u043d\u0442\u043e\u0432<\/h4>\n<p>\u0422\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0448\u043a\u0430\u043b\u0430 \u0447\u0435\u0440\u0435\u0437 <code>clamp()<\/code> \u0437\u0430\u0434\u0430\u0451\u0442 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043a \u0432\u043c\u0435\u0441\u0442\u043e \u0434\u0438\u0441\u043a\u0440\u0435\u0442\u043d\u044b\u0445 \u0441\u043a\u0430\u0447\u043a\u043e\u0432 \u043d\u0430 \u043c\u0435\u0434\u0438\u0430\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445. \u041a\u0430\u0436\u0434\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u043d\u0430 \u0443\u0437\u043a\u043e\u043c \u0432\u044c\u044e\u043f\u043e\u0440\u0442\u0435, \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0440\u043e\u0441\u0442\u0430 \u0447\u0435\u0440\u0435\u0437 <code>vw<\/code> \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u043d\u0430 \u0448\u0438\u0440\u043e\u043a\u043e\u043c:<\/p>\n<pre><code class=\"css\">:root {  --step--1: clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);  --step-0:  clamp(1rem,     0.95rem + 0.25vw, 1.125rem);  --step-1:  clamp(1.2rem,   1.1rem  + 0.5vw,  1.5rem);  --step-2:  clamp(1.44rem,  1.25rem + 1vw,    2rem);  --step-3:  clamp(1.728rem, 1.4rem  + 1.5vw,  2.5rem);  --step-4:  clamp(2.074rem, 1.6rem  + 2.5vw,  3.5rem);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u0440\u043e\u0441\u0442\u0430 \u043c\u0435\u0436\u0434\u0443 \u0441\u0442\u0443\u043f\u0435\u043d\u044f\u043c\u0438 (~1.2) \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043c\u0443\u0437\u044b\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0448\u043a\u0430\u043b\u044b \u043d\u0430 \u043b\u044e\u0431\u043e\u043c \u0440\u0430\u0437\u043c\u0435\u0440\u0435 \u044d\u043a\u0440\u0430\u043d\u0430 \u0431\u0435\u0437 \u0440\u0443\u0447\u043d\u043e\u0439 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439.<\/p>\n<h4>OpenType-\u0444\u0443\u043d\u043a\u0446\u0438\u0438<\/h4>\n<p>\u0428\u0440\u0438\u0444\u0442\u044b \u0441 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439 OpenType \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0433\u043b\u0438\u0444\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0432\u044b\u043a\u043b\u044e\u0447\u0435\u043d\u044b. \u0412\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u044f\u0432\u043d\u043e\u0433\u043e \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u044f:<\/p>\n<pre><code class=\"css\">.article-body {  font-feature-settings:    'kern' 1,   \/* \u043a\u0435\u0440\u043d\u0438\u043d\u0433 *\/    'liga' 1,   \/* \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u043b\u0438\u0433\u0430\u0442\u0443\u0440\u044b: fi, fl *\/    'calt' 1,   \/* \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043d\u044b\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b *\/    'onum' 1;   \/* \u0441\u0442\u0440\u043e\u0447\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u2014 \u043d\u0435 \u0442\u043e\u0440\u0447\u0430\u0442 \u0432\u044b\u0448\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 *\/}\/* \u0422\u043e\u043b\u044c\u043a\u043e \u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445 \u0438 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445: *\/.data-table, .post-meta {  font-feature-settings: 'tnum' 1; \/* \u0442\u0430\u0431\u043b\u0438\u0447\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u2014 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u0430\u044f \u0448\u0438\u0440\u0438\u043d\u0430 *\/}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>onum<\/code> (oldstyle numerals) \u2014 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u0434\u0435\u0442\u0430\u043b\u044c \u0434\u043b\u044f \u0434\u043b\u0438\u043d\u043d\u043e\u0433\u043e \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430. \u0417\u0430\u0433\u043b\u0430\u0432\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b (0\u20139 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435) \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u0432\u044b\u043f\u0438\u0440\u0430\u044e\u0442 \u0438\u0437 \u0441\u0442\u0440\u043e\u043a\u0438, \u0441\u0442\u0440\u043e\u0447\u043d\u044b\u0435 \u0438\u043d\u0442\u0435\u0433\u0440\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0432 \u0440\u0438\u0442\u043c \u0442\u0435\u043a\u0441\u0442\u0430.<\/p>\n<h4>\u041e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u043d\u0438\u0435 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u043e\u0432<\/h4>\n<p>\u0418\u0437-\u0437\u0430 \u0431\u043e\u043a\u043e\u0432\u044b\u0445 \u043f\u043e\u043b\u0435\u0439 \u0433\u043b\u0438\u0444\u043e\u0432 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0438 \u0441 \u0437\u0430\u0441\u0435\u0447\u043a\u0430\u043c\u0438 \u0438\u043b\u0438 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u0438\u043c\u0438 \u0448\u0440\u0438\u0444\u0442\u0430\u043c\u0438 \u043a\u0430\u0436\u0443\u0442\u0441\u044f \u00ab\u0441\u044a\u0435\u0445\u0430\u0432\u0448\u0438\u043c\u0438\u00bb \u0432\u043f\u0440\u0430\u0432\u043e \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430\u0447\u0430\u043b\u0430 \u043a\u043e\u043b\u043e\u043d\u043a\u0438. \u041a\u043e\u043c\u043f\u0435\u043d\u0441\u0430\u0446\u0438\u044f:<\/p>\n<pre><code class=\"css\">h1, h2, h3 {  text-indent: -0.05em;  hanging-punctuation: first last;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>hanging-punctuation<\/code> \u0432\u044b\u043d\u043e\u0441\u0438\u0442 \u043a\u0430\u0432\u044b\u0447\u043a\u0438 \u0438 \u0442\u0438\u0440\u0435 \u0437\u0430 \u043f\u043e\u043b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u2014 \u0442\u0430\u043a \u043e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0433\u0440\u0430\u043d\u0438\u0446\u0430 \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442 \u0441 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439.<\/p>\n<h4>\u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f prose-\u0431\u043b\u043e\u043a\u043e\u0432<\/h4>\n<p>\u0421\u0442\u0430\u0442\u044c\u044f \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0442\u0438\u043f\u043e\u0432 \u0431\u043b\u043e\u043a\u043e\u0432 \u0441 \u0440\u0430\u0437\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0435\u0439. \u041d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u043d\u043e\u0433\u043e \u0442\u043e\u043a\u0435\u043d\u0430 \u0434\u0435\u043b\u0430\u0435\u0442 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u044e \u044f\u0432\u043d\u043e\u0439 \u0438 \u043b\u0435\u0433\u043a\u043e \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u0438\u0440\u0443\u0435\u043c\u043e\u0439 \u0431\u0435\u0437 \u043f\u0440\u0430\u0432\u043a\u0438 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0431\u043b\u043e\u043a\u0430 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e:<\/p>\n<pre><code class=\"css\">:root {  --sbrd-single-body:       1.0rem;  \/* \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0435\u043a\u0441\u0442 *\/  --sbrd-single-quote:      0.93rem; \/* \u0446\u0438\u0442\u0430\u0442\u0430 \u2014 \u0442\u0438\u0448\u0435 body *\/  --sbrd-single-list:       0.90rem; \/* \u0441\u043f\u0438\u0441\u043a\u0438 \u2014 \u0432\u0441\u043f\u043e\u043c\u043e\u0433\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 *\/  --sbrd-single-disclaimer: 0.84rem; \/* \u0441\u043b\u0443\u0436\u0435\u0431\u043d\u044b\u0439 \u0431\u043b\u043e\u043a *\/  --sbrd-single-code:       0.875rem;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u043b\u044e\u0447\u0435\u0432\u043e\u0435 \u0441\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435: <code>body &gt; quote &gt; list &gt; disclaimer<\/code>. \u041d\u0430\u0440\u0443\u0448\u0435\u043d\u0438\u0435 \u044d\u0442\u043e\u0439 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438 \u2014 \u043a\u043e\u0433\u0434\u0430 \u0441\u043f\u0438\u0441\u043e\u043a \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442 \u043f\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0443 \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u2014 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u0435 \u00ab\u0434\u0432\u0443\u0445 \u043a\u043e\u043d\u043a\u0443\u0440\u0438\u0440\u0443\u044e\u0449\u0438\u0445 \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u00bb \u0432\u043c\u0435\u0441\u0442\u043e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0447\u0442\u0435\u043d\u0438\u044f.<\/p>\n<h3>\u0426\u0432\u0435\u0442: \u043f\u0435\u0440\u0446\u0435\u043f\u0442\u0438\u0432\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043d\u0430 OKLCH<\/h3>\n<h4>\u041f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435 HSL<\/h4>\n<p>\u041c\u043e\u0434\u0435\u043b\u044c HSL \u043e\u043f\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u043c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0435\u0439, \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u044f \u0444\u0438\u0437\u0438\u043e\u043b\u043e\u0433\u0438\u044e \u0447\u0435\u043b\u043e\u0432\u0435\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0437\u0440\u0435\u043d\u0438\u044f. \u041f\u0440\u0438 \u0440\u0430\u0432\u043d\u044b\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u0438 \u0436\u0435\u043b\u0442\u044b\u0439 \u0438 \u0441\u0438\u043d\u0438\u0439 \u0446\u0432\u0435\u0442\u0430 \u0431\u0443\u0434\u0443\u0442 \u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u0433\u043b\u0430\u0437\u0443 \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u043f\u043e \u0441\u0432\u0435\u0442\u043b\u043e\u0442\u0435, \u043f\u0440\u0438\u0447\u0435\u043c \u0436\u0435\u043b\u0442\u044b\u0439 \u0432\u0441\u0435\u0433\u0434\u0430 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u0432\u0435\u0442\u043b\u0435\u0435. \u041f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e OKLCH \u0443\u0441\u0442\u0440\u0430\u043d\u044f\u0435\u0442 \u044d\u0442\u043e\u0442 \u043f\u0435\u0440\u0435\u043a\u043e\u0441, \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u044f \u0446\u0432\u0435\u0442\u043e\u0432\u044b\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u043f\u043e\u0434 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u043e\u0441\u043f\u0440\u0438\u044f\u0442\u0438\u0435. \u0420\u0430\u0432\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u0441\u0432\u0435\u0442\u043b\u043e\u0442\u044b \u0432 \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u0443\u044e\u0442, \u0447\u0442\u043e \u043b\u044e\u0431\u044b\u0435 \u043e\u0442\u0442\u0435\u043d\u043a\u0438 \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043a\u0430\u043a \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u044f\u0440\u043a\u0438\u0435, \u0447\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u0441\u0431\u0430\u043b\u0430\u043d\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043d\u044b\u0435 \u043f\u0430\u043b\u0438\u0442\u0440\u044b.  <\/p>\n<p>\u042d\u0442\u043e \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u0441\u0438\u0441\u0442\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0439 \u2014 success, warning, danger, info:<\/p>\n<pre><code class=\"css\">:root {  --state-success: oklch(65% 0.18 145);  \/* \u0437\u0435\u043b\u0451\u043d\u044b\u0439 *\/  --state-warning: oklch(75% 0.18 85);   \/* \u044f\u043d\u0442\u0430\u0440\u043d\u044b\u0439 *\/  --state-danger:  oklch(62% 0.22 25);   \/* \u043a\u0440\u0430\u0441\u043d\u044b\u0439 *\/  --state-info:    oklch(65% 0.18 250);  \/* \u0441\u0438\u043d\u0438\u0439 *\/}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041f\u0440\u0438 \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c <code>L<\/code> \u0438 \u0441\u043e\u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043c\u043e\u043c <code>C<\/code> \u0432\u0441\u0435 \u0447\u0435\u0442\u044b\u0440\u0435 \u0446\u0432\u0435\u0442\u0430 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u00abloud\u00bb \u2014 \u043d\u0438 \u043e\u0434\u0438\u043d \u043d\u0435 \u0434\u043e\u043c\u0438\u043d\u0438\u0440\u0443\u0435\u0442 \u043d\u0430\u0434 \u0434\u0440\u0443\u0433\u0438\u043c \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430 \u0441\u0447\u0451\u0442 \u044f\u0440\u043a\u043e\u0441\u0442\u0438.<\/p>\n<h4>Relative color syntax<\/h4>\n<p>CSS Relative Color Syntax \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u043d\u044b\u0435 \u043e\u0442 \u0431\u0430\u0437\u043e\u0432\u043e\u0433\u043e \u0442\u043e\u043a\u0435\u043d\u0430 \u043c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u0431\u0435\u0437 \u0440\u0443\u0447\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0431\u043e\u0440\u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439:<\/p>\n<pre><code class=\"css\">:root {  --accent: oklch(65% 0.2 250);  --accent-light:      oklch(from var(--accent) calc(l + 0.15) c h);  --accent-dark:       oklch(from var(--accent) calc(l - 0.15) c h);  --accent-muted:      oklch(from var(--accent) l calc(c * 0.4) h);  --accent-complement: oklch(from var(--accent) l c calc(h + 180));  --accent-10: oklch(from var(--accent) l c h \/ 0.10);  --accent-20: oklch(from var(--accent) l c h \/ 0.20);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041f\u0440\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0438 <code>--accent<\/code> \u0432\u0441\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u043d\u044b\u0435 \u043f\u0435\u0440\u0435\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438. \u042d\u0442\u043e \u0438\u0441\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044e, \u043a\u043e\u0433\u0434\u0430 \u0441\u043c\u0435\u043d\u0430 \u0430\u043a\u0446\u0435\u043d\u0442\u043d\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0440\u0443\u0447\u043d\u043e\u0433\u043e \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445.<\/p>\n<h4>\u0422\u0440\u0438 \u0443\u0440\u043e\u0432\u043d\u044f \u0442\u043e\u043a\u0435\u043d\u043e\u0432<\/h4>\n<p>\u0425\u043e\u0440\u043e\u0448\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0441\u0442\u0440\u043e\u0438\u0442\u0441\u044f \u043e\u0442 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u0432 \u043a \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0435 \u0438 \u043e\u0442 \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0438 \u043a \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c:<\/p>\n<pre><code class=\"css\">\/* \u0423\u0440\u043e\u0432\u0435\u043d\u044c 1 \u2014 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b, \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e *\/--blue-500: oklch(55% 0.18 250);--gray-950: oklch(10% 0.01 250);\/* \u0423\u0440\u043e\u0432\u0435\u043d\u044c 2 \u2014 \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0430 *\/--color-bg-primary:    var(--gray-950);--color-text-primary:  var(--gray-50);--color-text-secondary:var(--gray-400);--color-border-subtle: var(--gray-800);\/* \u0423\u0440\u043e\u0432\u0435\u043d\u044c 3 \u2014 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b *\/--article-bg:   var(--color-bg-primary);--callout-border: var(--color-border-default);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u0441\u044b\u043b\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e. \u042d\u0442\u043e \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u0443\u0435\u0442, \u0447\u0442\u043e \u043f\u0440\u0438 \u0441\u043c\u0435\u043d\u0435 \u0442\u0435\u043c\u044b \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u0435\u0440\u0435\u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u043b\u043e\u0439.<\/p>\n<h4>\u041a\u043e\u043d\u0442\u0440\u0430\u0441\u0442 \u043a\u0430\u043a \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438<\/h4>\n<p>WCAG \u0437\u0430\u0434\u0430\u0451\u0442 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0443\u044e \u043f\u043b\u0430\u043d\u043a\u0443. \u0420\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430 \u2014 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0443\u044e \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u044e, \u043f\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044f \u0434\u0432\u0438\u0433\u0430\u0435\u0442\u0441\u044f \u043f\u043e \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e:<\/p>\n<pre><code>\u041e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0435\u043a\u0441\u0442 \u0441\u0442\u0430\u0442\u044c\u0438     ~12:1   \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0447\u0438\u0442\u0430\u0435\u043c\u043e\u0441\u0442\u044c\u041a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0438               ~8:1    \u0432\u0430\u0436\u043d\u043e, \u043d\u043e \u0432\u0442\u043e\u0440\u0438\u0447\u043d\u043e\u041c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 (\u0434\u0430\u0442\u0430, \u0441\u0447\u0451\u0442)   ~5:1    \u0441\u043a\u0430\u043d\u0438\u0440\u0443\u0435\u0442\u0441\u044f\u041f\u043b\u0435\u0439\u0441\u0445\u043e\u043b\u0434\u0435\u0440\u044b              ~3.5:1  \u043d\u0430\u043c\u0451\u043a, \u043d\u0435 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0414\u0435\u043a\u043e\u0440\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b      ~2:1    \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0431\u0435\u0437 \u0430\u043a\u0446\u0435\u043d\u0442\u0430<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0443\u0440\u043e\u0432\u043d\u044f \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u2014 \u044d\u0442\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0448\u0443\u043c. \u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430 \u0440\u0430\u0432\u043d\u0430 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u044f.<\/p>\n<h3>\u041f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0438 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e<\/h3>\n<h4>Surface ladder<\/h4>\n<p>\u0413\u043b\u0443\u0431\u0438\u043d\u0430 \u0442\u0435\u043c\u043d\u043e\u0433\u043e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u0435 \u0442\u0435\u043d\u044f\u043c\u0438 (\u043e\u043d\u0438 \u0442\u0435\u0440\u044f\u044e\u0442 \u0441\u043c\u044b\u0441\u043b \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435), \u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043e\u0441\u0432\u0435\u0442\u043b\u0435\u043d\u0438\u0435\u043c \u0441\u043b\u043e\u0451\u0432:<\/p>\n<pre><code class=\"css\">--surface-0: oklch(12% 0.01 250);  \/* \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 *\/--surface-1: oklch(15% 0.01 250);  \/* \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438 *\/--surface-2: oklch(18% 0.015 250); \/* \u043f\u043e\u0434\u043d\u044f\u0442\u044b\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b *\/--surface-3: oklch(22% 0.02 250);  \/* hover *\/--surface-4: oklch(26% 0.02 250);  \/* \u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f *\/<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 \u0441\u043b\u043e\u0439 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043d\u0430 <code>3%<\/code> \u043f\u043e <code>L<\/code>. \u042d\u0442\u043e \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u043c\u0443\u044e \u0433\u043b\u0443\u0431\u0438\u043d\u0443 \u0431\u0435\u0437 \u0440\u0435\u0437\u043a\u0438\u0445 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u043e\u0432. \u041a\u043b\u044e\u0447\u0435\u0432\u043e\u0435: <code>surface-0<\/code> \u2014 \u044d\u0442\u043e \u0444\u043e\u043d \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b, \u0430 \u043d\u0435 \u0441\u0430\u043c\u044b\u0439 \u0442\u0451\u043c\u043d\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442.<\/p>\n<h4>\u0422\u0451\u043c\u043d\u0430\u044f \u0442\u0435\u043c\u0430: \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043b\u043e\u0432\u0443\u0448\u043a\u0438<\/h4>\n<p>\u0420\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u0435 \u0431\u043b\u043e\u043a\u043e\u0432 \u0447\u0438\u0441\u0442\u043e\u0433\u043e \u0431\u0435\u043b\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430 (#ffffff) \u043d\u0430 \u0433\u043b\u0443\u0431\u043e\u043a\u043e\u043c \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435 (#080b0f) \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442 \u0437\u043e\u043d\u044b \u044d\u043a\u0441\u0442\u0440\u0435\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430. \u0427\u0435\u043b\u043e\u0432\u0435\u0447\u0435\u0441\u043a\u0438\u0439 \u0433\u043b\u0430\u0437 \u0430\u0434\u0430\u043f\u0442\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043a \u043e\u0431\u0449\u0435\u043c\u0443 \u0443\u0440\u043e\u0432\u043d\u044e \u043e\u0441\u0432\u0435\u0449\u0451\u043d\u043d\u043e\u0441\u0442\u0438 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430. \u0420\u0435\u0437\u043a\u0438\u0435 \u043f\u0435\u0440\u0435\u043f\u0430\u0434\u044b \u044f\u0440\u043a\u043e\u0441\u0442\u0438 \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u0433\u0430\u043b\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u0443\u044e \u0443\u0442\u043e\u043c\u043b\u044f\u0435\u043c\u043e\u0441\u0442\u044c. \u0424\u043e\u0440\u043c\u0438\u0440\u0443\u0439\u0442\u0435 \u043f\u043e\u0434\u043d\u044f\u0442\u044b\u0435 \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438 \u0438 \u043c\u043e\u0434\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u043a\u043d\u0430 \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0447\u0435\u0440\u0435\u0437 \u0442\u043e\u043a\u0435\u043d\u044b \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u043d\u044b\u0445 \u0441\u043b\u043e\u0451\u0432 (&#8212;surface-1, &#8212;surface-2). \u041f\u0440\u044f\u043c\u043e\u0435 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435 <code>background: white<\/code> \u0432 \u0441\u0442\u0438\u043b\u044f\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e.<\/p>\n<p>\u041d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c (chroma) \u0430\u043a\u0446\u0435\u043d\u0442\u043d\u044b\u0445 \u043e\u0442\u0442\u0435\u043d\u043a\u043e\u0432 \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043f\u0440\u0438\u043d\u0443\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u043d\u0438\u0436\u0435\u043d\u0438\u044f. \u041f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u044f\u0440\u043a\u043e\u0433\u043e \u0441\u0438\u043d\u0435\u0433\u043e <code>oklch(65% 0.25 250)<\/code> \u043d\u0430 \u043f\u043e\u0434\u043b\u043e\u0436\u043a\u0435 <code>oklch(12%)<\/code> \u043f\u0440\u043e\u0432\u043e\u0446\u0438\u0440\u0443\u0435\u0442 \u043e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0432\u0438\u0431\u0440\u0430\u0446\u0438\u044e. \u0421\u0432\u0435\u0442\u043b\u044b\u0439 \u0438 \u0442\u0451\u043c\u043d\u044b\u0439 \u0446\u0432\u0435\u0442\u0430 \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u043a\u043e\u043d\u043a\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430 \u0444\u043e\u043a\u0443\u0441, \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u043b\u043e\u0436\u043d\u044b\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b \u0438 \u043c\u0435\u0440\u0446\u0430\u043d\u0438\u0435 \u043d\u0430 \u0441\u0442\u044b\u043a\u0435. \u041e\u0433\u0440\u0430\u043d\u0438\u0447\u044c\u0442\u0435 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u0439 \u043f\u043e\u0434\u043b\u043e\u0436\u043a\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 0.15\u20130.20. \u041f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u0435 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0440\u043e\u0433\u0430 \u043d\u0435\u0438\u0437\u0431\u0435\u0436\u043d\u043e \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0448\u0443\u043c.<\/p>\n<h3>\u0410\u0442\u043c\u043e\u0441\u0444\u0435\u0440\u0430: \u0434\u0435\u0442\u0430\u043b\u0438 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043a\u043e\u043f\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u043e\u0439<\/h3>\n<h4>Noise texture<\/h4>\n<p>\u041f\u043b\u043e\u0441\u043a\u0438\u0439 \u0437\u0430\u043b\u0438\u0432\u043d\u043e\u0439 \u0446\u0432\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0434\u0451\u0448\u0435\u0432\u043e \u043d\u0430 \u0432\u044b\u0441\u043e\u043a\u043e\u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0445 \u044d\u043a\u0440\u0430\u043d\u0430\u0445. \u0422\u043e\u043d\u043a\u0438\u0439 \u0437\u0435\u0440\u043d\u0438\u0441\u0442\u044b\u0439 \u0441\u043b\u043e\u0439 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c, \u0438\u043c\u0438\u0442\u0438\u0440\u0443\u044f \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443:<\/p>\n<pre><code class=\"css\">.article-hero::after {  content: '';  position: absolute;  inset: 0;  background-image: url(\"data:image\/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'\/%3E%3C\/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'\/%3E%3C\/svg%3E\");  pointer-events: none;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>opacity: 0.04<\/code> \u2014 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0438\u0439 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d. \u041d\u0438\u0436\u0435 \u2014 \u043d\u0435\u0437\u0430\u043c\u0435\u0442\u043d\u043e, \u0432\u044b\u0448\u0435 \u2014 \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0430\u0440\u0442\u0435\u0444\u0430\u043a\u0442\u043e\u043c.<\/p>\n<h4>Gradient mesh<\/h4>\n<p>\u041c\u043d\u043e\u0433\u043e\u0442\u043e\u0447\u0435\u0447\u043d\u044b\u0439 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043d\u044b\u0439 \u0444\u043e\u043d \u0437\u0430 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u043e\u043c \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0433\u043b\u0443\u0431\u0438\u043d\u0443 \u0431\u0435\u0437 \u0442\u044f\u0436\u0451\u043b\u044b\u0445 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439:<\/p>\n<pre><code class=\"css\">.article-header__mesh {  position: absolute;  inset: -50%;  background:    radial-gradient(ellipse 60% 50% at 20% 50%,      oklch(55% 0.2 280 \/ 0.15) 0%, transparent 70%),    radial-gradient(ellipse 50% 60% at 80% 30%,      oklch(60% 0.18 200 \/ 0.12) 0%, transparent 70%);  filter: blur(60px);  animation: mesh-drift 20s ease-in-out infinite alternate;  pointer-events: none;}@keyframes mesh-drift {  0%   { transform: translate(0, 0) scale(1); }  50%  { transform: translate(2%, 1%) scale(1.02); }  100% { transform: translate(1%, -1%) scale(1.01); }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>blur(60px)<\/code> \u0434\u0435\u043b\u0430\u0435\u0442 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u044b \u043c\u0435\u0436\u0434\u0443 \u043f\u044f\u0442\u043d\u0430\u043c\u0438 \u043c\u044f\u0433\u043a\u0438\u043c\u0438. <code>inset: -50%<\/code> \u2014 \u043e\u0431\u0451\u0440\u0442\u043a\u0430 \u0431\u043e\u043b\u044c\u0448\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043c\u044b\u0442\u044b\u0435 \u043a\u0440\u0430\u044f \u043d\u0435 \u043e\u0431\u0440\u0435\u0437\u0430\u043b\u0438\u0441\u044c.<\/p>\n<h3>Scroll-driven animations: CSS \u0431\u0435\u0437 JavaScript<\/h3>\n<h4>\u041f\u0440\u043e\u0433\u0440\u0435\u0441\u0441 \u0447\u0442\u0435\u043d\u0438\u044f<\/h4>\n<p>\u041f\u0440\u043e\u0433\u0440\u0435\u0441\u0441-\u0431\u0430\u0440 \u043a\u0430\u043a \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f, \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043d\u0430\u044f \u043a \u0441\u043a\u0440\u043e\u043b\u043b\u0443 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430:<\/p>\n<pre><code class=\"css\">@keyframes progress {  from { width: 0%; }  to   { width: 100%; }}.reading-progress {  position: fixed;  top: 0; left: 0;  height: 2px;  background: var(--accent);  animation: progress linear both;  animation-timeline: scroll(root);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>\u041f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432<\/h4>\n<p><code>view()<\/code> timeline \u043f\u0440\u0438\u0432\u044f\u0437\u044b\u0432\u0430\u0435\u0442 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044e \u043a \u0432\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0432 \u0432\u044c\u044e\u043f\u043e\u0440\u0442:<\/p>\n<pre><code class=\"css\">.article-body &gt; * {  animation: fade-up linear both;  animation-timeline: view();  animation-range: entry 0% entry 30%;}@keyframes fade-up {  from { opacity: 0; transform: translateY(24px); filter: blur(4px); }  to   { opacity: 1; transform: translateY(0);    filter: blur(0);   }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>animation-range: entry 0% entry 30%<\/code> \u2014 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u0437\u0430\u0432\u0435\u0440\u0448\u0430\u0435\u0442\u0441\u044f, \u043a\u043e\u0433\u0434\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u043f\u0440\u043e\u0448\u0451\u043b 30% \u043e\u0442 \u043d\u0438\u0436\u043d\u0435\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b \u0432\u044c\u044e\u043f\u043e\u0440\u0442\u0430. \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0432\u0438\u0434\u0438\u043c\u044b\u043c.<\/p>\n<h4>Reduced motion<\/h4>\n<p>\u041f\u0440\u0438 <code>prefers-reduced-motion: reduce<\/code> \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0435 \u043e\u0442\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f, \u043d\u043e \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043d\u0435 \u0438\u0441\u0447\u0435\u0437\u0430\u0435\u0442 \u2014 \u0442\u043e\u043b\u044c\u043a\u043e fade:<\/p>\n<pre><code class=\"css\">@media (prefers-reduced-motion: reduce) {  .article-header__mesh { animation: none; }  .article-body &gt; * {    animation: fade-in linear both;    animation-timeline: view();    animation-range: entry 0% entry 20%;  }  @keyframes fade-in {    from { opacity: 0; }    to   { opacity: 1; }  }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h3>\u041a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438-\u0441\u043b\u043e\u0439: \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430<\/h3>\n<p>\u041a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0436\u0438\u0432\u0443\u0442 \u043f\u043e\u0432\u0435\u0440\u0445 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430. \u0418\u0445 \u0446\u0432\u0435\u0442\u043e\u0432\u0430\u044f \u043b\u043e\u0433\u0438\u043a\u0430 \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u043a\u043e\u043d\u043a\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441 \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441\u0442\u0430\u0442\u044c\u0438 \u2014 \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 \u0432\u0442\u043e\u0440\u0438\u0447\u043d\u043e \u043f\u043e \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u044e.<\/p>\n<h4>\u0410\u0432\u0430\u0442\u0430\u0440\u044b: \u0434\u0435\u0442\u0430\u043b\u0438 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u043c\u0435\u0447\u0430\u044e\u0442<\/h4>\n<p>\u0412\u043c\u0435\u0441\u0442\u043e \u0431\u0435\u043b\u043e\u0439 \u0440\u0430\u043c\u043a\u0438 \u2014 \u0441\u0432\u0435\u0447\u0435\u043d\u0438\u0435 \u0446\u0432\u0435\u0442\u0430 \u0441\u0430\u043c\u043e\u0433\u043e \u0430\u0432\u0430\u0442\u0430\u0440\u0430. \u042d\u0442\u043e \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u0441\u043b\u043e\u0436\u043d\u0435\u0435, \u043d\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0435\u0435: \u0440\u0430\u043c\u043a\u0430 \u043e\u0442\u0434\u0435\u043b\u044f\u0435\u0442, \u0441\u0432\u0435\u0447\u0435\u043d\u0438\u0435 \u0438\u043d\u0442\u0435\u0433\u0440\u0438\u0440\u0443\u0435\u0442:<\/p>\n<pre><code class=\"css\">.avatar {  width: 36px; height: 36px;  border-radius: 50%;  flex-shrink: 0;  box-shadow:    0 0 0 2px var(--surface-1),    0 0 0 3px oklch(from var(--user-color) l c h \/ 0.4);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0426\u0432\u0435\u0442 \u0430\u0432\u0430\u0442\u0430\u0440\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e \u0438\u0437 \u0438\u043c\u0435\u043d\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u2014 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u0435 \u0438\u043c\u044f \u0432\u0441\u0435\u0433\u0434\u0430 \u0434\u0430\u0451\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u0439 \u0446\u0432\u0435\u0442:<\/p>\n<pre><code>function userColor(username) {  let hash = 0;  for (let i = 0; i &lt; username.length; i++) {    hash = username.charCodeAt(i) + ((hash &lt;&lt; 5) - hash);  }  const hue = Math.abs(hash) % 360;  return `oklch(65% 0.18 ${hue})`;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0424\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 <code>L<\/code> \u0438 <code>C<\/code> \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u043c <code>H<\/code> \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u0443\u044e\u0442, \u0447\u0442\u043e \u0432\u0441\u0435 \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0446\u0432\u0435\u0442\u0430 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u044f\u0440\u043a\u0438\u0435 \u2014 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u00ab\u0441\u0442\u0440\u0430\u0448\u043d\u043e \u0442\u0451\u043c\u043d\u044b\u0439\u00bb \u0438\u043b\u0438 \u00ab\u0441\u043b\u0435\u043f\u044f\u0449\u0438\u0439\u00bb \u0430\u0432\u0430\u0442\u0430\u0440.<\/p>\n<p>\u0421\u0442\u0435\u043a \u0430\u0432\u0430\u0442\u0430\u0440\u043e\u0432 \u0440\u0430\u0437\u0434\u0432\u0438\u0433\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u0438 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u0438\u0438:<\/p>\n<pre><code class=\"css\">.avatar-stack .avatar { margin-left: -10px; transition: margin 0.2s ease; }.avatar-stack:hover .avatar { margin-left: 4px; }.avatar-stack .avatar:hover { z-index: 10; transform: translateY(-2px) scale(1.1); }<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>\u0424\u043e\u0440\u043c\u0430 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f: \u0436\u0438\u0432\u044b\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f<\/h4>\n<p>\u0424\u043e\u0440\u043c\u0430 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0432 \u0442\u0440\u0451\u0445 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u0445, \u043a\u0430\u0436\u0434\u043e\u0435 \u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0434\u043e\u043b\u0436\u043d\u043e \u043e\u0449\u0443\u0449\u0430\u0442\u044c\u0441\u044f \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u0442\u043b\u0438\u0447\u043d\u044b\u043c:<\/p>\n<p><strong>\u041f\u043e\u043a\u043e\u0439<\/strong> \u2014 \u043d\u0435\u0439\u0442\u0440\u0430\u043b\u044c\u043d\u044b\u0439 <code>--surface-1<\/code>, \u0442\u043e\u043d\u043a\u0430\u044f \u0433\u0440\u0430\u043d\u0438\u0446\u0430.<\/p>\n<p><strong>\u0412\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435<\/strong> \u2014 \u043f\u0440\u0438 <code>:focus-within<\/code> \u0433\u0440\u0430\u043d\u0438\u0446\u0430 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442 \u0432 \u0430\u043a\u0446\u0435\u043d\u0442\u043d\u044b\u0439 \u0446\u0432\u0435\u0442, \u0444\u043e\u043d \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u0434\u043e <code>--surface-2<\/code>, \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f glow, \u0442\u0443\u043b\u0431\u0430\u0440 \u0441 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f\u043c\u0438 \u0432\u044a\u0435\u0437\u0436\u0430\u0435\u0442 \u0441\u043d\u0438\u0437\u0443:<\/p>\n<pre><code class=\"css\">.comment-form:focus-within {  border-color: var(--border-focus);  background: var(--surface-2);  box-shadow:    0 0 0 3px var(--glow-focus),    0 8px 24px rgb(0 0 0 \/ 0.15);}.comment-form__toolbar {  opacity: 0;  transform: translateY(4px);  transition: opacity 0.2s ease, transform 0.2s ease;}.comment-form:focus-within .comment-form__toolbar {  opacity: 1;  transform: translateY(0);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>field-sizing: content<\/code> \u043d\u0430 textarea \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u043e\u043b\u044e \u0440\u0430\u0441\u0442\u0438 \u0441 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u043c \u0431\u0435\u0437 JavaScript:<\/p>\n<pre><code class=\"css\">.comment-textarea {  field-sizing: content;  min-height: 80px;  max-height: 400px;  resize: none;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0421\u0447\u0451\u0442\u0447\u0438\u043a \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432 \u043c\u0435\u043d\u044f\u0435\u0442 \u0446\u0432\u0435\u0442 \u043f\u0440\u0438 \u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0435\u043d\u0438\u0438 \u043a \u043b\u0438\u043c\u0438\u0442\u0443 \u0447\u0435\u0440\u0435\u0437 data-\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u2014 \u044d\u0442\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u044f\u0435\u0442 \u043b\u043e\u0433\u0438\u043a\u0443 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u0438 \u0435\u0433\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e:<\/p>\n<pre><code class=\"css\">.char-counter[data-warning='true'] { color: var(--state-warning); }.char-counter[data-danger='true']  { color: var(--state-danger);  }<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>\u041a\u043d\u043e\u043f\u043a\u0438: \u0442\u0440\u0438 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430<\/h4>\n<p><strong>Primary<\/strong> \u2014 \u0437\u0430\u043b\u0438\u0432\u043a\u0430 \u0430\u043a\u0446\u0435\u043d\u0442\u043d\u044b\u043c \u0446\u0432\u0435\u0442\u043e\u043c, \u0442\u0451\u043c\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u043f\u043e\u0432\u0435\u0440\u0445, \u043f\u0440\u0438 hover \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u0438 \u0441\u0432\u0435\u0442\u043b\u0435\u0435\u0442:<\/p>\n<pre><code class=\"css\">.btn--primary:hover {  background: oklch(from var(--accent) calc(l + 0.05) c h);  box-shadow: 0 4px 12px oklch(from var(--accent) l c h \/ 0.4);  transform: translateY(-1px);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>Ghost<\/strong> \u2014 \u0431\u0435\u0437 \u0437\u0430\u043b\u0438\u0432\u043a\u0438, \u0442\u043e\u043b\u044c\u043a\u043e \u0433\u0440\u0430\u043d\u0438\u0446\u0430. \u041f\u0440\u0438 hover \u0444\u043e\u043d \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u2014 \u043d\u0435 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442.<\/p>\n<p><strong>Danger<\/strong> \u2014 \u0441\u043a\u0440\u044b\u0442\u0430\u044f \u0443\u0433\u0440\u043e\u0437\u0430: \u0432 \u043f\u043e\u043a\u043e\u0435 \u043d\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043e\u043f\u0430\u0441\u043d\u043e\u0439, \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u0438 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u0438\u0438 \u043f\u0440\u043e\u044f\u0432\u043b\u044f\u0435\u0442 \u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u0444\u043e\u043d. \u042d\u0442\u043e \u0441\u043d\u0438\u0436\u0430\u0435\u0442 \u0442\u0440\u0435\u0432\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043e\u0442 \u043d\u0435\u0439\u0442\u0440\u0430\u043b\u044c\u043d\u043e\u0433\u043e UI, \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u044f \u0441\u0438\u0433\u043d\u0430\u043b \u043f\u0440\u0438 \u043d\u0430\u043c\u0435\u0440\u0435\u043d\u043d\u043e\u043c \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438.<\/p>\n<p>\u0421\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0447\u0435\u0440\u0435\u0437 <code>aria-busy<\/code> \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0438:<\/p>\n<pre><code class=\"css\">.btn[aria-busy='true'] { pointer-events: none; opacity: 0.7; }.btn[aria-busy='true'] .btn__text { opacity: 0; }.btn[aria-busy='true']::before {  content: '';  position: absolute;  width: 16px; height: 16px;  border: 2px solid currentColor;  border-top-color: transparent;  border-radius: 50%;  animation: spin 0.6s linear infinite;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>\u0420\u0435\u0430\u043a\u0446\u0438\u0438 \u043d\u0430 \u0430\u0431\u0437\u0430\u0446\u044b<\/h4>\n<p>\u0422\u0440\u0438\u0433\u0433\u0435\u0440 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 gutter \u043f\u0440\u0438 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u0438\u0438 \u043d\u0430 \u0430\u0431\u0437\u0430\u0446 \u2014 \u043d\u0435 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u043c\u0435\u0441\u0442\u0430 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c \u043f\u043e\u0442\u043e\u043a\u0435:<\/p>\n<pre><code class=\"css\">.reactions-trigger {  position: absolute;  left: -2.5rem;  top: 50%;  transform: translateY(-50%) scale(0.8);  opacity: 0;  transition: opacity 0.15s ease, transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);}.paragraph-wrapper:hover .reactions-trigger {  opacity: 1;  transform: translateY(-50%) scale(1);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041f\u0440\u0443\u0436\u0438\u043d\u043d\u0430\u044f \u043a\u0443\u0431\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u043a\u0440\u0438\u0432\u0430\u044f <code>cubic-bezier(0.34, 1.56, 0.64, 1)<\/code> \u2014 spring easing. \u0417\u043d\u0430\u0447\u0435\u043d\u0438\u044f <code>&gt;1<\/code> \u043f\u043e <code>y<\/code> \u0441\u043e\u0437\u0434\u0430\u044e\u0442 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0439 overshooting, \u0438\u043c\u043c\u0438\u0442\u0438\u0440\u0443\u044e\u0449\u0438\u0439 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0443\u043f\u0440\u0443\u0433\u043e\u0441\u0442\u044c. \u042d\u0442\u043e \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442 UI \u043e\u0442 \u00ab\u043f\u043b\u0430\u043d\u0448\u0435\u0442\u043d\u043e\u0433\u043e\u00bb \u0440\u0430\u0432\u043d\u043e\u043c\u0435\u0440\u043d\u043e\u0433\u043e \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f.<\/p>\n<p>\u041f\u043e\u043f\u0430\u043f \u0441 \u044d\u043c\u043e\u0434\u0437\u0438 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0442 \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u0430 \u0441 \u0442\u0435\u043c \u0436\u0435 spring:<\/p>\n<pre><code class=\"css\">.reaction-emoji:hover {  transform: scale(1.3) translateY(-2px);  background: var(--surface-3);}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>\u041c\u0438\u043a\u0440\u043e\u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438: \u043a\u0430\u0436\u0434\u0430\u044f \u0440\u0435\u0448\u0430\u0435\u0442 \u0437\u0430\u0434\u0430\u0447\u0443<\/h4>\n<p>\u041a\u0430\u0436\u0434\u0430\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u0432 \u0445\u043e\u0440\u043e\u0448\u0435\u043c UI \u043d\u0435\u0441\u0451\u0442 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u2014 \u043d\u0435 \u0434\u0435\u043a\u043e\u0440\u0430\u0442\u0438\u0432\u043d\u0430.<\/p>\n<p><strong>\u041f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u0435 \u043d\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f<\/strong> \u0441\u043e\u043e\u0431\u0449\u0430\u0435\u0442: \u00ab\u044d\u0442\u043e\u0433\u043e \u0437\u0434\u0435\u0441\u044c \u043d\u0435 \u0431\u044b\u043b\u043e\u00bb. <code>blur<\/code> \u043f\u0440\u0438 \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u0438 \u0430\u043a\u0446\u0435\u043d\u0442\u0438\u0440\u0443\u0435\u0442 \u043f\u0435\u0440\u0435\u0445\u043e\u0434 \u0438\u0437 \u043d\u0435\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0433\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u0432 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0435:<\/p>\n<pre><code class=\"css\">@keyframes comment-appear {  from { opacity: 0; transform: translateY(12px); filter: blur(2px); }  to   { opacity: 1; transform: translateY(0);    filter: blur(0);   }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435<\/strong> \u0441\u0445\u043b\u043e\u043f\u044b\u0432\u0430\u0435\u0442 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u2014 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e \u043d\u0435 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043f\u0443\u0441\u0442\u044b\u043c \u0440\u0435\u0437\u043a\u043e:<\/p>\n<pre><code class=\"css\">@keyframes comment-remove {  to { opacity: 0; transform: translateX(-12px) scale(0.97); max-height: 0; margin: 0; padding: 0; }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u041b\u0430\u0439\u043a<\/strong> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0434\u0432\u0443\u0445\u0444\u0430\u0437\u043d\u044b\u0439 bounce \u2014 \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u0436\u0430\u0442\u0438\u0435 (\u0430\u043d\u0442\u0438\u0446\u0438\u043f\u0430\u0446\u0438\u044f), \u043f\u043e\u0442\u043e\u043c overshooting. \u042d\u0442\u043e \u0438\u043c\u0438\u0442\u0438\u0440\u0443\u0435\u0442 \u0444\u0438\u0437\u0438\u043a\u0443 \u043d\u0430\u0436\u0430\u0442\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u0438:<\/p>\n<pre><code class=\"css\">@keyframes like-bounce {  0%   { transform: scale(1); }  30%  { transform: scale(0.8); }  60%  { transform: scale(1.35); }  80%  { transform: scale(0.95); }  100% { transform: scale(1); }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0421\u043a\u0435\u043b\u0435\u0442\u043e\u043d<\/strong> \u0432\u043c\u0435\u0441\u0442\u043e \u0441\u043f\u0438\u043d\u043d\u0435\u0440\u0430 \u2014 shimmer \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u0442 \u0444\u043e\u0440\u043c\u0443 \u0431\u0443\u0434\u0443\u0449\u0435\u0433\u043e \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430, \u0441\u043d\u0438\u0436\u0430\u044f \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u043c\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f:<\/p>\n<pre><code class=\"css\">@keyframes skeleton-shimmer {  from { background-position: -200% 0; }  to   { background-position:  200% 0; }}.skeleton {  background: linear-gradient(90deg,    var(--surface-1) 0%, var(--surface-3) 50%, var(--surface-1) 100%);  background-size: 200% 100%;  animation: skeleton-shimmer 1.5s ease infinite;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u0421\u0447\u0451\u0442\u0447\u0438\u043a \u043b\u0430\u0439\u043a\u043e\u0432<\/strong> \u043f\u0440\u043e\u043a\u0440\u0443\u0447\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043a\u0430\u043a \u0441\u043b\u043e\u0442-\u043c\u0430\u0448\u0438\u043d\u0430 \u2014 \u043d\u043e\u0432\u043e\u0435 \u0447\u0438\u0441\u043b\u043e \u0432\u044a\u0435\u0437\u0436\u0430\u0435\u0442 \u0441\u043d\u0438\u0437\u0443, \u0441\u0442\u0430\u0440\u043e\u0435 \u0443\u0435\u0437\u0436\u0430\u0435\u0442 \u0432\u0432\u0435\u0440\u0445. \u042d\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0437\u0430\u043c\u0435\u0442\u043d\u044b\u043c \u0431\u0435\u0437 \u0446\u0432\u0435\u0442\u043e\u0432\u043e\u0433\u043e \u0441\u0438\u0433\u043d\u0430\u043b\u0430:<\/p>\n<pre><code class=\"css\">.like-count { display: inline-block; overflow: hidden; height: 1.2em; }.like-count__inner { display: flex; flex-direction: column; transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }.like-count__inner.increment { transform: translateY(-50%); }<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u041e\u043d\u043b\u0430\u0439\u043d-\u0438\u043d\u0434\u0438\u043a\u0430\u0442\u043e\u0440<\/strong> \u043f\u0443\u043b\u044c\u0441\u0438\u0440\u0443\u0435\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u044e\u0449\u0435\u0433\u043e\u0441\u044f box-shadow \u2014 \u043d\u0435 \u043c\u0438\u0433\u0430\u0435\u0442, \u0447\u0442\u043e \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0430\u0435\u0442, \u0430 \u00ab\u0434\u044b\u0448\u0438\u0442\u00bb:<\/p>\n<pre><code class=\"css\">@keyframes online-pulse {  0%, 100% { box-shadow: 0 0 0 0 oklch(65% 0.18 145 \/ 0.6); }  50%       { box-shadow: 0 0 0 4px oklch(65% 0.18 145 \/ 0); }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>Toast-\u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u044f<\/strong> \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441-\u0431\u0430\u0440 \u0430\u0432\u0442\u043e\u0437\u0430\u043a\u0440\u044b\u0442\u0438\u044f \u2014 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0432\u0438\u0434\u0438\u0442, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c:<\/p>\n<pre><code class=\"css\">.notification::after {  content: '';  position: absolute;  bottom: 0; left: 0;  height: 2px;  background: var(--notification-color, var(--accent));  animation: notification-timer var(--duration, 5s) linear forwards;}@keyframes notification-timer {  from { width: 100%; }  to   { width: 0%; }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<h4>\u041c\u043e\u0434\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u043a\u043d\u0430<\/h4>\n<p><code>backdrop-filter: blur<\/code> \u043d\u0430 \u043f\u043e\u0434\u043b\u043e\u0436\u043a\u0435 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u00ab\u0441\u0442\u0435\u043a\u043b\u0430\u00bb \u2014 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u043e\u0434 \u043c\u043e\u0434\u0430\u043b\u043a\u043e\u0439 \u0432\u0438\u0434\u0435\u043d, \u043d\u043e \u0432\u0442\u043e\u0440\u0438\u0447\u0435\u043d. \u042d\u0442\u043e \u0432\u0430\u0436\u043d\u043e: blur \u0441\u043e\u043e\u0431\u0449\u0430\u0435\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e, \u0447\u0442\u043e \u043e\u043d \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0432 \u0434\u0440\u0443\u0433\u043e\u043c \u0441\u043b\u043e\u0435, \u0430 \u043d\u0435 \u0447\u0442\u043e \u0444\u043e\u043d \u0438\u0441\u0447\u0435\u0437:<\/p>\n<pre><code class=\"css\">.modal-backdrop {  backdrop-filter: blur(8px);  background: rgb(0 0 0 \/ 0.6);}.modal {  animation: modal-appear 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) both;}@keyframes modal-appear {  from { opacity: 0; transform: scale(0.94) translateY(8px); }  to   { opacity: 1; transform: scale(1) translateY(0); }}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0417\u0430\u043a\u0440\u044b\u0442\u0438\u0435 \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f, \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u044f. \u042d\u0442\u043e \u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u043e: \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0445\u043e\u0447\u0435\u0442 \u0432\u0435\u0440\u043d\u0443\u0442\u044c\u0441\u044f \u043a \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0443 \u0431\u044b\u0441\u0442\u0440\u043e.<\/p>\n<h3>\u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0430 CSS: @layer \u043f\u0440\u043e\u0442\u0438\u0432 \u0432\u043e\u0439\u043d\u044b \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u043e\u0441\u0442\u0438<\/h3>\n<p>\u041a\u0430\u0441\u043a\u0430\u0434\u043d\u044b\u0435 \u0441\u043b\u043e\u0438 \u0434\u0435\u043b\u0430\u044e\u0442 \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043f\u0440\u0430\u0432\u0438\u043b \u044f\u0432\u043d\u044b\u043c:<\/p>\n<pre><code class=\"css\">@layer reset, base, tokens, layout, components, utilities, overrides;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041f\u0440\u0430\u0432\u0438\u043b\u043e \u0432 <code>utilities<\/code> \u0432\u0441\u0435\u0433\u0434\u0430 \u043f\u0435\u0440\u0435\u043a\u0440\u043e\u0435\u0442 <code>components<\/code> \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e \u043e\u0442 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u043e\u0441\u0442\u0438 \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440\u043e\u0432. \u042d\u0442\u043e \u0443\u0441\u0442\u0440\u0430\u043d\u044f\u0435\u0442 <code>!important<\/code>-\u0432\u043e\u0439\u043d\u044b \u0438 \u0434\u0435\u043b\u0430\u0435\u0442 \u043f\u0435\u0440\u0435\u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u044b\u043c\u0438. \u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438 \u0434\u043e\u043b\u0436\u043d\u044b \u0436\u0438\u0442\u044c \u0432 \u043e\u0434\u043d\u043e\u043c \u0441\u043b\u043e\u0435 \u0441 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c\u0438 \u0441\u0442\u0430\u0442\u044c\u0438 \u2014 \u043d\u0435 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u043c <code>@layer<\/code> \u043f\u043e\u0432\u0435\u0440\u0445, \u0438\u043d\u0430\u0447\u0435 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u0441\u0432\u043e\u044f \u0442\u043e\u0447\u043a\u0430 \u043a\u043e\u043d\u0444\u043b\u0438\u043a\u0442\u0430.<\/p>\n<h3>\u0414\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u044c \u043a\u0430\u043a \u0447\u0430\u0441\u0442\u044c \u0441\u0438\u0441\u0442\u0435\u043c\u044b<\/h3>\n<p><strong>Focus visible<\/strong> \u2014 \u043d\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0439 default:<\/p>\n<pre><code class=\"css\">:focus-visible {  outline: 2px solid var(--accent);  outline-offset: 3px;  border-radius: 4px;}:focus:not(:focus-visible) { outline: none; }<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412\u0442\u043e\u0440\u043e\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u0443\u0431\u0438\u0440\u0430\u0435\u0442 outline \u043f\u0440\u0438 \u043a\u043b\u0438\u043a\u0435 \u043c\u044b\u0448\u044c\u044e \u2014 focus-\u0441\u0442\u0438\u043b\u044c \u043d\u0443\u0436\u0435\u043d \u043a\u043b\u0430\u0432\u0438\u0430\u0442\u0443\u0440\u043d\u044b\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f\u043c, \u0430 \u043d\u0435 \u0432\u0441\u0435\u043c \u043f\u043e\u0434\u0440\u044f\u0434.<\/p>\n<p><strong>Touch targets<\/strong> \u2014 \u043c\u0438\u043d\u0438\u043c\u0443\u043c 44\u00d744 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u043d\u0430 mobile \u0434\u043b\u044f \u043a\u043d\u043e\u043f\u043e\u043a \u0440\u0435\u0430\u043a\u0446\u0438\u0439. \u041a\u043d\u043e\u043f\u043a\u0438 \u043c\u0435\u043d\u044c\u0448\u0435\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u2014 \u044d\u0442\u043e \u043d\u0435 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0430, \u044d\u0442\u043e \u043e\u0448\u0438\u0431\u043a\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439.<\/p>\n<p><strong>ARIA<\/strong> \u2014 <code>aria-busy<\/code> \u043d\u0430 \u043a\u043d\u043e\u043f\u043a\u0430\u0445 \u0432 loading-\u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438, live regions \u0434\u043b\u044f toast-\u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0439 \u0438 \u043d\u043e\u0432\u044b\u0445 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0435\u0432. \u0421\u043a\u0440\u0438\u043d\u0440\u0438\u0434\u0435\u0440 \u0434\u043e\u043b\u0436\u0435\u043d \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0442\u044c \u043e\u0431 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f\u0445, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u043b\u0438 \u0431\u0435\u0437 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f.<\/p>\n<h3>\u0411\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u044c \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438-\u0444\u0443\u043d\u043a\u0446\u0438\u0439<\/h3>\n<p>\u0412\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438-\u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043d\u0435 \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u043c \u0442\u0440\u0430\u0444\u0438\u043a\u043e\u043c. \u041a\u0430\u043a \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u0441\u0430\u0439\u0442\u0435 \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0440\u0435\u0430\u043a\u0446\u0438\u0438, \u0433\u043e\u043b\u043e\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u0438 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0438, \u0432\u043a\u043b\u044e\u0447\u0430\u044e\u0442\u0441\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438. \u0417\u0430\u0449\u0438\u0442\u0430 \u0437\u0434\u0435\u0441\u044c \u0441\u0442\u0440\u043e\u0438\u0442\u0441\u044f \u043d\u0435 \u043d\u0430 \u0441\u043b\u043e\u0436\u043d\u044b\u0445 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430\u0445, \u0430 \u043d\u0430 \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0438 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u043c\u0435\u043d\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0431\u043e\u0442\u044b \u0438 \u0443\u044f\u0437\u0432\u0438\u043c\u044b\u0435 \u043f\u0430\u0440\u0441\u0435\u0440\u044b.<\/p>\n<p><strong>\u041b\u0438\u043c\u0438\u0442\u044b \u043f\u043e IP \u0432\u043c\u0435\u0441\u0442\u043e \u0441\u0435\u0441\u0441\u0438\u0439<\/strong> \u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e \u0441\u0435\u0441\u0441\u0438\u0438 \u2014 \u044d\u0442\u043e \u0438\u043b\u043b\u044e\u0437\u0438\u044f \u0437\u0430\u0449\u0438\u0442\u044b. \u0421\u043a\u0440\u0438\u043f\u0442\u0443 \u043d\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0442\u0440\u0443\u0434\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u043e\u0432\u0443\u044e \u0441\u0435\u0441\u0441\u0438\u044e \u043a\u0430\u0436\u0434\u044b\u0435 \u043f\u044f\u0442\u044c \u0441\u0435\u043a\u0443\u043d\u0434, \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0447\u0438\u0449\u0430\u044f \u043a\u0443\u043a\u0438. \u0415\u0441\u043b\u0438 \u0432\u044b \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u0435\u0442\u0435 \u0447\u0430\u0441\u0442\u043e\u0442\u0443 \u0440\u0435\u0430\u043a\u0446\u0438\u0439 \u0438\u043b\u0438 \u0433\u043e\u043b\u043e\u0441\u043e\u0432 \u043f\u043e \u0441\u0435\u0441\u0441\u0438\u0438, \u0431\u043e\u0442 \u043e\u0431\u043e\u0439\u0434\u0451\u0442 \u043b\u0438\u043c\u0438\u0442 \u0437\u0430 \u043c\u0438\u043d\u0443\u0442\u0443. \u041f\u0440\u0438\u0432\u044f\u0437\u043a\u0430 \u043a IP-\u0430\u0434\u0440\u0435\u0441\u0443 \u0443\u0441\u043b\u043e\u0436\u043d\u044f\u0435\u0442 \u0437\u0430\u0434\u0430\u0447\u0443: \u0441\u043c\u0435\u043d\u0438\u0442\u044c IP \u043d\u0430 \u043b\u0435\u0442\u0443 \u0431\u0435\u0437 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0434\u043e\u0440\u043e\u0433\u043e\u0439 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u043f\u0440\u043e\u043a\u0441\u0438-\u0441\u0435\u0440\u0432\u0435\u0440\u043e\u0432 \u0433\u043e\u0440\u0430\u0437\u0434\u043e \u0441\u043b\u043e\u0436\u043d\u0435\u0435. \u0414\u0430, \u044d\u0442\u043e \u043d\u0435 \u0441\u043f\u0430\u0441\u0451\u0442 \u043e\u0442 \u043a\u0440\u0443\u043f\u043d\u043e\u0433\u043e \u0431\u043e\u0442\u043d\u0435\u0442\u0430, \u043d\u043e \u043e\u0442\u0441\u0435\u0447\u0451\u0442 90% \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u0438, \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0439 \u043d\u0430 \u043a\u043e\u043b\u0435\u043d\u043a\u0435.<\/p>\n<p><strong>\u041e\u0442\u043f\u0435\u0447\u0430\u0442\u043a\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u0432\u043c\u0435\u0441\u0442\u043e cookies<\/strong> \u0411\u0440\u0430\u0443\u0437\u0435\u0440\u044b \u043c\u0430\u0441\u0441\u043e\u0432\u043e \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0435 cookies. \u041f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u043d\u0438\u0445 \u043f\u0440\u0438 \u043f\u043e\u0434\u0441\u0447\u0451\u0442\u0435 \u0433\u043e\u043b\u043e\u0441\u043e\u0432 \u0438\u043b\u0438 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0435 \u0441\u043f\u0430\u043c\u0430 \u0431\u0435\u0441\u0441\u043c\u044b\u0441\u043b\u0435\u043d\u043d\u043e \u2014 \u0432\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u0442\u0435\u0440\u044f\u0435\u0442\u0435 \u0447\u0430\u0441\u0442\u044c \u043b\u0435\u0433\u0438\u0442\u0438\u043c\u043d\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439. \u0420\u0430\u0431\u043e\u0447\u0430\u044f \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u0430 \u2014 \u0441\u0432\u044f\u0437\u043a\u0430 IP-\u0430\u0434\u0440\u0435\u0441\u0430, User-Agent \u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0433\u043e \u043e\u043a\u043d\u0430. \u0415\u0441\u043b\u0438 \u043e\u0434\u0438\u043d \u0438 \u0442\u043e\u0442 \u0436\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0441 \u043e\u0434\u043d\u043e\u0433\u043e \u0430\u0434\u0440\u0435\u0441\u0430 \u043f\u044b\u0442\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0433\u043e\u043b\u043e\u0441\u043e\u0432\u0430\u0442\u044c \u0434\u0435\u0441\u044f\u0442\u044c \u0440\u0430\u0437 \u0437\u0430 \u0434\u0435\u0441\u044f\u0442\u044c \u043c\u0438\u043d\u0443\u0442, \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435. \u0425\u0440\u0430\u043d\u0438\u0442\u044c \u0442\u0430\u043a\u043e\u0439 \u0441\u043b\u0435\u043f\u043e\u043a \u0434\u0435\u0448\u0435\u0432\u043b\u0435, \u0430 \u0434\u043b\u044f \u0440\u044f\u0434\u043e\u0432\u043e\u0433\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u043a\u0440\u044b\u043b \u0441\u0430\u0439\u0442 \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 \u0438\u043d\u043a\u043e\u0433\u043d\u0438\u0442\u043e, \u044d\u0442\u043e \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c.<\/p>\n<p><strong>Magic link \u0432\u043c\u0435\u0441\u0442\u043e \u043f\u0430\u0440\u043e\u043b\u0435\u0439<\/strong> \u041e\u0442\u043a\u0430\u0437 \u043e\u0442 \u043f\u0430\u0440\u043e\u043b\u0435\u0439 \u0437\u0430\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0441\u0440\u0430\u0437\u0443 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0430\u0442\u0430\u043a. \u041d\u0435\u0442 \u043f\u0430\u0440\u043e\u043b\u044f \u2014 \u043d\u0435\u0447\u0435\u0433\u043e \u0443\u043a\u0440\u0430\u0441\u0442\u044c \u0438\u0437 \u0431\u0430\u0437\u044b \u043f\u0440\u0438 \u0432\u0437\u043b\u043e\u043c\u0435, \u043d\u0435\u0447\u0435\u0433\u043e \u043f\u043e\u0434\u0431\u0438\u0440\u0430\u0442\u044c \u0431\u0440\u0443\u0442\u0444\u043e\u0440\u0441\u043e\u043c, \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0437\u0430\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u043f\u0440\u0438\u0434\u0443\u043c\u044b\u0432\u0430\u0442\u044c \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 \u0432\u0440\u043e\u0434\u0435 <code>Qwerty123!<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u043d\u0438 \u043f\u043e\u0442\u043e\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u043d\u0430 \u0431\u0430\u043d\u043a\u043e\u0432\u0441\u043a\u0438\u0445 \u0441\u0430\u0439\u0442\u0430\u0445. \u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0432\u0432\u043e\u0434\u0438\u0442 email \u0438 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u0441\u0441\u044b\u043b\u043a\u0443 \u0441 \u043e\u0434\u043d\u043e\u0440\u0430\u0437\u043e\u0432\u044b\u043c \u0442\u043e\u043a\u0435\u043d\u043e\u043c. \u0422\u043e\u043a\u0435\u043d \u0436\u0438\u0432\u0451\u0442 15\u201330 \u043c\u0438\u043d\u0443\u0442. \u0415\u0441\u043b\u0438 \u043f\u0438\u0441\u044c\u043c\u043e \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u044f\u0442 \u0438\u043b\u0438 \u0430\u043a\u043a\u0430\u0443\u043d\u0442 \u043f\u043e\u0447\u0442\u044b \u0432\u0437\u043b\u043e\u043c\u0430\u044e\u0442 \u043f\u043e\u0441\u0442\u0444\u0430\u043a\u0442\u0443\u043c, \u0441\u0441\u044b\u043b\u043a\u0430 \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u0442\u0441\u044f \u0432 \u0431\u0435\u0441\u043f\u043e\u043b\u0435\u0437\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432.<\/p>\n<p><strong>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 MD5 \u0438 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 email<\/strong> \u0421 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435\u043c email \u0441\u0432\u044f\u0437\u0430\u043d\u0430 \u0447\u0430\u0441\u0442\u0430\u044f \u043e\u0448\u0438\u0431\u043a\u0430. API \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0445 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 Gravatar, \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c MD5-\u0445\u0435\u0448 \u0430\u0434\u0440\u0435\u0441\u0430 \u0434\u043b\u044f \u043f\u043e\u0434\u0431\u043e\u0440\u0430 \u0430\u0432\u0430\u0442\u0430\u0440\u0430. \u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043f\u043e \u043f\u0440\u0438\u0432\u044b\u0447\u043a\u0435 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u044e\u0442 \u044d\u0442\u043e\u0442 \u0436\u0435 MD5 \u0432 \u0441\u0432\u043e\u044e \u0431\u0430\u0437\u0443 \u0434\u0430\u043d\u043d\u044b\u0445 \u043a\u0430\u043a \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440. MD5 \u0434\u043b\u044f \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0443\u0447\u0451\u0442\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0435\u043f\u0440\u0438\u0435\u043c\u043b\u0435\u043c: \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0432\u0438\u0434\u0435\u043e\u043a\u0430\u0440\u0442\u044b \u043f\u0435\u0440\u0435\u0431\u0438\u0440\u0430\u044e\u0442 \u0442\u0430\u043a\u0438\u0435 \u0445\u0435\u0448\u0438 \u0437\u0430 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, \u0430 \u0440\u0430\u0434\u0443\u0436\u043d\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043b\u0435\u0436\u0430\u0442 \u0432 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u0435. \u0414\u043b\u044f \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0439 \u0431\u0430\u0437\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 SHA-256 \u0441 \u0441\u043e\u043b\u044c\u044e \u0438\u043b\u0438 bcrypt. MD5 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0439\u0442\u0435 \u043d\u0430 \u043b\u0435\u0442\u0443 \u0442\u043e\u043b\u044c\u043a\u043e \u043a\u0430\u043a \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0439 \u0431\u0443\u0444\u0435\u0440 \u043f\u0435\u0440\u0435\u0434 \u043e\u0442\u043f\u0440\u0430\u0432\u043a\u043e\u0439 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u043a Gravatar, \u0438 \u0441\u0440\u0430\u0437\u0443 \u0443\u0434\u0430\u043b\u044f\u0439\u0442\u0435 \u0438\u0437 \u043f\u0430\u043c\u044f\u0442\u0438.<\/p>\n<p><strong>\u0411\u0435\u043b\u044b\u0435 \u0441\u043f\u0438\u0441\u043a\u0438 \u0432 Markdown<\/strong> \u0427\u0451\u0440\u043d\u044b\u0435 \u0441\u043f\u0438\u0441\u043a\u0438 \u0437\u0430\u043f\u0440\u0435\u0449\u0451\u043d\u043d\u044b\u0445 \u0442\u0435\u0433\u043e\u0432 \u0432 \u043f\u0430\u0440\u0441\u0435\u0440\u0430\u0445 Markdown \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442. \u0412\u044b \u0437\u0430\u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442\u0435 <code>&lt;script&gt;<\/code>, \u0430 \u0437\u043b\u043e\u0443\u043c\u044b\u0448\u043b\u0435\u043d\u043d\u0438\u043a \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f <code>&lt;img src=\"x\"&gt;<\/code> \u0438\u043b\u0438 \u0432\u0441\u0442\u0430\u0432\u0438\u0442 \u0432\u0440\u0435\u0434\u043e\u043d\u043e\u0441\u043d\u044b\u0439 \u043a\u043e\u0434 \u0432\u043d\u0443\u0442\u0440\u044c \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432 SVG. \u041d\u043e\u0432\u044b\u0435 \u0432\u0435\u043a\u0442\u043e\u0440\u044b \u0430\u0442\u0430\u043a \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u0435\u0435, \u0447\u0435\u043c \u0432\u044b \u0443\u0441\u043f\u0435\u0432\u0430\u0435\u0442\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0442\u044c \u0447\u0451\u0440\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a. \u0415\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u2014 \u0431\u0435\u043b\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a. \u041f\u0430\u0440\u0441\u0435\u0440 \u0434\u043e\u043b\u0436\u0435\u043d \u0437\u043d\u0430\u0442\u044c, \u0447\u0442\u043e \u0440\u0430\u0437\u0440\u0435\u0448\u0435\u043d\u044b \u0442\u043e\u043b\u044c\u043a\u043e <code>&lt;b&gt;<\/code>, <code>&lt;i&gt;<\/code>, <code>&lt;a&gt;<\/code>, <code>&lt;code&gt;<\/code>. \u0412\u0441\u0451, \u0447\u0435\u0433\u043e \u043d\u0435\u0442 \u0432 \u0441\u043f\u0438\u0441\u043a\u0435, \u0431\u0435\u0437\u0436\u0430\u043b\u043e\u0441\u0442\u043d\u043e \u0432\u044b\u0440\u0435\u0437\u0430\u0435\u0442\u0441\u044f \u0438\u043b\u0438 \u044d\u043a\u0440\u0430\u043d\u0438\u0440\u0443\u0435\u0442\u0441\u044f. \u0421\u0438\u0441\u0442\u0435\u043c\u0430 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043d\u0435 \u0437\u043d\u0430\u0435\u0442 \u043e \u043d\u043e\u0432\u044b\u0445 \u0443\u044f\u0437\u0432\u0438\u043c\u043e\u0441\u0442\u044f\u0445, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0438 \u043d\u0435 \u043c\u043e\u0436\u0435\u0442 \u0438\u0445 \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c.<\/p>\n<p><strong>\u041f\u0440\u0435\u043c\u043e\u0434\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f<\/strong> \u041d\u0430 \u0441\u0442\u0430\u0440\u0442\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u043d\u0435\u0442 \u0441\u043c\u044b\u0441\u043b\u0430 \u0432\u043d\u0435\u0434\u0440\u044f\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u044b\u0435 ML-\u043c\u043e\u0434\u0435\u043b\u0438 \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u0441\u043f\u0430\u043c\u0430 \u0438\u043b\u0438 \u043f\u043b\u0430\u0442\u0438\u0442\u044c \u0437\u0430 \u043a\u0430\u043f\u0447\u0443. \u0421\u0430\u043c\u044b\u0439 \u0434\u0435\u0448\u0451\u0432\u044b\u0439 \u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043c\u0435\u0442\u043e\u0434 \u2014 \u0440\u0443\u0447\u043d\u0430\u044f \u043f\u0440\u0435\u043c\u043e\u0434\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f. \u0411\u043e\u0442\u044b \u043d\u0430\u0445\u043e\u0434\u044f\u0442 API \u044d\u043d\u0434\u043f\u043e\u0438\u043d\u0442 \u0438 \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u0441\u043f\u0430\u043c\u0438\u0442\u044c. \u0415\u0441\u043b\u0438 \u043f\u0435\u0440\u0432\u044b\u0439 \u043f\u043e\u0441\u0442 \u043e\u0442 \u043d\u043e\u0432\u043e\u0433\u043e \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0430 \u0443\u0445\u043e\u0434\u0438\u0442 \u0432 \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u043a \u043c\u043e\u0434\u0435\u0440\u0430\u0442\u043e\u0440\u0443, \u0430 \u0432\u0441\u0435 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u044e\u0442\u0441\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u0432\u044b \u043e\u0442\u0440\u0435\u0437\u0430\u0435\u0442\u0435 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0430\u0442\u0430\u043a\u0438. \u041e\u0434\u0438\u043d \u043a\u043b\u0438\u043a \u0441\u043e\u0442\u0440\u0443\u0434\u043d\u0438\u043a\u0430 \u043c\u043e\u0434\u0435\u0440\u0430\u0446\u0438\u0438 \u0434\u0430\u0451\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u0434\u043e\u0432\u0435\u0440\u0438\u0435, \u0438 \u0434\u0430\u043b\u044c\u0448\u0435 \u043e\u043d \u043f\u0438\u0448\u0435\u0442 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e, \u043d\u0435 \u043d\u0430\u0442\u044b\u043a\u0430\u044f\u0441\u044c \u043d\u0430 \u0438\u0441\u043a\u0443\u0441\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u0431\u0430\u0440\u044c\u0435\u0440\u044b.<\/p>\n<h3>\u041f\u0440\u0438\u043d\u0446\u0438\u043f: \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438 \u043d\u0435 \u043f\u0435\u0440\u0435\u0431\u0438\u0432\u0430\u0435\u0442 \u0441\u0442\u0430\u0442\u044c\u044e<\/h3>\n<p>\u042d\u0442\u043e \u043d\u0435 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0435 \u2014 \u044d\u0442\u043e \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u043e\u0432\u044b\u0439 \u043f\u0440\u0438\u043d\u0446\u0438\u043f. \u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u043f\u0440\u0438\u0448\u0451\u043b \u0447\u0438\u0442\u0430\u0442\u044c. \u041a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0437\u0430\u043c\u0435\u0442\u043d\u044b, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u0438\u0432\u043b\u0435\u0447\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043f\u0440\u0438 \u0436\u0435\u043b\u0430\u043d\u0438\u0438, \u0438 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0442\u0438\u0445\u0438, \u0447\u0442\u043e\u0431\u044b \u043d\u0435 \u043c\u0435\u0448\u0430\u0442\u044c \u0447\u0442\u0435\u043d\u0438\u044e.<\/p>\n<p>\u0410\u043a\u0446\u0435\u043d\u0442\u043d\u044b\u0439 \u0446\u0432\u0435\u0442 \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438 \u0441\u043b\u0430\u0431\u0435\u0435, \u0447\u0435\u043c \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0438 \u0441\u0442\u0430\u0442\u044c\u0438. \u0410\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u043a\u043e\u043c\u044c\u044e\u043d\u0438\u0442\u0438 \u043d\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u044e\u0442\u0441\u044f \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438 \u0441\u0442\u0430\u0442\u044c\u0438. \u0420\u0435\u0430\u043a\u0446\u0438\u0438 \u043d\u0430 \u0430\u0431\u0437\u0430\u0446\u044b \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0432 gutter, \u0430 \u043d\u0435 \u0432\u043d\u0443\u0442\u0440\u0438 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u043e\u0439 \u043a\u043e\u043b\u043e\u043d\u043a\u0438. \u0424\u043e\u0440\u043c\u0430 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u043e\u0441\u043b\u0435 \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430, \u0430 \u043d\u0435 \u043c\u0435\u0436\u0434\u0443 \u0440\u0430\u0437\u0434\u0435\u043b\u0430\u043c\u0438.<\/p>\n<p>\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u043e\u0431\u044b\u0447\u043d\u044b\u043c \u0441\u0430\u0439\u0442\u043e\u043c \u0438 \u0432\u044b\u0434\u0430\u044e\u0449\u0438\u043c\u0441\u044f \u2014 \u043d\u0435 \u0432 \u043d\u0430\u043b\u0438\u0447\u0438\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u0430 \u0432 \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u0438 \u043f\u0440\u043e\u0434\u0443\u043c\u0430\u043d\u043d\u044b\u0445 \u0434\u0435\u0442\u0430\u043b\u0435\u0439 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0443\u0440\u043e\u0432\u043d\u0435: \u043e\u0442 \u043e\u0441\u0438 <code>GRAD<\/code> \u0432 \u0448\u0440\u0438\u0444\u0442\u0435 \u0434\u043e \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u0438\u044f \u043c\u043e\u0434\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043e\u043a\u043d\u0430.<\/p>\n<\/div>\n<p>\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1053162\/\">https:\/\/habr.com\/ru\/articles\/1053162\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0412\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441\u0442\u0430\u0442\u0435\u0439\u043d\u043e\u0433\u043e \u0441\u0430\u0439\u0442\u0430 \u0441\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u0437 \u0441\u043e\u0442\u0435\u043d \u043c\u0435\u043b\u043a\u0438\u0445 \u0440\u0435\u0448\u0435\u043d\u0438\u0439 \u2014 \u043e\u0442 \u043e\u0441\u0438 GRAD \u0432 \u0448\u0440\u0438\u0444\u0442\u0435 \u0434\u043e \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u0438\u044f \u043c\u043e\u0434\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043e\u043a\u043d\u0430. \u041a\u0430\u0436\u0434\u043e\u0435 \u0442\u0430\u043a\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043b\u0438\u0431\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435, \u043b\u0438\u0431\u043e \u0432\u043e\u0440\u0443\u0435\u0442 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0443 \u0442\u0435\u043a\u0441\u0442\u0430.\u041f\u043e\u0447\u0435\u043c\u0443 \u043e\u0434\u0438\u043d \u0448\u0440\u0438\u0444\u0442\u043e\u0432\u043e\u0439 \u0444\u0430\u0439\u043b \u0437\u0430\u043c\u0435\u043d\u044f\u0435\u0442 \u0446\u0435\u043b\u043e\u0435 \u0441\u0435\u043c\u0435\u0439\u0441\u0442\u0432\u043e \u043d\u0430\u0447\u0435\u0440\u0442\u0430\u043d\u0438\u0439\u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043e\u0431\u044b\u0447\u043d\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0434\u0432\u0443\u043c\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438: \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0448\u0440\u0438\u0444\u0442\u0430 \u0438 \u043c\u0435\u0436\u0441\u0442\u0440\u043e\u0447\u043d\u044b\u043c \u0438\u043d\u0442\u0435\u0440\u0432\u0430\u043b\u043e\u043c. \u0422\u0430\u043a\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0442\u043e\u0447\u043a\u043e\u0439 \u0432\u0445\u043e\u0434\u0430, \u043d\u043e \u043d\u0435 \u0440\u0430\u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0448\u0440\u0438\u0444\u0442\u043e\u0432\u044b\u0445 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0439.\u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0439 \u0448\u0440\u0438\u0444\u0442 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u043d\u0435 \u043d\u0430\u0431\u043e\u0440 \u0441\u0442\u0430\u0442\u0438\u0447\u043d\u044b\u0445 \u043d\u0430\u0447\u0435\u0440\u0442\u0430\u043d\u0438\u0439, \u0430 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u043e\u0435 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432. Inter Variable, \u043a \u043f\u0440\u0438\u043c\u0435\u0440\u0443, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u043e\u0441\u044c wght \u0434\u043b\u044f \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0432\u0435\u0441\u043e\u043c \u043e\u0442 100 \u0434\u043e 900 \u0438 \u043e\u0441\u044c opsz \u0434\u043b\u044f \u043e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u0442 \u0444\u043e\u0440\u043c\u0443 \u0433\u043b\u0438\u0444\u043e\u0432 \u043f\u043e\u0434 \u043a\u0435\u0433\u043b\u044c. \u041d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0448\u0440\u0438\u0444\u0442\u043e\u0432\u044b\u0435 \u0441\u0435\u043c\u0435\u0439\u0441\u0442\u0432\u0430 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442 \u043e\u0441\u044c GRAD \u2014 grade, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043c\u0435\u043d\u044f\u0435\u0442 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0443\u044e \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u044c \u0441\u0438\u043c\u0432\u043e\u043b\u0430 \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0435\u0433\u043e \u0448\u0438\u0440\u0438\u043d\u044b. \u0421\u0432\u044f\u0437\u043a\u0430 \u044d\u0442\u0438\u0445 \u043e\u0441\u0435\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0442\u043e\u0447\u043d\u043e \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0442\u044c \u0442\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u043a\u0443 \u043f\u043e\u0434 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0435 \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u043d\u0435 \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u044b \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043d\u0430\u0447\u0435\u0440\u0442\u0430\u043d\u0438\u044f.body {  font-family: &#8216;Inter Variable&#8217;, sans-serif;  font-variation-settings: &#8216;wght&#8217; 400, &#8216;opsz&#8217; 32;}h1 {  font-variation-settings: &#8216;wght&#8217; 750, &#8216;opsz&#8217; 72, &#8216;GRAD&#8217; 0;}\u041d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435 \u0431\u0443\u043a\u0432\u044b \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u0436\u0438\u0440\u043d\u0435\u0435 \u0438\u0437-\u0437\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 irradiation \u2014 \u0441\u0432\u0435\u0442\u043b\u043e\u0435 \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u00ab\u0440\u0430\u0441\u043f\u043b\u044b\u0432\u0430\u0435\u0442\u0441\u044f\u00bb \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0444\u043e\u043d\u0430. \u041e\u0441\u044c GRAD \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043a\u043e\u043c\u043f\u0435\u043d\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u043e \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0438 \u0433\u043b\u0438\u0444\u043e\u0432:@media (prefers-color-scheme: dark) {  body { font-variation-settings: &#8216;wght&#8217; 400, &#8216;opsz&#8217; 32, &#8216;GRAD&#8217; -25; }}Fluid-\u0448\u043a\u0430\u043b\u0430 \u0432\u043c\u0435\u0441\u0442\u043e \u0431\u0440\u0435\u0439\u043a\u043f\u043e\u0438\u043d\u0442\u043e\u0432\u0422\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0448\u043a\u0430\u043b\u0430 \u0447\u0435\u0440\u0435\u0437 clamp() \u0437\u0430\u0434\u0430\u0451\u0442 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043a \u0432\u043c\u0435\u0441\u0442\u043e \u0434\u0438\u0441\u043a\u0440\u0435\u0442\u043d\u044b\u0445 \u0441\u043a\u0430\u0447\u043a\u043e\u0432 \u043d\u0430 \u043c\u0435\u0434\u0438\u0430\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445. \u041a\u0430\u0436\u0434\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u043d\u0430 \u0443\u0437\u043a\u043e\u043c \u0432\u044c\u044e\u043f\u043e\u0440\u0442\u0435, \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0440\u043e\u0441\u0442\u0430 \u0447\u0435\u0440\u0435\u0437 vw \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u043d\u0430 \u0448\u0438\u0440\u043e\u043a\u043e\u043c::root {  &#8212;step&#8212;1: clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);  &#8212;step-0:  clamp(1rem,     0.95rem + 0.25vw, 1.125rem);  &#8212;step-1:  clamp(1.2rem,   1.1rem  + 0.5vw,  1.5rem);  &#8212;step-2:  clamp(1.44rem,  1.25rem + 1vw,    2rem);  &#8212;step-3:  clamp(1.728rem, 1.4rem  + 1.5vw,  2.5rem);  &#8212;step-4:  clamp(2.074rem, 1.6rem  + 2.5vw,  3.5rem);}\u041a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u0440\u043e\u0441\u0442\u0430 \u043c\u0435\u0436\u0434\u0443 \u0441\u0442\u0443\u043f\u0435\u043d\u044f\u043c\u0438 (~1.2) \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043c\u0443\u0437\u044b\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0448\u043a\u0430\u043b\u044b \u043d\u0430 \u043b\u044e\u0431\u043e\u043c \u0440\u0430\u0437\u043c\u0435\u0440\u0435 \u044d\u043a\u0440\u0430\u043d\u0430 \u0431\u0435\u0437 \u0440\u0443\u0447\u043d\u043e\u0439 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439.OpenType-\u0444\u0443\u043d\u043a\u0446\u0438\u0438\u0428\u0440\u0438\u0444\u0442\u044b \u0441 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439 OpenType \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0433\u043b\u0438\u0444\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0432\u044b\u043a\u043b\u044e\u0447\u0435\u043d\u044b. \u0412\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u044f\u0432\u043d\u043e\u0433\u043e \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u044f:.article-body {  font-feature-settings:    &#8216;kern&#8217; 1,   \/* \u043a\u0435\u0440\u043d\u0438\u043d\u0433 *\/    &#8216;liga&#8217; 1,   \/* \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u043b\u0438\u0433\u0430\u0442\u0443\u0440\u044b: fi, fl *\/    &#8216;calt&#8217; 1,   \/* \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043d\u044b\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b *\/    &#8216;onum&#8217; 1;   \/* \u0441\u0442\u0440\u043e\u0447\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u2014 \u043d\u0435 \u0442\u043e\u0440\u0447\u0430\u0442 \u0432\u044b\u0448\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 *\/}\/* \u0422\u043e\u043b\u044c\u043a\u043e \u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445 \u0438 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445: *\/.data-table, .post-meta {  font-feature-settings: &#8216;tnum&#8217; 1; \/* \u0442\u0430\u0431\u043b\u0438\u0447\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u2014 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u0430\u044f \u0448\u0438\u0440\u0438\u043d\u0430 *\/}onum (oldstyle numerals) \u2014 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u0434\u0435\u0442\u0430\u043b\u044c \u0434\u043b\u044f \u0434\u043b\u0438\u043d\u043d\u043e\u0433\u043e \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430. \u0417\u0430\u0433\u043b\u0430\u0432\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b (0\u20139 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435) \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u0432\u044b\u043f\u0438\u0440\u0430\u044e\u0442 \u0438\u0437 \u0441\u0442\u0440\u043e\u043a\u0438, \u0441\u0442\u0440\u043e\u0447\u043d\u044b\u0435 \u0438\u043d\u0442\u0435\u0433\u0440\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0432 \u0440\u0438\u0442\u043c \u0442\u0435\u043a\u0441\u0442\u0430.\u041e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u043d\u0438\u0435 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u043e\u0432\u0418\u0437-\u0437\u0430 \u0431\u043e\u043a\u043e\u0432\u044b\u0445 \u043f\u043e\u043b\u0435\u0439 \u0433\u043b\u0438\u0444\u043e\u0432 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0438 \u0441 \u0437\u0430\u0441\u0435\u0447\u043a\u0430\u043c\u0438 \u0438\u043b\u0438 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u0438\u043c\u0438 \u0448\u0440\u0438\u0444\u0442\u0430\u043c\u0438 \u043a\u0430\u0436\u0443\u0442\u0441\u044f \u00ab\u0441\u044a\u0435\u0445\u0430\u0432\u0448\u0438\u043c\u0438\u00bb \u0432\u043f\u0440\u0430\u0432\u043e \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430\u0447\u0430\u043b\u0430 \u043a\u043e\u043b\u043e\u043d\u043a\u0438. \u041a\u043e\u043c\u043f\u0435\u043d\u0441\u0430\u0446\u0438\u044f:h1, h2, h3 {  text-indent: -0.05em;  hanging-punctuation: first last;}hanging-punctuation \u0432\u044b\u043d\u043e\u0441\u0438\u0442 \u043a\u0430\u0432\u044b\u0447\u043a\u0438 \u0438 \u0442\u0438\u0440\u0435 \u0437\u0430 \u043f\u043e\u043b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u2014 \u0442\u0430\u043a \u043e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0433\u0440\u0430\u043d\u0438\u0446\u0430 \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442 \u0441 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439.\u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f prose-\u0431\u043b\u043e\u043a\u043e\u0432\u0421\u0442\u0430\u0442\u044c\u044f \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0442\u0438\u043f\u043e\u0432 \u0431\u043b\u043e\u043a\u043e\u0432 \u0441 \u0440\u0430\u0437\u043d\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0435\u0439. \u041d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u043d\u043e\u0433\u043e \u0442\u043e\u043a\u0435\u043d\u0430 \u0434\u0435\u043b\u0430\u0435\u0442 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u044e \u044f\u0432\u043d\u043e\u0439 \u0438 \u043b\u0435\u0433\u043a\u043e \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u0438\u0440\u0443\u0435\u043c\u043e\u0439 \u0431\u0435\u0437 \u043f\u0440\u0430\u0432\u043a\u0438 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0431\u043b\u043e\u043a\u0430 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e::root {  &#8212;sbrd-single-body:       1.0rem;  \/* \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0435\u043a\u0441\u0442 *\/  &#8212;sbrd-single-quote:      0.93rem; \/* \u0446\u0438\u0442\u0430\u0442\u0430 \u2014 \u0442\u0438\u0448\u0435 body *\/  &#8212;sbrd-single-list:       0.90rem; \/* \u0441\u043f\u0438\u0441\u043a\u0438 \u2014 \u0432\u0441\u043f\u043e\u043c\u043e\u0433\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 *\/  &#8212;sbrd-single-disclaimer: 0.84rem; \/* \u0441\u043b\u0443\u0436\u0435\u0431\u043d\u044b\u0439 \u0431\u043b\u043e\u043a *\/  &#8212;sbrd-single-code:       0.875rem;}\u041a\u043b\u044e\u0447\u0435\u0432\u043e\u0435 \u0441\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435: body &gt; quote &gt; list &gt; disclaimer. \u041d\u0430\u0440\u0443\u0448\u0435\u043d\u0438\u0435 \u044d\u0442\u043e\u0439 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438 \u2014 \u043a\u043e\u0433\u0434\u0430 \u0441\u043f\u0438\u0441\u043e\u043a \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442 \u043f\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0443 \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u2014 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u0435 \u00ab\u0434\u0432\u0443\u0445 \u043a\u043e\u043d\u043a\u0443\u0440\u0438\u0440\u0443\u044e\u0449\u0438\u0445 \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u00bb \u0432\u043c\u0435\u0441\u0442\u043e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0447\u0442\u0435\u043d\u0438\u044f.\u0426\u0432\u0435\u0442: \u043f\u0435\u0440\u0446\u0435\u043f\u0442\u0438\u0432\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043d\u0430 OKLCH\u041f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435 HSL\u041c\u043e\u0434\u0435\u043b\u044c HSL \u043e\u043f\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u043c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0435\u0439, \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u044f \u0444\u0438\u0437\u0438\u043e\u043b\u043e\u0433\u0438\u044e \u0447\u0435\u043b\u043e\u0432\u0435\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0437\u0440\u0435\u043d\u0438\u044f. \u041f\u0440\u0438 \u0440\u0430\u0432\u043d\u044b\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u0438 \u0436\u0435\u043b\u0442\u044b\u0439 \u0438 \u0441\u0438\u043d\u0438\u0439 \u0446\u0432\u0435\u0442\u0430 \u0431\u0443\u0434\u0443\u0442 \u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u0433\u043b\u0430\u0437\u0443 \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u043f\u043e \u0441\u0432\u0435\u0442\u043b\u043e\u0442\u0435, \u043f\u0440\u0438\u0447\u0435\u043c \u0436\u0435\u043b\u0442\u044b\u0439 \u0432\u0441\u0435\u0433\u0434\u0430 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u0432\u0435\u0442\u043b\u0435\u0435. \u041f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e OKLCH \u0443\u0441\u0442\u0440\u0430\u043d\u044f\u0435\u0442 \u044d\u0442\u043e\u0442 \u043f\u0435\u0440\u0435\u043a\u043e\u0441, \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u044f \u0446\u0432\u0435\u0442\u043e\u0432\u044b\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u043f\u043e\u0434 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u043e\u0441\u043f\u0440\u0438\u044f\u0442\u0438\u0435. \u0420\u0430\u0432\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b \u0441\u0432\u0435\u0442\u043b\u043e\u0442\u044b \u0432 \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u0443\u044e\u0442, \u0447\u0442\u043e \u043b\u044e\u0431\u044b\u0435 \u043e\u0442\u0442\u0435\u043d\u043a\u0438 \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043a\u0430\u043a \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u044f\u0440\u043a\u0438\u0435, \u0447\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e \u0441\u0431\u0430\u043b\u0430\u043d\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043d\u044b\u0435 \u043f\u0430\u043b\u0438\u0442\u0440\u044b.  \u042d\u0442\u043e \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u0441\u0438\u0441\u0442\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0439 \u2014 success, warning, danger, info::root {  &#8212;state-success: oklch(65% 0.18 145);  \/* \u0437\u0435\u043b\u0451\u043d\u044b\u0439 *\/  &#8212;state-warning: oklch(75% 0.18 85);   \/* \u044f\u043d\u0442\u0430\u0440\u043d\u044b\u0439 *\/  &#8212;state-danger:  oklch(62% 0.22 25);   \/* \u043a\u0440\u0430\u0441\u043d\u044b\u0439 *\/  &#8212;state-info:    oklch(65% 0.18 250);  \/* \u0441\u0438\u043d\u0438\u0439 *\/}\u041f\u0440\u0438 \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c L \u0438 \u0441\u043e\u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043c\u043e\u043c C \u0432\u0441\u0435 \u0447\u0435\u0442\u044b\u0440\u0435 \u0446\u0432\u0435\u0442\u0430 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u00abloud\u00bb \u2014 \u043d\u0438 \u043e\u0434\u0438\u043d \u043d\u0435 \u0434\u043e\u043c\u0438\u043d\u0438\u0440\u0443\u0435\u0442 \u043d\u0430\u0434 \u0434\u0440\u0443\u0433\u0438\u043c \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430 \u0441\u0447\u0451\u0442 \u044f\u0440\u043a\u043e\u0441\u0442\u0438.Relative color syntaxCSS Relative Color Syntax \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u043d\u044b\u0435 \u043e\u0442 \u0431\u0430\u0437\u043e\u0432\u043e\u0433\u043e \u0442\u043e\u043a\u0435\u043d\u0430 \u043c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u0431\u0435\u0437 \u0440\u0443\u0447\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0431\u043e\u0440\u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439::root {  &#8212;accent: oklch(65% 0.2 250);  &#8212;accent-light:      oklch(from var(&#8212;accent) calc(l + 0.15) c h);  &#8212;accent-dark:       oklch(from var(&#8212;accent) calc(l &#8212; 0.15) c h);  &#8212;accent-muted:      oklch(from var(&#8212;accent) l calc(c * 0.4) h);  &#8212;accent-complement: oklch(from var(&#8212;accent) l c calc(h + 180));  &#8212;accent-10: oklch(from var(&#8212;accent) l c h \/ 0.10);  &#8212;accent-20: oklch(from var(&#8212;accent) l c h \/ 0.20);}\u041f\u0440\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0438 &#8212;accent \u0432\u0441\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u043d\u044b\u0435 \u043f\u0435\u0440\u0435\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438. \u042d\u0442\u043e \u0438\u0441\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044e, \u043a\u043e\u0433\u0434\u0430 \u0441\u043c\u0435\u043d\u0430 \u0430\u043a\u0446\u0435\u043d\u0442\u043d\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0440\u0443\u0447\u043d\u043e\u0433\u043e \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445.\u0422\u0440\u0438 \u0443\u0440\u043e\u0432\u043d\u044f \u0442\u043e\u043a\u0435\u043d\u043e\u0432\u0425\u043e\u0440\u043e\u0448\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0441\u0442\u0440\u043e\u0438\u0442\u0441\u044f \u043e\u0442 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u0432 \u043a \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0435 \u0438 \u043e\u0442 \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0438 \u043a \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c:\/* \u0423\u0440\u043e\u0432\u0435\u043d\u044c 1 \u2014 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b, \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e *\/&#8212;blue-500: oklch(55% 0.18 250);&#8212;gray-950: oklch(10% 0.01 250);\/* \u0423\u0440\u043e\u0432\u0435\u043d\u044c 2 \u2014 \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0430 *\/&#8212;color-bg-primary:    var(&#8212;gray-950);&#8212;color-text-primary:  var(&#8212;gray-50);&#8212;color-text-secondary:var(&#8212;gray-400);&#8212;color-border-subtle: var(&#8212;gray-800);\/* \u0423\u0440\u043e\u0432\u0435\u043d\u044c 3 \u2014 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b *\/&#8212;article-bg:   var(&#8212;color-bg-primary);&#8212;callout-border: var(&#8212;color-border-default);\u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u0441\u044b\u043b\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e. \u042d\u0442\u043e \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u0443\u0435\u0442, \u0447\u0442\u043e \u043f\u0440\u0438 \u0441\u043c\u0435\u043d\u0435 \u0442\u0435\u043c\u044b \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u0435\u0440\u0435\u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u043b\u043e\u0439.\u041a\u043e\u043d\u0442\u0440\u0430\u0441\u0442 \u043a\u0430\u043a \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438WCAG \u0437\u0430\u0434\u0430\u0451\u0442 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0443\u044e \u043f\u043b\u0430\u043d\u043a\u0443. \u0420\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430 \u2014 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0443\u044e \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u044e, \u043f\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044f \u0434\u0432\u0438\u0433\u0430\u0435\u0442\u0441\u044f \u043f\u043e \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e:\u041e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0435\u043a\u0441\u0442 \u0441\u0442\u0430\u0442\u044c\u0438     ~12:1   \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0447\u0438\u0442\u0430\u0435\u043c\u043e\u0441\u0442\u044c\u041a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0438               ~8:1    \u0432\u0430\u0436\u043d\u043e, \u043d\u043e \u0432\u0442\u043e\u0440\u0438\u0447\u043d\u043e\u041c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 (\u0434\u0430\u0442\u0430, \u0441\u0447\u0451\u0442)   ~5:1    \u0441\u043a\u0430\u043d\u0438\u0440\u0443\u0435\u0442\u0441\u044f\u041f\u043b\u0435\u0439\u0441\u0445\u043e\u043b\u0434\u0435\u0440\u044b              ~3.5:1  \u043d\u0430\u043c\u0451\u043a, \u043d\u0435 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0414\u0435\u043a\u043e\u0440\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b      ~2:1    \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0431\u0435\u0437 \u0430\u043a\u0446\u0435\u043d\u0442\u0430\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0443\u0440\u043e\u0432\u043d\u044f \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u2014 \u044d\u0442\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0448\u0443\u043c. \u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430 \u0440\u0430\u0432\u043d\u0430 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u044f.\u041f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0438 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043eSurface ladder\u0413\u043b\u0443\u0431\u0438\u043d\u0430 \u0442\u0435\u043c\u043d\u043e\u0433\u043e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u0435 \u0442\u0435\u043d\u044f\u043c\u0438 (\u043e\u043d\u0438 \u0442\u0435\u0440\u044f\u044e\u0442 \u0441\u043c\u044b\u0441\u043b \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435), \u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043e\u0441\u0432\u0435\u0442\u043b\u0435\u043d\u0438\u0435\u043c \u0441\u043b\u043e\u0451\u0432:&#8212;surface-0: oklch(12% 0.01 250);  \/* \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 *\/&#8212;surface-1: oklch(15% 0.01 250);  \/* \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438 *\/&#8212;surface-2: oklch(18% 0.015 250); \/* \u043f\u043e\u0434\u043d\u044f\u0442\u044b\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b *\/&#8212;surface-3: oklch(22% 0.02 250);  \/* hover *\/&#8212;surface-4: oklch(26% 0.02 250);  \/* \u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f *\/\u041a\u0430\u0436\u0434\u044b\u0439 \u0441\u043b\u043e\u0439 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043d\u0430 3% \u043f\u043e L. \u042d\u0442\u043e \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u043c\u0443\u044e \u0433\u043b\u0443\u0431\u0438\u043d\u0443 \u0431\u0435\u0437 \u0440\u0435\u0437\u043a\u0438\u0445 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u043e\u0432. \u041a\u043b\u044e\u0447\u0435\u0432\u043e\u0435: surface-0 \u2014 \u044d\u0442\u043e \u0444\u043e\u043d \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b, \u0430 \u043d\u0435 \u0441\u0430\u043c\u044b\u0439 \u0442\u0451\u043c\u043d\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442.\u0422\u0451\u043c\u043d\u0430\u044f \u0442\u0435\u043c\u0430: \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043b\u043e\u0432\u0443\u0448\u043a\u0438\u0420\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u0435 \u0431\u043b\u043e\u043a\u043e\u0432 \u0447\u0438\u0441\u0442\u043e\u0433\u043e \u0431\u0435\u043b\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430 (#ffffff) \u043d\u0430 \u0433\u043b\u0443\u0431\u043e\u043a\u043e\u043c \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435 (#080b0f) \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442 \u0437\u043e\u043d\u044b \u044d\u043a\u0441\u0442\u0440\u0435\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430. \u0427\u0435\u043b\u043e\u0432\u0435\u0447\u0435\u0441\u043a\u0438\u0439 \u0433\u043b\u0430\u0437 \u0430\u0434\u0430\u043f\u0442\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043a \u043e\u0431\u0449\u0435\u043c\u0443 \u0443\u0440\u043e\u0432\u043d\u044e \u043e\u0441\u0432\u0435\u0449\u0451\u043d\u043d\u043e\u0441\u0442\u0438 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430. \u0420\u0435\u0437\u043a\u0438\u0435 \u043f\u0435\u0440\u0435\u043f\u0430\u0434\u044b \u044f\u0440\u043a\u043e\u0441\u0442\u0438 \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u0433\u0430\u043b\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u0443\u044e \u0443\u0442\u043e\u043c\u043b\u044f\u0435\u043c\u043e\u0441\u0442\u044c. \u0424\u043e\u0440\u043c\u0438\u0440\u0443\u0439\u0442\u0435 \u043f\u043e\u0434\u043d\u044f\u0442\u044b\u0435 \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438 \u0438 \u043c\u043e\u0434\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u043a\u043d\u0430 \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0447\u0435\u0440\u0435\u0437 \u0442\u043e\u043a\u0435\u043d\u044b \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u043d\u044b\u0445 \u0441\u043b\u043e\u0451\u0432 (&#8212;surface-1, &#8212;surface-2). \u041f\u0440\u044f\u043c\u043e\u0435 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435 background: white \u0432 \u0441\u0442\u0438\u043b\u044f\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e.\u041d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c (chroma) \u0430\u043a\u0446\u0435\u043d\u0442\u043d\u044b\u0445 \u043e\u0442\u0442\u0435\u043d\u043a\u043e\u0432 \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u043c \u0444\u043e\u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043f\u0440\u0438\u043d\u0443\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u043d\u0438\u0436\u0435\u043d\u0438\u044f. \u041f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u044f\u0440\u043a\u043e\u0433\u043e \u0441\u0438\u043d\u0435\u0433\u043e oklch(65% 0.25 250) \u043d\u0430 \u043f\u043e\u0434\u043b\u043e\u0436\u043a\u0435 oklch(12%) \u043f\u0440\u043e\u0432\u043e\u0446\u0438\u0440\u0443\u0435\u0442 \u043e\u043f\u0442\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0432\u0438\u0431\u0440\u0430\u0446\u0438\u044e. \u0421\u0432\u0435\u0442\u043b\u044b\u0439 \u0438 \u0442\u0451\u043c\u043d\u044b\u0439 \u0446\u0432\u0435\u0442\u0430 \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0442 \u043a\u043e\u043d\u043a\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430 \u0444\u043e\u043a\u0443\u0441, \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u043b\u043e\u0436\u043d\u044b\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b \u0438 \u043c\u0435\u0440\u0446\u0430\u043d\u0438\u0435 \u043d\u0430 \u0441\u0442\u044b\u043a\u0435. \u041e\u0433\u0440\u0430\u043d\u0438\u0447\u044c\u0442\u0435 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043d\u0430 \u0442\u0451\u043c\u043d\u043e\u0439 \u043f\u043e\u0434\u043b\u043e\u0436\u043a\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 0.15\u20130.20. \u041f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u0435 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0440\u043e\u0433\u0430 \u043d\u0435\u0438\u0437\u0431\u0435\u0436\u043d\u043e \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0439 \u0448\u0443\u043c.\u0410\u0442\u043c\u043e\u0441\u0444\u0435\u0440\u0430: \u0434\u0435\u0442\u0430\u043b\u0438 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043a\u043e\u043f\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u043e\u0439Noise texture\u041f\u043b\u043e\u0441\u043a\u0438\u0439 \u0437\u0430\u043b\u0438\u0432\u043d\u043e\u0439 \u0446\u0432\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0434\u0451\u0448\u0435\u0432\u043e \u043d\u0430 \u0432\u044b\u0441\u043e\u043a\u043e\u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0445 \u044d\u043a\u0440\u0430\u043d\u0430\u0445. \u0422\u043e\u043d\u043a\u0438\u0439 \u0437\u0435\u0440\u043d\u0438\u0441\u0442\u044b\u0439 \u0441\u043b\u043e\u0439 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c, \u0438\u043c\u0438\u0442\u0438\u0440\u0443\u044f \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443:.article-hero::after {  content: &#187;;  position: absolute;  inset: 0;  background-image: url(&#171;data:image\/svg+xml,%3Csvg viewBox=&#8217;0 0 256 256&#8242; xmlns=&#8217;http:\/\/www.w3.org\/2000\/svg&#8217;%3E%3Cfilter id=&#8217;noise&#8217;%3E%3CfeTurbulence type=&#8217;fractalNoise&#8217; baseFrequency=&#8217;0.9&#8242; numOctaves=&#8217;4&#8242; stitchTiles=&#8217;stitch&#8217;\/%3E%3C\/filter%3E%3Crect width=&#8217;100%25&#8242; height=&#8217;100%25&#8242; filter=&#8217;url(%23noise)&#8217; opacity=&#8217;0.04&#8217;\/%3E%3C\/svg%3E&#187;);  pointer-events: none;}opacity: 0.04 \u2014 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0438\u0439 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d. \u041d\u0438\u0436\u0435 \u2014 \u043d\u0435\u0437\u0430\u043c\u0435\u0442\u043d\u043e, \u0432\u044b\u0448\u0435 \u2014 \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0430\u0440\u0442\u0435\u0444\u0430\u043a\u0442\u043e\u043c.Gradient mesh\u041c\u043d\u043e\u0433\u043e\u0442\u043e\u0447\u0435\u0447\u043d\u044b\u0439 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043d\u044b\u0439 \u0444\u043e\u043d \u0437\u0430 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u043e\u043c \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0433\u043b\u0443\u0431\u0438\u043d\u0443 \u0431\u0435\u0437 \u0442\u044f\u0436\u0451\u043b\u044b\u0445 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439:.article-header__mesh {  position: absolute;  inset: -50%;  background:    radial-gradient(ellipse 60% 50% at 20% 50%,      oklch(55% 0.2 280 \/ 0.15) 0%, transparent 70%),    radial-gradient(ellipse 50% 60% at 80% 30%,      oklch(60% 0.18 200 \/ 0.12) 0%, transparent 70%);  filter: blur(60px);  animation: mesh-drift 20s ease-in-out infinite alternate;  pointer-events: none;}@keyframes mesh-drift {  0%   { transform: translate(0, 0) scale(1); }  50%  { transform: translate(2%, 1%) scale(1.02); }  100% { transform: translate(1%, -1%) scale(1.01); }}blur(60px) \u0434\u0435\u043b\u0430\u0435\u0442 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u044b \u043c\u0435\u0436\u0434\u0443 \u043f\u044f\u0442\u043d\u0430\u043c\u0438 \u043c\u044f\u0433\u043a\u0438\u043c\u0438. inset: -50% \u2014 \u043e\u0431\u0451\u0440\u0442\u043a\u0430 \u0431\u043e\u043b\u044c\u0448\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043c\u044b\u0442\u044b\u0435 \u043a\u0440\u0430\u044f \u043d\u0435&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-485395","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/485395","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=485395"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/485395\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=485395"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=485395"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=485395"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}