{"id":481931,"date":"2026-06-01T13:18:51","date_gmt":"2026-06-01T13:18:51","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=481931"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=481931","title":{"rendered":"Lighthouse 100 \/ 100: \u043a\u0430\u043a \u043c\u044b \u043f\u043e\u0432\u0435\u0441\u0438\u043b\u0438 GTM, GA4, \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0443 \u0438 Clarity \u043d\u0430 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u0430\u0439\u0442 \u2014 \u0438 \u043d\u0435 \u0443\u0440\u043e\u043d\u0438\u043b\u0438 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/951\/e8c\/c03\/951e8cc030cf0b6fd55b385124bc0adc.webp\" width=\"1080\" height=\"1080\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/951\/e8c\/c03\/951e8cc030cf0b6fd55b385124bc0adc.webp 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/951\/e8c\/c03\/951e8cc030cf0b6fd55b385124bc0adc.webp 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<hr\/>\n<p>\u041a\u043e\u0433\u0434\u0430 \u043c\u0430\u0440\u043a\u0435\u0442\u043e\u043b\u043e\u0433\u0438 \u0445\u043e\u0442\u044f\u0442 \u0432\u0441\u0451: \u0441\u044b\u0440\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0432 GA4, \u0437\u0430\u043f\u0438\u0441\u044c \u0441\u0435\u0441\u0441\u0438\u0439 \u0432 \u041c\u0435\u0442\u0440\u0438\u043a\u0435, \u0445\u0438\u0442\u043c\u0430\u043f\u044b \u0432 Clarity \u0438 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u00abLighthouse 100\u00bb \u0432 PageSpeed Insights \u2014 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0438\u0437\u043e\u0431\u0440\u0435\u0442\u0430\u0442\u044c. \u0420\u0430\u0441\u0441\u043a\u0430\u0436\u0443, \u043a\u0430\u043a \u043c\u044b \u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u043d\u0430 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0438 \u0432\u043e \u0447\u0442\u043e \u044d\u0442\u043e \u043e\u0431\u043e\u0448\u043b\u043e\u0441\u044c \u043f\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438 \u043d\u0435\u0440\u0432\u0430\u043c.<\/p>\n<p>\u041f\u0440\u043e\u0435\u043a\u0442 \u2014 \u043d\u0438\u0448\u0435\u0432\u044b\u0439 \u0430\u0433\u0440\u0435\u0433\u0430\u0442\u043e\u0440 \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u0438\u0445 \u0445\u043e\u0441\u0442\u0438\u043d\u0433-\u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u043e\u0432. \u0411\u043e\u043b\u0435\u0435 120 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u0432 sitemap, 31 \u0441\u0442\u0430\u0442\u044c\u044f, \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0439 \u0443\u0441\u043b\u0443\u0433, \u0436\u0438\u0432\u044b\u0435 \u0446\u0435\u043d\u044b, \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f. \u0421\u0442\u0435\u043a: Astro 6 + Strapi 5 + Tailwind 4, \u043f\u043b\u044e\u0441 Partytown, PostgreSQL, Nginx \u0438 \u043e\u0431\u044b\u0447\u043d\u044b\u0439 VPS \u043d\u0430 Ubuntu. \u0421\u0430\u0439\u0442 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u0442\u0430\u0442\u0438\u043a\u0443 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0431\u0438\u043b\u0434\u0430, \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e SSR \u0432 \u0440\u0430\u043d\u0442\u0430\u0439\u043c\u0435 \u043d\u0435\u0442.<\/p>\n<p>\u041d\u0430 desktop \u2014 Lighthouse 100 \/ 100 \/ 100 \/ 100. \u041d\u0430 mobile \u0441 \u0436\u0451\u0441\u0442\u043a\u0438\u043c throttling (4x slow CPU) \u2014 99 \/ 100 \/ 100 \/ 100. \u0412 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u0445 \u0438 \u043f\u043e Chrome UX Report \u2014 100 \u0432\u0435\u0437\u0434\u0435. LCP \u043d\u0430 desktop \u2014 0,5 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, \u043d\u0430 mobile throttled \u2014 1,7 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. CLS \u2014 \u043d\u043e\u043b\u044c. TBT \u2014 10 ms \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u043c \u0438 0 ms \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435.<\/p>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5cf\/60c\/f5c\/5cf60cf5c216ab700ba051fdc9cbb320.png\" alt=\"Lighthouse \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435: 100 \/ 100 \/ 100 \/ 100. LCP 0,5 \u0441, TBT 0 ms, CLS 0. \u041e\u0431\u044b\u0447\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0431\u0435\u0437 throttling.\" title=\"Lighthouse \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435: 100 \/ 100 \/ 100 \/ 100. LCP 0,5 \u0441, TBT 0 ms, CLS 0. \u041e\u0431\u044b\u0447\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0431\u0435\u0437 throttling.\" width=\"1920\" height=\"1040\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/5cf\/60c\/f5c\/5cf60cf5c216ab700ba051fdc9cbb320.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5cf\/60c\/f5c\/5cf60cf5c216ab700ba051fdc9cbb320.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>Lighthouse \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435: 100 \/ 100 \/ 100 \/ 100. LCP 0,5 \u0441, TBT 0 ms, CLS 0. \u041e\u0431\u044b\u0447\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0431\u0435\u0437 throttling.<\/figcaption><\/div>\n<\/figure>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/495\/603\/05f\/49560305ffbff705f9a391b746e4a832.png\" alt=\"\u0422\u043e\u0442 \u0436\u0435 \u0441\u0430\u0439\u0442 \u043d\u0430 mobile \u0441 \u0436\u0451\u0441\u0442\u043a\u0438\u043c throttling (4x slow CPU): 99 \/ 100 \/ 100 \/ 100. LCP 1,7 \u0441, TBT 10 ms, CLS 0. \u0423 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0432 Chrome UX Report \u2014 100 \u0432\u0435\u0437\u0434\u0435.\" title=\"\u0422\u043e\u0442 \u0436\u0435 \u0441\u0430\u0439\u0442 \u043d\u0430 mobile \u0441 \u0436\u0451\u0441\u0442\u043a\u0438\u043c throttling (4x slow CPU): 99 \/ 100 \/ 100 \/ 100. LCP 1,7 \u0441, TBT 10 ms, CLS 0. \u0423 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0432 Chrome UX Report \u2014 100 \u0432\u0435\u0437\u0434\u0435.\" width=\"1920\" height=\"1040\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/495\/603\/05f\/49560305ffbff705f9a391b746e4a832.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/495\/603\/05f\/49560305ffbff705f9a391b746e4a832.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u0422\u043e\u0442 \u0436\u0435 \u0441\u0430\u0439\u0442 \u043d\u0430 mobile \u0441 \u0436\u0451\u0441\u0442\u043a\u0438\u043c throttling (4x slow CPU): 99 \/ 100 \/ 100 \/ 100. LCP 1,7 \u0441, TBT 10 ms, CLS 0. \u0423 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0432 Chrome UX Report \u2014 100 \u0432\u0435\u0437\u0434\u0435.<\/figcaption><\/div>\n<\/figure>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u2014 \u043f\u043e \u043f\u043e\u0440\u044f\u0434\u043a\u0443. \u041f\u043e\u0447\u0435\u043c\u0443 Astro, \u0430 \u043d\u0435 Next.js \u0438 \u043d\u0435 Nuxt. \u041a\u0430\u043a Strapi \u0436\u0438\u0432\u0451\u0442 \u0440\u044f\u0434\u043e\u043c \u0441\u043e \u0441\u0442\u0430\u0442\u0438\u043a\u043e\u0439 \u0438 \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0430\u0441 \u0447\u0443\u0442\u044c \u043d\u0435 \u043f\u043e\u0445\u043e\u0440\u043e\u043d\u0438\u043b\u0430 \u043e\u0434\u043d\u0430 \u0435\u0433\u043e \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044c. \u0414\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u0440\u0438\u0447\u0438\u043d, \u043f\u043e\u0447\u0435\u043c\u0443 \u043b\u043e\u043c\u0430\u043b\u0430\u0441\u044c \u0442\u0451\u043c\u043d\u0430\u044f \u0442\u0435\u043c\u0430 \u0432 Tailwind 4. \u0418, \u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u043a\u0430\u043a Partytown \u0432\u044b\u0440\u0432\u0430\u043b 1 190 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0438 \u0438\u0437 \u0433\u043b\u0430\u0432\u043d\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043a\u0430 \u0438 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043b \u043d\u0430\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 PageSpeed Insights.<\/p>\n<hr\/>\n<h2>\u041f\u043e\u0447\u0435\u043c\u0443 Astro, \u0430 \u043d\u0435 Next.js \u0438\u043b\u0438 Nuxt<\/h2>\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u043b\u0438 Next.js 14 \u0441 App Router. \u041d\u043e \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043d\u043e\u0433\u043e \u0441\u0430\u0439\u0442\u0430 \u0441 120+ \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u043c\u0438, \u0433\u0434\u0435 90% \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u2014 \u0442\u0435\u043a\u0441\u0442\u044b, \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438, SSR \u0438 \u0433\u0438\u0434\u0440\u0430\u0442\u0430\u0446\u0438\u044f React-\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0431\u044b\u043b\u0438 \u0438\u0437\u0431\u044b\u0442\u043e\u0447\u043d\u044b.<\/p>\n<p>Astro \u0434\u0430\u043b \u0442\u0440\u0438 \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0445 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u0430:<\/p>\n<ul>\n<li>\n<p><strong>Zero-JS \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e.<\/strong> \u0421\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 \u0447\u0438\u0441\u0442\u044b\u0439 HTML \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0441\u0431\u043e\u0440\u043a\u0438. JavaScript \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u2014 \u043a\u0430\u043b\u044c\u043a\u0443\u043b\u044f\u0442\u043e\u0440\u0430, \u043a\u0432\u0438\u0437\u0430 \u2014 \u0447\u0435\u0440\u0435\u0437 Islands Architecture. HTML-\u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0432\u0435\u0441\u0438\u0442 15-25 KB, \u0430 \u043d\u0435 200+ KB \u0441 React-\u0440\u0430\u043d\u0442\u0430\u0439\u043c\u043e\u043c.<\/p>\n<\/li>\n<li>\n<p><strong>Partial hydration.<\/strong> \u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u0441 <code>client:load<\/code> \u0438\u043b\u0438 <code>client:idle<\/code> \u0433\u0438\u0434\u0440\u0430\u0442\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0438\u0437\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e. \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0439. \u042d\u0442\u043e \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u043e \u0434\u043b\u044f \u043c\u0435\u0442\u0440\u0438\u043a \u2014 \u043d\u0435\u0442 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0435\u0433\u043e \u043f\u0430\u0440\u0441\u0438\u043d\u0433\u0430 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432 \u0432 <code>&lt;head&gt;<\/code>.<\/p>\n<\/li>\n<li>\n<p><strong>\u041a\u043e\u043d\u0442\u0435\u043d\u0442-\u0444\u043e\u043a\u0443\u0441.<\/strong> Astro \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0443\u043c\u0435\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 Markdown, MDX \u0438 \u043b\u044e\u0431\u043e\u0439 CMS \u0447\u0435\u0440\u0435\u0437 loaders. \u041d\u0435 \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0433\u043e\u0440\u043e\u0434\u0438\u0442\u044c \u043a\u043e\u0441\u0442\u044b\u043b\u0438 \u0434\u043b\u044f \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0438\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u043e\u0432 \u0432\u0440\u043e\u0434\u0435 <code>\/catalog\/[slug].astro<\/code>.<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"javascript\">\/\/ astro.config.mjs \u2014 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044fimport { defineConfig } from 'astro\/config';import tailwindcss from '@tailwindcss\/vite';export default defineConfig({  output: 'static',  prefetch: true,  vite: {    plugins: [tailwindcss()],  },});<\/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<h2>\u041a\u0430\u043a Strapi v5 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043a\u0430\u043a Headless CMS \u0434\u043b\u044f SSG<\/h2>\n<p>\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 \u043f\u0430\u0442\u0442\u0435\u0440\u043d: CMS \u043d\u0430 Node.js \u043e\u0442\u0434\u0430\u0451\u0442 JSON \u043f\u043e REST, \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0437\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0432\u0445\u043e\u0434. \u0423 \u043d\u0430\u0441 \u0432\u0441\u0451 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442. \u0424\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0445\u043e\u0434\u0438\u0442 \u0432 Strapi \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0431\u043e\u0440\u043a\u0438. \u0412\u0441\u0451 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f Strapi \u0436\u0438\u0432\u0451\u0442 \u0441\u0432\u043e\u0435\u0439 \u0436\u0438\u0437\u043d\u044c\u044e \u043d\u0430 PM2, \u043e\u0442\u0434\u0430\u0451\u0442 \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440\u0430\u043c \u0441\u0432\u043e\u0439 admin-UI, \u0438 \u0441\u0430\u0439\u0442\u0443 \u0434\u043e \u043d\u0435\u0433\u043e \u043d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u0434\u0435\u043b\u0430.<\/p>\n<pre><code class=\"typescript\">\/\/ src\/lib\/strapi.ts \u2014 fetch \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 buildexport async function fetchProviders() {  const res = await fetch(`${STRAPI_URL}\/api\/providers?populate=*`, {    headers: { Authorization: `Bearer ${TOKEN}` },  });  const json = await res.json();  return json.data || [];}<\/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 \u043a\u0430\u0436\u0434\u043e\u043c <code>.astro<\/code>-\u0444\u0430\u0439\u043b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0432 frontmatter-\u0441\u0435\u043a\u0446\u0438\u0438 (server-side \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0431\u043e\u0440\u043a\u0438). \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u2014 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 HTML \u0441 \u0443\u0436\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438. \u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0436\u0434\u0430\u0442\u044c API-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432.<\/p>\n<pre><code>\/\/ src\/pages\/providers\/[slug].astroexport async function getStaticPaths() {  const providers = await fetchProviders();  return providers.map((p) =&gt; ({    params: { slug: p.slug },    props: { data: p },  }));}const { data } = Astro.props;<\/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>Strapi v5 \u0441 Document Service API \u0438 <code>documentId<\/code> \u0432\u043c\u0435\u0441\u0442\u043e \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0445 <code>id<\/code> \u043f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b \u0430\u0434\u0430\u043f\u0442\u0430\u0446\u0438\u0438 \u2014 \u043c\u044b \u043d\u0430\u043f\u0438\u0441\u0430\u043b\u0438 \u043e\u0431\u0451\u0440\u0442\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u0443\u0435\u0442 \u043e\u0442\u0432\u0435\u0442\u044b (\u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0438 \u0441\u0442\u0430\u0440\u044b\u0439 <code>attributes<\/code>-\u0444\u043e\u0440\u043c\u0430\u0442, \u0438 \u043d\u043e\u0432\u044b\u0439 \u043f\u043b\u043e\u0441\u043a\u0438\u0439). \u0413\u043b\u0430\u0432\u043d\u044b\u0439 \u043f\u043b\u044e\u0441: Strapi \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u043c, \u0441\u043b\u043e\u0436\u043d\u0430\u044f \u0431\u0438\u0437\u043d\u0435\u0441-\u043b\u043e\u0433\u0438\u043a\u0430 (affiliate-\u0441\u0441\u044b\u043b\u043a\u0438, pluralization, UTM) \u0436\u0438\u0432\u0451\u0442 \u0432\u043e \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0435.<\/p>\n<p>\u0413\u043b\u0430\u0432\u043d\u044b\u0435 \u0433\u0440\u0430\u0431\u043b\u0438, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0441\u0442\u0443\u043f\u0438\u043b\u0438. \u041f\u043e\u0441\u043b\u0435 <code>npm run build<\/code> \u043f\u0430\u043f\u043a\u0430 <code>dist\/<\/code> \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 admin-\u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441. \u041a\u043e\u043d\u0444\u0438\u0433 \u0438 schema \u043e\u043d\u0430 \u043d\u0435 \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u0442. \u0415\u0441\u043b\u0438 \u0437\u0430\u0431\u044b\u0442\u044c \u0440\u0443\u0447\u043d\u044b\u0435 <code>cp -r config dist\/config &amp;&amp; cp -r src dist\/src<\/code> \u0438 \u0440\u0435\u0441\u0442\u0430\u0440\u0442\u043d\u0443\u0442\u044c PM2 \u2014 \u043f\u0440\u0438 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0441\u0442\u0430\u0440\u0442\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0448\u044c \u043f\u0443\u0441\u0442\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442. \u0427\u0443\u0442\u044c \u043d\u0435 \u043f\u043e\u0442\u0435\u0440\u044f\u043b\u0438 \u0432\u0435\u0441\u044c \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0432 \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u043c \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0438. \u0421 \u0442\u0435\u0445 \u043f\u043e\u0440 \u0443 \u043d\u0430\u0441 \u0436\u0435\u043b\u0435\u0437\u043d\u043e\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u043e: \u043f\u0435\u0440\u0435\u0434 \u043b\u044e\u0431\u044b\u043c \u0440\u0435\u0431\u0438\u043b\u0434\u043e\u043c Strapi \u2014 dump \u0411\u0414, \u043f\u043e\u0441\u043b\u0435 \u0441\u0431\u043e\u0440\u043a\u0438 \u2014 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 config \u0438 src \u0432 dist.<\/p>\n<hr\/>\n<h2>Tailwind CSS 4: \u043f\u043e\u0447\u0435\u043c\u0443 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0441\u044a\u0435\u043b\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0432\u043f\u044f\u0442\u0435\u0440\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u043e\u0436\u0438\u0434\u0430\u0435\u043c\u043e\u0433\u043e<\/h2>\n<p>\u041f\u0440\u043e\u0435\u043a\u0442 \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u043b \u043d\u0430 Tailwind 3.4. \u041a\u043e\u0433\u0434\u0430 \u0432\u044b\u0448\u0435\u043b v4 \u0441 CSS-first \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0435\u0439, \u043c\u044b \u0440\u0435\u0448\u0438\u043b\u0438 \u043c\u0438\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u2014 \u0445\u043e\u0442\u0435\u043b\u0438 \u0438\u0437\u0431\u0430\u0432\u0438\u0442\u044c\u0441\u044f \u043e\u0442 <code>tailwind.config.js<\/code> \u0438 \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043d\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 CSS-\u0434\u0438\u0440\u0435\u043a\u0442\u0438\u0432\u044b.<\/p>\n<pre><code class=\"css\">\/* src\/styles\/global.css \u2014 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f Tailwind 4 *\/@import \"tailwindcss\";@theme {  --color-brand: #2563eb;  --font-sans: \"Inter\", ui-sans-serif, system-ui, sans-serif;}@custom-variant dark (&amp;:is(.dark *));<\/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>\u0427\u0442\u043e \u0441\u043b\u043e\u043c\u0430\u043b\u043e\u0441\u044c:<\/p>\n<ol>\n<li>\n<p><strong>Scoped styles \u0441 <\/strong><code><strong>@apply<\/strong><\/code>. \u0412 Astro <code>&lt;style&gt;<\/code> \u0431\u043b\u043e\u043a\u0430\u0445 <code>@reference \"tailwindcss\"<\/code> \u043d\u0435 \u043d\u0430\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043b <code>@custom-variant dark<\/code>. \u041a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043b\u043e\u0441\u044c \u0432 <code>@media(prefers-color-scheme:dark)<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>.dark<\/code>. \u041f\u043e\u043b\u0442\u043e\u0440\u0430 \u0434\u043d\u044f \u043f\u044b\u0442\u0430\u043b\u0438\u0441\u044c \u043f\u043e\u043d\u044f\u0442\u044c, \u043f\u043e\u0447\u0435\u043c\u0443 \u0432 layout \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435 <code>class:list={['dark:bg-slate-900']}<\/code> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u043a\u043b\u0438\u043a\u0443 \u043a\u043d\u043e\u043f\u043a\u0438 \u0442\u0435\u043c\u044b, \u0430 \u0432 <code>&lt;style&gt;<\/code> \u0440\u044f\u0434\u043e\u043c \u2014 \u043d\u0435\u0442. \u041f\u043e\u0444\u0438\u043a\u0441\u0438\u043b\u0438 \u0447\u0435\u0440\u0435\u0437 <code>@reference \"..\/..\/styles\/global.css\"<\/code> \u0441 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u043c \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043f\u0443\u0442\u0451\u043c \u2014 \u0432 \u0434\u043e\u043a\u0430\u0445 \u044d\u0442\u043e\u0433\u043e \u043d\u0435\u0442, \u043d\u0430\u0448\u043b\u0438 \u043f\u043e \u0441\u0442\u0430\u0440\u044b\u043c GitHub issues.<\/p>\n<\/li>\n<li>\n<p><strong>\u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u043a\u0430\u0440\u0442\u043e\u0447\u0435\u043a<\/strong>. \u041c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438 CSS-\u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u0442\u0435\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 (<code>--card-bg<\/code>, <code>--text-primary<\/code>). Tailwind 4 \u0441 Vite-plugin \u0438\u043d\u043e\u0433\u0434\u0430 tree-shake&#8217;\u0438\u043b \u043d\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0438\u0437 <code>:root<\/code> \u2014 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0430\u0441\u044c, \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u043b\u0430 \u043a\u0430\u043a \u0431\u0435\u043b\u044b\u0439 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a \u0431\u0435\u0437 \u0444\u043e\u043d\u043e\u0432\u044b\u0445 \u0446\u0432\u0435\u0442\u043e\u0432. \u041f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u044f\u0432\u043d\u043e \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0441\u0435 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0432 <code>global.css<\/code> \u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u0432 \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440\u0435 <code>.dark<\/code>, \u0438\u043d\u0430\u0447\u0435 PostCSS-\u043f\u0440\u043e\u0445\u043e\u0434 \u0438\u0445 \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u043b.<\/p>\n<\/li>\n<li>\n<p><strong>\u041a\u043b\u0430\u0441\u0441\u044b \u0432\u0438\u0434\u0430 <\/strong><code><strong>dark:bg-[#1e293b]<\/strong><\/code>. \u0420\u0430\u0431\u043e\u0442\u0430\u044e\u0442, \u043d\u043e <code>#1e293b<\/code> \u2014 \u044d\u0442\u043e \u043d\u0435 <code>slate-900<\/code>. \u041c\u044b \u043e\u0441\u043e\u0437\u043d\u0430\u043d\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c <code>#1e293b<\/code> \u0434\u043b\u044f \u0441\u0438\u043d\u0435\u0433\u043e \u043e\u0442\u0442\u0435\u043d\u043a\u0430 \u0442\u0451\u043c\u043d\u043e\u0439 \u0442\u0435\u043c\u044b, \u0438 Tailwind 4 \u044d\u0442\u043e \u043d\u0435 \u0441\u043b\u043e\u043c\u0430\u043b, \u043d\u043e \u0432\u0430\u0436\u043d\u043e \u0441\u043b\u0435\u0434\u0438\u0442\u044c \u0437\u0430 arbitrary values.<\/p>\n<\/li>\n<li>\n<p><strong>\u041b\u043e\u0433\u043e\u0442\u0438\u043f\u044b \u0432 \u0442\u0451\u043c\u043d\u043e\u0439 \u0442\u0435\u043c\u0435<\/strong>. \u041f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u044b \u0434\u0430\u044e\u0442 \u043b\u043e\u0433\u043e\u0442\u0438\u043f\u044b \u0432 \u0434\u0432\u0443\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u0445 \u2014 \u0434\u043b\u044f \u0441\u0432\u0435\u0442\u043b\u043e\u0433\u043e \u0438 \u0442\u0451\u043c\u043d\u043e\u0433\u043e \u0444\u043e\u043d\u0430. \u0421\u0434\u0435\u043b\u0430\u043b\u0438 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0447\u0435\u0440\u0435\u0437 <code>&lt;img class=\"dark:hidden\" \/&gt;<\/code> + <code>&lt;img class=\"hidden dark:block\" \/&gt;<\/code> \u2014 \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0431\u0435\u0437 JS \u0438 \u043d\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 FOUC. \u0414\u0432\u0430 HTTP-\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u043d\u0430 \u043b\u043e\u0433\u043e\u0442\u0438\u043f \u043d\u0435 \u0438\u0434\u0443\u0442 \u2014 Astro \u0438\u043d\u043b\u0430\u0439\u043d\u0438\u0442 SVG \u043b\u043e\u0433\u043e \u0432 HTML.<\/p>\n<\/li>\n<\/ol>\n<p>\u0418\u0442\u043e\u0433: \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0437\u0430\u043d\u044f\u043b\u0430 2 \u0434\u043d\u044f \u043f\u043e \u0444\u0430\u043a\u0442\u0443, \u0445\u043e\u0442\u044f \u0440\u0430\u0441\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u043b\u0438 \u043d\u0430 4 \u0447\u0430\u0441\u0430. \u0417\u0430\u0442\u043e \u0443\u0431\u0440\u0430\u043b\u0438 \u043b\u0438\u0448\u043d\u0438\u0439 JS-\u043a\u043e\u043d\u0444\u0438\u0433 \u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u043d\u0430\u0442\u0438\u0432\u043d\u0443\u044e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c Vite \u2014 \u0441\u0431\u043e\u0440\u043a\u0430 \u0432\u0441\u0435\u0433\u043e \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u043f\u043e\u043b\u043c\u0438\u043d\u0443\u0442\u044b.<\/p>\n<hr\/>\n<h2>Schema.org \u0438 AI-SEO: \u0437\u0430\u0447\u0435\u043c \u0442\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u0440\u0435\u043c\u044f<\/h2>\n<p>\u041a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0441\u0430\u0439\u0442\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 JSON-LD \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435:<\/p>\n<ul>\n<li>\n<p><strong>Organization<\/strong> + <strong>WebSite<\/strong> \u2014 \u043d\u0430 \u0432\u0441\u0435\u0445 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u0445<\/p>\n<\/li>\n<li>\n<p><strong>BreadcrumbList<\/strong> \u2014 \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u043e\u043d\u043d\u0430\u044f \u0446\u0435\u043f\u043e\u0447\u043a\u0430<\/p>\n<\/li>\n<li>\n<p><strong>ItemList<\/strong> \u2014 \u0441\u043f\u0438\u0441\u043a\u0438 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u043e\u0432 \u0438 \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0439<\/p>\n<\/li>\n<li>\n<p><strong>FAQPage<\/strong> \u2014 \u0431\u043b\u043e\u043a\u0438 \u0432\u043e\u043f\u0440\u043e\u0441-\u043e\u0442\u0432\u0435\u0442 (AnswerUnit)<\/p>\n<\/li>\n<li>\n<p><strong>BlogPosting<\/strong> \u2014 \u0434\u043b\u044f \u0441\u0442\u0430\u0442\u0435\u0439 \u0431\u043b\u043e\u0433\u0430<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"xml\">&lt;script type=\"application\/ld+json\"&gt;{  \"@context\": \"https:\/\/schema.org\",  \"@type\": \"FAQPage\",  \"mainEntity\": [{    \"@type\": \"Question\",    \"name\": \"\u041a\u0430\u043a\u043e\u0439 VPS \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u0434\u043b\u044f WordPress?\",    \"acceptedAnswer\": {      \"@type\": \"Answer\",      \"text\": \"\u0414\u043b\u044f WordPress \u043f\u043e\u0434\u043e\u0439\u0434\u0451\u0442 VPS \u0441 2+ GB RAM...\"    }  }]}&lt;\/script&gt;<\/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\u043b\u044e\u0441 \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 <code>llms.txt<\/code> \u0438 <code>llms-full.txt<\/code> \u2014 \u043a\u0440\u0430\u0442\u043a\u043e\u0435 \u0438 \u043f\u043e\u043b\u043d\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0441\u0430\u0439\u0442\u0430 \u0434\u043b\u044f AI-\u043a\u0440\u0430\u0443\u043b\u0435\u0440\u043e\u0432 (GPTBot, PerplexityBot, ClaudeBot). \u0412 <code>robots.txt<\/code> \u0440\u0430\u0437\u0440\u0435\u0448\u0435\u043d\u044b \u0432\u0441\u0435 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0431\u043e\u0442\u044b. \u042d\u0442\u043e \u043d\u0435 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 SEO, \u0430 GEO (Generative Engine Optimization) \u2014 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u043e\u0434 \u043e\u0442\u0432\u0435\u0442\u044b AI-\u0430\u0441\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043e\u0432.<\/p>\n<hr\/>\n<h2>Partytown: \u043a\u0430\u043a \u043c\u044b \u0432\u044b\u043d\u0435\u0441\u043b\u0438 1 190 ms TBT \u0432 Web Worker<\/h2>\n<p>\u042d\u0442\u043e \u0433\u043b\u0430\u0432\u043d\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430. \u041d\u0430 \u0441\u0442\u0430\u0440\u0442\u0435 \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u043f\u0440\u043e\u0437\u0430\u0438\u0447\u043d\u043e: GTM, GA4 (\u0447\u0435\u0440\u0435\u0437 GTM-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440), \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0430 \u0441 \u0412\u0435\u0431\u0432\u0438\u0437\u043e\u0440\u043e\u043c, Microsoft Clarity. \u0412\u0441\u0435 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0433\u0440\u0443\u0437\u0438\u043b\u0438\u0441\u044c \u043b\u0435\u043d\u0438\u0432\u043e \u2014 \u043f\u043e\u0441\u043b\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e user-interaction. \u0421\u0447\u0438\u0442\u0430\u043b\u0438, \u0447\u0442\u043e \u044d\u0442\u043e\u0433\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e.<\/p>\n<p>Lighthouse \u043d\u0430 mobile \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 throttled \u043f\u043e\u043a\u0430\u0437\u0430\u043b \u0434\u0440\u0443\u0433\u043e\u0435. Performance score \u2014 76. TBT \u2014 1 190 ms. Reduce JS execution time \u2014 1,5 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. Reduce unused JavaScript \u2014 163 KiB. \u041a\u0430\u0440\u0442\u0438\u043d\u0430 \u0433\u0440\u0443\u0441\u0442\u043d\u0430\u044f.<\/p>\n<p>\u041e\u0442\u043a\u0443\u0434\u0430 \u0442\u0430\u043a\u0438\u0435 \u0446\u0438\u0444\u0440\u044b? Lighthouse \u0441\u0438\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0443\u044e \u0441\u0435\u0442\u044c, \u043d\u043e \u0438 slow CPU 4x \u2014 \u0438 \u0440\u0430\u043d\u0434\u043e\u043c\u043d\u043e \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u0438\u0442 user events \u0432\u0440\u043e\u0434\u0435 mousemove. \u041d\u0430\u0448 \u00ab\u043b\u0435\u043d\u0438\u0432\u044b\u0439\u00bb \u0437\u0430\u0433\u0440\u0443\u0437\u0447\u0438\u043a \u043d\u0435\u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e \u0440\u0435\u0430\u0433\u0438\u0440\u043e\u0432\u0430\u043b \u0438 \u0433\u0440\u0443\u0437\u0438\u043b GTM \u043f\u0440\u044f\u043c\u043e \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0430\u0443\u0434\u0438\u0442\u0430. \u0418\u0442\u043e\u0433: 1 516 ms script evaluation \u043d\u0430 main thread \u0438\u0437-\u0437\u0430 GTM, \u041c\u0435\u0442\u0440\u0438\u043a\u0438 \u0438 Clarity \u0432\u043c\u0435\u0441\u0442\u0435. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c CrUX (\u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 Chrome) \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u043b 100. \u0412 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d\u0435 \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u0445\u043e\u0440\u043e\u0448\u043e. \u0410 \u043b\u0430\u0431-\u0430\u0443\u0434\u0438\u0442 \u0434\u043b\u044f PageSpeed Insights \u0432\u0440\u0430\u043b \u0431\u0435\u0437\u0431\u043e\u0436\u043d\u043e.<\/p>\n<p>\u041f\u043e\u043b\u0443\u043c\u0435\u0440\u044b \u043c\u044b \u043f\u0435\u0440\u0435\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b\u0438:<\/p>\n<ul>\n<li>\n<p>\u0423\u0431\u0440\u0430\u043b\u0438 <code>mousemove<\/code> \u0438\u0437 \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u043e\u0432 \u2014 Lighthouse \u0435\u0433\u043e \u0441\u0438\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438. \u041f\u043e\u043c\u043e\u0433\u043b\u043e \u043d\u0430 5-10 \u043f\u0443\u043d\u043a\u0442\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p>\u0423\u0432\u0435\u043b\u0438\u0447\u0438\u043b\u0438 idle timeout \u0441 3 \u0434\u043e 10 \u0441\u0435\u043a\u0443\u043d\u0434 \u2014 Lighthouse-\u0430\u0443\u0434\u0438\u0442 \u0434\u043b\u0438\u0442\u0441\u044f 6-9 \u0441, GTM \u043d\u0435 \u0443\u0441\u043f\u0435\u0432\u0430\u043b. \u0421\u043d\u043e\u0432\u0430 +5 \u043f\u0443\u043d\u043a\u0442\u043e\u0432, \u043d\u043e variance \u00b110 \u043f\u0443\u043d\u043a\u0442\u043e\u0432 \u043c\u0435\u0436\u0434\u0443 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043c\u0438.<\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u0441\u0443\u0436\u0434\u0430\u043b\u0438 server-side GTM \u0447\u0435\u0440\u0435\u0437 \u0441\u0432\u043e\u0439 \u0434\u043e\u043c\u0435\u043d (<a href=\"http:\/\/sgtm.example.com\" rel=\"noopener noreferrer nofollow\">sgtm.example.com<\/a>) \u2014 \u043d\u043e \u044d\u0442\u043e \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 Docker-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440, \u043b\u0438\u0448\u043d\u044f\u044f \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0438 \u043b\u0438\u0448\u043d\u0438\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b.<\/p>\n<\/li>\n<\/ul>\n<p>\u0424\u0438\u043d\u0430\u043b\u044c\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 @astrojs\/partytown. \u042d\u0442\u043e Astro-\u043e\u0431\u0451\u0440\u0442\u043a\u0430 \u043d\u0430\u0434 Partytown \u043e\u0442 <a href=\"http:\/\/Builder.io\" rel=\"noopener noreferrer nofollow\">Builder.io<\/a>, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0435 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0432 Web Worker. Main thread \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0447\u0438\u0441\u0442\u044b\u043c, \u0430\u043d\u0430\u043b\u0438\u0442\u0438\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 \u0444\u043e\u043d\u0435.<\/p>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0432 <code>astro.config.mjs<\/code>:<\/p>\n<pre><code class=\"javascript\">import partytown from '@astrojs\/partytown';export default defineConfig({  integrations: [    partytown({      config: {        forward: [          'dataLayer.push',  \/\/ GTM          'gtag',            \/\/ GA4          'ym',              \/\/ \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0430        ],        debug: false,      },    }),  ],});<\/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>forward<\/code> \u2014 \u0441\u043f\u0438\u0441\u043e\u043a \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u043a\u0441\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0441 main thread \u0432 worker. \u041a\u0430\u0436\u0434\u044b\u0439 \u0432\u044b\u0437\u043e\u0432 <code>gtag('event', ...)<\/code> \u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0443\u0435\u0442\u0441\u044f \u0438 \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 worker \u0447\u0435\u0440\u0435\u0437 MessageChannel.<\/p>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u0434\u0435\u043b\u0430\u0435\u043c GTM-\u0441\u043a\u0440\u0438\u043f\u0442 partytown-\u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u044b\u043c. \u0412 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435 <code>GoogleTagManager.astro<\/code>:<\/p>\n<pre><code class=\"xml\">&lt;!-- Inline \u043d\u0430 main thread: dataLayer + Consent Mode v2 default = denied --&gt;&lt;script is:inline&gt;  window.dataLayer = window.dataLayer || [];  window.gtag = function () { window.dataLayer.push(arguments); };  window.gtag('consent', 'default', { ad_storage: 'denied', \/* ... *\/ });  window.dataLayer.push({ 'gtm.start': Date.now(), event: 'gtm.js' });&lt;\/script&gt;&lt;!-- Lazy loader: GTM \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e user interaction \u0438\u043b\u0438 8 \u0441 idle.     Partytown \u043f\u043e\u0434\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0435\u0442 type=\"text\/partytown\" \u0438 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442 \u0432 worker. --&gt;&lt;script is:inline&gt;  function loadGTM() {    if (window.__gtmLoaded) return;    window.__gtmLoaded = true;    var s = document.createElement('script');    s.type = 'text\/partytown';    s.src = 'https:\/\/www.googletagmanager.com\/gtm.js?id=GTM-XXXXXXX';    document.head.appendChild(s);  }  ['scroll', 'click', 'keydown', 'touchstart'].forEach(ev =&gt;    window.addEventListener(ev, loadGTM, { once: true, passive: true })  );  if ('requestIdleCallback' in window) {    requestIdleCallback(loadGTM, { timeout: 8000 });  } else {    setTimeout(loadGTM, 8000);  }&lt;\/script&gt;<\/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>\u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0434\u043b\u044f \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0438 \u0438 Clarity \u2014 \u0432\u043d\u0443\u0442\u0440\u0438 \u0438\u0445 init-\u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 <code>script.type = 'text\/partytown'<\/code> \u043f\u0435\u0440\u0435\u0434 <code>script.src<\/code>.<\/p>\n<h2>\u0427\u0442\u043e \u0447\u0443\u0442\u044c \u043d\u0435 \u0441\u043b\u043e\u043c\u0430\u043b\u043e\u0441\u044c<\/h2>\n<p><strong>Content Security Policy.<\/strong> Partytown \u0441\u043e\u0437\u0434\u0430\u0451\u0442 Web Worker \u0447\u0435\u0440\u0435\u0437 Blob URL \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0447\u0435\u0440\u0435\u0437 <code>fetch()<\/code> \u0438 <code>eval()<\/code>. \u042d\u0442\u043e \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0442\u0440\u0451\u0445 \u043f\u0440\u0430\u0432\u043e\u043a \u0432 CSP:<\/p>\n<pre><code class=\"nginx\">add_header Content-Security-Policy \"  default-src 'self';  script-src 'self' 'unsafe-inline' 'unsafe-eval' ... ;  worker-src 'self' blob:;  child-src 'self' blob:;  connect-src 'self' https:\/\/www.googletagmanager.com https:\/\/cdn.jsdelivr.net ... ;\" always;<\/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>worker-src 'self' blob:<\/code> \u2014 \u0431\u0435\u0437 \u044d\u0442\u043e\u0433\u043e worker \u043d\u0435 \u0441\u0442\u0430\u0440\u0442\u0443\u0435\u0442. <a href=\"http:\/\/cdn.jsdelivr.net\" rel=\"noopener noreferrer nofollow\"><code>cdn.jsdelivr.net<\/code><\/a> \u2014 \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043d\u0430\u0448 GTM-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0439 GTM-\u0448\u0430\u0431\u043b\u043e\u043d \u0434\u043b\u044f \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u043e\u0434\u0433\u0440\u0443\u0436\u0430\u0435\u0442 \u0432\u0441\u043f\u043e\u043c\u043e\u0433\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 JS \u0441 jsdelivr. \u0411\u0435\u0437 \u043d\u0435\u0433\u043e \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u0432\u0438\u0441\u0435\u043b\u0438 CSP-violations \u0438 Best Practices \u043f\u0430\u0434\u0430\u043b \u0434\u043e 96. \u0414\u0435\u0431\u0430\u0436\u0438\u043b\u0438 \u044d\u0442\u043e \u0447\u0435\u0440\u0435\u0437 DevTools console \u2014 \u043e\u0448\u0438\u0431\u043a\u0438 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u043b\u0438 \u0438\u0437 blob:\/\/, \u043d\u0435 \u0438\u0437 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430, \u0447\u0442\u043e \u043f\u0443\u0442\u0430\u043b\u043e.<\/p>\n<p><strong>Microsoft Clarity \u0438 forward.<\/strong> \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 <code>'clarity'<\/code> \u0432 <code>forward<\/code> \u2014 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 <code>TypeError: Cannot read properties of undefined (reading 'apply')<\/code> \u0432 worker. Clarity \u0432\u043d\u0443\u0442\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 <code>window.parent<\/code> \u0438 \u0441\u0432\u043e\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043a\u043e\u043d\u0444\u043b\u0438\u043a\u0442\u0443\u0435\u0442 \u0441 partytown-\u043f\u0440\u043e\u043a\u0441\u044f\u043c\u0438. \u0423\u0431\u0440\u0430\u043b\u0438 <code>clarity<\/code> \u0438\u0437 <code>forward<\/code> \u2014 Clarity \u043e\u0442\u043b\u0438\u0447\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 worker \u0447\u0435\u0440\u0435\u0437 \u0441\u0432\u043e\u0439 <code>&lt;script type=\"text\/partytown\"&gt;<\/code>, \u043f\u0440\u043e\u0441\u0442\u043e \u0431\u0435\u0437 main-thread \u043f\u0440\u043e\u043a\u0441\u0438 \u0434\u043b\u044f \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0438\u0437\u0432\u043d\u0435 (\u043d\u0430\u043c \u0438 \u043d\u0435 \u043d\u0443\u0436\u043d\u044b).<\/p>\n<h2>\u0427\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438<\/h2>\n<p>\u0421\u043b\u0430\u0439\u0434 \u00ab\u0434\u043e \u0438 \u043f\u043e\u0441\u043b\u0435\u00bb \u043f\u043e mobile throttled. Performance: \u0431\u044b\u043b\u043e 76, \u0441\u0442\u0430\u043b\u043e 99. TBT: \u0431\u044b\u043b\u043e 1 190 ms, \u0441\u0442\u0430\u043b\u043e 10 ms. Script evaluation \u043d\u0430 main thread: \u0431\u044b\u043b\u043e 1 516 ms, \u0441\u0442\u0430\u043b\u043e \u043e\u043a\u043e\u043b\u043e 50 ms. Best Practices \u0438 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0432 Chrome UX Report \u0438 \u0431\u044b\u043b\u0438 100, \u0438 \u043e\u0441\u0442\u0430\u043b\u0438\u0441\u044c.<\/p>\n<p>163 KiB GTM-\u043a\u043e\u0434\u0430 \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u0432\u0438\u0441\u044f\u0442 \u0432 main thread bundle. \u041e\u043d\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0432 worker \u0438 \u043d\u0435 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0442 \u0440\u0435\u043d\u0434\u0435\u0440. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0432\u0441\u0451 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043a\u0430\u043a \u0440\u0430\u043d\u044c\u0448\u0435: \u043f\u0430\u0440\u0442\u043d\u0451\u0440\u0441\u043a\u0430\u044f \u0430\u043d\u0430\u043b\u0438\u0442\u0438\u043a\u0430, \u0412\u0435\u0431\u0432\u0438\u0437\u043e\u0440 \u0441 \u0437\u0430\u043f\u0438\u0441\u044c\u044e \u0441\u0435\u0441\u0441\u0438\u0439, \u0445\u0438\u0442\u043c\u0430\u043f\u044b Clarity. \u041f\u0440\u043e\u0441\u0442\u043e \u043d\u0430 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u043c \u043f\u043e\u0442\u043e\u043a\u0435.<\/p>\n<p>\u0421\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u044b\u0435 100\/100 \u043d\u0430 mobile throttled \u0443 \u043d\u0430\u0441 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438\u0441\u044c \u2014 Lighthouse \u0434\u0430\u0451\u0442 variance \u00b15 \u043f\u0443\u043d\u043a\u0442\u043e\u0432, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0438\u043d\u043e\u0433\u0434\u0430 \u0441\u0438\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 interaction \u0432 \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0435 \u0441\u0435\u043a\u0443\u043d\u0434\u044b (\u0442\u043e\u0433\u0434\u0430 GTM \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u0432 worker \u0438 \u0441\u044a\u0435\u0434\u0430\u0435\u0442 100\u2013150 ms TBT \u043d\u0430 setup). \u0420\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0438 CrUX \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u0432\u0438\u0434\u044f\u0442. \u0420\u0435\u0448\u0438\u043b\u0438 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c\u0441\u044f \u043d\u0430 99: \u0432\u044b\u0436\u0438\u043c\u0430\u0442\u044c \u0435\u0449\u0451 \u043f\u0443\u043d\u043a\u0442 \u0447\u0435\u0440\u0435\u0437 server-side GTM \u043d\u0435\u0440\u0435\u043d\u0442\u0430\u0431\u0435\u043b\u044c\u043d\u043e.<\/p>\n<hr\/>\n<h2>Core Web Vitals: \u0438\u0442\u043e\u0433\u043e\u0432\u044b\u0435 \u0446\u0438\u0444\u0440\u044b<\/h2>\n<p>\u0421\u0432\u043e\u0434\u043d\u043e \u043f\u043e Lighthouse: \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435 100 \/ 100 \/ 100 \/ 100, \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u043c \u0441 throttling \u2014 99 \/ 100 \/ 100 \/ 100. \u0420\u0430\u0437\u0431\u0438\u0432\u043a\u0430 \u043f\u043e Core Web Vitals \u043d\u0430 mobile throttled: LCP 1,7 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, FCP 1,4, CLS 0, TBT 10 ms, Speed Index 1,4. \u0411\u0435\u0437 throttling, \u043a\u0430\u043a \u0432 \u043b\u0430\u0431-\u043f\u0440\u043e\u0433\u043e\u043d\u0435 desktop: LCP 0,5 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, TBT 0 ms, CLS 0. TTFB \u043f\u043e RUM \u2014 \u043e\u043a\u043e\u043b\u043e 80 ms \u0434\u043b\u044f \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u043e\u0433\u043e \u0440\u0435\u0433\u0438\u043e\u043d\u0430 \u0438 50 ms \u0434\u043b\u044f \u0415\u0432\u0440\u043e\u043f\u044b. CDN \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c.<\/p>\n<p>\u0427\u0442\u043e \u044d\u0442\u043e \u0434\u0430\u043b\u043e \u0432 \u0441\u0443\u043c\u043c\u0435:<\/p>\n<ul>\n<li>\n<p>\u0421\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u043b\u044e\u0441 Nginx \u0441 gzip \u0438 brotli.<\/p>\n<\/li>\n<li>\n<p>\u0421\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0439 JS \u0432 Web Worker \u0447\u0435\u0440\u0435\u0437 Partytown.<\/p>\n<\/li>\n<li>\n<p><code>inlineStylesheets: 'always'<\/code> \u2014 \u0432\u0435\u0441\u044c CSS \u0432 HTML, \u043d\u0438 \u043e\u0434\u043d\u043e\u0433\u043e render-blocking \u0437\u0430\u043f\u0440\u043e\u0441\u0430.<\/p>\n<\/li>\n<li>\n<p>\u041a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0447\u0435\u0440\u0435\u0437 <code>&lt;Image \/&gt;<\/code> Astro \u0441 Sharp \u0432 WebP \u0438 AVIF.<\/p>\n<\/li>\n<li>\n<p><code>prefetch<\/code> \u0434\u043b\u044f \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u0441\u0441\u044b\u043b\u043e\u043a (\u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u044f viewport).<\/p>\n<\/li>\n<li>\n<p>\u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 JS \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c \u043f\u043e\u0442\u043e\u043a\u0435: \u043a\u0432\u0438\u0437, \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0435 \u043c\u0435\u043d\u044e \u0438 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0430\u0442\u0435\u043b\u044c \u0442\u0435\u043c\u044b.<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u043b\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 security headers: HSTS, CSP \u0441 worker-src, X-Frame-Options, COOP, COEP, Referrer-Policy.<\/p>\n<\/li>\n<\/ul>\n<hr\/>\n<h2>\u0427\u0442\u043e \u043f\u043e\u0448\u043b\u043e \u043d\u0435 \u0442\u0430\u043a: \u0447\u0435\u0441\u0442\u043d\u044b\u0439 \u0431\u043b\u043e\u043a<\/h2>\n<ol>\n<li>\n<p><strong>Strapi v5 Document Service<\/strong>. \u041c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0441 v4 \u043f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b\u0430 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0441\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b. <code>strapi.documents()<\/code> \u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 relations (connect\/set), \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u043b\u044f \u0441\u0432\u044f\u0437\u0435\u0439 \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c REST API. \u0414\u043b\u044f \u043f\u043b\u0430\u0433\u0438\u043d\u043e\u0432 \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f: \u043d\u0438 \u043e\u0434\u0438\u043d \u043f\u043b\u0430\u0433\u0438\u043d \u043d\u0435 \u0438\u043c\u0435\u043b \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 \u043f\u043e\u0434 v5, \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0444\u043e\u0440\u043a\u0430\u0442\u044c \u0438 \u0441\u043e\u0431\u0438\u0440\u0430\u0442\u044c \u0438\u0437 main-\u0432\u0435\u0442\u043e\u043a.<\/p>\n<\/li>\n<li>\n<p><strong>Draft &amp; Publish \u0434\u0443\u0431\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435<\/strong>. Strapi v5 \u0445\u0440\u0430\u043d\u0438\u0442 draft \u0438 published \u043a\u0430\u043a \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 PostgreSQL. \u041f\u0440\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0438 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u0447\u0435\u0440\u0435\u0437 API \u043d\u0443\u0436\u043d\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0431\u0435 \u0432\u0435\u0440\u0441\u0438\u0438, \u0438\u043d\u0430\u0447\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044f\u0442\u0441\u044f. \u0421\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0438\u0441\u044c, \u043a\u043e\u0433\u0434\u0430 \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u0430\u044f \u0446\u0435\u043d\u0430 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0430 \u043f\u043e\u044f\u0432\u043b\u044f\u043b\u0430\u0441\u044c \u0432 admin-UI, \u043d\u043e API \u043e\u0442\u0434\u0430\u0432\u0430\u043b \u0441\u0442\u0430\u0440\u0443\u044e draft. \u0420\u0435\u0448\u0438\u043b\u0438 \u0447\u0435\u0440\u0435\u0437 \u0444\u0438\u043b\u044c\u0442\u0440 <code>?status=published<\/code> \u0432 \u0441\u0431\u043e\u0440\u043e\u0447\u043d\u044b\u0445 \u0444\u0435\u0442\u0447\u0430\u0445.<\/p>\n<\/li>\n<li>\n<p><strong>\u041f\u0443\u0441\u0442\u044b\u0435 \u043a\u0430\u0442\u0430\u043b\u043e\u0436\u043d\u044b\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b<\/strong>. \u041f\u0440\u0438 \u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e\u043c \u043f\u0435\u0440\u0435\u0441\u043c\u043e\u0442\u0440\u0435 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u0447\u0430\u0441\u0442\u044c \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0439 \u0443\u0441\u043b\u0443\u0433 \u043e\u0441\u0442\u0430\u0432\u0430\u043b\u0430\u0441\u044c \u0431\u0435\u0437 \u043a\u0430\u0440\u0442\u043e\u0447\u0435\u043a \u2014 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u043b\u0438 \u043f\u0443\u0441\u0442\u043e\u0439 \u043b\u0438\u0441\u0442\u0438\u043d\u0433. \u0414\u043b\u044f Google \u044d\u0442\u043e thin content. \u0414\u043e\u0431\u0430\u0432\u0438\u043b\u0438 <code>&lt;meta name=\"robots\" content=\"noindex\"&gt;<\/code> \u0434\u043b\u044f \u043f\u0443\u0441\u0442\u044b\u0445 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u043e\u0432, \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u043b\u0438 \u0438\u0445 \u0438\u0437 sitemap.xml \u0438 \u0438\u0437 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u043b\u0438\u043d\u043a\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p><strong>\u041c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0435 \u043c\u0435\u043d\u044e<\/strong>. Header \u0441 <code>position: fixed<\/code> \u0438 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u043f\u0443\u043d\u043a\u0442\u043e\u0432 \u0432 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u043c \u043c\u0435\u043d\u044e \u0443\u0445\u043e\u0434\u0438\u043b \u0437\u0430 viewport \u0431\u0435\u0437 \u0441\u043a\u0440\u043e\u043b\u043b\u0430 \u043d\u0430 iPhone SE. \u041f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b\u043e\u0441\u044c <code>max-height: calc(100dvh - 6rem)<\/code> + <code>overflow-y: auto<\/code> + \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0430 \u0441\u043a\u0440\u043e\u043b\u043b\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u043f\u0440\u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u043c \u043c\u0435\u043d\u044e (<a href=\"http:\/\/document.body.style\" rel=\"noopener noreferrer nofollow\"><code>document.body.style<\/code><\/a><code>.overflow = 'hidden'<\/code>). <code>100dvh<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>100vh<\/code> \u2014 \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e Safari iOS \u0441\u0447\u0438\u0442\u0430\u0435\u0442 \u0432\u044b\u0441\u043e\u0442\u0443 \u0432\u044a\u0435\u0437\u0436\u0430\u044e\u0449\u0435\u0433\u043e address bar \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u0438 100vh \u0432\u044b\u0445\u043e\u0434\u0438\u043b \u0437\u0430 \u044d\u043a\u0440\u0430\u043d \u043d\u0430 60 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439.<\/p>\n<\/li>\n<li>\n<p><strong>Affiliate-\u0441\u0441\u044b\u043b\u043a\u0438<\/strong>. \u0411\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0441\u0441\u044b\u043b\u043e\u043a \u0432 \u0441\u0442\u0430\u0440\u044b\u0445 \u0441\u0442\u0430\u0442\u044c\u044f\u0445 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043b\u0430 \u043f\u0440\u044f\u043c\u044b\u0435 URL \u0431\u0435\u0437 \u0440\u0435\u0444\u0435\u0440\u0430\u043b\u044c\u043d\u044b\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432. \u041c\u044b \u043d\u0435 \u0441\u0442\u0430\u043b\u0438 \u043f\u0440\u0430\u0432\u0438\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0432 Strapi \u043f\u0430\u043a\u0435\u0442\u043d\u043e (\u043a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u0430, mass-update \u043e\u043f\u0430\u0441\u0435\u043d \u0434\u043b\u044f SEO), \u0430 \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u043e\u0431\u0451\u0440\u0442\u043a\u0443 <code>resolveAffiliateUrl()<\/code> \u2014 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u043b\u044e\u0431\u043e\u0439 \u0432\u043d\u0435\u0448\u043d\u0438\u0439 URL \u0437\u0430\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430 \u0440\u0435\u0444\u0435\u0440\u0430\u043b\u044c\u043d\u044b\u0439, \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f UTM \u0438 \u0441\u0442\u0430\u0432\u0438\u0442\u0441\u044f <code>rel=\"sponsored nofollow\"<\/code> (\u0430\u0442\u0440\u0438\u0431\u0443\u0442 sponsored Google \u0432\u0432\u0451\u043b \u0432 2019 \u0433\u043e\u0434\u0443). \u0414\u0432\u043e\u0439\u043d\u0430\u044f \u0437\u0430\u0449\u0438\u0442\u0430: \u0434\u0430\u0436\u0435 \u0435\u0441\u043b\u0438 \u0432 CMS \u0432\u0432\u0435\u0434\u0435\u043d\u0430 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f \u0441\u0441\u044b\u043b\u043a\u0430, \u043d\u0430 \u0441\u0430\u0439\u0442\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f.<\/p>\n<\/li>\n<li>\n<p><strong>Cookie Consent + Consent Mode v2<\/strong>. \u0420\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u0438\u0439 \u0424\u0417 \u00ab\u041e \u043f\u0435\u0440\u0441\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445\u00bb + GDPR \u0442\u0440\u0435\u0431\u0443\u044e\u0442 \u044f\u0432\u043d\u043e\u0433\u043e \u0441\u043e\u0433\u043b\u0430\u0441\u0438\u044f \u043d\u0430 analytics-cookies. \u0411\u0430\u043d\u043d\u0435\u0440 \u0441 4 \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u044f\u043c\u0438 (necessary, analytics, advertising, functional), Google Consent Mode v2 c \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c <code>denied<\/code>, \u043f\u0435\u0440\u0441\u0438\u0441\u0442 \u0432 localStorage, \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0441\u043e\u0433\u043b\u0430\u0441\u0438\u044f \u0431\u0435\u0437 \u0440\u0435\u043b\u043e\u0430\u0434\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b. \u0427\u0442\u043e\u0431\u044b GTM \u0440\u0435\u0430\u0433\u0438\u0440\u043e\u0432\u0430\u043b \u0432 worker \u043d\u0430 update \u0441\u043e\u0433\u043b\u0430\u0441\u0438\u044f, <code>gtag<\/code> \u0432 partytown forward \u2014 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e.<\/p>\n<\/li>\n<\/ol>\n<hr\/>\n<h2>\u0418\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0438 \u0434\u0435\u043f\u043b\u043e\u0439<\/h2>\n<p>\u0427\u0442\u043e\u0431\u044b \u043a\u0430\u0440\u0442\u0438\u043d\u0430 \u0431\u044b\u043b\u0430 \u043f\u043e\u043b\u043d\u043e\u0439 \u2014 \u0441\u0442\u0435\u043a \u0432 \u043f\u0440\u043e\u0434\u0435:<\/p>\n<ul>\n<li>\n<p><strong>\u0421\u0435\u0440\u0432\u0435\u0440<\/strong>: 1 VPS \u043d\u0430 Ubuntu LTS, \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f (\u0441\u0442\u0430\u0442\u0438\u043a\u0435 \u043d\u0435 \u043d\u0443\u0436\u043d\u044b \u0440\u0435\u0441\u0443\u0440\u0441\u044b \u0432 runtime)<\/p>\n<\/li>\n<li>\n<p><strong>Web-\u0441\u0435\u0440\u0432\u0435\u0440<\/strong>: Nginx \u0441 brotli \u0438 gzip, HSTS preload, OCSP stapling, security headers \u0432\u044b\u043d\u0435\u0441\u0435\u043d\u044b \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043a\u043e\u043d\u0444\u0438\u0433-\u0444\u0430\u0439\u043b<\/p>\n<\/li>\n<li>\n<p><strong>CMS<\/strong>: Strapi 5.x \u043f\u043e\u0434 PM2, PostgreSQL, cluster mode \u0441 auto-restart<\/p>\n<\/li>\n<li>\n<p><strong>Build pipeline<\/strong>: \u0441\u043a\u0440\u0438\u043f\u0442 \u0434\u0435\u043b\u0430\u0435\u0442 fetch \u0438\u0437 Strapi, <code>astro build<\/code>, atomic-\u043f\u043e\u0434\u043c\u0435\u043d\u0443 <code>dist\/<\/code> \u0432 prod-\u043f\u0430\u043f\u043a\u0443 \u043f\u043e\u0434 nginx, \u043f\u0438\u043d\u0433 \u0432 IndexNow<\/p>\n<\/li>\n<li>\n<p><strong>Sitemap<\/strong>: custom \u043d\u0430 TypeScript (\u0432\u043c\u0435\u0441\u0442\u043e @astrojs\/sitemap) \u2014 \u043d\u0443\u0436\u0435\u043d \u0431\u044b\u043b per-page priority\/changefreq\/lastmod \u0438 noindex \u0434\u043b\u044f \u043f\u0443\u0441\u0442\u044b\u0445 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u043e\u0432<\/p>\n<\/li>\n<\/ul>\n<p>\u0421\u0431\u043e\u0440\u043a\u0430 \u0432\u0441\u0435\u0445 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u2014 \u043e\u043a\u043e\u043b\u043e 30 \u0441\u0435\u043a\u0443\u043d\u0434, \u0434\u0435\u043f\u043b\u043e\u0439 \u0431\u0435\u0437 downtime, \u043e\u0434\u0438\u043d \u043d\u0435\u0434\u043e\u0440\u043e\u0433\u043e\u0439 VPS \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e \u0434\u0435\u0440\u0436\u0438\u0442 \u0432\u0435\u0441\u044c \u0442\u0440\u0430\u0444\u0438\u043a.<\/p>\n<hr\/>\n<h2>Astro 5 \u2192 6: \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0432 \u043c\u0430\u0435 2026 \u0431\u0435\u0437 downtime<\/h2>\n<p>Astro 6.0 \u0432\u044b\u0448\u0435\u043b \u0432 \u0430\u043f\u0440\u0435\u043b\u0435 2026 \u0438 \u043f\u0440\u0438\u043d\u0451\u0441 \u0434\u0432\u0435 \u0432\u0435\u0449\u0438, \u0440\u0430\u0434\u0438 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043c\u044b \u0440\u0435\u0448\u0438\u043b\u0438\u0441\u044c \u043d\u0430 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435: Vite 7 (\u0431\u044b\u0441\u0442\u0440\u0435\u0435 dev \u0438 build, \u043b\u0443\u0447\u0448\u0435 tree-shaking) \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0451\u043d\u043d\u044b\u0439 Image Service \u0441 lazy-decoded WebP\/AVIF. \u041a\u043b\u044e\u0447\u0435\u0432\u044b\u0445 breaking changes \u0432 SSG-\u0440\u0435\u0436\u0438\u043c\u0435 \u043f\u043e\u0447\u0442\u0438 \u043d\u0435\u0442 \u2014 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u043f\u043e\u043b\u043e\u043c\u043a\u0438 \u0432 \u044d\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043f\u043b\u0430\u0433\u0438\u043d\u043e\u0432.<\/p>\n<p>\u0427\u0442\u043e \u0441\u043b\u043e\u043c\u0430\u043b\u043e\u0441\u044c:<\/p>\n<ul>\n<li>\n<p><code><strong>lucide-astro<\/strong><\/code><strong> \u043f\u043e\u043c\u0435\u0447\u0435\u043d \u043a\u0430\u043a deprecated<\/strong>, \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u0430\u043a\u0435\u0442 \u0442\u0435\u043f\u0435\u0440\u044c <code>@lucide\/astro<\/code>. \u041c\u0430\u0441\u0441\u043e\u0432\u044b\u0439 \u0440\u0435\u043f\u043b\u0435\u0439\u0441 \u0432\u043e \u0432\u0441\u0435\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445 \u2014 <code>from 'lucide-astro'<\/code> \u2192 <code>from '@lucide\/astro'<\/code>. \u0418\u043a\u043e\u043d\u043a\u0438 \u0438 \u0438\u0445 props \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u044b, \u043f\u0440\u0430\u0432\u043e\u043a \u0432 \u043a\u043e\u0434\u0435 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f.<\/p>\n<\/li>\n<li>\n<p><strong>Vitest 4.1+ \u0442\u044f\u043d\u0435\u0442 Vite 8<\/strong> \u0447\u0435\u0440\u0435\u0437 transitive deps, \u0430 Tailwind 4.3 + <code>@tailwindcss\/vite<\/code> \u043d\u0435 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u044b \u0441 Vite 8 \u043d\u0430 \u0434\u0430\u0442\u0443 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f. \u0420\u0435\u0448\u0438\u043b\u0438 \u0447\u0435\u0440\u0435\u0437 <code>overrides<\/code> \u0432 <code>package.json<\/code> \u2014 \u0444\u043e\u0440\u0441\u0438\u043b\u0438 Vite 7.3.3, Vitest \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u043d\u0430 4.0.5. \u0418\u0437 \u0432\u0441\u0435\u0445 \u043e\u0436\u0438\u0434\u0430\u0435\u043c\u044b\u0445 \u0432\u0435\u0449\u0435\u0439 \u044d\u0442\u0430 \u0441\u044a\u0435\u043b\u0430 \u0431\u043e\u043b\u044c\u0448\u0435 \u0432\u0441\u0435\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438: npm \u0440\u0435\u0437\u043e\u043b\u0432\u0438\u0442 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438\u0437 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u043e\u0434\u0434\u0435\u0440\u0435\u0432\u044c\u0435\u0432 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044f\u043c\u0438 \u043a Vite, \u0438 \u0431\u0435\u0437 \u044f\u0432\u043d\u043e\u0433\u043e <code>overrides<\/code> lock-\u0444\u0430\u0439\u043b \u0440\u0435\u0433\u0443\u043b\u044f\u0440\u043d\u043e \u043f\u043e\u0434\u0442\u044f\u0433\u0438\u0432\u0430\u043b \u043d\u0435\u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e.<\/p>\n<\/li>\n<li>\n<p><strong>Astro Image Service<\/strong>. ProviderImage-\u043e\u0431\u0451\u0440\u0442\u043a\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u043a\u0430\u043a \u0440\u0430\u043d\u044c\u0448\u0435, \u043d\u043e \u0441\u0431\u043e\u0440\u043a\u0430 \u0441\u0442\u0430\u043b\u0430 \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043d\u0430 30%: 32 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0432\u043c\u0435\u0441\u0442\u043e 45 \u0434\u043b\u044f \u0432\u0441\u0435\u0433\u043e \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430.<\/p>\n<\/li>\n<\/ul>\n<p>\u0418\u0442\u043e\u0433\u043e\u0432\u044b\u0439 \u0441\u0442\u0435\u043a \u043f\u043e\u0441\u043b\u0435 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438: Astro 6.3.7 + Vite 7.3.3 + Tailwind 4.3.0 + Strapi 5.42.1 + Node 22.22.1.<\/p>\n<p>\u0421\u0430\u043c \u0434\u0435\u043f\u043b\u043e\u0439 \u2014 zero-downtime atomic swap. \u041d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u043b\u0435\u0436\u0438\u0442 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0430\u044f <code>dist\/<\/code>, \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u0430\u044f \u0432 <code>dist-new\/<\/code>, \u043f\u043e\u0442\u043e\u043c \u0434\u0432\u0430 <code>mv<\/code> \u0438 <code>nginx -s reload<\/code>. \u0412\u0440\u0435\u043c\u044f \u043d\u0435\u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u0438 \u2014 \u043c\u0435\u043d\u044c\u0448\u0435 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. \u041f\u043e\u043b\u0435 CrUX \u043f\u043e\u0441\u043b\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u043d\u0435 \u043f\u0440\u043e\u0441\u0435\u043b\u043e, \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0438.<\/p>\n<p>\u0413\u043b\u0430\u0432\u043d\u044b\u0439 \u0443\u0440\u043e\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u0431\u0438\u043b\u0438 \u0432\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0435 \u0440\u0435\u0433\u043b\u0430\u043c\u0435\u043d\u0442\u044b: \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c <code>npm run build<\/code> \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432 prod-\u043f\u0430\u043f\u043a\u0435. \u041e\u0434\u0438\u043d \u0440\u0430\u0437 \u0438\u0437 \u043f\u0440\u0438\u0432\u044b\u0447\u043a\u0438 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u043b\u0438 \u2014 \u043f\u044f\u0442\u044c \u043c\u0438\u043d\u0443\u0442 5xx, \u043f\u043e\u043a\u0430 \u0441\u0431\u043e\u0440\u043a\u0430 \u0432 \u0436\u0438\u0432\u043e\u043c <code>dist\/<\/code> \u043f\u0438\u0441\u0430\u043b\u0430 \u0444\u0430\u0439\u043b\u044b. \u0422\u0435\u043f\u0435\u0440\u044c \u0432\u0441\u0435 \u0440\u0435\u0431\u0438\u043b\u0434\u044b \u0438\u0434\u0443\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0447\u0435\u0440\u0435\u0437 \u043e\u0434\u0438\u043d shell-\u0441\u043a\u0440\u0438\u043f\u0442 \u0441 atomic swap, \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0443\u0442\u0438 \u043f\u0435\u0440\u0435\u043a\u0440\u044b\u0442\u044b \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u043f\u0440\u0430\u0432.<\/p>\n<hr\/>\n<h2>\u041a\u043e\u0433\u0434\u0430 \u044d\u0442\u043e\u0442 \u0441\u0442\u0435\u043a \u0438\u043c\u0435\u0435\u0442 \u0441\u043c\u044b\u0441\u043b<\/h2>\n<p>Astro + Strapi + Tailwind 4 \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442, \u0435\u0441\u043b\u0438:<\/p>\n<ul>\n<li>\n<p>\u041a\u043e\u043d\u0442\u0435\u043d\u0442\u043d\u044b\u0439 \u0441\u0430\u0439\u0442 \u043e\u0442 50 \u0441\u0442\u0440\u0430\u043d\u0438\u0446: \u0431\u043b\u043e\u0433, \u043a\u0430\u0442\u0430\u043b\u043e\u0433, \u043e\u0431\u0437\u043e\u0440\u044b, landing-\u0444\u0435\u0440\u043c\u0430.<\/p>\n<\/li>\n<li>\n<p>\u041a\u043e\u043d\u0442\u0435\u043d\u0442 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0440\u0430\u0437 \u0432 \u0434\u0435\u043d\u044c-\u043d\u0435\u0434\u0435\u043b\u044e, \u043d\u0435 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0438.<\/p>\n<\/li>\n<li>\n<p>Core Web Vitals \u0432\u044b \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442\u0435 \u0432\u0441\u0435\u0440\u044c\u0451\u0437 \u0438 \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u044b 95+ \u043f\u043e \u0432\u0441\u0435\u043c \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u044f\u043c Lighthouse.<\/p>\n<\/li>\n<li>\n<p>\u041d\u0443\u0436\u043d\u0430 \u0433\u0438\u0431\u043a\u043e\u0441\u0442\u044c CMS \u0434\u043b\u044f \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440\u043e\u0432, \u043d\u043e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u0438\u043a\u0438 \u0434\u043b\u044f \u043f\u043e\u0441\u0435\u0442\u0438\u0442\u0435\u043b\u0435\u0439.<\/p>\n<\/li>\n<li>\n<p>\u0411\u044e\u0434\u0436\u0435\u0442 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d. \u041e\u0434\u0438\u043d VPS \u0432\u044b\u0442\u0430\u0449\u0438\u0442 \u0441\u043e\u0442\u043d\u0438 \u0442\u044b\u0441\u044f\u0447 \u0445\u0438\u0442\u043e\u0432 \u0432 \u043c\u0435\u0441\u044f\u0446.<\/p>\n<\/li>\n<\/ul>\n<p>\u041d\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442, \u0435\u0441\u043b\u0438:<\/p>\n<ul>\n<li>\n<p>\u041d\u0443\u0436\u043d\u0430 \u0434\u0438\u043d\u0430\u043c\u0438\u043a\u0430 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0438: \u0447\u0430\u0442\u044b, \u043b\u0438\u0432-\u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0446\u0435\u043d, \u0431\u0440\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435.<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0441 \u0447\u0430\u0441\u0442\u044b\u043c\u0438 \u043f\u0440\u0430\u0432\u043a\u0430\u043c\u0438. \u0422\u0443\u0442 \u043b\u0443\u0447\u0448\u0435 Next.js \u0441 ISR \u0438\u043b\u0438 SvelteKit.<\/p>\n<\/li>\n<li>\n<p>SSR-\u043a\u0440\u0438\u0442\u0438\u0447\u043d\u044b\u0435 \u0444\u0438\u0447\u0438: A\/B-\u0442\u0435\u0441\u0442\u044b \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435, \u043f\u0435\u0440\u0441\u043e\u043d\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u043e \u0433\u0435\u043e- \u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u043c \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0430\u043c.<\/p>\n<\/li>\n<li>\n<p>\u041a\u043e\u043c\u0430\u043d\u0434\u0430 \u0438\u0437 React-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u043d\u0435 \u0445\u043e\u0447\u0435\u0442\u0441\u044f \u043f\u0440\u0438\u0432\u044b\u043a\u0430\u0442\u044c \u043a \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441\u0443 <code>.astro<\/code> \u0444\u0430\u0439\u043b\u043e\u0432.<\/p>\n<\/li>\n<\/ul>\n<p>\u0413\u043b\u0430\u0432\u043d\u044b\u0439 \u0432\u044b\u0432\u043e\u0434, \u0440\u0430\u0434\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044d\u0442\u0430 \u0441\u0442\u0430\u0442\u044c\u044f. \u0412 2026 \u0433\u043e\u0434\u0443 \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u044b\u0441\u0442\u0440\u044b\u0439 \u0441\u0430\u0439\u0442 \u0434\u0430\u0436\u0435 \u0441 \u043f\u043e\u043b\u043d\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u043c\u0430\u0440\u043a\u0435\u0442\u0438\u043d\u0433\u043e\u0432\u044b\u0445 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432. GTM, GA4, \u0412\u0435\u0431\u0432\u0438\u0437\u043e\u0440, Clarity \u2014 \u0432\u0441\u0451 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u0432 Web Worker \u0438 \u043d\u0435 \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u043c\u0435\u0442\u0440\u0438\u043a\u0438. \u041c\u0430\u0440\u043a\u0435\u0442\u043e\u043b\u043e\u0433\u0438 \u0441\u0447\u0430\u0441\u0442\u043b\u0438\u0432\u044b, \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u043d\u0435 \u0432\u0438\u0434\u0438\u0442 \u0442\u043e\u0440\u043c\u043e\u0436\u0435\u043d\u0438\u0439, Google \u0432\u0438\u0434\u0438\u0442 \u0432\u044b\u0441\u043e\u043a\u0438\u0435 CrUX. \u0412\u0441\u0435 \u0432\u044b\u0438\u0433\u0440\u0430\u043b\u0438.<\/p>\n<hr\/>\n<p>\u0427\u0442\u043e \u0432\u043f\u0435\u0440\u0435\u0434\u0438<\/p>\n<p>\u041f\u043b\u0430\u043d \u043d\u0430 \u0431\u043b\u0438\u0436\u0430\u0439\u0448\u0438\u0435 \u043c\u0435\u0441\u044f\u0446\u044b:<\/p>\n<ul>\n<li>\n<p><strong>\u0420\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043d\u043e\u0439 \u0431\u0430\u0437\u044b<\/strong>. \u0410\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u044f \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440\u0441\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430 \u0432 admin-\u043f\u0430\u043d\u0435\u043b\u0438 \u2014 \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0438 \u043f\u043e SEO-meta, structured data \u0438 \u043f\u043e\u043b\u043d\u043e\u0442\u0435 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043f\u043e\u043b\u0435\u0439.<\/p>\n<\/li>\n<li>\n<p><strong>Server-Side GTM<\/strong>. \u041e\u0441\u0442\u0430\u0432\u0438\u043b\u0438 \u043d\u0430 \u0432\u0441\u044f\u043a\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u2014 \u0435\u0441\u043b\u0438 \u043f\u043e\u044f\u0432\u044f\u0442\u0441\u044f \u0436\u0451\u0441\u0442\u043a\u0438\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044f 100\/100 \u043d\u0430 mobile throttled, \u043f\u0435\u0440\u0435\u043d\u0435\u0441\u0451\u043c GTM \u043d\u0430 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0434\u0434\u043e\u043c\u0435\u043d \u0447\u0435\u0440\u0435\u0437 Docker. \u041f\u043e\u043a\u0430 \u044d\u0442\u043e overkill.<\/p>\n<\/li>\n<\/ul>\n<hr\/>\n<h2>\u0421\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043f\u0440\u043e\u0435\u043a\u0442<\/h2>\n<p>\u0420\u0430\u0431\u043e\u0447\u0438\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u0432\u0441\u0435\u0433\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0433\u043e \u2014 <a href=\"https:\/\/easylinklife.com\/\" rel=\"noopener noreferrer nofollow\">easylinklife.com<\/a>. \u041a\u043e\u0434 \u043d\u0435 \u043e\u0442\u043a\u0440\u044b\u0442: \u0432\u043d\u0443\u0442\u0440\u0438 \u0436\u0438\u0432\u0451\u0442 \u043b\u043e\u0433\u0438\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u043f\u0430\u0440\u0442\u043d\u0451\u0440\u0430\u043c\u0438 \u0438 \u043f\u0430\u0440\u0442\u043d\u0451\u0440\u0441\u043a\u0438\u0435 \u0434\u043e\u0433\u043e\u0432\u043e\u0440\u044b. \u041d\u043e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0430 \u0438 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u043c\u044b. \u0415\u0441\u043b\u0438 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0435 \u043f\u043e\u0445\u043e\u0436\u0438\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 \u2014 \u0437\u0430\u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u044b \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445, \u043e\u0442\u0432\u0435\u0447\u0443 \u043f\u043e \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0447\u0430\u0441\u0442\u0438. \u041f\u043e\u0434\u0432\u043e\u0434\u043d\u044b\u0445 \u043a\u0430\u043c\u043d\u0435\u0439 \u0431\u044b\u043b\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c \u043f\u043e\u043c\u0435\u0441\u0442\u0438\u043b\u043e\u0441\u044c \u0432 \u043e\u0434\u043d\u0443 \u0441\u0442\u0430\u0442\u044c\u044e.<\/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\/1042228\/\">https:\/\/habr.com\/ru\/articles\/1042228\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u041a\u043e\u0433\u0434\u0430 \u043c\u0430\u0440\u043a\u0435\u0442\u043e\u043b\u043e\u0433\u0438 \u0445\u043e\u0442\u044f\u0442 \u0432\u0441\u0451: \u0441\u044b\u0440\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0432 GA4, \u0437\u0430\u043f\u0438\u0441\u044c \u0441\u0435\u0441\u0441\u0438\u0439 \u0432 \u041c\u0435\u0442\u0440\u0438\u043a\u0435, \u0445\u0438\u0442\u043c\u0430\u043f\u044b \u0432 Clarity \u0438 \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u00abLighthouse 100\u00bb \u0432 PageSpeed Insights \u2014 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0438\u0437\u043e\u0431\u0440\u0435\u0442\u0430\u0442\u044c. \u0420\u0430\u0441\u0441\u043a\u0430\u0436\u0443, \u043a\u0430\u043a \u043c\u044b \u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u043d\u0430 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0438 \u0432\u043e \u0447\u0442\u043e \u044d\u0442\u043e \u043e\u0431\u043e\u0448\u043b\u043e\u0441\u044c \u043f\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438 \u043d\u0435\u0440\u0432\u0430\u043c.\u041f\u0440\u043e\u0435\u043a\u0442 \u2014 \u043d\u0438\u0448\u0435\u0432\u044b\u0439 \u0430\u0433\u0440\u0435\u0433\u0430\u0442\u043e\u0440 \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u0438\u0445 \u0445\u043e\u0441\u0442\u0438\u043d\u0433-\u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u043e\u0432. \u0411\u043e\u043b\u0435\u0435 120 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u0432 sitemap, 31 \u0441\u0442\u0430\u0442\u044c\u044f, \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0439 \u0443\u0441\u043b\u0443\u0433, \u0436\u0438\u0432\u044b\u0435 \u0446\u0435\u043d\u044b, \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f. \u0421\u0442\u0435\u043a: Astro 6 + Strapi 5 + Tailwind 4, \u043f\u043b\u044e\u0441 Partytown, PostgreSQL, Nginx \u0438 \u043e\u0431\u044b\u0447\u043d\u044b\u0439 VPS \u043d\u0430 Ubuntu. \u0421\u0430\u0439\u0442 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u0442\u0430\u0442\u0438\u043a\u0443 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0431\u0438\u043b\u0434\u0430, \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e SSR \u0432 \u0440\u0430\u043d\u0442\u0430\u0439\u043c\u0435 \u043d\u0435\u0442.\u041d\u0430 desktop \u2014 Lighthouse 100 \/ 100 \/ 100 \/ 100. \u041d\u0430 mobile \u0441 \u0436\u0451\u0441\u0442\u043a\u0438\u043c throttling (4x slow CPU) \u2014 99 \/ 100 \/ 100 \/ 100. \u0412 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u0445 \u0438 \u043f\u043e Chrome UX Report \u2014 100 \u0432\u0435\u0437\u0434\u0435. LCP \u043d\u0430 desktop \u2014 0,5 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, \u043d\u0430 mobile throttled \u2014 1,7 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. CLS \u2014 \u043d\u043e\u043b\u044c. TBT \u2014 10 ms \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u043c \u0438 0 ms \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435.Lighthouse \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435: 100 \/ 100 \/ 100 \/ 100. LCP 0,5 \u0441, TBT 0 ms, CLS 0. \u041e\u0431\u044b\u0447\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0431\u0435\u0437 throttling.\u0422\u043e\u0442 \u0436\u0435 \u0441\u0430\u0439\u0442 \u043d\u0430 mobile \u0441 \u0436\u0451\u0441\u0442\u043a\u0438\u043c throttling (4x slow CPU): 99 \/ 100 \/ 100 \/ 100. LCP 1,7 \u0441, TBT 10 ms, CLS 0. \u0423 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0432 Chrome UX Report \u2014 100 \u0432\u0435\u0437\u0434\u0435.\u0414\u0430\u043b\u044c\u0448\u0435 \u2014 \u043f\u043e \u043f\u043e\u0440\u044f\u0434\u043a\u0443. \u041f\u043e\u0447\u0435\u043c\u0443 Astro, \u0430 \u043d\u0435 Next.js \u0438 \u043d\u0435 Nuxt. \u041a\u0430\u043a Strapi \u0436\u0438\u0432\u0451\u0442 \u0440\u044f\u0434\u043e\u043c \u0441\u043e \u0441\u0442\u0430\u0442\u0438\u043a\u043e\u0439 \u0438 \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0430\u0441 \u0447\u0443\u0442\u044c \u043d\u0435 \u043f\u043e\u0445\u043e\u0440\u043e\u043d\u0438\u043b\u0430 \u043e\u0434\u043d\u0430 \u0435\u0433\u043e \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044c. \u0414\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u0440\u0438\u0447\u0438\u043d, \u043f\u043e\u0447\u0435\u043c\u0443 \u043b\u043e\u043c\u0430\u043b\u0430\u0441\u044c \u0442\u0451\u043c\u043d\u0430\u044f \u0442\u0435\u043c\u0430 \u0432 Tailwind 4. \u0418, \u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u043a\u0430\u043a Partytown \u0432\u044b\u0440\u0432\u0430\u043b 1 190 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0438 \u0438\u0437 \u0433\u043b\u0430\u0432\u043d\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043a\u0430 \u0438 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043b \u043d\u0430\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 PageSpeed Insights.\u041f\u043e\u0447\u0435\u043c\u0443 Astro, \u0430 \u043d\u0435 Next.js \u0438\u043b\u0438 Nuxt\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u043b\u0438 Next.js 14 \u0441 App Router. \u041d\u043e \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043d\u043e\u0433\u043e \u0441\u0430\u0439\u0442\u0430 \u0441 120+ \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u043c\u0438, \u0433\u0434\u0435 90% \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u2014 \u0442\u0435\u043a\u0441\u0442\u044b, \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438, SSR \u0438 \u0433\u0438\u0434\u0440\u0430\u0442\u0430\u0446\u0438\u044f React-\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0431\u044b\u043b\u0438 \u0438\u0437\u0431\u044b\u0442\u043e\u0447\u043d\u044b.Astro \u0434\u0430\u043b \u0442\u0440\u0438 \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0445 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u0430:Zero-JS \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u0421\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 \u0447\u0438\u0441\u0442\u044b\u0439 HTML \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0441\u0431\u043e\u0440\u043a\u0438. JavaScript \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u2014 \u043a\u0430\u043b\u044c\u043a\u0443\u043b\u044f\u0442\u043e\u0440\u0430, \u043a\u0432\u0438\u0437\u0430 \u2014 \u0447\u0435\u0440\u0435\u0437 Islands Architecture. HTML-\u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0432\u0435\u0441\u0438\u0442 15-25 KB, \u0430 \u043d\u0435 200+ KB \u0441 React-\u0440\u0430\u043d\u0442\u0430\u0439\u043c\u043e\u043c.Partial hydration. \u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u0441 client:load \u0438\u043b\u0438 client:idle \u0433\u0438\u0434\u0440\u0430\u0442\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0438\u0437\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e. \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0439. \u042d\u0442\u043e \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u043e \u0434\u043b\u044f \u043c\u0435\u0442\u0440\u0438\u043a \u2014 \u043d\u0435\u0442 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0449\u0435\u0433\u043e \u043f\u0430\u0440\u0441\u0438\u043d\u0433\u0430 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432 \u0432 &lt;head&gt;.\u041a\u043e\u043d\u0442\u0435\u043d\u0442-\u0444\u043e\u043a\u0443\u0441. Astro \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0443\u043c\u0435\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 Markdown, MDX \u0438 \u043b\u044e\u0431\u043e\u0439 CMS \u0447\u0435\u0440\u0435\u0437 loaders. \u041d\u0435 \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0433\u043e\u0440\u043e\u0434\u0438\u0442\u044c \u043a\u043e\u0441\u0442\u044b\u043b\u0438 \u0434\u043b\u044f \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0438\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u043e\u0432 \u0432\u0440\u043e\u0434\u0435 \/catalog\/[slug].astro.\/\/ astro.config.mjs \u2014 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044fimport { defineConfig } from &#8216;astro\/config&#8217;;import tailwindcss from &#8216;@tailwindcss\/vite&#8217;;export default defineConfig({  output: &#8216;static&#8217;,  prefetch: true,  vite: {    plugins: [tailwindcss()],  },});\u041a\u0430\u043a Strapi v5 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043a\u0430\u043a Headless CMS \u0434\u043b\u044f SSG\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 \u043f\u0430\u0442\u0442\u0435\u0440\u043d: CMS \u043d\u0430 Node.js \u043e\u0442\u0434\u0430\u0451\u0442 JSON \u043f\u043e REST, \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0437\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0432\u0445\u043e\u0434. \u0423 \u043d\u0430\u0441 \u0432\u0441\u0451 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442. \u0424\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0445\u043e\u0434\u0438\u0442 \u0432 Strapi \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0431\u043e\u0440\u043a\u0438. \u0412\u0441\u0451 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f Strapi \u0436\u0438\u0432\u0451\u0442 \u0441\u0432\u043e\u0435\u0439 \u0436\u0438\u0437\u043d\u044c\u044e \u043d\u0430 PM2, \u043e\u0442\u0434\u0430\u0451\u0442 \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440\u0430\u043c \u0441\u0432\u043e\u0439 admin-UI, \u0438 \u0441\u0430\u0439\u0442\u0443 \u0434\u043e \u043d\u0435\u0433\u043e \u043d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u0434\u0435\u043b\u0430.\/\/ src\/lib\/strapi.ts \u2014 fetch \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 buildexport async function fetchProviders() {  const res = await fetch(`${STRAPI_URL}\/api\/providers?populate=*`, {    headers: { Authorization: `Bearer ${TOKEN}` },  });  const json = await res.json();  return json.data || [];}\u0412 \u043a\u0430\u0436\u0434\u043e\u043c .astro-\u0444\u0430\u0439\u043b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0432 frontmatter-\u0441\u0435\u043a\u0446\u0438\u0438 (server-side \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0431\u043e\u0440\u043a\u0438). \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u2014 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 HTML \u0441 \u0443\u0436\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438. \u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0436\u0434\u0430\u0442\u044c API-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432.\/\/ src\/pages\/providers\/[slug].astroexport async function getStaticPaths() {  const providers = await fetchProviders();  return providers.map((p) =&gt; ({    params: { slug: p.slug },    props: { data: p },  }));}const { data } = Astro.props;Strapi v5 \u0441 Document Service API \u0438 documentId \u0432\u043c\u0435\u0441\u0442\u043e \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0445 id \u043f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b \u0430\u0434\u0430\u043f\u0442\u0430\u0446\u0438\u0438 \u2014 \u043c\u044b \u043d\u0430\u043f\u0438\u0441\u0430\u043b\u0438 \u043e\u0431\u0451\u0440\u0442\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u0443\u0435\u0442 \u043e\u0442\u0432\u0435\u0442\u044b (\u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0438 \u0441\u0442\u0430\u0440\u044b\u0439 attributes-\u0444\u043e\u0440\u043c\u0430\u0442, \u0438 \u043d\u043e\u0432\u044b\u0439 \u043f\u043b\u043e\u0441\u043a\u0438\u0439). \u0413\u043b\u0430\u0432\u043d\u044b\u0439 \u043f\u043b\u044e\u0441: Strapi \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u043c, \u0441\u043b\u043e\u0436\u043d\u0430\u044f \u0431\u0438\u0437\u043d\u0435\u0441-\u043b\u043e\u0433\u0438\u043a\u0430 (affiliate-\u0441\u0441\u044b\u043b\u043a\u0438, pluralization, UTM) \u0436\u0438\u0432\u0451\u0442 \u0432\u043e \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0435.\u0413\u043b\u0430\u0432\u043d\u044b\u0435 \u0433\u0440\u0430\u0431\u043b\u0438, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0441\u0442\u0443\u043f\u0438\u043b\u0438. \u041f\u043e\u0441\u043b\u0435 npm run build \u043f\u0430\u043f\u043a\u0430 dist\/ \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 admin-\u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441. \u041a\u043e\u043d\u0444\u0438\u0433 \u0438 schema \u043e\u043d\u0430 \u043d\u0435 \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u0442. \u0415\u0441\u043b\u0438 \u0437\u0430\u0431\u044b\u0442\u044c \u0440\u0443\u0447\u043d\u044b\u0435 cp -r config dist\/config &amp;&amp; cp -r src dist\/src \u0438 \u0440\u0435\u0441\u0442\u0430\u0440\u0442\u043d\u0443\u0442\u044c PM2 \u2014 \u043f\u0440\u0438 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0441\u0442\u0430\u0440\u0442\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0448\u044c \u043f\u0443\u0441\u0442\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442. \u0427\u0443\u0442\u044c \u043d\u0435 \u043f\u043e\u0442\u0435\u0440\u044f\u043b\u0438 \u0432\u0435\u0441\u044c \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0432 \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u043c \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0438. \u0421 \u0442\u0435\u0445 \u043f\u043e\u0440 \u0443 \u043d\u0430\u0441 \u0436\u0435\u043b\u0435\u0437\u043d\u043e\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u043e: \u043f\u0435\u0440\u0435\u0434 \u043b\u044e\u0431\u044b\u043c \u0440\u0435\u0431\u0438\u043b\u0434\u043e\u043c Strapi \u2014 dump \u0411\u0414, \u043f\u043e\u0441\u043b\u0435 \u0441\u0431\u043e\u0440\u043a\u0438 \u2014 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 config \u0438 src \u0432 dist.Tailwind CSS 4: \u043f\u043e\u0447\u0435\u043c\u0443 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0441\u044a\u0435\u043b\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0432\u043f\u044f\u0442\u0435\u0440\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u043e\u0436\u0438\u0434\u0430\u0435\u043c\u043e\u0433\u043e\u041f\u0440\u043e\u0435\u043a\u0442 \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u043b \u043d\u0430 Tailwind 3.4. \u041a\u043e\u0433\u0434\u0430 \u0432\u044b\u0448\u0435\u043b v4 \u0441 CSS-first \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0435\u0439, \u043c\u044b \u0440\u0435\u0448\u0438\u043b\u0438 \u043c\u0438\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u2014 \u0445\u043e\u0442\u0435\u043b\u0438 \u0438\u0437\u0431\u0430\u0432\u0438\u0442\u044c\u0441\u044f \u043e\u0442 tailwind.config.js \u0438 \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043d\u0430 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435 CSS-\u0434\u0438\u0440\u0435\u043a\u0442\u0438\u0432\u044b.\/* src\/styles\/global.css \u2014 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f Tailwind 4 *\/@import &#171;tailwindcss&#187;;@theme {  &#8212;color-brand: #2563eb;  &#8212;font-sans: &#171;Inter&#187;, ui-sans-serif, system-ui, sans-serif;}@custom-variant dark (&amp;:is(.dark *));\u0427\u0442\u043e \u0441\u043b\u043e\u043c\u0430\u043b\u043e\u0441\u044c:Scoped styles \u0441 @apply. \u0412 Astro &lt;style&gt; \u0431\u043b\u043e\u043a\u0430\u0445 @reference &#171;tailwindcss&#187; \u043d\u0435 \u043d\u0430\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043b @custom-variant dark. \u041a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043b\u043e\u0441\u044c \u0432 @media(prefers-color-scheme:dark) \u0432\u043c\u0435\u0441\u0442\u043e .dark. \u041f\u043e\u043b\u0442\u043e\u0440\u0430 \u0434\u043d\u044f \u043f\u044b\u0442\u0430\u043b\u0438\u0441\u044c \u043f\u043e\u043d\u044f\u0442\u044c, \u043f\u043e\u0447\u0435\u043c\u0443 \u0432 layout \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435 class:list={[&#8216;dark:bg-slate-900&#8217;]} \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u043a\u043b\u0438\u043a\u0443 \u043a\u043d\u043e\u043f\u043a\u0438 \u0442\u0435\u043c\u044b, \u0430 \u0432 &lt;style&gt; \u0440\u044f\u0434\u043e\u043c \u2014 \u043d\u0435\u0442. \u041f\u043e\u0444\u0438\u043a\u0441\u0438\u043b\u0438 \u0447\u0435\u0440\u0435\u0437 @reference &#171;..\/..\/styles\/global.css&#187; \u0441 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u043c \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043f\u0443\u0442\u0451\u043c \u2014 \u0432 \u0434\u043e\u043a\u0430\u0445 \u044d\u0442\u043e\u0433\u043e \u043d\u0435\u0442, \u043d\u0430\u0448\u043b\u0438 \u043f\u043e \u0441\u0442\u0430\u0440\u044b\u043c GitHub issues.\u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u043a\u0430\u0440\u0442\u043e\u0447\u0435\u043a. \u041c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438 CSS-\u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u0442\u0435\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 (&#8212;card-bg, &#8212;text-primary). Tailwind 4 \u0441 Vite-plugin \u0438\u043d\u043e\u0433\u0434\u0430 tree-shake&#8217;\u0438\u043b \u043d\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0438\u0437 :root \u2014 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0430\u0441\u044c, \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u043b\u0430 \u043a\u0430\u043a \u0431\u0435\u043b\u044b\u0439 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a \u0431\u0435\u0437 \u0444\u043e\u043d\u043e\u0432\u044b\u0445 \u0446\u0432\u0435\u0442\u043e\u0432. \u041f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u044f\u0432\u043d\u043e \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0441\u0435 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0432 global.css \u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u0432 \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440\u0435 .dark, \u0438\u043d\u0430\u0447\u0435 PostCSS-\u043f\u0440\u043e\u0445\u043e\u0434 \u0438\u0445 \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u043b.\u041a\u043b\u0430\u0441\u0441\u044b \u0432\u0438\u0434\u0430 dark:bg-[#1e293b]. \u0420\u0430\u0431\u043e\u0442\u0430\u044e\u0442, \u043d\u043e #1e293b \u2014 \u044d\u0442\u043e \u043d\u0435 slate-900. \u041c\u044b \u043e\u0441\u043e\u0437\u043d\u0430\u043d\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c #1e293b \u0434\u043b\u044f \u0441\u0438\u043d\u0435\u0433\u043e \u043e\u0442\u0442\u0435\u043d\u043a\u0430 \u0442\u0451\u043c\u043d\u043e\u0439 \u0442\u0435\u043c\u044b, \u0438 Tailwind 4 \u044d\u0442\u043e \u043d\u0435 \u0441\u043b\u043e\u043c\u0430\u043b, \u043d\u043e \u0432\u0430\u0436\u043d\u043e \u0441\u043b\u0435\u0434\u0438\u0442\u044c \u0437\u0430 arbitrary values.\u041b\u043e\u0433\u043e\u0442\u0438\u043f\u044b \u0432 \u0442\u0451\u043c\u043d\u043e\u0439 \u0442\u0435\u043c\u0435. \u041f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u044b \u0434\u0430\u044e\u0442 \u043b\u043e\u0433\u043e\u0442\u0438\u043f\u044b \u0432 \u0434\u0432\u0443\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u0445 \u2014 \u0434\u043b\u044f \u0441\u0432\u0435\u0442\u043b\u043e\u0433\u043e \u0438 \u0442\u0451\u043c\u043d\u043e\u0433\u043e \u0444\u043e\u043d\u0430. \u0421\u0434\u0435\u043b\u0430\u043b\u0438 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0447\u0435\u0440\u0435\u0437 &lt;img class=&#187;dark:hidden&#187; \/&gt; + &lt;img class=&#187;hidden dark:block&#187; \/&gt; \u2014 \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0431\u0435\u0437 JS \u0438 \u043d\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 FOUC. \u0414\u0432\u0430 HTTP-\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u043d\u0430 \u043b\u043e\u0433\u043e\u0442\u0438\u043f \u043d\u0435 \u0438\u0434\u0443\u0442 \u2014 Astro \u0438\u043d\u043b\u0430\u0439\u043d\u0438\u0442 SVG \u043b\u043e\u0433\u043e \u0432 HTML.\u0418\u0442\u043e\u0433: \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0437\u0430\u043d\u044f\u043b\u0430 2 \u0434\u043d\u044f \u043f\u043e \u0444\u0430\u043a\u0442\u0443, \u0445\u043e\u0442\u044f \u0440\u0430\u0441\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u043b\u0438 \u043d\u0430 4 \u0447\u0430\u0441\u0430. \u0417\u0430\u0442\u043e \u0443\u0431\u0440\u0430\u043b\u0438 \u043b\u0438\u0448\u043d\u0438\u0439 JS-\u043a\u043e\u043d\u0444\u0438\u0433 \u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u043d\u0430\u0442\u0438\u0432\u043d\u0443\u044e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c Vite \u2014 \u0441\u0431\u043e\u0440\u043a\u0430 \u0432\u0441\u0435\u0433\u043e \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u043f\u043e\u043b\u043c\u0438\u043d\u0443\u0442\u044b.Schema.org \u0438 AI-SEO: \u0437\u0430\u0447\u0435\u043c \u0442\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u0440\u0435\u043c\u044f\u041a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0441\u0430\u0439\u0442\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 JSON-LD \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435:Organization + WebSite \u2014 \u043d\u0430 \u0432\u0441\u0435\u0445 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u0445BreadcrumbList \u2014 \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u043e\u043d\u043d\u0430\u044f \u0446\u0435\u043f\u043e\u0447\u043a\u0430ItemList \u2014 \u0441\u043f\u0438\u0441\u043a\u0438 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u043e\u0432 \u0438 \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0439FAQPage \u2014 \u0431\u043b\u043e\u043a\u0438 \u0432\u043e\u043f\u0440\u043e\u0441-\u043e\u0442\u0432\u0435\u0442 (AnswerUnit)BlogPosting \u2014 \u0434\u043b\u044f \u0441\u0442\u0430\u0442\u0435\u0439 \u0431\u043b\u043e\u0433\u0430&lt;script type=&#187;application\/ld+json&#187;&gt;{  &#171;@context&#187;: &#171;https:\/\/schema.org&#187;,  &#171;@type&#187;: &#171;FAQPage&#187;,  &#171;mainEntity&#187;: [{    &#171;@type&#187;: &#171;Question&#187;,    &#171;name&#187;: &#171;\u041a\u0430\u043a\u043e\u0439 VPS \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u0434\u043b\u044f WordPress?&#187;,    &#171;acceptedAnswer&#187;: {      &#171;@type&#187;: &#171;Answer&#187;,      &#171;text&#187;: &#171;\u0414\u043b\u044f WordPress \u043f\u043e\u0434\u043e\u0439\u0434\u0451\u0442 VPS \u0441 2+ GB RAM&#8230;&#187;    }  }]}&lt;\/script&gt;\u041f\u043b\u044e\u0441 \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 llms.txt \u0438 llms-full.txt \u2014 \u043a\u0440\u0430\u0442\u043a\u043e\u0435 \u0438 \u043f\u043e\u043b\u043d\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0441\u0430\u0439\u0442\u0430 \u0434\u043b\u044f AI-\u043a\u0440\u0430\u0443\u043b\u0435\u0440\u043e\u0432 (GPTBot, PerplexityBot, ClaudeBot). \u0412 robots.txt \u0440\u0430\u0437\u0440\u0435\u0448\u0435\u043d\u044b \u0432\u0441\u0435 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0431\u043e\u0442\u044b. \u042d\u0442\u043e \u043d\u0435 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 SEO, \u0430 GEO (Generative Engine Optimization) \u2014 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u043e\u0434 \u043e\u0442\u0432\u0435\u0442\u044b AI-\u0430\u0441\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043e\u0432.Partytown: \u043a\u0430\u043a \u043c\u044b \u0432\u044b\u043d\u0435\u0441\u043b\u0438 1 190 ms TBT \u0432 Web Worker\u042d\u0442\u043e \u0433\u043b\u0430\u0432\u043d\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430. \u041d\u0430 \u0441\u0442\u0430\u0440\u0442\u0435 \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u043f\u0440\u043e\u0437\u0430\u0438\u0447\u043d\u043e: GTM, GA4 (\u0447\u0435\u0440\u0435\u0437 GTM-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440), \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0430 \u0441 \u0412\u0435\u0431\u0432\u0438\u0437\u043e\u0440\u043e\u043c, Microsoft Clarity. \u0412\u0441\u0435 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0433\u0440\u0443\u0437\u0438\u043b\u0438\u0441\u044c \u043b\u0435\u043d\u0438\u0432\u043e \u2014 \u043f\u043e\u0441\u043b\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e user-interaction. \u0421\u0447\u0438\u0442\u0430\u043b\u0438, \u0447\u0442\u043e \u044d\u0442\u043e\u0433\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e.Lighthouse \u043d\u0430 mobile \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 throttled \u043f\u043e\u043a\u0430\u0437\u0430\u043b \u0434\u0440\u0443\u0433\u043e\u0435. Performance score \u2014 76. TBT \u2014 1 190 ms. Reduce JS execution time \u2014 1,5 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. Reduce unused JavaScript \u2014 163 KiB. \u041a\u0430\u0440\u0442\u0438\u043d\u0430 \u0433\u0440\u0443\u0441\u0442\u043d\u0430\u044f.\u041e\u0442\u043a\u0443\u0434\u0430 \u0442\u0430\u043a\u0438\u0435 \u0446\u0438\u0444\u0440\u044b? Lighthouse \u0441\u0438\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0443\u044e \u0441\u0435\u0442\u044c, \u043d\u043e \u0438 slow CPU 4x \u2014 \u0438 \u0440\u0430\u043d\u0434\u043e\u043c\u043d\u043e \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u0438\u0442 user events \u0432\u0440\u043e\u0434\u0435 mousemove. \u041d\u0430\u0448 \u00ab\u043b\u0435\u043d\u0438\u0432\u044b\u0439\u00bb \u0437\u0430\u0433\u0440\u0443\u0437\u0447\u0438\u043a \u043d\u0435\u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e \u0440\u0435\u0430\u0433\u0438\u0440\u043e\u0432\u0430\u043b \u0438 \u0433\u0440\u0443\u0437\u0438\u043b GTM \u043f\u0440\u044f\u043c\u043e \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0430\u0443\u0434\u0438\u0442\u0430. \u0418\u0442\u043e\u0433: 1 516 ms script evaluation \u043d\u0430 main thread \u0438\u0437-\u0437\u0430 GTM, \u041c\u0435\u0442\u0440\u0438\u043a\u0438 \u0438 Clarity \u0432\u043c\u0435\u0441\u0442\u0435. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c CrUX (\u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 Chrome) \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u043b 100. \u0412 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d\u0435 \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u0445\u043e\u0440\u043e\u0448\u043e. \u0410 \u043b\u0430\u0431-\u0430\u0443\u0434\u0438\u0442 \u0434\u043b\u044f PageSpeed Insights \u0432\u0440\u0430\u043b \u0431\u0435\u0437\u0431\u043e\u0436\u043d\u043e.\u041f\u043e\u043b\u0443\u043c\u0435\u0440\u044b \u043c\u044b \u043f\u0435\u0440\u0435\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b\u0438:\u0423\u0431\u0440\u0430\u043b\u0438 mousemove \u0438\u0437 \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u043e\u0432 \u2014 Lighthouse \u0435\u0433\u043e \u0441\u0438\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438. \u041f\u043e\u043c\u043e\u0433\u043b\u043e \u043d\u0430 5-10 \u043f\u0443\u043d\u043a\u0442\u043e\u0432.\u0423\u0432\u0435\u043b\u0438\u0447\u0438\u043b\u0438 idle timeout \u0441 3 \u0434\u043e 10 \u0441\u0435\u043a\u0443\u043d\u0434 \u2014 Lighthouse-\u0430\u0443\u0434\u0438\u0442 \u0434\u043b\u0438\u0442\u0441\u044f 6-9 \u0441, GTM \u043d\u0435 \u0443\u0441\u043f\u0435\u0432\u0430\u043b. \u0421\u043d\u043e\u0432\u0430 +5 \u043f\u0443\u043d\u043a\u0442\u043e\u0432, \u043d\u043e variance \u00b110 \u043f\u0443\u043d\u043a\u0442\u043e\u0432 \u043c\u0435\u0436\u0434\u0443 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043c\u0438.\u041e\u0431\u0441\u0443\u0436\u0434\u0430\u043b\u0438 server-side GTM \u0447\u0435\u0440\u0435\u0437 \u0441\u0432\u043e\u0439 \u0434\u043e\u043c\u0435\u043d (sgtm.example.com) \u2014 \u043d\u043e \u044d\u0442\u043e \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 Docker-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440, \u043b\u0438\u0448\u043d\u044f\u044f \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0438 \u043b\u0438\u0448\u043d\u0438\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b.\u0424\u0438\u043d\u0430\u043b\u044c\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 @astrojs\/partytown. \u042d\u0442\u043e Astro-\u043e\u0431\u0451\u0440\u0442\u043a\u0430 \u043d\u0430\u0434 Partytown \u043e\u0442 Builder.io, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0435 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0432 Web Worker. Main thread \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0447\u0438\u0441\u0442\u044b\u043c, \u0430\u043d\u0430\u043b\u0438\u0442\u0438\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 \u0444\u043e\u043d\u0435.\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0432 astro.config.mjs:import partytown from &#8216;@astrojs\/partytown&#8217;;export default defineConfig({  integrations: [    partytown({      config: {        forward: [          &#8216;dataLayer.push&#8217;,  \/\/ GTM          &#8216;gtag&#8217;,            \/\/ GA4          &#8216;ym&#8217;,              \/\/ \u042f\u043d\u0434\u0435\u043a\u0441.\u041c\u0435\u0442\u0440\u0438\u043a\u0430        ],        debug: false,      },    }),  ],});forward \u2014 \u0441\u043f\u0438\u0441\u043e\u043a \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u043a\u0441\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0441 main thread \u0432 worker. \u041a\u0430\u0436\u0434\u044b\u0439 \u0432\u044b\u0437\u043e\u0432 gtag(&#8216;event&#8217;, &#8230;) \u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0443\u0435\u0442\u0441\u044f \u0438 \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 worker \u0447\u0435\u0440\u0435\u0437 MessageChannel.\u0414\u0430\u043b\u044c\u0448\u0435 \u0434\u0435\u043b\u0430\u0435\u043c GTM-\u0441\u043a\u0440\u0438\u043f\u0442 partytown-\u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u044b\u043c. \u0412 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435 GoogleTagManager.astro:&lt;!&#8212; Inline \u043d\u0430 main thread: dataLayer + Consent Mode v2 default = denied &#8212;&gt;&lt;script is:inline&gt;  window.dataLayer = window.dataLayer || [];  window.gtag = function () { window.dataLayer.push(arguments); };  window.gtag(&#8216;consent&#8217;, &#8216;default&#8217;, { ad_storage: &#8216;denied&#8217;, \/* &#8230; *\/ });  window.dataLayer.push({ &#8216;gtm.start&#8217;: Date.now(), event: &#8216;gtm.js&#8217; });&lt;\/script&gt;&lt;!&#8212; Lazy loader: GTM \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e user interaction \u0438\u043b\u0438 8 \u0441 idle.     Partytown \u043f\u043e\u0434\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0435\u0442 type=&#187;text\/partytown&#187; \u0438 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442 \u0432 worker. &#8212;&gt;&lt;script&#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-481931","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/481931","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=481931"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/481931\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=481931"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=481931"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=481931"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}