[{"data":1,"prerenderedAt":9709},["ShallowReactive",2],{"navigation_docs":3,"-tailwind-tailwind-cli-tooling":3338,"-tailwind-tailwind-cli-tooling-surround":9704},[4,1707,1904,2358,2539,2608,2815,2937,2987,3044,3078,3204,3281,3334],{"title":5,"icon":6,"path":7,"stem":8,"children":9},"C#","i-devicon-csharp","\u002Fcsharp","01.csharp",[10,13,60,90,120,202,219,253,379,404,457,650,1364,1654,1703],{"title":11,"path":7,"stem":12},"C# та .NET","01.csharp\u002Findex",{"title":14,"icon":15,"path":16,"stem":17,"children":18,"page":59},"Fundamentals","i-lucide-book-open","\u002Fcsharp\u002Ffundamentals","01.csharp\u002F01.fundamentals",[19,23,27,31,35,39,43,47,51,55],{"title":20,"path":21,"stem":22},"Вступ до екосистеми .NET","\u002Fcsharp\u002Ffundamentals\u002Fintroduction-to-ecosystem","01.csharp\u002F01.fundamentals\u002F01.introduction-to-ecosystem",{"title":24,"path":25,"stem":26},"Структура програми на C#","\u002Fcsharp\u002Ffundamentals\u002Fprogram-structure","01.csharp\u002F01.fundamentals\u002F02.program-structure",{"title":28,"path":29,"stem":30},"Змінні та Типи Даних","\u002Fcsharp\u002Ffundamentals\u002Fvariables-data-types","01.csharp\u002F01.fundamentals\u002F03.variables-data-types",{"title":32,"path":33,"stem":34},"Масиви","\u002Fcsharp\u002Ffundamentals\u002Farrays","01.csharp\u002F01.fundamentals\u002F04.arrays",{"title":36,"path":37,"stem":38},"Strings & Text Handling","\u002Fcsharp\u002Ffundamentals\u002Fstrings-text-handling","01.csharp\u002F01.fundamentals\u002F05.strings-text-handling",{"title":40,"path":41,"stem":42},"Дати і Час","\u002Fcsharp\u002Ffundamentals\u002Fdates-time-handling","01.csharp\u002F01.fundamentals\u002F06.dates-time-handling",{"title":44,"path":45,"stem":46},"Потік Керування","\u002Fcsharp\u002Ffundamentals\u002Fcontrol-flow","01.csharp\u002F01.fundamentals\u002F07.control-flow",{"title":48,"path":49,"stem":50},"Методи","\u002Fcsharp\u002Ffundamentals\u002Fmethods","01.csharp\u002F01.fundamentals\u002F08.methods",{"title":52,"path":53,"stem":54},"Основи Відлагодження","\u002Fcsharp\u002Ffundamentals\u002Fdebugging-basics","01.csharp\u002F01.fundamentals\u002F09.debugging-basics",{"title":56,"path":57,"stem":58},"Інтерактивна Консоль (Classic)","\u002Fcsharp\u002Ffundamentals\u002Finteractive-console","01.csharp\u002F01.fundamentals\u002F10.interactive-console",false,{"title":61,"icon":62,"path":63,"stem":64,"children":65,"page":59},"OOP","i-lucide-box","\u002Fcsharp\u002Foop","01.csharp\u002F02.oop",[66,70,74,78,82,86],{"title":67,"path":68,"stem":69},"Package Management (Управління Пакетами)","\u002Fcsharp\u002Foop\u002Fpackage-management","01.csharp\u002F02.oop\u002F01.package-management",{"title":71,"path":72,"stem":73},"Класи та Об'єкти","\u002Fcsharp\u002Foop\u002Fclasses-objects","01.csharp\u002F02.oop\u002F02.classes-objects",{"title":75,"path":76,"stem":77},"Властивості та Поля","\u002Fcsharp\u002Foop\u002Fproperties-fields","01.csharp\u002F02.oop\u002F03.properties-fields",{"title":79,"path":80,"stem":81},"Стовпи ООП","\u002Fcsharp\u002Foop\u002Foop-pillars","01.csharp\u002F02.oop\u002F04.oop-pillars",{"title":83,"path":84,"stem":85},"Advanced Types","\u002Fcsharp\u002Foop\u002Fadvanced-types","01.csharp\u002F02.oop\u002F05.advanced-types",{"title":87,"path":88,"stem":89},"Namespaces (Простори Імен)","\u002Fcsharp\u002Foop\u002Fnamespaces","01.csharp\u002F02.oop\u002F06.namespaces",{"title":91,"icon":92,"path":93,"stem":94,"children":95,"page":59},"Advanced Core","i-lucide-zap","\u002Fcsharp\u002Fadvanced-core","01.csharp\u002F03.advanced-core",[96,100,104,108,112,116],{"title":97,"path":98,"stem":99},"Generics (Узагальнення)","\u002Fcsharp\u002Fadvanced-core\u002Fgenerics","01.csharp\u002F03.advanced-core\u002F01.generics",{"title":101,"path":102,"stem":103},"Делегати, Події та Лямбда-вирази","\u002Fcsharp\u002Fadvanced-core\u002Fdelegates-events-lambdas","01.csharp\u002F03.advanced-core\u002F02.delegates-events-lambdas",{"title":105,"path":106,"stem":107},"Interfaces Deep Dive (Інтерфейси: Поглиблений Розгляд)","\u002Fcsharp\u002Fadvanced-core\u002Finterfaces-deep-dive","01.csharp\u002F03.advanced-core\u002F03.interfaces-deep-dive",{"title":109,"path":110,"stem":111},"Обробка Винятків","\u002Fcsharp\u002Fadvanced-core\u002Fexception-handling","01.csharp\u002F03.advanced-core\u002F04.exception-handling",{"title":113,"path":114,"stem":115},"Pattern Matching","\u002Fcsharp\u002Fadvanced-core\u002Fpattern-matching","01.csharp\u002F03.advanced-core\u002F05.pattern-matching",{"title":117,"path":118,"stem":119},"Додаткові Можливості C#","\u002Fcsharp\u002Fadvanced-core\u002Fadditional-features","01.csharp\u002F03.advanced-core\u002F06.additional-features",{"title":121,"icon":122,"path":123,"stem":124,"children":125,"page":59},"Architecture Best Practices","i-lucide-building-2","\u002Fcsharp\u002Farchitecture-best-practices","01.csharp\u002F04.architecture-best-practices",[126,130,149,153,157,161,165,169],{"title":127,"path":128,"stem":129},"Software Design Principles (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fsoftware-design-principles","01.csharp\u002F04.architecture-best-practices\u002F01.software-design-principles",{"title":131,"icon":132,"path":133,"stem":134,"children":135,"page":59},"Design Patterns","i-lucide-folder","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns",[136],{"title":137,"icon":132,"path":138,"stem":139,"children":140,"page":59},"Creational","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational",[141,145],{"title":142,"path":143,"stem":144},"Singleton (Одинак)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fsingleton","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F01.singleton",{"title":146,"path":147,"stem":148},"Builder (Будівельник)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fbuilder","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F02.builder",{"title":150,"path":151,"stem":152},"Building Professional CLIs","\u002Fcsharp\u002Farchitecture-best-practices\u002Fbuilding-professional-clis","01.csharp\u002F04.architecture-best-practices\u002F03.building-professional-clis",{"title":154,"path":155,"stem":156},"Validation & Flow Control","\u002Fcsharp\u002Farchitecture-best-practices\u002Fvalidation-flow-control","01.csharp\u002F04.architecture-best-practices\u002F04.validation-flow-control",{"title":158,"path":159,"stem":160},"The Modern .NET Host (Microsoft.Extensions)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fmodern-dotnet-host","01.csharp\u002F04.architecture-best-practices\u002F05.modern-dotnet-host",{"title":162,"path":163,"stem":164},"Data Mapper: Repository та DAO патерни (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part1","01.csharp\u002F04.architecture-best-practices\u002F06.data-mapper-part1",{"title":166,"path":167,"stem":168},"Data Mapper: Repository та DAO патерни (Частина 2)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part2","01.csharp\u002F04.architecture-best-practices\u002F07.data-mapper-part2",{"title":170,"icon":132,"path":171,"stem":172,"children":173,"page":59},"Di Ioc","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc",[174,178,182,186,190,194,198],{"title":175,"path":176,"stem":177},"Проблема залежностей та Інверсія Контролю","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fthe-dependency-problem","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F01.the-dependency-problem",{"title":179,"path":180,"stem":181},"Будуємо власний Service Container","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fbuild-your-own-container","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F02.build-your-own-container",{"title":183,"path":184,"stem":185},"Service Locator: Паттерн та Анти-паттерн","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-locator-pattern","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F03.service-locator-pattern",{"title":187,"path":188,"stem":189},"Паттерни Dependency Injection","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdependency-injection-patterns","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F04.dependency-injection-patterns",{"title":191,"path":192,"stem":193},"Microsoft DI: IServiceCollection та IServiceProvider","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fmicrosoft-di-deep-dive","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F05.microsoft-di-deep-dive",{"title":195,"path":196,"stem":197},"Service Lifetimes та Scopes","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-lifetimes-and-scopes","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F06.service-lifetimes-and-scopes",{"title":199,"path":200,"stem":201},"DI Анти-паттерни та Найкращі Практики","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdi-anti-patterns-and-best-practices","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F07.di-anti-patterns-and-best-practices",{"title":203,"icon":132,"path":204,"stem":205,"children":206,"page":59},"Standard Library","\u002Fcsharp\u002Fstandard-library","01.csharp\u002F05.standard-library",[207,211,215],{"title":208,"path":209,"stem":210},"Collections (Колекції)","\u002Fcsharp\u002Fstandard-library\u002Fcollections","01.csharp\u002F05.standard-library\u002F01.collections",{"title":212,"path":213,"stem":214},"High Performance Types (Високопродуктивні Типи)","\u002Fcsharp\u002Fstandard-library\u002Fhigh-performance-types","01.csharp\u002F05.standard-library\u002F02.high-performance-types",{"title":216,"path":217,"stem":218},"LINQ (Language Integrated Query)","\u002Fcsharp\u002Fstandard-library\u002Flinq","01.csharp\u002F05.standard-library\u002F03.linq",{"title":220,"icon":221,"path":222,"stem":223,"children":224,"page":59},"System Internals Concurrency","i-lucide-server","\u002Fcsharp\u002Fsystem-internals-concurrency","01.csharp\u002F06.system-internals-concurrency",[225,229,233,237,241,245,249],{"title":226,"path":227,"stem":228},"Memory Management","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmemory-management","01.csharp\u002F06.system-internals-concurrency\u002F01.memory-management",{"title":230,"path":231,"stem":232},"Reflection API: System.Type та Метадані","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Freflection-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F02.reflection-fundamentals",{"title":234,"path":235,"stem":236},"Attributes та Dynamic Language Runtime","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fattributes-dynamic","01.csharp\u002F06.system-internals-concurrency\u002F03.attributes-dynamic",{"title":238,"path":239,"stem":240},"Expression Trees: Швидка Альтернатива Рефлексії","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fexpression-trees-compiled","01.csharp\u002F06.system-internals-concurrency\u002F04.expression-trees-compiled",{"title":242,"path":243,"stem":244},"Source Generators: Compile-Time Code Generation","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsource-generators","01.csharp\u002F06.system-internals-concurrency\u002F05.source-generators",{"title":246,"path":247,"stem":248},"Multithreading Fundamentals","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmultithreading-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F06.multithreading-fundamentals",{"title":250,"path":251,"stem":252},"Synchronization Primitives","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsynchronization-primitives","01.csharp\u002F06.system-internals-concurrency\u002F07.synchronization-primitives",{"title":254,"icon":255,"path":256,"stem":257,"children":258,"page":59},"System Programming Windows","i-lucide-cpu","\u002Fcsharp\u002Fsystem-programming-windows","01.csharp\u002F07.system-programming-windows",[259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327,331,335,339,343,347,351,355,359,363,367,371,375],{"title":260,"path":261,"stem":262},"Як Працює Операційна Система","\u002Fcsharp\u002Fsystem-programming-windows\u002Fhow-os-works","01.csharp\u002F07.system-programming-windows\u002F01.how-os-works",{"title":264,"path":265,"stem":266},"Процеси в .NET — API та Запуск","\u002Fcsharp\u002Fsystem-programming-windows\u002Fprocesses-in-dotnet","01.csharp\u002F07.system-programming-windows\u002F02.processes-in-dotnet",{"title":268,"path":269,"stem":270},"Процеси в .NET — IPC та Міжпроцесна Комунікація","\u002Fcsharp\u002Fsystem-programming-windows\u002F02a.processes-ipc","01.csharp\u002F07.system-programming-windows\u002F02a.processes-ipc",{"title":272,"path":273,"stem":274},"Application Domains та Збірки — AppDomain і AssemblyLoadContext","\u002Fcsharp\u002Fsystem-programming-windows\u002Fappdomains-assemblies","01.csharp\u002F07.system-programming-windows\u002F03.appdomains-assemblies",{"title":276,"path":277,"stem":278},"Application Domains та Збірки — Plug-in Система з Hot-Reload","\u002Fcsharp\u002Fsystem-programming-windows\u002F03a.appdomains-plugin-system","01.csharp\u002F07.system-programming-windows\u002F03a.appdomains-plugin-system",{"title":280,"path":281,"stem":282},"Потоки — Основи та API Thread","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-fundamentals","01.csharp\u002F07.system-programming-windows\u002F04.thread-fundamentals",{"title":284,"path":285,"stem":286},"Потоки — Lifecycle, Пріоритети та Безпечне Завершення","\u002Fcsharp\u002Fsystem-programming-windows\u002F04a.thread-lifecycle-priorities","01.csharp\u002F07.system-programming-windows\u002F04a.thread-lifecycle-priorities",{"title":288,"path":289,"stem":290},"Проблеми Спільного Стану — Race Condition та Data Race","\u002Fcsharp\u002Fsystem-programming-windows\u002Fshared-state-problems","01.csharp\u002F07.system-programming-windows\u002F05.shared-state-problems",{"title":292,"path":293,"stem":294},"Проблеми Спільного Стану — Memory Model та volatile","\u002Fcsharp\u002Fsystem-programming-windows\u002F05a.shared-state-memory-model","01.csharp\u002F07.system-programming-windows\u002F05a.shared-state-memory-model",{"title":296,"path":297,"stem":298},"Синхронізація — Monitor, lock та еволюція примітивів","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-fundamentals","01.csharp\u002F07.system-programming-windows\u002F06.synchronization-fundamentals",{"title":300,"path":301,"stem":302},"Синхронізація — Наскрізний Приклад та Deadlock Detection","\u002Fcsharp\u002Fsystem-programming-windows\u002F06a.synchronization-walkthrough","01.csharp\u002F07.system-programming-windows\u002F06a.synchronization-walkthrough",{"title":304,"path":305,"stem":306},"Синхронізація — Mutex, Semaphore та Event-Based Primitives","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-advanced","01.csharp\u002F07.system-programming-windows\u002F07.synchronization-advanced",{"title":308,"path":309,"stem":310},"Синхронізація — Interlocked, Volatile та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002F07a.synchronization-advanced-walkthrough","01.csharp\u002F07.system-programming-windows\u002F07a.synchronization-advanced-walkthrough",{"title":312,"path":313,"stem":314},"Interlocked, CAS та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002Finterlocked-cas-lockfree","01.csharp\u002F07.system-programming-windows\u002F08.interlocked-cas-lockfree",{"title":316,"path":317,"stem":318},"Volatile, Memory Model та Spinning","\u002Fcsharp\u002Fsystem-programming-windows\u002F08a.volatile-memory-model","01.csharp\u002F07.system-programming-windows\u002F08a.volatile-memory-model",{"title":320,"path":321,"stem":322},"ThreadPool — Пул Потоків для Ефективного Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-pool","01.csharp\u002F07.system-programming-windows\u002F09.thread-pool",{"title":324,"path":325,"stem":326},"ThreadPool — Просунуті Сценарії та Внутрішня Будова","\u002Fcsharp\u002Fsystem-programming-windows\u002F09a.thread-pool-advanced","01.csharp\u002F07.system-programming-windows\u002F09a.thread-pool-advanced",{"title":328,"path":329,"stem":330},"Concurrent та Immutable Collections","\u002Fcsharp\u002Fsystem-programming-windows\u002Fconcurrent-collections","01.csharp\u002F07.system-programming-windows\u002F10.concurrent-collections",{"title":332,"path":333,"stem":334},"TPL, Task та Композиція — Від Thread до Task","\u002Fcsharp\u002Fsystem-programming-windows\u002Ftpl-parallel-plinq","01.csharp\u002F07.system-programming-windows\u002F11.tpl-parallel-plinq",{"title":336,"path":337,"stem":338},"Parallel Class та PLINQ — Data Parallelism","\u002Fcsharp\u002Fsystem-programming-windows\u002F11a.tpl-parallel-plinq-advanced","01.csharp\u002F07.system-programming-windows\u002F11a.tpl-parallel-plinq-advanced",{"title":340,"path":341,"stem":342},"Async\u002FAwait — Фундамент Асинхронного Програмування","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-fundamentals","01.csharp\u002F07.system-programming-windows\u002F12.async-fundamentals",{"title":344,"path":345,"stem":346},"SynchronizationContext та ConfigureAwait — Контекст Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-context-configureawait","01.csharp\u002F07.system-programming-windows\u002F13.async-context-configureawait",{"title":348,"path":349,"stem":350},"Async — Просунуті Паттерни","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-advanced","01.csharp\u002F07.system-programming-windows\u002F14.async-advanced",{"title":352,"path":353,"stem":354},"System.Threading.Channels — Async Producer-Consumer","\u002Fcsharp\u002Fsystem-programming-windows\u002Fchannels","01.csharp\u002F07.system-programming-windows\u002F15.channels",{"title":356,"path":357,"stem":358},"Асинхронна Синхронізація","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-synchronization","01.csharp\u002F07.system-programming-windows\u002F16.async-synchronization",{"title":360,"path":361,"stem":362},"Unsafe Code та Вказівники","\u002Fcsharp\u002Fsystem-programming-windows\u002Funsafe-code","01.csharp\u002F07.system-programming-windows\u002F17.unsafe-code",{"title":364,"path":365,"stem":366},"P\u002FInvoke та Windows API — Міст між .NET та Native Code","\u002Fcsharp\u002Fsystem-programming-windows\u002Fpinvoke-winapi","01.csharp\u002F07.system-programming-windows\u002F18.pinvoke-winapi",{"title":368,"path":369,"stem":370},"Реєстр Windows — Центральна База Конфігурації Системи","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-registry","01.csharp\u002F07.system-programming-windows\u002F19.windows-registry",{"title":372,"path":373,"stem":374},"Windows Hooks, Hotkeys та Services — Глибока Інтеграція з ОС","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-hooks-services","01.csharp\u002F07.system-programming-windows\u002F20.windows-hooks-services",{"title":376,"path":377,"stem":378},"Системне Програмування C# (Windows) — 07.system-programming-windows","\u002Fcsharp\u002Fsystem-programming-windows\u002Fimplementation_plan","01.csharp\u002F07.system-programming-windows\u002Fimplementation_plan",{"title":380,"icon":132,"path":381,"stem":382,"children":383,"page":59},"Io","\u002Fcsharp\u002Fio","01.csharp\u002F08.io",[384,388,392,396,400],{"title":385,"path":386,"stem":387},"8.1.1. Основи роботи з файловою системою","\u002Fcsharp\u002Fio\u002Ffile-system-basics","01.csharp\u002F08.io\u002F01.file-system-basics",{"title":389,"path":390,"stem":391},"8.1.2. Потоки (Streams) та Серіалізація Даних","\u002Fcsharp\u002Fio\u002Fstreams-serialization","01.csharp\u002F08.io\u002F02.streams-serialization",{"title":393,"path":394,"stem":395},"8.2.1. JSON Serialization з System.Text.Json","\u002Fcsharp\u002Fio\u002Fjson-serialization","01.csharp\u002F08.io\u002F03.json-serialization",{"title":397,"path":398,"stem":399},"8.2.2. XML Serialization та LINQ to XML","\u002Fcsharp\u002Fio\u002Fxml-serialization","01.csharp\u002F08.io\u002F04.xml-serialization",{"title":401,"path":402,"stem":403},"8.2.3. Binary Serialization: MessagePack та Protocol Buffers","\u002Fcsharp\u002Fio\u002Fbinary-serialization","01.csharp\u002F08.io\u002F05.binary-serialization",{"title":405,"icon":132,"path":406,"stem":407,"children":408,"page":59},"Ado Net","\u002Fcsharp\u002Fado-net","01.csharp\u002F09.ado-net",[409,413,417,421,425,429,433,437,441,445,449,453],{"title":410,"path":411,"stem":412},"9.1. Введення в ADO.NET","\u002Fcsharp\u002Fado-net\u002Fintroduction-to-adonet","01.csharp\u002F09.ado-net\u002F01.introduction-to-adonet",{"title":414,"path":415,"stem":416},"9.2. Клас DbConnection — з'єднання з базою даних","\u002Fcsharp\u002Fado-net\u002Fconnection","01.csharp\u002F09.ado-net\u002F02.connection",{"title":418,"path":419,"stem":420},"9.3. Клас DbCommand — виконання SQL-запитів","\u002Fcsharp\u002Fado-net\u002Fcommand-and-queries","01.csharp\u002F09.ado-net\u002F03.command-and-queries",{"title":422,"path":423,"stem":424},"9.4. Клас DbDataReader — ефективне читання даних","\u002Fcsharp\u002Fado-net\u002Fdatareader","01.csharp\u002F09.ado-net\u002F04.datareader",{"title":426,"path":427,"stem":428},"9.5. Параметризовані запити та захист від SQL Injection","\u002Fcsharp\u002Fado-net\u002Fparameters-and-sql-injection","01.csharp\u002F09.ado-net\u002F05.parameters-and-sql-injection",{"title":430,"path":431,"stem":432},"9.6. Транзакції в ADO.NET","\u002Fcsharp\u002Fado-net\u002Ftransactions","01.csharp\u002F09.ado-net\u002F06.transactions",{"title":434,"path":435,"stem":436},"9.7. DbProviderFactory — провайдер-незалежний код","\u002Fcsharp\u002Fado-net\u002Fprovider-factory","01.csharp\u002F09.ado-net\u002F07.provider-factory",{"title":438,"path":439,"stem":440},"9.8. Асинхронний доступ до даних","\u002Fcsharp\u002Fado-net\u002Fasync-data-access","01.csharp\u002F09.ado-net\u002F08.async-data-access",{"title":442,"path":443,"stem":444},"9.9. Від'єднаний режим: DataSet, DataTable, DataRow","\u002Fcsharp\u002Fado-net\u002Fdisconnected-mode-dataset","01.csharp\u002F09.ado-net\u002F09.disconnected-mode-dataset",{"title":446,"path":447,"stem":448},"9.10. DataAdapter — міст між DataSet та базою даних","\u002Fcsharp\u002Fado-net\u002Fdata-adapter","01.csharp\u002F09.ado-net\u002F10.data-adapter",{"title":450,"path":451,"stem":452},"9.11. Data Mapper та Repository: Архітектура доступу до даних","\u002Fcsharp\u002Fado-net\u002Fdata-mapper-repository","01.csharp\u002F09.ado-net\u002F11.data-mapper-repository",{"title":454,"path":455,"stem":456},"9.12. Identity Map, Unit of Work та Specification Pattern","\u002Fcsharp\u002Fado-net\u002Fadvanced-patterns","01.csharp\u002F09.ado-net\u002F12.advanced-patterns",{"title":458,"icon":255,"path":459,"stem":460,"children":461,"page":59},"Ef Core","\u002Fcsharp\u002Fef-core","01.csharp\u002F10.ef-core",[462,466,470,474,478,482,486,490,494,498,502,506,510,514,518,522,526,532,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618,622,626,630,634,638,642,646],{"title":463,"path":464,"stem":465},"Що таке ORM? Від SQL до об'єктів","\u002Fcsharp\u002Fef-core\u002Fwhat-is-orm","01.csharp\u002F10.ef-core\u002F01.what-is-orm",{"title":467,"path":468,"stem":469},"Перший проєкт — від нуля до CRUD","\u002Fcsharp\u002Fef-core\u002Ffirst-project","01.csharp\u002F10.ef-core\u002F02.first-project",{"title":471,"path":472,"stem":473},"DbContext — Серце EF Core","\u002Fcsharp\u002Fef-core\u002Fdbcontext-deep-dive","01.csharp\u002F10.ef-core\u002F03.dbcontext-deep-dive",{"title":475,"path":476,"stem":477},"Провайдери баз даних — Архітектура та Вибір СУБД","\u002Fcsharp\u002Fef-core\u002Fdatabase-providers","01.csharp\u002F10.ef-core\u002F04.database-providers",{"title":479,"path":480,"stem":481},"Конвенції EF Core — Магія без конфігурації","\u002Fcsharp\u002Fef-core\u002Fconventions","01.csharp\u002F10.ef-core\u002F05.conventions",{"title":483,"path":484,"stem":485},"Fluent API та Data Annotations — Явна конфігурація моделі","\u002Fcsharp\u002Fef-core\u002Ffluent-api-vs-annotations","01.csharp\u002F10.ef-core\u002F06.fluent-api-vs-annotations",{"title":487,"path":488,"stem":489},"Зв'язки — One-to-One та One-to-Many","\u002Fcsharp\u002Fef-core\u002Frelationships-basics","01.csharp\u002F10.ef-core\u002F07.relationships-basics",{"title":491,"path":492,"stem":493},"Зв'язки Advanced — Many-to-Many та Складні Сценарії","\u002Fcsharp\u002Fef-core\u002Frelationships-advanced","01.csharp\u002F10.ef-core\u002F08.relationships-advanced",{"title":495,"path":496,"stem":497},"Властивості — Типи, Конвертери, Компаратори (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part1","01.csharp\u002F10.ef-core\u002F09.property-configuration-part1",{"title":499,"path":500,"stem":501},"Властивості — Value Comparers, Generators, Shadow Properties (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part2","01.csharp\u002F10.ef-core\u002F09.property-configuration-part2",{"title":503,"path":504,"stem":505},"Складні типи — Owned Types та Complex Types (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part1","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part1",{"title":507,"path":508,"stem":509},"Складні типи — Complex Types, Keyless Entities, Порівняння (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part2","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part2",{"title":511,"path":512,"stem":513},"JSON Columns — Складні дані у JSON (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part1","01.csharp\u002F10.ef-core\u002F11.json-columns-part1",{"title":515,"path":516,"stem":517},"JSON Columns — Value Comparers, Індекси, Провайдери (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part2","01.csharp\u002F10.ef-core\u002F11.json-columns-part2",{"title":519,"path":520,"stem":521},"Успадкування — Абстрактні класи та TPH (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finheritance-part1","01.csharp\u002F10.ef-core\u002F12.inheritance-part1",{"title":523,"path":524,"stem":525},"Успадкування — TPT, TPC та Порівняння Стратегій (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finheritance-part2","01.csharp\u002F10.ef-core\u002F12.inheritance-part2",{"title":527,"path":528,"stem":529,"children":530},"Індекси, Обмеження та Схема (Частина 1)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part1","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part1",[531],{"title":527,"path":528,"stem":529},{"title":533,"path":534,"stem":535,"children":536},"Індекси, Обмеження та Схема (Частина 2)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part2","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part2",[537],{"title":533,"path":534,"stem":535},{"title":539,"path":540,"stem":541},"Seed Data — Початкові Дані (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fseeding-part1","01.csharp\u002F10.ef-core\u002F14.seeding-part1",{"title":543,"path":544,"stem":545},"Seed Data — SQL-скрипти, Bogus та Стратегії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fseeding-part2","01.csharp\u002F10.ef-core\u002F14.seeding-part2",{"title":547,"path":548,"stem":549},"Global Query Filters — Глобальні Фільтри (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part1","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part1",{"title":551,"path":552,"stem":553},"Global Query Filters — Підводні камені та Інтеграція (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part2","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part2",{"title":555,"path":556,"stem":557},"LINQ-запити в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part1","01.csharp\u002F10.ef-core\u002F16.linq-queries-part1",{"title":559,"path":560,"stem":561},"LINQ-запити в EF Core (Частина 2)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part2","01.csharp\u002F10.ef-core\u002F16.linq-queries-part2",{"title":563,"path":564,"stem":565},"Завантаження Пов'язаних Даних (Частина 1)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part1","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part1",{"title":567,"path":568,"stem":569},"Завантаження Пов'язаних Даних (Частина 2)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part2","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part2",{"title":571,"path":572,"stem":573},"Raw SQL, Views та Stored Procedures (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part1","01.csharp\u002F10.ef-core\u002F18.raw-sql-part1",{"title":575,"path":576,"stem":577},"Raw SQL — Stored Procedures, DbFunction та Bulk Operations (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part2","01.csharp\u002F10.ef-core\u002F18.raw-sql-part2",{"title":579,"path":580,"stem":581},"Продвинуті Запити — Compiled Queries, Bulk та Оптимізація (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part1","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part1",{"title":583,"path":584,"stem":585},"Продвинуті Запити — Query Tags, Bulk та Interceptors (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part2","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part2",{"title":587,"path":588,"stem":589},"Change Tracker — Відстеження Змін (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part1","01.csharp\u002F10.ef-core\u002F20.change-tracking-part1",{"title":591,"path":592,"stem":593},"Change Tracker — Графи Об'єктів та Disconnected (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part2","01.csharp\u002F10.ef-core\u002F20.change-tracking-part2",{"title":595,"path":596,"stem":597},"Збереження Даних та Транзакції (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part1","01.csharp\u002F10.ef-core\u002F21.saving-data-part1",{"title":599,"path":600,"stem":601},"Збереження Даних — Concurrency та Outbox (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part2","01.csharp\u002F10.ef-core\u002F21.saving-data-part2",{"title":603,"path":604,"stem":605},"Конкурентність та Блокування (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part1","01.csharp\u002F10.ef-core\u002F22.concurrency-part1",{"title":607,"path":608,"stem":609},"Конкурентність — Дедлоки та Queue Processing (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part2","01.csharp\u002F10.ef-core\u002F22.concurrency-part2",{"title":611,"path":612,"stem":613},"Міграції в EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part1","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part1",{"title":615,"path":616,"stem":617},"Міграції в EF Core — Основи (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part2","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part2",{"title":619,"path":620,"stem":621},"Міграції — Просунуті Сценарії (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part1","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part1",{"title":623,"path":624,"stem":625},"Міграції — Просунуті Сценарії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part2","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part2",{"title":627,"path":628,"stem":629},"Управління Схемою та Database-First (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part1","01.csharp\u002F10.ef-core\u002F25.schema-management-part1",{"title":631,"path":632,"stem":633},"Управління Схемою та Database-First (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part2","01.csharp\u002F10.ef-core\u002F25.schema-management-part2",{"title":635,"path":636,"stem":637},"Продуктивність EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fperformance-fundamentals-part1","01.csharp\u002F10.ef-core\u002F26.performance-fundamentals-part1",{"title":639,"path":640,"stem":641},"Interceptors в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part1","01.csharp\u002F10.ef-core\u002F29.interceptors-part1",{"title":643,"path":644,"stem":645},"Interceptors в EF Core — Connection, Transaction та Materialization (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part2","01.csharp\u002F10.ef-core\u002F29.interceptors-part2",{"title":647,"path":648,"stem":649},"План вивчення Entity Framework Core — Повний курс","\u002Fcsharp\u002Fef-core\u002Fimplementation_plan","01.csharp\u002F10.ef-core\u002Fimplementation_plan",{"title":651,"icon":652,"path":653,"stem":654,"children":655,"page":59},"ASP.NET","i-devicon-dotnetcore","\u002Fcsharp\u002Faspnet","01.csharp\u002F11.aspnet",[656,730,791,869,927,941,967,1057,1111,1182,1212,1289,1346],{"title":657,"icon":658,"path":659,"stem":660,"children":661,"page":59},"Minimal API","i-lucide-network","\u002Fcsharp\u002Faspnet\u002Fminimal-api","01.csharp\u002F11.aspnet\u002F01.minimal-api",[662,666,670,674,678,682,686,690,694,698,702,706,710,714,718,722,726],{"title":663,"path":664,"stem":665},"Вступ до ASP.NET та еволюція фреймворку","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fintroduction","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F01.introduction",{"title":667,"path":668,"stem":669},"Перший додаток на ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Ffirst-application","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F02.first-application",{"title":671,"path":672,"stem":673},"WebApplication, Builder та Dependency Injection","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fwebapplication-builder","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F03.webapplication-builder",{"title":675,"path":676,"stem":677},"Конвеєр запитів та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frequest-pipeline-middleware","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F04.request-pipeline-middleware",{"title":679,"path":680,"stem":681},"Маршрутизація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F05.routing-basics",{"title":683,"path":684,"stem":685},"Маршрутизація в ASP.NET Core: Розширені можливості","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F06.routing-advanced",{"title":687,"path":688,"stem":689},"Статичні файли в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-files","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F07.static-files",{"title":691,"path":692,"stem":693},"Статичні Активи: MapStaticAssets (ASP.NET Core 9.0)","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-assets","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F08.static-assets",{"title":695,"path":696,"stem":697},"Конфігурація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-fundamentals","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F09.configuration-fundamentals",{"title":699,"path":700,"stem":701},"Конфігурація: Паттерн Options","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-options","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F10.configuration-options",{"title":703,"path":704,"stem":705},"Логування в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F11.logging-basics",{"title":707,"path":708,"stem":709},"Логування: Serilog та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F12.logging-advanced",{"title":711,"path":712,"stem":713},"Управління станом: HttpContext.Items та Cookies","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstate-management","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F13.state-management",{"title":715,"path":716,"stem":717},"Стан сесії: Sessions","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fsession-state","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F14.session-state",{"title":719,"path":720,"stem":721},"Структура проєкту: від хаосу до архітектури","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fproject-structure","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F15.project-structure",{"title":723,"path":724,"stem":725},"Scalar у Minimal API: повний проєкт і Fluent OpenAPI","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fscalar-openapi-fluent","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F16.scalar-openapi-fluent",{"title":727,"path":728,"stem":729},"Swagger \u002F Swashbuckle у Minimal API: окремий класичний шлях","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fswagger-swashbuckle","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F17.swagger-swashbuckle",{"title":731,"icon":658,"path":732,"stem":733,"children":734,"page":59},"API","\u002Fcsharp\u002Faspnet\u002Fapi","01.csharp\u002F11.aspnet\u002F02.api",[735,739,743,747,751,755,759,763,767,771,775,779,783,787],{"title":736,"path":737,"stem":738},"Що таке API. Клієнт-серверна архітектура","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fwhat-is-api","01.csharp\u002F11.aspnet\u002F02.api\u002F01.what-is-api",{"title":740,"path":741,"stem":742},"Формати даних: JSON, XML, TOML та бінарні формати","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fdata-formats","01.csharp\u002F11.aspnet\u002F02.api\u002F02.data-formats",{"title":744,"path":745,"stem":746},"Парадигми API та концепція REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-paradigms-rest","01.csharp\u002F11.aspnet\u002F02.api\u002F03.api-paradigms-rest",{"title":748,"path":749,"stem":750},"HTTP-методи, статус-коди та заголовки","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fhttp-methods-status-codes","01.csharp\u002F11.aspnet\u002F02.api\u002F04.http-methods-status-codes",{"title":752,"path":753,"stem":754},"Організація HTTP API за принципами REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Frest-organizing","01.csharp\u002F11.aspnet\u002F02.api\u002F05.rest-organizing",{"title":756,"path":757,"stem":758},"Номенклатура URL та CRUD-операції","\u002Fcsharp\u002Faspnet\u002Fapi\u002Furl-nomenclature-crud","01.csharp\u002F11.aspnet\u002F02.api\u002F06.url-nomenclature-crud",{"title":760,"path":761,"stem":762},"Правила дизайну: іменування та стандарти","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-naming","01.csharp\u002F11.aspnet\u002F02.api\u002F07.api-design-naming",{"title":764,"path":765,"stem":766},"Валідація, ліміти та обробка помилок","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-validation","01.csharp\u002F11.aspnet\u002F02.api\u002F08.api-design-validation",{"title":768,"path":769,"stem":770},"Обробка помилок у Minimal API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Ferror-handling-http","01.csharp\u002F11.aspnet\u002F02.api\u002F09.error-handling-http",{"title":772,"path":773,"stem":774},"Ідемпотентність та синхронізація стану","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fidempotency-sync","01.csharp\u002F11.aspnet\u002F02.api\u002F10.idempotency-sync",{"title":776,"path":777,"stem":778},"Пагінація та організація списків","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fpagination-lists","01.csharp\u002F11.aspnet\u002F02.api\u002F11.pagination-lists",{"title":780,"path":781,"stem":782},"Безпека API, кешування та інтернаціоналізація","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fsecurity-auth","01.csharp\u002F11.aspnet\u002F02.api\u002F12.security-auth",{"title":784,"path":785,"stem":786},"Процес проєктування API та документування","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-process","01.csharp\u002F11.aspnet\u002F02.api\u002F13.api-design-process",{"title":788,"path":789,"stem":790},"OpenAPI: контракт, специфікація та документація API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fopenapi","01.csharp\u002F11.aspnet\u002F02.api\u002F14.openapi",{"title":792,"icon":793,"path":794,"stem":795,"children":796,"page":59},"Auth","i-lucide-shield-check","\u002Fcsharp\u002Faspnet\u002Fauth","01.csharp\u002F11.aspnet\u002F03.auth",[797,801,805,809,813,817,821,825,829,833,837,841,845,849,853,857,861,865],{"title":798,"path":799,"stem":800},"Основи аутентифікації та авторизації","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauth-fundamentals","01.csharp\u002F11.aspnet\u002F03.auth\u002F01.auth-fundamentals",{"title":802,"path":803,"stem":804},"JWT-аутентифікація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fjwt-authentication","01.csharp\u002F11.aspnet\u002F03.auth\u002F02.jwt-authentication",{"title":806,"path":807,"stem":808},"Авторизація: ролі, політики та resource-based доступ","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauthorization-policies","01.csharp\u002F11.aspnet\u002F03.auth\u002F03.authorization-policies",{"title":810,"path":811,"stem":812},"Cookie-аутентифікація та ASP.NET Core Identity","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcookie-auth-identity","01.csharp\u002F11.aspnet\u002F03.auth\u002F04.cookie-auth-identity",{"title":814,"path":815,"stem":816},"JWT + Refresh Tokens (HttpOnly Cookie)","\u002Fcsharp\u002Faspnet\u002Fauth\u002F04b.identity-auth-jwt","01.csharp\u002F11.aspnet\u002F03.auth\u002F04b.identity-auth-jwt",{"title":818,"path":819,"stem":820},"Identity: Підтвердження Email та Скидання Пароля","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-email-confirmation","01.csharp\u002F11.aspnet\u002F03.auth\u002F05.identity-email-confirmation",{"title":822,"path":823,"stem":824},"Identity: Двофакторна Аутентифікація (2FA)","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-two-factor","01.csharp\u002F11.aspnet\u002F03.auth\u002F06.identity-two-factor",{"title":826,"path":827,"stem":828},"Identity: Внутрішня Архітектура та Кастомізація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-internals","01.csharp\u002F11.aspnet\u002F03.auth\u002F07.identity-internals",{"title":830,"path":831,"stem":832},"OAuth 2.0 та зовнішні провайдери","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-external-providers","01.csharp\u002F11.aspnet\u002F03.auth\u002F08.oauth-external-providers",{"title":834,"path":835,"stem":836},"Безпека на практиці: CORS, HTTPS та захист від атак","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fsecurity-hardening","01.csharp\u002F11.aspnet\u002F03.auth\u002F09.security-hardening",{"title":838,"path":839,"stem":840},"Теорія OAuth 2.0: Поняття, Аналогії та Флоу","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-theory","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oauth-theory",{"title":842,"path":843,"stem":844},"OIDC, OAuth 2.0 та Keycloak в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foidc-keycloak","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oidc-keycloak",{"title":846,"path":847,"stem":848},"API Keys аутентифікація в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fapi-keys","01.csharp\u002F11.aspnet\u002F03.auth\u002F11.api-keys",{"title":850,"path":851,"stem":852},"Rate Limiting та Throttling в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frate-limiting","01.csharp\u002F11.aspnet\u002F03.auth\u002F12.rate-limiting",{"title":854,"path":855,"stem":856},"Refresh Token Rotation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frefresh-token-rotation","01.csharp\u002F11.aspnet\u002F03.auth\u002F13.refresh-token-rotation",{"title":858,"path":859,"stem":860},"Certificate Authentication та mTLS в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcertificate-auth","01.csharp\u002F11.aspnet\u002F03.auth\u002F14.certificate-auth",{"title":862,"path":863,"stem":864},"RBAC, ABAC та ReBAC в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frbac-abac-rebac","01.csharp\u002F11.aspnet\u002F03.auth\u002F15.rbac-abac-rebac",{"title":866,"path":867,"stem":868},"Multi-tenancy та ізоляція даних в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fmulti-tenancy","01.csharp\u002F11.aspnet\u002F03.auth\u002F16.multi-tenancy",{"title":870,"icon":871,"path":872,"stem":873,"children":874,"page":59},"Нотифікації","i-lucide-bell","\u002Fcsharp\u002Faspnet\u002Fnotifications","01.csharp\u002F11.aspnet\u002F04.notifications",[875,879,883,887,891,895,899,903,907,911,915,919,923],{"title":876,"path":877,"stem":878},"In-App нотифікації через базу даних","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fin-app-database-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F01.in-app-database-notifications",{"title":880,"path":881,"stem":882},"Polling: Регулярний запит оновлень","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fpolling","01.csharp\u002F11.aspnet\u002F04.notifications\u002F02.polling",{"title":884,"path":885,"stem":886},"Server-Sent Events: Однострімовий push від сервера","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fserver-sent-events","01.csharp\u002F11.aspnet\u002F04.notifications\u002F03.server-sent-events",{"title":888,"path":889,"stem":890},"WebSockets: Двостороннє з'єднання в реальному часі","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fwebsockets","01.csharp\u002F11.aspnet\u002F04.notifications\u002F04.websockets",{"title":892,"path":893,"stem":894},"SignalR: Абстракція над транспортами реального часу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fsignalr","01.csharp\u002F11.aspnet\u002F04.notifications\u002F05.signalr",{"title":896,"path":897,"stem":898},"Background Services: Фонові задачі в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fbackground-services","01.csharp\u002F11.aspnet\u002F04.notifications\u002F06.background-services",{"title":900,"path":901,"stem":902},"Web Push нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fweb-push","01.csharp\u002F11.aspnet\u002F04.notifications\u002F07.web-push",{"title":904,"path":905,"stem":906},"Email нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Femail-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F08.email-notifications",{"title":908,"path":909,"stem":910},"Порівняння підходів: Як вибрати правильну технологію нотифікацій","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fchoosing-the-right-approach","01.csharp\u002F11.aspnet\u002F04.notifications\u002F09.choosing-the-right-approach",{"title":912,"path":913,"stem":914},"Hangfire: Надійне планування фонових задач","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire","01.csharp\u002F11.aspnet\u002F04.notifications\u002F10.hangfire",{"title":916,"path":917,"stem":918},"Практика: Конвертація зображень у WebP через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-image-webp","01.csharp\u002F11.aspnet\u002F04.notifications\u002F11.hangfire-image-webp",{"title":920,"path":921,"stem":922},"Практика: Підготовка відео до HLS-стрімінгу через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-video-hls","01.csharp\u002F11.aspnet\u002F04.notifications\u002F12.hangfire-video-hls",{"title":924,"path":925,"stem":926},"Telegram-нотифікації: від одного повідомлення до масових розсилок і мульти-канального підходу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Ftelegram-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F13.telegram-notifications",{"title":928,"icon":929,"path":930,"stem":931,"children":932,"page":59},"Інтернаціоналізація","i-lucide-languages","\u002Fcsharp\u002Faspnet\u002Fi18n","01.csharp\u002F11.aspnet\u002F05.i18n",[933,937],{"title":934,"path":935,"stem":936},"Інтернаціоналізація (i18n) у Minimal API: від A до Я","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Finternationalization","01.csharp\u002F11.aspnet\u002F05.i18n\u002F01.internationalization",{"title":938,"path":939,"stem":940},"Humanizer: людиномовні рядки у .NET","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Fhumanizer","01.csharp\u002F11.aspnet\u002F05.i18n\u002F02.humanizer",{"title":942,"icon":943,"path":944,"stem":945,"children":946,"page":59},"Кешування","i-lucide-layers","\u002Fcsharp\u002Faspnet\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching",[947,951,955,959,963],{"title":948,"path":949,"stem":950},"Огляд кешування: чотири рівні і коли що обирати","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching\u002F01.caching",{"title":952,"path":953,"stem":954},"IMemoryCache: кеш в оперативній пам'яті","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fmemory-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F02.memory-cache",{"title":956,"path":957,"stem":958},"IDistributedCache і Redis: розподілений кеш","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fdistributed-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F03.distributed-cache",{"title":960,"path":961,"stem":962},"Response Cache: HTTP-кешування через Cache-Control","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fresponse-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F04.response-cache",{"title":964,"path":965,"stem":966},"Output Cache: серверний кеш HTTP-відповідей (.NET 7+)","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Foutput-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F05.output-cache",{"title":968,"icon":969,"path":970,"stem":971,"children":972,"page":59},"Тестування","i-lucide-test-tube","\u002Fcsharp\u002Faspnet\u002Ftesting","01.csharp\u002F11.aspnet\u002F07.testing",[973,977,981,985,989,993,997,1001,1005,1009,1013,1017,1021,1025,1029,1033,1037,1041,1045,1049,1053],{"title":974,"path":975,"stem":976},"Що таке тестування? Від інтуїції до науки","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-is-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F01.what-is-testing",{"title":978,"path":979,"stem":980},"Піраміда тестування — Стратегія, а не Догма","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-pyramid","01.csharp\u002F11.aspnet\u002F07.testing\u002F02.testing-pyramid",{"title":982,"path":983,"stem":984},"Дві Школи Тестування — Лондон проти Детройту","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-schools","01.csharp\u002F11.aspnet\u002F07.testing\u002F03.testing-schools",{"title":986,"path":987,"stem":988},"TDD та BDD — Тести як Дизайн-інструмент","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftdd-and-bdd","01.csharp\u002F11.aspnet\u002F07.testing\u002F04.tdd-and-bdd",{"title":990,"path":991,"stem":992},"Що саме тестувати — Техніки аналізу та Циклomatична складність","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-to-test","01.csharp\u002F11.aspnet\u002F07.testing\u002F05.what-to-test",{"title":994,"path":995,"stem":996},"Тестові Фреймворки — Навіщо вони і що всередині","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftest-frameworks","01.csharp\u002F11.aspnet\u002F07.testing\u002F06.test-frameworks",{"title":998,"path":999,"stem":1000},"xUnit — Факти, Теорії та Lifecycle тестів","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-basics","01.csharp\u002F11.aspnet\u002F07.testing\u002F07.xunit-basics",{"title":1002,"path":1003,"stem":1004},"xUnit Advanced — Fixtures, Кастомізація та Розширення","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F08.xunit-advanced",{"title":1006,"path":1007,"stem":1008},"Moq — Глибоке занурення в мокування","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fmocking-with-moq","01.csharp\u002F11.aspnet\u002F07.testing\u002F09.mocking-with-moq",{"title":1010,"path":1011,"stem":1012},"Тестування Баз Даних — EF Core, SQLite та Testcontainers","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fdatabase-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F10.database-testing",{"title":1014,"path":1015,"stem":1016},"Integration Testing — Частина 1 [Теорія та WebApplicationFactory]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F11.integration-testing",{"title":1018,"path":1019,"stem":1020},"Інтеграційне тестування — Практика","\u002Fcsharp\u002Faspnet\u002Ftesting\u002F11a.integration-testing-practice","01.csharp\u002F11.aspnet\u002F07.testing\u002F11a.integration-testing-practice",{"title":1022,"path":1023,"stem":1024},"Integration Testing — Частина 2 [Просунуті Сценарії та Testcontainers]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F12.integration-testing-advanced",{"title":1026,"path":1027,"stem":1028},"Професійний Postman: Колекції, Змінні та GitHub Інтеграція","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fpostman-professional","01.csharp\u002F11.aspnet\u002F07.testing\u002F13.postman-professional",{"title":1030,"path":1031,"stem":1032},"HttpClient у Тестах Частина 1: Архітектура та MockHttpMessageHandler","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fhttpclient-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F14.httpclient-testing",{"title":1034,"path":1035,"stem":1036},"HttpClient у Тестах Частина 2: WireMock.Net та Resilience","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwiremock-net","01.csharp\u002F11.aspnet\u002F07.testing\u002F15.wiremock-net",{"title":1038,"path":1039,"stem":1040},"Патерни та Анти-патерни Тестування: Test Smells","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-patterns","01.csharp\u002F11.aspnet\u002F07.testing\u002F16.testing-patterns",{"title":1042,"path":1043,"stem":1044},"Просунуті інструменти: Time, Snapshots та Властивості","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fadvanced-testing-tools","01.csharp\u002F11.aspnet\u002F07.testing\u002F17.advanced-testing-tools",{"title":1046,"path":1047,"stem":1048},"Тестування Архітектури з NetArchTest","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Farchitecture-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F18.architecture-testing",{"title":1050,"path":1051,"stem":1052},"Тестування Продуктивності: BenchmarkDotNet, NBomber та k6","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fperformance-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F19.performance-testing",{"title":1054,"path":1055,"stem":1056},"Залишок плану для курсу \"Тестування ASP.NET Minimal API\"","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fremaining_plan","01.csharp\u002F11.aspnet\u002F07.testing\u002Fremaining_plan",{"title":1058,"icon":1059,"path":1060,"stem":1061,"children":1062,"page":59},"Платежі","i-lucide-credit-card","\u002Fcsharp\u002Faspnet\u002Fpayments","01.csharp\u002F11.aspnet\u002F08.payments",[1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103,1107],{"title":1064,"path":1065,"stem":1066},"Основи платіжної інфраструктури","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-fundamentals","01.csharp\u002F11.aspnet\u002F08.payments\u002F01.payment-fundamentals",{"title":1068,"path":1069,"stem":1070},"Методи оплати в Україні","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-methods-ukraine","01.csharp\u002F11.aspnet\u002F08.payments\u002F02.payment-methods-ukraine",{"title":1072,"path":1073,"stem":1074},"PCI DSS та безпека платежів","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpci-dss-security","01.csharp\u002F11.aspnet\u002F08.payments\u002F03.pci-dss-security",{"title":1076,"path":1077,"stem":1078},"Архітектура платіжної підсистеми","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-architecture","01.csharp\u002F11.aspnet\u002F08.payments\u002F04.payment-architecture",{"title":1080,"path":1081,"stem":1082},"Інтеграція LiqPay (ПриватБанк)","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fliqpay-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F05.liqpay-integration",{"title":1084,"path":1085,"stem":1086},"Інтеграція Monobank Acquiring API","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fmonobank-acquiring","01.csharp\u002F11.aspnet\u002F08.payments\u002F06.monobank-acquiring",{"title":1088,"path":1089,"stem":1090},"Інтеграція Stripe","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fstripe-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F07.stripe-integration",{"title":1092,"path":1093,"stem":1094},"Webhooks — глибоке занурення","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fwebhooks-deep-dive","01.csharp\u002F11.aspnet\u002F08.payments\u002F08.webhooks-deep-dive",{"title":1096,"path":1097,"stem":1098},"Підписки та рекурентні платежі","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fsubscriptions-recurring","01.csharp\u002F11.aspnet\u002F08.payments\u002F09.subscriptions-recurring",{"title":1100,"path":1101,"stem":1102},"Повернення коштів та диспути","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Frefunds-disputes","01.csharp\u002F11.aspnet\u002F08.payments\u002F10.refunds-disputes",{"title":1104,"path":1105,"stem":1106},"Тестування платіжних інтеграцій","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Ftesting-payments","01.csharp\u002F11.aspnet\u002F08.payments\u002F11.testing-payments",{"title":1108,"path":1109,"stem":1110},"Чекліст виходу в Production","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fproduction-checklist","01.csharp\u002F11.aspnet\u002F08.payments\u002F12.production-checklist",{"title":1112,"icon":1113,"items":1114,"path":1127,"stem":1128,"children":1129,"page":59},"Популярні бібліотеки","lucide:box",[1115,1116,1117,1118,1119,1120,1121,1122,1123,1124,1125,1126],"01.fluent-validation","02.mapster","03.erroror-result-pattern","04.serilog","05.mediatr","06.polly","07.health-checks","08.feature-management","09.fluent-email","10.quest-pdf","11.bogus","12.humanizer-guard","\u002Fcsharp\u002Faspnet\u002Flibraries","01.csharp\u002F11.aspnet\u002F09.libraries",[1130,1134,1138,1142,1146,1150,1154,1158,1162,1166,1170,1174,1178],{"title":1131,"path":1132,"stem":1133},"Валідація з FluentValidation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-validation","01.csharp\u002F11.aspnet\u002F09.libraries\u002F01.fluent-validation",{"title":1135,"path":1136,"stem":1137},"Маппінг об","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmapster","01.csharp\u002F11.aspnet\u002F09.libraries\u002F02.mapster",{"title":1139,"path":1140,"stem":1141},"Обробка помилок з ErrorOr та Result Pattern в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ferroror-result-pattern","01.csharp\u002F11.aspnet\u002F09.libraries\u002F03.erroror-result-pattern",{"title":1143,"path":1144,"stem":1145},"Структуроване логування з Serilog в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fserilog","01.csharp\u002F11.aspnet\u002F09.libraries\u002F04.serilog",{"title":1147,"path":1148,"stem":1149},"CQRS та Mediator з MediatR в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmediatr","01.csharp\u002F11.aspnet\u002F09.libraries\u002F05.mediatr",{"title":1151,"path":1152,"stem":1153},"Відмовостійкість з Polly в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fpolly","01.csharp\u002F11.aspnet\u002F09.libraries\u002F06.polly",{"title":1155,"path":1156,"stem":1157},"Health Checks в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F09.libraries\u002F07.health-checks",{"title":1159,"path":1160,"stem":1161},"Feature Management та Feature Flags в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffeature-management","01.csharp\u002F11.aspnet\u002F09.libraries\u002F08.feature-management",{"title":1163,"path":1164,"stem":1165},"Відправка Email з FluentEmail в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-email","01.csharp\u002F11.aspnet\u002F09.libraries\u002F09.fluent-email",{"title":1167,"path":1168,"stem":1169},"Генерація PDF з QuestPDF в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fquest-pdf","01.csharp\u002F11.aspnet\u002F09.libraries\u002F10.quest-pdf",{"title":1171,"path":1172,"stem":1173},"Генерація тестових даних з Bogus в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fbogus","01.csharp\u002F11.aspnet\u002F09.libraries\u002F11.bogus",{"title":1175,"path":1176,"stem":1177},"Humanizer та Guard Clauses в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhumanizer-guard","01.csharp\u002F11.aspnet\u002F09.libraries\u002F12.humanizer-guard",{"title":1179,"path":1180,"stem":1181},"План модуля 10.libraries — Популярні бібліотеки ASP.NET","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fplan","01.csharp\u002F11.aspnet\u002F09.libraries\u002Fplan",{"title":1183,"icon":1184,"path":1185,"stem":1186,"children":1187,"page":59},"Razor Pages","i-lucide-layout-template","\u002Fcsharp\u002Faspnet\u002Frazor-pages","01.csharp\u002F11.aspnet\u002F10.razor-pages",[1188,1192,1196,1200,1204,1208],{"title":1189,"path":1190,"stem":1191},"Від Minimal API до Razor Pages: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ffrom-minimal-api","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F01.from-minimal-api",{"title":1193,"path":1194,"stem":1195},"PageModel: логіка сторінки Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fpage-model","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F02.page-model",{"title":1197,"path":1198,"stem":1199},"Razor синтаксис: шаблонізатор у .cshtml","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Frazor-syntax","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F03.razor-syntax",{"title":1201,"path":1202,"stem":1203},"Tag Helpers: типізований HTML","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ftag-helpers","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F04.tag-helpers",{"title":1205,"path":1206,"stem":1207},"Форми і валідація: повний цикл обробки даних","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fforms-validation","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F05.forms-validation",{"title":1209,"path":1210,"stem":1211},"Практичний проєкт: TaskManager на Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fproject-task-manager","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F06.project-task-manager",{"title":1213,"path":1214,"stem":1215,"children":1216,"page":59},"ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc","01.csharp\u002F11.aspnet\u002F11.mvc",[1217,1221,1225,1229,1233,1237,1241,1245,1249,1253,1257,1261,1265,1269,1273,1277,1281,1285],{"title":1218,"path":1219,"stem":1220},"Патерн MVC: архітектура, що змінила веб","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-pattern","01.csharp\u002F11.aspnet\u002F11.mvc\u002F01.mvc-pattern",{"title":1222,"path":1223,"stem":1224},"Від Razor Pages до MVC: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffrom-razor-pages","01.csharp\u002F11.aspnet\u002F11.mvc\u002F02.from-razor-pages",{"title":1226,"path":1227,"stem":1228},"Controllers та Actions: серце MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fcontrollers-actions","01.csharp\u002F11.aspnet\u002F11.mvc\u002F03.controllers-actions",{"title":1230,"path":1231,"stem":1232},"Маршрутизація в MVC: Convention vs Attribute Routing","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Frouting-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F04.routing-mvc",{"title":1234,"path":1235,"stem":1236},"Model Binding: від HTTP до C#","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmodel-binding","01.csharp\u002F11.aspnet\u002F11.mvc\u002F05.model-binding",{"title":1238,"path":1239,"stem":1240},"Views, ViewData, ViewBag, TempData і ViewModel","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fviews-viewdata-tempdata","01.csharp\u002F11.aspnet\u002F11.mvc\u002F06.views-viewdata-tempdata",{"title":1242,"path":1243,"stem":1244},"Filters: аспектно-орієнтоване програмування в MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffilters","01.csharp\u002F11.aspnet\u002F11.mvc\u002F07.filters",{"title":1246,"path":1247,"stem":1248},"Areas: структурування великих застосунків","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fareas","01.csharp\u002F11.aspnet\u002F11.mvc\u002F08.areas",{"title":1250,"path":1251,"stem":1252},"View Components: повторювані незалежні блоки UI","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fview-components","01.csharp\u002F11.aspnet\u002F11.mvc\u002F09.view-components",{"title":1254,"path":1255,"stem":1256},"Display та Editor Templates","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fdisplay-editor-templates","01.csharp\u002F11.aspnet\u002F11.mvc\u002F10.display-editor-templates",{"title":1258,"path":1259,"stem":1260},"Валідація: IValidatableObject та FluentValidation","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fvalidation-advanced","01.csharp\u002F11.aspnet\u002F11.mvc\u002F11.validation-advanced",{"title":1262,"path":1263,"stem":1264},"HTMX: інтерактивність через HTML-атрибути","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx","01.csharp\u002F11.aspnet\u002F11.mvc\u002F12.htmx",{"title":1266,"path":1267,"stem":1268},"HTMX у ASP.NET Core MVC: серверна інтеграція","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fajax-htmx-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F13.ajax-htmx-mvc",{"title":1270,"path":1271,"stem":1272},"Практичний проєкт: Каталог товарів з HTMX","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F14.htmx-project",{"title":1274,"path":1275,"stem":1276},"Завантаження та обробка файлів","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffile-upload","01.csharp\u002F11.aspnet\u002F11.mvc\u002F15.file-upload",{"title":1278,"path":1279,"stem":1280},"Глобалізація та Локалізація MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fglobalization-localization","01.csharp\u002F11.aspnet\u002F11.mvc\u002F16.globalization-localization",{"title":1282,"path":1283,"stem":1284},"Підсумковий проєкт: Блог-платформа","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F17.mvc-project",{"title":1286,"path":1287,"stem":1288},"План курсу: ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fplan","01.csharp\u002F11.aspnet\u002F11.mvc\u002Fplan",{"title":1290,"path":1291,"stem":1292,"children":1293,"page":59},"Web Api","\u002Fcsharp\u002Faspnet\u002Fweb-api","01.csharp\u002F11.aspnet\u002F12.web-api",[1294,1298,1302,1306,1310,1314,1318,1322,1326,1330,1334,1338,1342],{"title":1295,"path":1296,"stem":1297},"Від Minimal API до Controller-based API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffrom-minimal-api-to-controllers","01.csharp\u002F11.aspnet\u002F12.web-api\u002F01.from-minimal-api-to-controllers",{"title":1299,"path":1300,"stem":1301},"ControllerBase, ActionResult\u003CT> та Response Types","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontroller-base-actionresult","01.csharp\u002F11.aspnet\u002F12.web-api\u002F02.controller-base-actionresult",{"title":1303,"path":1304,"stem":1305},"Content Negotiation - JSON, XML та власні форматери","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontent-negotiation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F03.content-negotiation",{"title":1307,"path":1308,"stem":1309},"Версіонування API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-versioning","01.csharp\u002F11.aspnet\u002F12.web-api\u002F04.api-versioning",{"title":1311,"path":1312,"stem":1313},"ProblemDetails та структурована обробка помилок","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fproblemdetails-error-handling","01.csharp\u002F11.aspnet\u002F12.web-api\u002F05.problemdetails-error-handling",{"title":1315,"path":1316,"stem":1317},"Фільтри у Web API контексті","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffilters-for-api","01.csharp\u002F11.aspnet\u002F12.web-api\u002F06.filters-for-api",{"title":1319,"path":1320,"stem":1321},"Пагінація, фільтрація та сортування","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fpagination-filtering-sorting","01.csharp\u002F11.aspnet\u002F12.web-api\u002F07.pagination-filtering-sorting",{"title":1323,"path":1324,"stem":1325},"HATEOAS та Resource Expansion","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhateoas-resource-expansion","01.csharp\u002F11.aspnet\u002F12.web-api\u002F08.hateoas-resource-expansion",{"title":1327,"path":1328,"stem":1329},"Гібридна архітектура - Minimal API + Controllers","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fminimal-api-vs-controllers-hybrid","01.csharp\u002F11.aspnet\u002F12.web-api\u002F09.minimal-api-vs-controllers-hybrid",{"title":1331,"path":1332,"stem":1333},"Документація API - Swashbuckle, NSwag та генерація клієнтів","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-documentation-generation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F10.api-documentation-generation",{"title":1335,"path":1336,"stem":1337},"Health Checks та моніторинг API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhealth-checks-monitoring","01.csharp\u002F11.aspnet\u002F12.web-api\u002F11.health-checks-monitoring",{"title":1339,"path":1340,"stem":1341},"Підсумковий проєкт - Production-Ready REST API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fweb-api-project","01.csharp\u002F11.aspnet\u002F12.web-api\u002F12.web-api-project",{"title":1343,"path":1344,"stem":1345},"План курсу: ASP.NET Core Web API (Controllers)","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fplan","01.csharp\u002F11.aspnet\u002F12.web-api\u002Fplan",{"title":1347,"icon":1348,"path":1349,"stem":1350,"children":1351,"page":59},"Моніторинг","i-lucide-activity","\u002Fcsharp\u002Faspnet\u002Fmonitoring","01.csharp\u002F11.aspnet\u002F13.monitoring",[1352,1356,1360],{"title":1353,"path":1354,"stem":1355},"Спостережуваність: від console.log до production-систем","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fobservability-intro","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F01.observability-intro",{"title":1357,"path":1358,"stem":1359},"Health Checks: перший рівень observability","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F02.health-checks",{"title":1361,"path":1362,"stem":1363},"Вбудовані метрики .NET 10 та System.Diagnostics.Metrics","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fdotnet-metrics","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F03.dotnet-metrics",{"title":1365,"icon":1366,"path":1367,"stem":1368,"children":1369,"page":59},"Desktop UI","i-lucide-app-window","\u002Fcsharp\u002Fdesktop-ui","01.csharp\u002F12.desktop-ui",[1370,1374,1378,1382,1386,1390,1394,1398,1402,1406,1410,1414,1418,1422,1426,1430,1434,1438,1442,1446,1450,1454,1458,1462,1466,1470,1474,1478,1482,1486,1490,1494,1498,1502,1506,1510,1514,1518,1522,1526,1530,1534,1538,1542,1546,1550,1554,1558,1562,1566,1570,1574,1578,1582,1586,1590,1594,1598,1602,1606,1610,1614,1618,1622,1626,1630,1634,1638,1642,1646,1650],{"title":1371,"path":1372,"stem":1373},"Що таке десктопна розробка?","\u002Fcsharp\u002Fdesktop-ui\u002Fwhat-is-desktop-dev","01.csharp\u002F12.desktop-ui\u002F01.what-is-desktop-dev",{"title":1375,"path":1376,"stem":1377},"Архітектура WPF — як влаштований графічний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-architecture","01.csharp\u002F12.desktop-ui\u002F02.wpf-architecture",{"title":1379,"path":1380,"stem":1381},"Перший WPF-проєкт — від нуля до вікна","\u002Fcsharp\u002Fdesktop-ui\u002Ffirst-wpf-app","01.csharp\u002F12.desktop-ui\u002F03.first-wpf-app",{"title":1383,"path":1384,"stem":1385},"Перший Avalonia-проєкт: WPF для всіх платформ","\u002Fcsharp\u002Fdesktop-ui\u002F03a.first-avalonia-app","01.csharp\u002F12.desktop-ui\u002F03a.first-avalonia-app",{"title":1387,"path":1388,"stem":1389},"XAML: декларативний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-basics","01.csharp\u002F12.desktop-ui\u002F04.xaml-basics",{"title":1391,"path":1392,"stem":1393},"Fluent UI у WPF — сучасний дизайн Windows 11","\u002Fcsharp\u002Fdesktop-ui\u002F04a.wpf-fluent-ui","01.csharp\u002F12.desktop-ui\u002F04a.wpf-fluent-ui",{"title":1395,"path":1396,"stem":1397},"WPF UI — сучасна бібліотека Fluent контролів","\u002Fcsharp\u002Fdesktop-ui\u002F04b.wpf-ui-library","01.csharp\u002F12.desktop-ui\u002F04b.wpf-ui-library",{"title":1399,"path":1400,"stem":1401},"HandyControl — велика бібліотека UI контролів для WPF","\u002Fcsharp\u002Fdesktop-ui\u002F04c.handycontrol-library","01.csharp\u002F12.desktop-ui\u002F04c.handycontrol-library",{"title":1403,"path":1404,"stem":1405},"Простори імен та ресурси XAML","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-namespaces-resources","01.csharp\u002F12.desktop-ui\u002F05.xaml-namespaces-resources",{"title":1407,"path":1408,"stem":1409},"XAML в Avalonia: ключові відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F05a.avalonia-xaml-differences","01.csharp\u002F12.desktop-ui\u002F05a.avalonia-xaml-differences",{"title":1411,"path":1412,"stem":1413},"Розширення розмітки XAML (Markup Extensions)","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-markup-extensions","01.csharp\u002F12.desktop-ui\u002F06.xaml-markup-extensions",{"title":1415,"path":1416,"stem":1417},"Панелі Layout: StackPanel, WrapPanel, DockPanel","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part1","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part1",{"title":1419,"path":1420,"stem":1421},"Grid, Canvas, UniformGrid","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part2","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part2",{"title":1423,"path":1424,"stem":1425},"Просунуті техніки Layout","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-advanced","01.csharp\u002F12.desktop-ui\u002F08.layout-advanced",{"title":1427,"path":1428,"stem":1429},"Адаптивний Layout та найкращі практики","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-responsive","01.csharp\u002F12.desktop-ui\u002F09.layout-responsive",{"title":1431,"path":1432,"stem":1433},"Layout в Avalonia: відмінності та нові можливості","\u002Fcsharp\u002Fdesktop-ui\u002F09a.layout-avalonia","01.csharp\u002F12.desktop-ui\u002F09a.layout-avalonia",{"title":1435,"path":1436,"stem":1437},"Button, Image, ProgressBar та інші базові контроли","\u002Fcsharp\u002Fdesktop-ui\u002Fbasic-controls","01.csharp\u002F12.desktop-ui\u002F10.basic-controls",{"title":1439,"path":1440,"stem":1441},"Контроли в Avalonia: відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F10a.controls-avalonia","01.csharp\u002F12.desktop-ui\u002F10a.controls-avalonia",{"title":1443,"path":1444,"stem":1445},"Текстові контроли — TextBlock, TextBox, RichTextBox","\u002Fcsharp\u002Fdesktop-ui\u002Ftext-controls","01.csharp\u002F12.desktop-ui\u002F11.text-controls",{"title":1447,"path":1448,"stem":1449},"Контроли вибору — CheckBox, RadioButton, ComboBox, ListBox, DatePicker","\u002Fcsharp\u002Fdesktop-ui\u002Fselection-controls","01.csharp\u002F12.desktop-ui\u002F12.selection-controls",{"title":1451,"path":1452,"stem":1453},"Content Model — GroupBox, Expander, TabControl, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fcontent-controls","01.csharp\u002F12.desktop-ui\u002F13.content-controls",{"title":1455,"path":1456,"stem":1457},"UI\u002FUX принципи десктопних застосунків","\u002Fcsharp\u002Fdesktop-ui\u002F13a.ui-ux-principles","01.csharp\u002F12.desktop-ui\u002F13a.ui-ux-principles",{"title":1459,"path":1460,"stem":1461},"Dependency Properties — Концепція та Value Resolution","\u002Fcsharp\u002Fdesktop-ui\u002Fdependency-properties-part1","01.csharp\u002F12.desktop-ui\u002F14.dependency-properties-part1",{"title":1463,"path":1464,"stem":1465},"Avalonia Property System — StyledProperty та DirectProperty","\u002Fcsharp\u002Fdesktop-ui\u002F14a.avalonia-property-system","01.csharp\u002F12.desktop-ui\u002F14a.avalonia-property-system",{"title":1467,"path":1468,"stem":1469},"Attached Properties — Властивості без меж","\u002Fcsharp\u002Fdesktop-ui\u002Fattached-properties","01.csharp\u002F12.desktop-ui\u002F15.attached-properties",{"title":1471,"path":1472,"stem":1473},"Routed Events — Маршрутизація подій у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Frouted-events","01.csharp\u002F12.desktop-ui\u002F16.routed-events",{"title":1475,"path":1476,"stem":1477},"Data Binding — Від Code-Behind до Декларативності","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part1","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part1",{"title":1479,"path":1480,"stem":1481},"INotifyPropertyChanged — Живе оновлення UI","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part2","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part2",{"title":1483,"path":1484,"stem":1485},"Compiled Bindings в Avalonia — Безпека на етапі компіляції","\u002Fcsharp\u002Fdesktop-ui\u002F17a.avalonia-compiled-bindings","01.csharp\u002F12.desktop-ui\u002F17a.avalonia-compiled-bindings",{"title":1487,"path":1488,"stem":1489},"Просунутий Data Binding — ElementName, RelativeSource, MultiBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-advanced","01.csharp\u002F12.desktop-ui\u002F18.data-binding-advanced",{"title":1491,"path":1492,"stem":1493},"Value Converters — Перетворення типів даних у Data Binding","\u002Fcsharp\u002Fdesktop-ui\u002Fvalue-converters","01.csharp\u002F12.desktop-ui\u002F19.value-converters",{"title":1495,"path":1496,"stem":1497},"Data Templates — Візуалізація об'єктів у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-templates","01.csharp\u002F12.desktop-ui\u002F20.data-templates",{"title":1499,"path":1500,"stem":1501},"Collections Binding Part 1 — ObservableCollection та ItemsControl","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part1","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part1",{"title":1503,"path":1504,"stem":1505},"Collections Binding Part 2 — ICollectionView, Filtering, Sorting та Virtualization","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part2","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part2",{"title":1507,"path":1508,"stem":1509},"MVVM Pattern — Від Spaghetti Code до архітектури","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-pattern","01.csharp\u002F12.desktop-ui\u002F22.mvvm-pattern",{"title":1511,"path":1512,"stem":1513},"ViewModel Implementation — Від BaseViewModel до валідації","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-implementation","01.csharp\u002F12.desktop-ui\u002F23.viewmodel-implementation",{"title":1515,"path":1516,"stem":1517},"Commands — Від event handlers до декларативних команд","\u002Fcsharp\u002Fdesktop-ui\u002Fcommands","01.csharp\u002F12.desktop-ui\u002F24.commands",{"title":1519,"path":1520,"stem":1521},"MVVM Toolkit — MVVM без boilerplate через Source Generators","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-toolkit","01.csharp\u002F12.desktop-ui\u002F25.mvvm-toolkit",{"title":1523,"path":1524,"stem":1525},"Messenger Pattern — Комунікація між ViewModel без прямих посилань","\u002Fcsharp\u002Fdesktop-ui\u002Fmessenger-pattern","01.csharp\u002F12.desktop-ui\u002F26.messenger-pattern",{"title":1527,"path":1528,"stem":1529},"Стилі WPF — CSS для десктопу","\u002Fcsharp\u002Fdesktop-ui\u002Fstyles-basics","01.csharp\u002F12.desktop-ui\u002F27.styles-basics",{"title":1531,"path":1532,"stem":1533},"CSS-like стилі Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F27a.avalonia-css-styling","01.csharp\u002F12.desktop-ui\u002F27a.avalonia-css-styling",{"title":1535,"path":1536,"stem":1537},"Control Templates — Частина 1. Концепція та TemplateBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part1","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part1",{"title":1539,"path":1540,"stem":1541},"Control Templates — Частина 2. Named Parts та ContentPresenter","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part2","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part2",{"title":1543,"path":1544,"stem":1545},"Control Themes в Avalonia — нова ера стилізації","\u002Fcsharp\u002Fdesktop-ui\u002F28a.avalonia-control-themes","01.csharp\u002F12.desktop-ui\u002F28a.avalonia-control-themes",{"title":1547,"path":1548,"stem":1549},"Triggers та Visual State Manager у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Ftriggers-visual-states","01.csharp\u002F12.desktop-ui\u002F29.triggers-visual-states",{"title":1551,"path":1552,"stem":1553},"Pseudo-classes в Avalonia — замість WPF Triggers","\u002Fcsharp\u002Fdesktop-ui\u002F29a.avalonia-pseudo-classes","01.csharp\u002F12.desktop-ui\u002F29a.avalonia-pseudo-classes",{"title":1555,"path":1556,"stem":1557},"Теми та ресурсні словники у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fresources-themes","01.csharp\u002F12.desktop-ui\u002F30.resources-themes",{"title":1559,"path":1560,"stem":1561},"Avalonia Themes — Fluent Design та система тематизації","\u002Fcsharp\u002Fdesktop-ui\u002F30a.avalonia-themes-fluent","01.csharp\u002F12.desktop-ui\u002F30a.avalonia-themes-fluent",{"title":1563,"path":1564,"stem":1565},"Контроли колекцій — глибоке занурення","\u002Fcsharp\u002Fdesktop-ui\u002Fcollection-controls","01.csharp\u002F12.desktop-ui\u002F31.collection-controls",{"title":1567,"path":1568,"stem":1569},"DataGrid — колонки та базове відображення","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part1","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part1",{"title":1571,"path":1572,"stem":1573},"DataGrid — сортування, фільтрація, редагування","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part2","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part2",{"title":1575,"path":1576,"stem":1577},"TreeView та GridView","\u002Fcsharp\u002Fdesktop-ui\u002Ftreeview-listview","01.csharp\u002F12.desktop-ui\u002F33.treeview-listview",{"title":1579,"path":1580,"stem":1581},"Меню, Toolbar, ContextMenu, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fmenus-toolbars","01.csharp\u002F12.desktop-ui\u002F34.menus-toolbars",{"title":1583,"path":1584,"stem":1585},"Навігація та керування вікнами. Частина 1: вікна та сторінки","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part1","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part1",{"title":1587,"path":1588,"stem":1589},"Навігація та керування вікнами. Частина 2: MVVM-навігація","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part2","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part2",{"title":1591,"path":1592,"stem":1593},"Avalonia — Навігація та діалоги","\u002Fcsharp\u002Fdesktop-ui\u002F35a.avalonia-navigation-dialogs","01.csharp\u002F12.desktop-ui\u002F35a.avalonia-navigation-dialogs",{"title":1595,"path":1596,"stem":1597},"Діалоги та File Pickers у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdialogs-file-pickers","01.csharp\u002F12.desktop-ui\u002F36.dialogs-file-pickers",{"title":1599,"path":1600,"stem":1601},"UserControl: компонентний підхід у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fuser-controls","01.csharp\u002F12.desktop-ui\u002F37.user-controls",{"title":1603,"path":1604,"stem":1605},"Custom Controls: Lookless Controls у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fcustom-controls","01.csharp\u002F12.desktop-ui\u002F38.custom-controls",{"title":1607,"path":1608,"stem":1609},"Avalonia TemplatedControl — Lookless Controls","\u002Fcsharp\u002Fdesktop-ui\u002F38a.avalonia-templated-controls","01.csharp\u002F12.desktop-ui\u002F38a.avalonia-templated-controls",{"title":1611,"path":1612,"stem":1613},"Анімації у WPF: Storyboard та Easing Functions","\u002Fcsharp\u002Fdesktop-ui\u002Fanimations-transitions","01.csharp\u002F12.desktop-ui\u002F39.animations-transitions",{"title":1615,"path":1616,"stem":1617},"Анімації в Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F39a.avalonia-animations","01.csharp\u002F12.desktop-ui\u002F39a.avalonia-animations",{"title":1619,"path":1620,"stem":1621},"2D Графіка та Мультимедіа у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fmedia-graphics","01.csharp\u002F12.desktop-ui\u002F40.media-graphics",{"title":1623,"path":1624,"stem":1625},"Dependency Injection у WPF та Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Fdi-integration","01.csharp\u002F12.desktop-ui\u002F41.di-integration",{"title":1627,"path":1628,"stem":1629},"SQLite та EF Core у десктопних додатках","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part1","01.csharp\u002F12.desktop-ui\u002F42.data-persistence-part1",{"title":1631,"path":1632,"stem":1633},"Repository Pattern та Unit of Work","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part2","01.csharp\u002F12.desktop-ui\u002F43.data-persistence-part2",{"title":1635,"path":1636,"stem":1637},"Тестування ViewModels","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-testing","01.csharp\u002F12.desktop-ui\u002F44.viewmodel-testing",{"title":1639,"path":1640,"stem":1641},"Avalonia Headless Testing — тестування UI без вікон","\u002Fcsharp\u002Fdesktop-ui\u002F44a.avalonia-headless-testing","01.csharp\u002F12.desktop-ui\u002F44a.avalonia-headless-testing",{"title":1643,"path":1644,"stem":1645},"Кросплатформна розробка з Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-cross-platform","01.csharp\u002F12.desktop-ui\u002F45.avalonia-cross-platform",{"title":1647,"path":1648,"stem":1649},"Пакування та розгортання Avalonia додатків","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F46.avalonia-packaging-deployment",{"title":1651,"path":1652,"stem":1653},"Розгортання WPF застосунків","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F47.wpf-packaging-deployment",{"title":1655,"icon":658,"path":1656,"stem":1657,"children":1658,"page":59},"Network Programming","\u002Fcsharp\u002Fnetwork-programming","01.csharp\u002F13.network-programming",[1659,1663,1667,1671,1675,1679,1683,1687,1691,1695,1699],{"title":1660,"path":1661,"stem":1662},"Основи комп'ютерних мереж","\u002Fcsharp\u002Fnetwork-programming\u002Ffoundations","01.csharp\u002F13.network-programming\u002F01.foundations",{"title":1664,"path":1665,"stem":1666},"Модель OSI та стек TCP\u002FIP","\u002Fcsharp\u002Fnetwork-programming\u002Fosi-model","01.csharp\u002F13.network-programming\u002F02.osi-model",{"title":1668,"path":1669,"stem":1670},"IP-протокол та адресація","\u002Fcsharp\u002Fnetwork-programming\u002Fip-addressing","01.csharp\u002F13.network-programming\u002F03.ip-addressing",{"title":1672,"path":1673,"stem":1674},"UDP — протокол без з'єднання","\u002Fcsharp\u002Fnetwork-programming\u002Fudp","01.csharp\u002F13.network-programming\u002F05.udp",{"title":1676,"path":1677,"stem":1678},"UDP Broadcast та Multicast","\u002Fcsharp\u002Fnetwork-programming\u002Fudp-broadcast-multicast","01.csharp\u002F13.network-programming\u002F06.udp-broadcast-multicast",{"title":1680,"path":1681,"stem":1682},"HTTP — протокол вебу","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-fundamentals","01.csharp\u002F13.network-programming\u002F07.http-fundamentals",{"title":1684,"path":1685,"stem":1686},"HttpListener — вбудований HTTP-сервер .NET","\u002Fcsharp\u002Fnetwork-programming\u002F07a.http-listener","01.csharp\u002F13.network-programming\u002F07a.http-listener",{"title":1688,"path":1689,"stem":1690},"HTTP Advanced — cookies, аутентифікація та HTTPS","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-advanced","01.csharp\u002F13.network-programming\u002F08.http-advanced",{"title":1692,"path":1693,"stem":1694},"SMTP та протоколи електронної пошти","\u002Fcsharp\u002Fnetwork-programming\u002Fsmtp","01.csharp\u002F13.network-programming\u002F09.smtp",{"title":1696,"path":1697,"stem":1698},"WebSocket — повнодуплексний протокол реального часу","\u002Fcsharp\u002Fnetwork-programming\u002Fwebsockets","01.csharp\u002F13.network-programming\u002F10.websockets",{"title":1700,"path":1701,"stem":1702},"TLS\u002FSSL — криптографічний захист мережевих з'єднань","\u002Fcsharp\u002Fnetwork-programming\u002Ftls-ssl","01.csharp\u002F13.network-programming\u002F11.tls-ssl",{"title":1704,"path":1705,"stem":1706},"C# & .NET: The Ultimate Roadmap","\u002Fcsharp\u002Froadmap","01.csharp\u002Froadmap",{"title":1708,"icon":1709,"path":1710,"stem":1711,"children":1712,"page":59},"C++","i-devicon-cplusplus","\u002Fcpp","02.cpp",[1713,1717,1721,1725,1729,1733,1737,1741,1745,1748,1752,1756,1760,1764,1768,1772,1776,1780,1784,1788,1792,1796,1800,1804,1808,1812,1816,1820,1824,1828,1832,1836,1840,1844,1848,1852,1856,1860,1864,1868,1872,1876,1880,1884,1888,1892,1896,1900],{"title":1714,"path":1715,"stem":1716},"Вступ у програмування та алгоритми","\u002Fcpp\u002Fintro-algorithms","02.cpp\u002F01.intro-algorithms",{"title":1718,"path":1719,"stem":1720},"Code Style: угоди про оформлення коду","\u002Fcpp\u002Fcode-style","02.cpp\u002F02.code-style",{"title":1722,"path":1723,"stem":1724},"Середовище розробки та перший проєкт","\u002Fcpp\u002Fide-setup","02.cpp\u002F03.ide-setup",{"title":1726,"path":1727,"stem":1728},"Вивід даних на екран","\u002Fcpp\u002Fdata-output","02.cpp\u002F04.data-output",{"title":1730,"path":1731,"stem":1732},"Типи даних, змінні та константи","\u002Fcpp\u002Fdata-types-variables","02.cpp\u002F05.data-types-variables",{"title":1734,"path":1735,"stem":1736},"Ввід даних з клавіатури","\u002Fcpp\u002Fdata-input","02.cpp\u002F06.data-input",{"title":1738,"path":1739,"stem":1740},"Оператори, перетворення типів та логічні операції","\u002Fcpp\u002Foperators-type-conversion","02.cpp\u002F07.operators-type-conversion",{"title":1742,"path":1743,"stem":1744},"Цикли","\u002Fcpp\u002Floops","02.cpp\u002F08.loops",{"title":32,"path":1746,"stem":1747},"\u002Fcpp\u002Farrays","02.cpp\u002F09.arrays",{"title":1749,"path":1750,"stem":1751},"Алгоритми сортування та аналіз складності","\u002Fcpp\u002Fsorting","02.cpp\u002F10.sorting",{"title":1753,"path":1754,"stem":1755},"Алгоритми пошуку","\u002Fcpp\u002Fsearching","02.cpp\u002F11.searching",{"title":1757,"path":1758,"stem":1759},"Функції: основи","\u002Fcpp\u002Ffunctions-basics","02.cpp\u002F12.functions-basics",{"title":1761,"path":1762,"stem":1763},"Функції: прототипи, область видимості та додаткові можливості","\u002Fcpp\u002Ffunctions-scope","02.cpp\u002F13.functions-scope",{"title":1765,"path":1766,"stem":1767},"Функції: перевантаження та шаблони","\u002Fcpp\u002Ffunctions-overloading-templates","02.cpp\u002F14.functions-overloading-templates",{"title":1769,"path":1770,"stem":1771},"Вказівники: основи","\u002Fcpp\u002Fpointers-basics","02.cpp\u002F15.pointers-basics",{"title":1773,"path":1774,"stem":1775},"Посилання (References)","\u002Fcpp\u002Freferences","02.cpp\u002F16.references",{"title":1777,"path":1778,"stem":1779},"Вказівники, const і масиви","\u002Fcpp\u002Fpointers-const-arrays","02.cpp\u002F17.pointers-const-arrays",{"title":1781,"path":1782,"stem":1783},"Адресна арифметика","\u002Fcpp\u002Fpointer-arithmetic","02.cpp\u002F18.pointer-arithmetic",{"title":1785,"path":1786,"stem":1787},"Динамічна пам'ять","\u002Fcpp\u002Fdynamic-memory","02.cpp\u002F19.dynamic-memory",{"title":1789,"path":1790,"stem":1791},"Вказівники типу void","\u002Fcpp\u002Fvoid-pointers","02.cpp\u002F20.void-pointers",{"title":1793,"path":1794,"stem":1795},"Вказівники на вказівники","\u002Fcpp\u002Fpointers-to-pointers","02.cpp\u002F21.pointers-to-pointers",{"title":1797,"path":1798,"stem":1799},"Оператор доступу до членів через вказівник (->)","\u002Fcpp\u002Fmember-access-operator","02.cpp\u002F22.member-access-operator",{"title":1801,"path":1802,"stem":1803},"Цикл for-each (Range-based for)","\u002Fcpp\u002Fforeach-loop","02.cpp\u002F23.foreach-loop",{"title":1805,"path":1806,"stem":1807},"Вказівники на функції","\u002Fcpp\u002Ffunction-pointers","02.cpp\u002F24.function-pointers",{"title":1809,"path":1810,"stem":1811},"Лямбда-вирази","\u002Fcpp\u002Flambdas","02.cpp\u002F25.lambdas",{"title":1813,"path":1814,"stem":1815},"Лямбда-захоплення","\u002Fcpp\u002Flambda-captures","02.cpp\u002F26.lambda-captures",{"title":1817,"path":1818,"stem":1819},"Еліпсис","\u002Fcpp\u002Fellipsis","02.cpp\u002F27.ellipsis",{"title":1821,"path":1822,"stem":1823},"Безпечні альтернативи еліпсису","\u002Fcpp\u002F27a.ellipsis","02.cpp\u002F27a.ellipsis",{"title":1825,"path":1826,"stem":1827},"Аргументи командного рядка","\u002Fcpp\u002Fcommand-line-arguments","02.cpp\u002F28.command-line-arguments",{"title":1829,"path":1830,"stem":1831},"Перерахування (enum)","\u002Fcpp\u002Fenum","02.cpp\u002F29.enum",{"title":1833,"path":1834,"stem":1835},"Класи-перерахування (enum class)","\u002Fcpp\u002Fenum-class","02.cpp\u002F30.enum-class",{"title":1837,"path":1838,"stem":1839},"Псевдоніми типів (typedef і using)","\u002Fcpp\u002Ftype-aliases","02.cpp\u002F31.type-aliases",{"title":1841,"path":1842,"stem":1843},"Системи числення та двійкова арифметика","\u002Fcpp\u002Fnumber-systems","02.cpp\u002F32.number-systems",{"title":1845,"path":1846,"stem":1847},"Структури (struct): агрегування даних","\u002Fcpp\u002Fstruct","02.cpp\u002F33.struct",{"title":1849,"path":1850,"stem":1851},"Структури у функціях","\u002Fcpp\u002Fstruct-functions","02.cpp\u002F34.struct-functions",{"title":1853,"path":1854,"stem":1855},"Масиви структур і вкладені структури","\u002Fcpp\u002Fstruct-arrays","02.cpp\u002F35.struct-arrays",{"title":1857,"path":1858,"stem":1859},"Патерни struct та межі застосування","\u002Fcpp\u002Fstruct-patterns","02.cpp\u002F36.struct-patterns",{"title":1861,"path":1862,"stem":1863},"Символи та таблиця ASCII","\u002Fcpp\u002Fascii-characters","02.cpp\u002F37.ascii-characters",{"title":1865,"path":1866,"stem":1867},"Unicode та кодування UTF","\u002Fcpp\u002Funicode-utf","02.cpp\u002F38.unicode-utf",{"title":1869,"path":1870,"stem":1871},"C-style рядки","\u002Fcpp\u002Fc-strings","02.cpp\u002F39.c-strings",{"title":1873,"path":1874,"stem":1875},"Вступ до std::string","\u002Fcpp\u002Fstd-string-intro","02.cpp\u002F40.std-string-intro",{"title":1877,"path":1878,"stem":1879},"Довжина, ємність та доступ до символів std::string","\u002Fcpp\u002Fstd-string-capacity-access","02.cpp\u002F41.std-string-capacity-access",{"title":1881,"path":1882,"stem":1883},"Модифікація std::string: присвоювання, додавання, вставка, видалення та заміна","\u002Fcpp\u002Fstd-string-modification","02.cpp\u002F42.std-string-modification",{"title":1885,"path":1886,"stem":1887},"Пошук у std::string: find, npos та практичні патерни","\u002Fcpp\u002Fstd-string-search","02.cpp\u002F43.std-string-search",{"title":1889,"path":1890,"stem":1891},"std::string_view: невласницький погляд на рядок без копіювання","\u002Fcpp\u002Fstd-string-view","02.cpp\u002F44.std-string-view",{"title":1893,"path":1894,"stem":1895},"Об'єднання (union): один блок пам'яті, кілька інтерпретацій","\u002Fcpp\u002Funion","02.cpp\u002F45.union",{"title":1897,"path":1898,"stem":1899},"Організація коду: файли, препроцесор, простори імен","\u002Fcpp\u002Fmultifile-programs","02.cpp\u002F46.multifile-programs",{"title":1901,"path":1902,"stem":1903},"План навчання: Курс C++ — Продовження (Статті 29–60+)","\u002Fcpp\u002Fcurriculum-plan","02.cpp\u002Fcurriculum-plan",{"title":1905,"icon":1906,"path":1907,"stem":1908,"children":1909,"page":59},"JavaScript","i-devicon-javascript","\u002Fjavascript","03.javascript",[1910,1936,1990,2012,2316,2354],{"title":1911,"icon":1912,"path":1913,"stem":1914,"children":1915,"page":59},"Events","i-lucide-mouse-pointer-click","\u002Fjavascript\u002Fevents","03.javascript\u002F01.events",[1916,1920,1924,1928,1932],{"title":1917,"path":1918,"stem":1919},"Вступ до подій браузера","\u002Fjavascript\u002Fevents\u002Fintro","03.javascript\u002F01.events\u002F01.intro",{"title":1921,"path":1922,"stem":1923},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","\u002Fjavascript\u002Fevents\u002Fbubbling-capturing","03.javascript\u002F01.events\u002F02.bubbling-capturing",{"title":1925,"path":1926,"stem":1927},"Делегування подій (Event Delegation)","\u002Fjavascript\u002Fevents\u002Fdelegate-events","03.javascript\u002F01.events\u002F03.delegate-events",{"title":1929,"path":1930,"stem":1931},"Типові дії браузера та preventDefault()","\u002Fjavascript\u002Fevents\u002Fprevent-default","03.javascript\u002F01.events\u002F04.prevent-default",{"title":1933,"path":1934,"stem":1935},"Запуск користувацьких подій (Custom Events)","\u002Fjavascript\u002Fevents\u002Fcustom-events","03.javascript\u002F01.events\u002F05.custom-events",{"title":1937,"icon":1938,"path":1939,"stem":1940,"children":1941,"page":59},"Network","i-lucide-globe","\u002Fjavascript\u002Fnetwork","03.javascript\u002F02.network",[1942,1946,1950,1954,1958,1962,1966,1970,1974,1978,1982,1986],{"title":1943,"path":1944,"stem":1945},"Fetch API - Сучасний підхід до HTTP-запитів","\u002Fjavascript\u002Fnetwork\u002F01-fetch-api","03.javascript\u002F02.network\u002F01-fetch-api",{"title":1947,"path":1948,"stem":1949},"FormData - Робота з формами та файлами","\u002Fjavascript\u002Fnetwork\u002F02-formdata","03.javascript\u002F02.network\u002F02-formdata",{"title":1951,"path":1952,"stem":1953},"Відстеження прогресу завантаження","\u002Fjavascript\u002Fnetwork\u002F03-download-progress","03.javascript\u002F02.network\u002F03-download-progress",{"title":1955,"path":1956,"stem":1957},"Переривання fetch-запитів","\u002Fjavascript\u002Fnetwork\u002F04-abort-requests","03.javascript\u002F02.network\u002F04-abort-requests",{"title":1959,"path":1960,"stem":1961},"CORS - Запити між різними джерелами","\u002Fjavascript\u002Fnetwork\u002F05-cors","03.javascript\u002F02.network\u002F05-cors",{"title":1963,"path":1964,"stem":1965},"Fetch API - Повний довідник опцій","\u002Fjavascript\u002Fnetwork\u002F06-fetch-options","03.javascript\u002F02.network\u002F06-fetch-options",{"title":1967,"path":1968,"stem":1969},"URL Objects - Робота з посиланнями","\u002Fjavascript\u002Fnetwork\u002F07-url-objects","03.javascript\u002F02.network\u002F07-url-objects",{"title":1971,"path":1972,"stem":1973},"XMLHttpRequest - AJAX та низькорівневі запити","\u002Fjavascript\u002Fnetwork\u002F08-xmlhttprequest","03.javascript\u002F02.network\u002F08-xmlhttprequest",{"title":1975,"path":1976,"stem":1977},"Відновлюване завантаження файлів","\u002Fjavascript\u002Fnetwork\u002F09-resumable-upload","03.javascript\u002F02.network\u002F09-resumable-upload",{"title":1979,"path":1980,"stem":1981},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","\u002Fjavascript\u002Fnetwork\u002F10-cookies","03.javascript\u002F02.network\u002F10-cookies",{"title":1983,"path":1984,"stem":1985},"js-cookie: Керування Cookies без Болю","\u002Fjavascript\u002Fnetwork\u002F11-js-cookie","03.javascript\u002F02.network\u002F11-js-cookie",{"title":1987,"path":1988,"stem":1989},"Axios: Потужний HTTP-клієнт для JavaScript","\u002Fjavascript\u002Fnetwork\u002F12-axios","03.javascript\u002F02.network\u002F12-axios",{"title":1991,"icon":1992,"path":1993,"stem":1994,"children":1995,"page":59},"Bom","i-lucide-monitor","\u002Fjavascript\u002Fbom","03.javascript\u002F03.bom",[1996,2000,2004,2008],{"title":1997,"path":1998,"stem":1999},"LocalStorage, SessionStorage та patterns збереження даних","\u002Fjavascript\u002Fbom\u002F01-localstorage","03.javascript\u002F03.bom\u002F01-localstorage",{"title":2001,"path":2002,"stem":2003},"Location Object - Керування адресою сторінки","\u002Fjavascript\u002Fbom\u002F02-location-object","03.javascript\u002F03.bom\u002F02-location-object",{"title":2005,"path":2006,"stem":2007},"History API - Керування історією браузера","\u002Fjavascript\u002Fbom\u002F03-history-api","03.javascript\u002F03.bom\u002F03-history-api",{"title":2009,"path":2010,"stem":2011},"Navigator Object - Ідентифікація та Можливості Пристрою","\u002Fjavascript\u002Fbom\u002F04-navigator-object","03.javascript\u002F03.bom\u002F04-navigator-object",{"title":2013,"icon":2014,"path":2015,"stem":2016,"children":2017},"React","i-devicon-react","\u002Fjavascript\u002Freact","03.javascript\u002F04.react\u002Findex",[2018,2019,2023,2027,2031,2035,2098,2133,2285],{"title":2013,"path":2015,"stem":2016},{"title":2020,"path":2021,"stem":2022},"Робота з Формами в React","\u002Fjavascript\u002Freact\u002Freact-forms","03.javascript\u002F04.react\u002F01.react-forms",{"title":2024,"path":2025,"stem":2026},"React Hook Form: Професійна Робота з Формами","\u002Fjavascript\u002Freact\u002Freact-hook-form","03.javascript\u002F04.react\u002F02.react-hook-form",{"title":2028,"path":2029,"stem":2030},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","\u002Fjavascript\u002Freact\u002Freact-hook-form-new","03.javascript\u002F04.react\u002F02.react-hook-form-new",{"title":2032,"path":2033,"stem":2034},"Axios та React: Професійна Архітектура Запитів","\u002Fjavascript\u002Freact\u002Fdata-fetching-axios","03.javascript\u002F04.react\u002F03.data-fetching-axios",{"title":2036,"icon":132,"path":2037,"stem":2038,"children":2039},"Tanstack Query","\u002Fjavascript\u002Freact\u002Ftanstack-query","03.javascript\u002F04.react\u002F04.tanstack-query\u002Findex",[2040,2042,2046,2050,2054,2058,2062,2066,2070,2074,2078,2082,2086,2090,2094],{"title":2041,"path":2037,"stem":2038},"TanStack Query: Майстерність Керування Станом Сервера",{"title":2043,"path":2044,"stem":2045},"Парадигма Server State: Чому useEffect недостатньо","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-state-paradigm","03.javascript\u002F04.react\u002F04.tanstack-query\u002F01.server-state-paradigm",{"title":2047,"path":2048,"stem":2049},"Встановлення та Налаштування: Фундамент","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Finstallation-and-devtools","03.javascript\u002F04.react\u002F04.tanstack-query\u002F02.installation-and-devtools",{"title":2051,"path":2052,"stem":2053},"Основи Запитів та Магія Ключів","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fquery-basics-and-keys","03.javascript\u002F04.react\u002F04.tanstack-query\u002F03.query-basics-and-keys",{"title":2055,"path":2056,"stem":2057},"Синхронізація Даних: Життєвий Цикл Запиту","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fdata-synchronization","03.javascript\u002F04.react\u002F04.tanstack-query\u002F04.data-synchronization",{"title":2059,"path":2060,"stem":2061},"Мутації та Інвалідація: Зміна Даних","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fmutations-and-invalidation","03.javascript\u002F04.react\u002F04.tanstack-query\u002F05.mutations-and-invalidation",{"title":2063,"path":2064,"stem":2065},"Оптимістичні Оновлення: Швидше за Світло","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Foptimistic-updates","03.javascript\u002F04.react\u002F04.tanstack-query\u002F06.optimistic-updates",{"title":2067,"path":2068,"stem":2069},"Пагінація та Infinite Scroll","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fpagination-and-load-more","03.javascript\u002F04.react\u002F04.tanstack-query\u002F07.pagination-and-load-more",{"title":2071,"path":2072,"stem":2073},"Просунуті Патерни та Оптимізація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F04.tanstack-query\u002F08.advanced-patterns",{"title":2075,"path":2076,"stem":2077},"Архітектура та Best Practices","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Farchitecture-and-best-practices","03.javascript\u002F04.react\u002F04.tanstack-query\u002F09.architecture-and-best-practices",{"title":2079,"path":2080,"stem":2081},"Server-Side Rendering (SSR) та Гідратація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-side-rendering","03.javascript\u002F04.react\u002F04.tanstack-query\u002F10.server-side-rendering",{"title":2083,"path":2084,"stem":2085},"Стратегії Тестування","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Ftesting-strategies","03.javascript\u002F04.react\u002F04.tanstack-query\u002F11.testing-strategies",{"title":2087,"path":2088,"stem":2089},"Аутентифікація та Обробка Помилок","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fauthentication-and-errors","03.javascript\u002F04.react\u002F04.tanstack-query\u002F12.authentication-and-errors",{"title":2091,"path":2092,"stem":2093},"React Suspense та Майбутнє","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Freact-suspense","03.javascript\u002F04.react\u002F04.tanstack-query\u002F13.react-suspense",{"title":2095,"path":2096,"stem":2097},"Глибоке Занурення в Продуктивність","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fperformance-deep-dive","03.javascript\u002F04.react\u002F04.tanstack-query\u002F14.performance-deep-dive",{"title":2099,"icon":2014,"path":2100,"stem":2101,"children":2102},"React Router","\u002Fjavascript\u002Freact\u002Freact-router","03.javascript\u002F04.react\u002F05.react-router\u002Findex",[2103,2105,2109,2113,2117,2121,2125,2129],{"title":2104,"path":2100,"stem":2101},"React Router: Навігаційна система сучасного вебу",{"title":2106,"path":2107,"stem":2108},"Налаштування та Базовий Роутинг","\u002Fjavascript\u002Freact\u002Freact-router\u002Fsetup-and-basic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F01.setup-and-basic-routing",{"title":2110,"path":2111,"stem":2112},"Динамічна Навігація","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnavigation-and-links","03.javascript\u002F04.react\u002F05.react-router\u002F02.navigation-and-links",{"title":2114,"path":2115,"stem":2116},"Вкладені Маршрути та Макети","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnested-routes-and-layouts","03.javascript\u002F04.react\u002F05.react-router\u002F03.nested-routes-and-layouts",{"title":2118,"path":2119,"stem":2120},"Динамічні Маршрути та Параметри","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdynamic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F04.dynamic-routing",{"title":2122,"path":2123,"stem":2124},"Data APIs: Loaders та Actions","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdata-loading","03.javascript\u002F04.react\u002F05.react-router\u002F05.data-loading",{"title":2126,"path":2127,"stem":2128},"Просунуті Патерни","\u002Fjavascript\u002Freact\u002Freact-router\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F05.react-router\u002F06.advanced-patterns",{"title":2130,"path":2131,"stem":2132},"Legacy Routing: Компонентний підхід","\u002Fjavascript\u002Freact\u002Freact-router\u002Flegacy-routing","03.javascript\u002F04.react\u002F05.react-router\u002F07.legacy-routing",{"title":2134,"icon":132,"path":2135,"stem":2136,"children":2137},"Redux","\u002Fjavascript\u002Freact\u002Fredux","03.javascript\u002F04.react\u002F06.redux\u002Findex",[2138,2140,2156,2185,2194,2215,2231,2260],{"title":2139,"path":2135,"stem":2136},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":2141,"stem":2142,"children":2143,"page":59},"\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals",[2144,2148,2152],{"title":2145,"path":2146,"stem":2147},"Вступ до State Management","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fintro-state-management","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F01.intro-state-management",{"title":2149,"path":2150,"stem":2151},"Філософія Redux та Три Принципи","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fredux-philosophy","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F02.redux-philosophy",{"title":2153,"path":2154,"stem":2155},"Чисті функції та Іммутабельність","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fpure-functions-immutability","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F03.pure-functions-immutability",{"title":2157,"icon":132,"path":2158,"stem":2159,"children":2160,"page":59},"Classic Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux",[2161,2165,2169,2173,2177,2181],{"title":2162,"path":2163,"stem":2164},"Створення Store (Classic Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fstore-setup","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F01.store-setup",{"title":2166,"path":2167,"stem":2168},"Actions, Constants та Action Creators","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Factions-constants","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F02.actions-constants",{"title":2170,"path":2171,"stem":2172},"Логіка Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freducers","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F03.reducers",{"title":2174,"path":2175,"stem":2176},"Комбінування Reducers (Root Reducer)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fdata-flow","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F04.data-flow",{"title":2178,"path":2179,"stem":2180},"Підключення до React (React-Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freact-redux-connection","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F05.react-redux-connection",{"title":2182,"path":2183,"stem":2184},"Middleware та Асинхронність (Redux Thunk)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fmiddleware-thunk","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F06.middleware-thunk",{"title":2186,"icon":132,"path":2187,"stem":2188,"children":2189,"page":59},"Transition To Rtk","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk",[2190],{"title":2191,"path":2192,"stem":2193},"Проблеми класичного Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk\u002Fproblems-with-classic","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk\u002F01.problems-with-classic",{"title":2195,"icon":132,"path":2196,"stem":2197,"children":2198,"page":59},"Redux Toolkit","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit",[2199,2203,2207,2211],{"title":2200,"path":2201,"stem":2202},"Налаштування Store з configureStore","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fconfigure-store","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F01.configure-store",{"title":2204,"path":2205,"stem":2206},"createSlice: Революція в Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fcreate-slice","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F02.create-slice",{"title":2208,"path":2209,"stem":2210},"Асинхронність з createAsyncThunk","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fasync-thunks","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F03.async-thunks",{"title":2212,"path":2213,"stem":2214},"04. Entity Adapter: Керування нормалізованим станом","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fentity-adapter","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F04.entity-adapter",{"title":2216,"icon":92,"path":2217,"stem":2218,"children":2219,"page":59},"Advanced","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced",[2220,2224,2228],{"title":2221,"path":2222,"stem":2223},"Мемоізація та Селектори: Повний Гайд по Reselect","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Fselectors-reselect","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F01.selectors-reselect",{"title":2225,"path":2226,"stem":2227},"RTK Query: Архітектура Серверного Кешу","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Frtk-query-intro","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F02.rtk-query-intro",{"title":2075,"path":2229,"stem":2230},"\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Farchitecture-best-practices","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F03.architecture-best-practices",{"title":2232,"icon":132,"path":2233,"stem":2234,"children":2235,"page":59},"Project Kanban","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban",[2236,2240,2244,2248,2252,2256],{"title":2237,"path":2238,"stem":2239},"Проєкт: Kanban Board (Trello Clone)","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fproject-overview","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F01.project-overview",{"title":2241,"path":2242,"stem":2243},"Налаштування та Типізація","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fsetup-and-types","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F02.setup-and-types",{"title":2245,"path":2246,"stem":2247},"Board Slice: Серце Дошки","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fboard-slice","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F03.board-slice",{"title":2249,"path":2250,"stem":2251},"Логіка Drag & Drop","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fdrag-and-drop-logic","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F04.drag-and-drop-logic",{"title":2253,"path":2254,"stem":2255},"Інтеграція з RTK Query","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Frtk-query-integration","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F05.rtk-query-integration",{"title":2257,"path":2258,"stem":2259},"Optimistic Updates","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Foptimistic-updates","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F06.optimistic-updates",{"title":2261,"icon":132,"path":2262,"stem":2263,"children":2264,"page":59},"Testing","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting","03.javascript\u002F04.react\u002F06.redux\u002F07.testing",[2265,2269,2273,2277,2281],{"title":2266,"path":2267,"stem":2268},"Тестування Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Fintro-testing","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F01.intro-testing",{"title":2270,"path":2271,"stem":2272},"Тестування Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-reducers","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F02.testing-reducers",{"title":2274,"path":2275,"stem":2276},"Тестування Селекторів","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-selectors","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F03.testing-selectors",{"title":2278,"path":2279,"stem":2280},"Тестування Компонентів (Integration)","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-components","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F04.testing-components",{"title":2282,"path":2283,"stem":2284},"Тестування Async Thunks","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-thunks","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F05.testing-thunks",{"title":2286,"icon":132,"path":2287,"stem":2288,"children":2289},"Ui Libraries","\u002Fjavascript\u002Freact\u002Fui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002Findex",[2290,2292,2296,2300,2304,2308,2312],{"title":2291,"path":2287,"stem":2288},"UI Бібліотеки в React",{"title":2293,"path":2294,"stem":2295},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fintroduction-to-ui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002F01.introduction-to-ui-libraries",{"title":2297,"path":2298,"stem":2299},"Філософія shadcn\u002Fui: \"Not a Component Library\"","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-philosophy","03.javascript\u002F04.react\u002F07.ui-libraries\u002F02.shadcn-philosophy",{"title":2301,"path":2302,"stem":2303},"Установка та Налаштування shadcn\u002Fui","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-installation","03.javascript\u002F04.react\u002F07.ui-libraries\u002F03.shadcn-installation",{"title":2305,"path":2306,"stem":2307},"Базові Компоненти shadcn\u002Fui: Фундамент Інтерфейсу","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-basics","03.javascript\u002F04.react\u002F07.ui-libraries\u002F04.shadcn-components-basics",{"title":2309,"path":2310,"stem":2311},"Компоненти Форм: Побудова Інтерактивних Form","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-forms","03.javascript\u002F04.react\u002F07.ui-libraries\u002F05.shadcn-components-forms",{"title":2313,"path":2314,"stem":2315},"Складні Компоненти: Dialog, Dropdown, Table та Command","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-advanced","03.javascript\u002F04.react\u002F07.ui-libraries\u002F06.shadcn-components-advanced",{"title":2317,"icon":2318,"path":2319,"stem":2320,"children":2321,"page":59},"TypeScript","i-devicon-typescript","\u002Fjavascript\u002Ftypescript","03.javascript\u002F05.typescript",[2322,2326,2330,2334,2338,2342,2346,2350],{"title":2323,"path":2324,"stem":2325},"TypeScript: Броня для вашого коду","\u002Fjavascript\u002Ftypescript\u002Fintro-and-basic-types","03.javascript\u002F05.typescript\u002F01.intro-and-basic-types",{"title":2327,"path":2328,"stem":2329},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","\u002Fjavascript\u002Ftypescript\u002Finterfaces-and-advanced-types","03.javascript\u002F05.typescript\u002F02.interfaces-and-advanced-types",{"title":2331,"path":2332,"stem":2333},"Алхімія Типів: Generics та Utility Types","\u002Fjavascript\u002Ftypescript\u002Fgenerics-and-utilities","03.javascript\u002F05.typescript\u002F03.generics-and-utilities",{"title":2335,"path":2336,"stem":2337},"Архітектура та Шаблони: Класи в TypeScript","\u002Fjavascript\u002Ftypescript\u002Fclasses-and-oop","03.javascript\u002F05.typescript\u002F04.classes-and-oop",{"title":2339,"path":2340,"stem":2341},"Продакшн та Екосистема: Advanced Config & Workflow","\u002Fjavascript\u002Ftypescript\u002Fadvanced-patterns-and-config","03.javascript\u002F05.typescript\u002F05.advanced-patterns-and-config",{"title":2343,"path":2344,"stem":2345},"TypeScript у світі React","\u002Fjavascript\u002Ftypescript\u002Freact-basics","03.javascript\u002F05.typescript\u002F06.react-basics",{"title":2347,"path":2348,"stem":2349},"React + TypeScript: Продвинуті патерни","\u002Fjavascript\u002Ftypescript\u002Freact-advanced","03.javascript\u002F05.typescript\u002F07.react-advanced",{"title":2351,"path":2352,"stem":2353},"React + TypeScript: Екосистема та бібліотеки","\u002Fjavascript\u002Ftypescript\u002Freact-ecosystem","03.javascript\u002F05.typescript\u002F08.react-ecosystem",{"title":2355,"path":2356,"stem":2357},"Atomic Design","\u002Fjavascript\u002Fatomic-design","03.javascript\u002F2.atomic-design",{"title":2359,"icon":2360,"path":2361,"stem":2362,"children":2363,"page":59},"Java","i-devicon-java","\u002Fjava","04.java",[2364,2367,2370,2374,2378,2382,2386],{"title":162,"path":2365,"stem":2366},"\u002Fjava\u002Fdata-mapper-part1","04.java\u002F01.data-mapper-part1",{"title":166,"path":2368,"stem":2369},"\u002Fjava\u002Fdata-mapper-part2","04.java\u002F02.data-mapper-part2",{"title":2371,"path":2372,"stem":2373},"Service Layer: Організація бізнес-логіки","\u002Fjava\u002Fservice-layer","04.java\u002F03.service-layer",{"title":2375,"path":2376,"stem":2377},"Rich Domain Model та State Pattern","\u002Fjava\u002Frich-domain-model","04.java\u002F04.rich-domain-model",{"title":2379,"path":2380,"stem":2381},"Патерни для складної бізнес-логіки","\u002Fjava\u002Fbusiness-logic-patterns","04.java\u002F05.business-logic-patterns",{"title":2383,"path":2384,"stem":2385},"Обробка помилок та валідація","\u002Fjava\u002Ferror-handling-validation","04.java\u002F06.error-handling-validation",{"title":2387,"path":2388,"stem":2389,"children":2390,"page":59},"Проектування баз даних","\u002Fjava\u002Fpr2","04.java\u002Fpr2",[2391,2395,2399,2403,2407,2411,2415,2419,2423,2427,2431,2435,2439,2443,2447,2451,2455,2459,2463,2467,2471,2475,2479,2483,2487,2491,2495,2499,2503,2507,2511,2515,2519,2523,2527,2531,2535],{"title":2392,"path":2393,"stem":2394},"Концептуальне моделювання: Мистецтво розуміння предметної області","\u002Fjava\u002Fpr2\u002Fconceptual-modeling","04.java\u002Fpr2\u002F01.conceptual-modeling",{"title":2396,"path":2397,"stem":2398},"Логічне моделювання: Від бізнес-ідей до структур даних","\u002Fjava\u002Fpr2\u002Flogical-modeling","04.java\u002Fpr2\u002F02.logical-modeling",{"title":2400,"path":2401,"stem":2402},"Нормалізація: Гігієна даних та боротьба з аномаліями","\u002Fjava\u002Fpr2\u002Fnormalization","04.java\u002Fpr2\u002F03.normalization",{"title":2404,"path":2405,"stem":2406},"Фізична схема: Від абстракції до DDL","\u002Fjava\u002Fpr2\u002Fphysical-schema","04.java\u002Fpr2\u002F04.physical-schema",{"title":2408,"path":2409,"stem":2410},"Архітектурна класифікація таблиць","\u002Fjava\u002Fpr2\u002Ftable-classification","04.java\u002Fpr2\u002F05.table-classification",{"title":2412,"path":2413,"stem":2414},"Database Migrations: Версіонування схеми з Flyway","\u002Fjava\u002Fpr2\u002Fdatabase-migrations","04.java\u002Fpr2\u002F06.database-migrations",{"title":2416,"path":2417,"stem":2418},"А що, якби це була не реляційна БД?","\u002Fjava\u002Fpr2\u002Fbeyond-relational","04.java\u002Fpr2\u002F07.beyond-relational",{"title":2420,"path":2421,"stem":2422},"Object-Relational Impedance Mismatch: Два світи, що не хочуть дружити","\u002Fjava\u002Fpr2\u002Fimpedance-mismatch","04.java\u002Fpr2\u002F09.impedance-mismatch",{"title":2424,"path":2425,"stem":2426},"JDBC: Перший контакт із базою даних","\u002Fjava\u002Fpr2\u002Fjdbc-fundamentals","04.java\u002Fpr2\u002F10.jdbc-fundamentals",{"title":2428,"path":2429,"stem":2430},"Якість коду: Spotless, SpotBugs та SonarQube","\u002Fjava\u002Fpr2\u002F10a.code-quality","04.java\u002Fpr2\u002F10a.code-quality",{"title":2432,"path":2433,"stem":2434},"Connection Pool: Патерн Object Pool для JDBC-з'єднань","\u002Fjava\u002Fpr2\u002Fconnection-pool","04.java\u002Fpr2\u002F11.connection-pool",{"title":2436,"path":2437,"stem":2438},"Row Data Gateway: Об'єкт як обгортка рядка таблиці","\u002Fjava\u002Fpr2\u002Frow-data-gateway","04.java\u002Fpr2\u002F12.row-data-gateway",{"title":2440,"path":2441,"stem":2442},"Table Data Gateway: Фасад таблиці як архітектурний відступ","\u002Fjava\u002Fpr2\u002Ftable-data-gateway","04.java\u002Fpr2\u002F13.table-data-gateway",{"title":2444,"path":2445,"stem":2446},"Repository + Data Mapper: Правильна шарова архітектура з JDBC","\u002Fjava\u002Fpr2\u002Frepository-data-mapper","04.java\u002Fpr2\u002F14.repository-data-mapper",{"title":2448,"path":2449,"stem":2450},"Identity Map: Кешування сутностей у рамках сесії","\u002Fjava\u002Fpr2\u002Fidentity-map","04.java\u002Fpr2\u002F15.identity-map",{"title":2452,"path":2453,"stem":2454},"Unit of Work: Відстеження змін і координація JDBC-транзакцій","\u002Fjava\u002Fpr2\u002Funit-of-work","04.java\u002Fpr2\u002F16.unit-of-work",{"title":2456,"path":2457,"stem":2458},"Strategy: Замінювані SQL-стратегії для підтримки різних СУБД","\u002Fjava\u002Fpr2\u002Fstrategy-sql","04.java\u002Fpr2\u002F17.strategy-sql",{"title":2460,"path":2461,"stem":2462},"Proxy: Lazy Loading для One-To-Many колекцій","\u002Fjava\u002Fpr2\u002Fproxy-lazy-loading","04.java\u002Fpr2\u002F18.proxy-lazy-loading",{"title":2464,"path":2465,"stem":2466},"Generic Repository через Java Reflection: анотації та динамічний SQL","\u002Fjava\u002Fpr2\u002Fgeneric-repository-reflection","04.java\u002Fpr2\u002F19.generic-repository-reflection",{"title":2468,"path":2469,"stem":2470},"Specification Pattern: Композиція бізнес-правил для складних запитів","\u002Fjava\u002Fpr2\u002Fspecification-pattern","04.java\u002Fpr2\u002F20.specification-pattern",{"title":2472,"path":2473,"stem":2474},"Розширені можливості Specification Pattern: підзапити, агрегації та гібридний підхід","\u002Fjava\u002Fpr2\u002F20a.advanced-specifications","04.java\u002Fpr2\u002F20a.advanced-specifications",{"title":2476,"path":2477,"stem":2478},"Асинхронність у JDBC: Від блокуючих викликів до CompletableFuture","\u002Fjava\u002Fpr2\u002Fasynchronous-jdbc","04.java\u002Fpr2\u002F21.asynchronous-jdbc",{"title":2480,"path":2481,"stem":2482},"Інтеграційне тестування JDBC-репозиторіїв: Embedded H2 та патерн AAA","\u002Fjava\u002Fpr2\u002Fintegration-testing-h2","04.java\u002Fpr2\u002F22.integration-testing-h2",{"title":2484,"path":2485,"stem":2486},"Testcontainers: Тестування з реальною PostgreSQL у Docker-контейнерах","\u002Fjava\u002Fpr2\u002Fintegration-testing-testcontainers","04.java\u002Fpr2\u002F23.integration-testing-testcontainers",{"title":2488,"path":2489,"stem":2490},"Google Guice: Впровадження залежностей у JavaFX-проєкті","\u002Fjava\u002Fpr2\u002Fdependency-injection-guice","04.java\u002Fpr2\u002F24.dependency-injection-guice",{"title":2492,"path":2493,"stem":2494},"JavaFX: Основи побудови графічних інтерфейсів","\u002Fjava\u002Fpr2\u002Fjavafx-fundamentals","04.java\u002Fpr2\u002F25.javafx-fundamentals",{"title":2496,"path":2497,"stem":2498},"Properties та Bindings: Реактивність у JavaFX","\u002Fjava\u002Fpr2\u002Fjavafx-properties-bindings","04.java\u002Fpr2\u002F26.javafx-properties-bindings",{"title":2500,"path":2501,"stem":2502},"MVC vs MVP vs MVVM: Еволюція архітектурних патернів UI","\u002Fjava\u002Fpr2\u002Fui-architecture-patterns","04.java\u002Fpr2\u002F27.ui-architecture-patterns",{"title":2504,"path":2505,"stem":2506},"MVVM на практиці: Побудова ViewModel","\u002Fjava\u002Fpr2\u002Fmvvm-viewmodel-implementation","04.java\u002Fpr2\u002F28.mvvm-viewmodel-implementation",{"title":2508,"path":2509,"stem":2510},"View та Controller: Зв'язування з ViewModel через FXML","\u002Fjava\u002Fpr2\u002Fmvvm-view-controller","04.java\u002Fpr2\u002F29.mvvm-view-controller",{"title":2512,"path":2513,"stem":2514},"Інтеграція MVVM з Guice: Автоматична ін'єкція залежностей","\u002Fjava\u002Fpr2\u002Fmvvm-guice-integration","04.java\u002Fpr2\u002F30.mvvm-guice-integration",{"title":2516,"path":2517,"stem":2518},"Валідація та обробка помилок у MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-validation-error-handling","04.java\u002Fpr2\u002F31.mvvm-validation-error-handling",{"title":2520,"path":2521,"stem":2522},"Навігація та управління екранами у JavaFX MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-navigation-screen-management","04.java\u002Fpr2\u002F32.mvvm-navigation-screen-management",{"title":2524,"path":2525,"stem":2526},"Тестування JavaFX MVVM-додатків","\u002Fjava\u002Fpr2\u002Fmvvm-testing","04.java\u002Fpr2\u002F33.mvvm-testing",{"title":2528,"path":2529,"stem":2530},"Стилізація та теми у JavaFX: CSS та User Experience","\u002Fjava\u002Fpr2\u002Fjavafx-styling-themes","04.java\u002Fpr2\u002F34.javafx-styling-themes",{"title":2532,"path":2533,"stem":2534},"AtlantaFX: Сучасні теми для JavaFX додатків","\u002Fjava\u002Fpr2\u002Fatlantafx-modern-themes","04.java\u002Fpr2\u002F35.atlantafx-modern-themes",{"title":2536,"path":2537,"stem":2538},"Пакування та розповсюдження JavaFX-додатків","\u002Fjava\u002Fpr2\u002Fjar-packaging-distribution","04.java\u002Fpr2\u002F36.jar-packaging-distribution",{"title":2540,"icon":2541,"path":2542,"stem":2543,"children":2544,"page":59},"Python","i-devicon-python","\u002Fpython","05.python",[2545,2549,2552,2556,2560,2564,2568,2572,2576,2580,2584,2588,2592,2596,2600,2604],{"title":2546,"path":2547,"stem":2548},"Модулі, Пакети та Віртуальні Середовища","\u002Fpython\u002Fmodules-packages-venv","05.python\u002F00.modules-packages-venv",{"title":71,"path":2550,"stem":2551},"\u002Fpython\u002Fclasses-objects","05.python\u002F01.classes-objects",{"title":2553,"path":2554,"stem":2555},"Інкапсуляція, Керування Доступом та Властивості","\u002Fpython\u002Fencapsulation","05.python\u002F02.encapsulation",{"title":2557,"path":2558,"stem":2559},"Наслідування, MRO та суперсила super()","\u002Fpython\u002Finheritance-mro","05.python\u002F03.inheritance-mro",{"title":2561,"path":2562,"stem":2563},"Абстракція — ABC проти Статичних Протоколів (PEP 544)","\u002Fpython\u002Fabstraction-protocols","05.python\u002F04.abstraction-protocols",{"title":2565,"path":2566,"stem":2567},"Магічні методи (Dunder) та Емуляція протоколів","\u002Fpython\u002Fdunder-methods","05.python\u002F05.dunder-methods",{"title":2569,"path":2570,"stem":2571},"Декоратори та Керування життєвим циклом методів","\u002Fpython\u002Fdecorators-static-class","05.python\u002F06.decorators-static-class",{"title":2573,"path":2574,"stem":2575},"Дескриптори — Магія доступу до атрибутів","\u002Fpython\u002Fdescriptors","05.python\u002F07.descriptors",{"title":2577,"path":2578,"stem":2579},"Метакласи — Динамічне створення класів під капотом CPython","\u002Fpython\u002Fmetaclasses","05.python\u002F08.metaclasses",{"title":2581,"path":2582,"stem":2583},"Dataclasses, NamedTuple та сучасні контейнери Python","\u002Fpython\u002Fmodern-containers","05.python\u002F09.modern-containers",{"title":2585,"path":2586,"stem":2587},"GIL та модель конкурентності CPython — фундамент перед потоками і процесами","\u002Fpython\u002Fgil-concurrency-intro","05.python\u002F11.gil-concurrency-intro",{"title":2589,"path":2590,"stem":2591},"Threading — конкурентність для I\u002FO-bound задач","\u002Fpython\u002Fthreading","05.python\u002F12.threading",{"title":2593,"path":2594,"stem":2595},"Multiprocessing — справжній паралелізм для CPU-bound задач","\u002Fpython\u002Fmultiprocessing","05.python\u002F13.multiprocessing",{"title":2597,"path":2598,"stem":2599},"asyncio — кооперативна конкурентність та event loop","\u002Fpython\u002Fasyncio","05.python\u002F14.asyncio",{"title":2601,"path":2602,"stem":2603},"📦 Повний посібник з модулів, пакетів та віртуальних середовищ у Python","\u002Fpython\u002Flesson_9","05.python\u002Flesson_9",{"title":2605,"path":2606,"stem":2607},"[object Object]","\u002Fpython\u002Foop-plan","05.python\u002Foop-plan",{"title":2609,"icon":2610,"path":2611,"stem":2612,"children":2613,"page":59},"Бази даних","i-lucide-database","\u002Fdatabases","06.databases",[2614,2644,2667,2704,2733,2751,2785,2797,2806],{"title":2615,"icon":2616,"path":2617,"stem":2618,"children":2619,"page":59},"Intro","i-lucide-play","\u002Fdatabases\u002Fintro","06.databases\u002F01.intro",[2620,2624,2628,2632,2636,2640],{"title":2621,"path":2622,"stem":2623},"Введення в теорію баз даних","\u002Fdatabases\u002Fintro\u002Fintroduction-to-databases","06.databases\u002F01.intro\u002F01.introduction-to-databases",{"title":2625,"path":2626,"stem":2627},"Реляційна модель даних","\u002Fdatabases\u002Fintro\u002Frelational-model-theory","06.databases\u002F01.intro\u002F02.relational-model-theory",{"title":2629,"path":2630,"stem":2631},"ER-моделювання","\u002Fdatabases\u002Fintro\u002Fer-modeling","06.databases\u002F01.intro\u002F03.er-modeling",{"title":2633,"path":2634,"stem":2635},"Логічне проектування БД","\u002Fdatabases\u002Fintro\u002Flogical-schema","06.databases\u002F01.intro\u002F04.logical-schema",{"title":2637,"path":2638,"stem":2639},"Класифікація таблиць","\u002Fdatabases\u002Fintro\u002Ftable-classification","06.databases\u002F01.intro\u002F05.table-classification",{"title":2641,"path":2642,"stem":2643},"PlantUML для баз даних","\u002Fdatabases\u002Fintro\u002Fplantuml-diagrams","06.databases\u002F01.intro\u002F06.plantuml-diagrams",{"title":2645,"icon":2610,"path":2646,"stem":2647,"children":2648,"page":59},"MS SQL Server Start","\u002Fdatabases\u002Fms-sql-server-start","06.databases\u002F02.ms-sql-server-start",[2649,2653,2659,2663],{"title":2650,"path":2651,"stem":2652},"Типи даних у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fdata-types","06.databases\u002F02.ms-sql-server-start\u002F01.data-types",{"title":2654,"path":2655,"stem":2656,"children":2657},"Індекси у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-indexes","06.databases\u002F02.ms-sql-server-start\u002F02.sql-indexes",[2658],{"title":2654,"path":2655,"stem":2656},{"title":2660,"path":2661,"stem":2662},"Системні бази даних MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsystem-databases","06.databases\u002F02.ms-sql-server-start\u002F03.system-databases",{"title":2664,"path":2665,"stem":2666},"Огляд мови SQL та запитів","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-queries-overview","06.databases\u002F02.ms-sql-server-start\u002F04.sql-queries-overview",{"title":2668,"icon":2610,"path":2669,"stem":2670,"children":2671,"page":59},"SQL","\u002Fdatabases\u002Fsql","06.databases\u002F03.sql",[2672,2676,2680,2684,2688,2692,2696,2700],{"title":2673,"path":2674,"stem":2675},"Налаштування демонстраційної бази даних","\u002Fdatabases\u002Fsql\u002Fsample-database-setup","06.databases\u002F03.sql\u002F00.sample-database-setup",{"title":2677,"path":2678,"stem":2679},"DDL - Створення таблиць (CREATE TABLE)","\u002Fdatabases\u002Fsql\u002Fddl-create-table","06.databases\u002F03.sql\u002F01.ddl-create-table",{"title":2681,"path":2682,"stem":2683},"DDL - Зміна та видалення таблиць (ALTER, DROP)","\u002Fdatabases\u002Fsql\u002Fddl-alter-drop-table","06.databases\u002F03.sql\u002F02.ddl-alter-drop-table",{"title":2685,"path":2686,"stem":2687},"SELECT запити - Основи","\u002Fdatabases\u002Fsql\u002Fselect-queries-fundamentals","06.databases\u002F03.sql\u002F03.select-queries-fundamentals",{"title":2689,"path":2690,"stem":2691},"SELECT запити - Розширені можливості","\u002Fdatabases\u002Fsql\u002Fselect-queries-advanced","06.databases\u002F03.sql\u002F04.select-queries-advanced",{"title":2693,"path":2694,"stem":2695},"INSERT запити - Додавання даних","\u002Fdatabases\u002Fsql\u002Finsert-queries","06.databases\u002F03.sql\u002F05.insert-queries",{"title":2697,"path":2698,"stem":2699},"UPDATE та DELETE запити","\u002Fdatabases\u002Fsql\u002Fupdate-delete-queries","06.databases\u002F03.sql\u002F06.update-delete-queries",{"title":2701,"path":2702,"stem":2703},"Транзакції в SQL","\u002Fdatabases\u002Fsql\u002Ftransactions","06.databases\u002F03.sql\u002F07.transactions",{"title":2705,"icon":2610,"path":2706,"stem":2707,"children":2708,"page":59},"Multi Table Databases","\u002Fdatabases\u002Fmulti-table-databases","06.databases\u002F04.multi-table-databases",[2709,2713,2717,2721,2725,2729],{"title":2710,"path":2711,"stem":2712},"Зв'язки та нормалізація БД","\u002Fdatabases\u002Fmulti-table-databases\u002Frelationships-and-normalization","06.databases\u002F04.multi-table-databases\u002F00.relationships-and-normalization",{"title":2714,"path":2715,"stem":2716},"INNER JOIN - З'єднання таблиць","\u002Fdatabases\u002Fmulti-table-databases\u002Finner-join","06.databases\u002F04.multi-table-databases\u002F01.inner-join",{"title":2718,"path":2719,"stem":2720},"OUTER JOINs - LEFT, RIGHT, FULL","\u002Fdatabases\u002Fmulti-table-databases\u002Fouter-joins","06.databases\u002F04.multi-table-databases\u002F02.outer-joins",{"title":2722,"path":2723,"stem":2724},"CROSS та SELF JOINs","\u002Fdatabases\u002Fmulti-table-databases\u002Fcross-self-joins","06.databases\u002F04.multi-table-databases\u002F03.cross-self-joins",{"title":2726,"path":2727,"stem":2728},"Підзапити (Subqueries)","\u002Fdatabases\u002Fmulti-table-databases\u002Fsubqueries","06.databases\u002F04.multi-table-databases\u002F04.subqueries",{"title":2730,"path":2731,"stem":2732},"Агрегації з JOIN","\u002Fdatabases\u002Fmulti-table-databases\u002Faggregations-with-joins","06.databases\u002F04.multi-table-databases\u002F05.aggregations-with-joins",{"title":2734,"icon":2735,"path":2736,"stem":2737,"children":2738,"page":59},"Aggregate Functions","i-lucide-calculator","\u002Fdatabases\u002Faggregate-functions","06.databases\u002F05.aggregate-functions",[2739,2743,2747],{"title":2740,"path":2741,"stem":2742},"Функції агрегування в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fintroduction-aggregate-functions","06.databases\u002F05.aggregate-functions\u002F01.introduction-aggregate-functions",{"title":2744,"path":2745,"stem":2746},"Групування даних в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fgrouping-data","06.databases\u002F05.aggregate-functions\u002F02.grouping-data",{"title":2748,"path":2749,"stem":2750},"Підзапити з агрегатними функціями","\u002Fdatabases\u002Faggregate-functions\u002Fsubqueries-aggregates","06.databases\u002F05.aggregate-functions\u002F03.subqueries-aggregates",{"title":2752,"icon":2753,"path":2754,"stem":2755,"children":2756,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","\u002Fdatabases\u002Ftriggers-stored-procedures","06.databases\u002F07.triggers-stored-procedures",[2757,2761,2765,2769,2773,2777,2781],{"title":2758,"path":2759,"stem":2760},"DML-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fdml-triggers","06.databases\u002F07.triggers-stored-procedures\u002F01.dml-triggers",{"title":2762,"path":2763,"stem":2764},"DDL-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fddl-triggers","06.databases\u002F07.triggers-stored-procedures\u002F02.ddl-triggers",{"title":2766,"path":2767,"stem":2768},"Transact-SQL розширення","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransact-sql-extensions","06.databases\u002F07.triggers-stored-procedures\u002F03.transact-sql-extensions",{"title":2770,"path":2771,"stem":2772},"Транзакції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransactions","06.databases\u002F07.triggers-stored-procedures\u002F04.transactions",{"title":2774,"path":2775,"stem":2776},"Зберігаємі процедури","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fstored-procedures","06.databases\u002F07.triggers-stored-procedures\u002F05.stored-procedures",{"title":2778,"path":2779,"stem":2780},"Користувацькі функції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fuser-defined-functions","06.databases\u002F07.triggers-stored-procedures\u002F06.user-defined-functions",{"title":2782,"path":2783,"stem":2784},"Безпека баз даних","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fsecurity","06.databases\u002F07.triggers-stored-procedures\u002F08.security",{"title":2782,"icon":793,"path":2786,"stem":2787,"children":2788,"page":59},"\u002Fdatabases\u002Fsecurity","06.databases\u002F08.security",[2789,2793],{"title":2790,"path":2791,"stem":2792},"Вступ до безпеки баз даних","\u002Fdatabases\u002Fsecurity\u002Fintroduction","06.databases\u002F08.security\u002F01.introduction",{"title":2794,"path":2795,"stem":2796},"Системні представлення та метадані","\u002Fdatabases\u002Fsecurity\u002Fsystem-views","06.databases\u002F08.security\u002F02.system-views",{"title":2798,"icon":2799,"path":2800,"stem":2801,"children":2802,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","\u002Fdatabases\u002Fbackup-recovery","06.databases\u002F09.backup-recovery",[2803],{"title":2798,"path":2804,"stem":2805},"\u002Fdatabases\u002Fbackup-recovery\u002Fbackup-restore","06.databases\u002F09.backup-recovery\u002F01.backup-restore",{"title":2807,"icon":2808,"path":2809,"stem":2810,"children":2811,"page":59},"Повнотекстовий пошук","i-lucide-search","\u002Fdatabases\u002Ffull-text-search","06.databases\u002F10.full-text-search",[2812],{"title":2807,"path":2813,"stem":2814},"\u002Fdatabases\u002Ffull-text-search\u002Ffull-text-search","06.databases\u002F10.full-text-search\u002F01.full-text-search",{"title":2816,"icon":2817,"path":2818,"stem":2819,"children":2820,"page":59},"Tools","i-lucide-wrench","\u002Ftools","07.tools",[2821,2897],{"title":2822,"icon":2823,"path":2824,"stem":2825,"children":2826},"Docker","i-simple-icons-docker","\u002Ftools\u002Fdocker","07.tools\u002F01.docker\u002Findex",[2827,2829,2833,2837,2841,2845,2849,2853,2857,2861,2865,2869,2873,2877,2881,2885,2889,2893],{"title":2828,"path":2824,"stem":2825},"Docker: від нуля до production",{"title":2830,"path":2831,"stem":2832},"Контейнеризація — від проблеми до рішення","\u002Ftools\u002Fdocker\u002Fcontainerization-concept","07.tools\u002F01.docker\u002F01.containerization-concept",{"title":2834,"path":2835,"stem":2836},"Docker — що це і навіщо?","\u002Ftools\u002Fdocker\u002Fdocker-what-and-why","07.tools\u002F01.docker\u002F02.docker-what-and-why",{"title":2838,"path":2839,"stem":2840},"Архітектура Docker Engine","\u002Ftools\u002Fdocker\u002Fdocker-architecture","07.tools\u002F01.docker\u002F03.docker-architecture",{"title":2842,"path":2843,"stem":2844},"Встановлення Docker","\u002Ftools\u002Fdocker\u002Finstallation","07.tools\u002F01.docker\u002F04.installation",{"title":2846,"path":2847,"stem":2848},"Перший контейнер — docker run","\u002Ftools\u002Fdocker\u002Ffirst-container","07.tools\u002F01.docker\u002F05.first-container",{"title":2850,"path":2851,"stem":2852},"Життєвий цикл контейнера","\u002Ftools\u002Fdocker\u002Fcontainer-lifecycle","07.tools\u002F01.docker\u002F06.container-lifecycle",{"title":2854,"path":2855,"stem":2856},"Docker Images — фундаментальні концепції","\u002Ftools\u002Fdocker\u002Fdocker-images-fundamentals","07.tools\u002F01.docker\u002F07.docker-images-fundamentals",{"title":2858,"path":2859,"stem":2860},"Dockerfile — основи","\u002Ftools\u002Fdocker\u002Fdockerfile-basics","07.tools\u002F01.docker\u002F08.dockerfile-basics",{"title":2862,"path":2863,"stem":2864},"Dockerfile — просунуті техніки","\u002Ftools\u002Fdocker\u002Fdockerfile-advanced","07.tools\u002F01.docker\u002F09.dockerfile-advanced",{"title":2866,"path":2867,"stem":2868},"Build Context та кешування шарів","\u002Ftools\u002Fdocker\u002Fbuild-context-and-cache","07.tools\u002F01.docker\u002F10.build-context-and-cache",{"title":2870,"path":2871,"stem":2872},"Реєстри Docker-образів","\u002Ftools\u002Fdocker\u002Fimage-registries","07.tools\u002F01.docker\u002F11.image-registries",{"title":2874,"path":2875,"stem":2876},"Контейнеризація .NET додатків","\u002Ftools\u002Fdocker\u002Fdotnet-containerization","07.tools\u002F01.docker\u002F12.dotnet-containerization",{"title":2878,"path":2879,"stem":2880},"Томи та збереження даних","\u002Ftools\u002Fdocker\u002Fvolumes-and-data","07.tools\u002F01.docker\u002F13.volumes-and-data",{"title":2882,"path":2883,"stem":2884},"Основи мережі в Docker","\u002Ftools\u002Fdocker\u002Fnetworking-basics","07.tools\u002F01.docker\u002F14.networking-basics",{"title":2886,"path":2887,"stem":2888},"Змінні оточення та конфігурація","\u002Ftools\u002Fdocker\u002Fenvironment-and-configuration","07.tools\u002F01.docker\u002F15.environment-and-configuration",{"title":2890,"path":2891,"stem":2892},"Docker Compose — оркестрація контейнерів","\u002Ftools\u002Fdocker\u002Fdocker-compose-basics","07.tools\u002F01.docker\u002F16.docker-compose-basics",{"title":2894,"path":2895,"stem":2896},"Docker Compose — Multi-Service застосунки","\u002Ftools\u002Fdocker\u002Fcompose-multi-service","07.tools\u002F01.docker\u002F17.compose-multi-service",{"title":2898,"icon":2899,"path":2900,"stem":2901,"children":2902},"Kubernetes","simple-icons:kubernetes","\u002Ftools\u002Fkubernetes","07.tools\u002F02.kubernetes\u002Findex",[2903,2905,2909,2913,2917,2921,2925,2929,2933],{"title":2904,"path":2900,"stem":2901},"Kubernetes: від розробки до production",{"title":2906,"path":2907,"stem":2908},"Kubernetes — коли Docker Compose більше не вистачає","\u002Ftools\u002Fkubernetes\u002Fwhy-kubernetes","07.tools\u002F02.kubernetes\u002F01.why-kubernetes",{"title":2910,"path":2911,"stem":2912},"Архітектура Kubernetes — анатомія кластера","\u002Ftools\u002Fkubernetes\u002Fkubernetes-architecture","07.tools\u002F02.kubernetes\u002F02.kubernetes-architecture",{"title":2914,"path":2915,"stem":2916},"Локальне середовище — minikube, kind та k3s","\u002Ftools\u002Fkubernetes\u002Flocal-environment","07.tools\u002F02.kubernetes\u002F03.local-environment",{"title":2918,"path":2919,"stem":2920},"Pod — атомарна одиниця Kubernetes","\u002Ftools\u002Fkubernetes\u002Fpods-and-containers","07.tools\u002F02.kubernetes\u002F04.pods-and-containers",{"title":2922,"path":2923,"stem":2924},"Патерни використання Pod","\u002Ftools\u002Fkubernetes\u002Fpod-patterns","07.tools\u002F02.kubernetes\u002F05.pod-patterns",{"title":2926,"path":2927,"stem":2928},"Deployment — декларативне управління Pod","\u002Ftools\u002Fkubernetes\u002Fdeployment-basics","07.tools\u002F02.kubernetes\u002F06.deployment-basics",{"title":2930,"path":2931,"stem":2932},"Rolling Updates та управління життєвим циклом Deployment","\u002Ftools\u002Fkubernetes\u002Fdeployment-rolling-updates","07.tools\u002F02.kubernetes\u002F07.deployment-rolling-updates",{"title":2934,"path":2935,"stem":2936},"Service — мережева абстракція для Pod","\u002Ftools\u002Fkubernetes\u002Fservices-networking","07.tools\u002F02.kubernetes\u002F08.services-networking",{"title":2938,"icon":2939,"path":2940,"stem":2941,"children":2942,"page":59},"Software Engineering","i-lucide-code-2","\u002Fsoftware-engineering","09.software-engineering",[2943,2947,2951,2955,2959,2963,2967,2971,2975,2979,2983],{"title":2944,"path":2945,"stem":2946},"1. Аналіз предметної області. Експертні знання та складність","\u002Fsoftware-engineering\u002Fintro-subdomains","09.software-engineering\u002F01.intro-subdomains",{"title":2948,"path":2949,"stem":2950},"2. Обмежені контексти. Інтеграція обмежених контекстів","\u002Fsoftware-engineering\u002Fintegrating-limited-contexts","09.software-engineering\u002F02.integrating-limited-contexts",{"title":2952,"path":2953,"stem":2954},"3. Реалізація простої бізнес-логіки","\u002Fsoftware-engineering\u002Fsimple","09.software-engineering\u002F03.simple",{"title":2956,"path":2957,"stem":2958},"4. Опрацювання складної бізнес-логіки","\u002Fsoftware-engineering\u002Fcomplex-business-logic","09.software-engineering\u002F04.complex-business-logic",{"title":2960,"path":2961,"stem":2962},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","\u002Fsoftware-engineering\u002Fmodelling-the-time-factor","09.software-engineering\u002F05.modelling-the-time-factor",{"title":2964,"path":2965,"stem":2966},"6. Архітектурні патерни","\u002Fsoftware-engineering\u002Farchitectural-patterns","09.software-engineering\u002F06.architectural-patterns",{"title":2968,"path":2969,"stem":2970},"Паттерни взаємодії","\u002Fsoftware-engineering\u002Fpatterns-of-interaction","09.software-engineering\u002F07.patterns-of-interaction",{"title":2972,"path":2973,"stem":2974},"Евристика проєктування","\u002Fsoftware-engineering\u002Fdesign-heuristics","09.software-engineering\u002F08.design-heuristics",{"title":2976,"path":2977,"stem":2978},"Еволюція проєктних рішень","\u002Fsoftware-engineering\u002Fevolution-of-design-solutions","09.software-engineering\u002F09.evolution-of-design-solutions",{"title":2980,"path":2981,"stem":2982},"EventStorming","\u002Fsoftware-engineering\u002Feventstorming","09.software-engineering\u002F10.eventstorming",{"title":2984,"path":2985,"stem":2986},"DDD на практиці","\u002Fsoftware-engineering\u002Fddd-in-practice","09.software-engineering\u002F11.ddd-in-practice",{"title":2988,"icon":943,"path":2989,"stem":2990,"children":2991,"page":59},"DDD","\u002Fddd","10.ddd",[2992,2996,3000,3004,3008,3012,3016,3020,3024,3028,3032,3036,3040],{"title":2993,"path":2994,"stem":2995},"Аналіз предметної області","\u002Fddd\u002Fdomain-analysis","10.ddd\u002F01.domain-analysis",{"title":2997,"path":2998,"stem":2999},"Експертні знання про предметну область","\u002Fddd\u002Fdomain-expert-knowledge","10.ddd\u002F02.domain-expert-knowledge",{"title":3001,"path":3002,"stem":3003},"Як осмислити складність предметної області","\u002Fddd\u002Fmanaging-domain-complexity","10.ddd\u002F03.managing-domain-complexity",{"title":3005,"path":3006,"stem":3007},"Інтеграція обмежених контекстів","\u002Fddd\u002Fbounded-context-integration","10.ddd\u002F04.bounded-context-integration",{"title":3009,"path":3010,"stem":3011},"Реалізація простої бізнес-логіки","\u002Fddd\u002Fsimple-business-logic","10.ddd\u002F05.simple-business-logic",{"title":3013,"path":3014,"stem":3015},"Обробка складної бізнес-логіки","\u002Fddd\u002Fcomplex-business-logic","10.ddd\u002F06.complex-business-logic",{"title":3017,"path":3018,"stem":3019},"Моделювання фактора часу","\u002Fddd\u002Ftime-modeling","10.ddd\u002F07.time-modeling",{"title":3021,"path":3022,"stem":3023},"Глава 8. Архітектурні Патерни","\u002Fddd\u002Farchitectural-patterns","10.ddd\u002F08.architectural-patterns",{"title":3025,"path":3026,"stem":3027},"Глава 9. Патерни Взаємодії","\u002Fddd\u002Finteraction-patterns","10.ddd\u002F09.interaction-patterns",{"title":3029,"path":3030,"stem":3031},"Глава 10. Проектні Евристики","\u002Fddd\u002Fdesign-heuristics","10.ddd\u002F10.design-heuristics",{"title":3033,"path":3034,"stem":3035},"Глава 11. Еволюція Проектних Рішень","\u002Fddd\u002Fevolution-of-design-decisions","10.ddd\u002F11.evolution-of-design-decisions",{"title":3037,"path":3038,"stem":3039},"Глава 12. EventStorming","\u002Fddd\u002Fevent-storming","10.ddd\u002F12.event-storming",{"title":3041,"path":3042,"stem":3043},"Глава 13. DDD на Практиці","\u002Fddd\u002Fddd-in-practice","10.ddd\u002F13.ddd-in-practice",{"title":3045,"icon":3046,"path":3047,"stem":3048,"children":3049,"page":59},"Media Streaming","i-lucide-video","\u002Fmedia-streaming","11.media-streaming",[3050,3054,3058,3062,3066,3070,3074],{"title":3051,"path":3052,"stem":3053},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","\u002Fmedia-streaming\u002Fintroduction","11.media-streaming\u002F01.introduction",{"title":3055,"path":3056,"stem":3057},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","\u002Fmedia-streaming\u002Faudio-video-anatomy","11.media-streaming\u002F02.audio-video-anatomy",{"title":3059,"path":3060,"stem":3061},"03. The Gym: FFmpeg Deep Dive","\u002Fmedia-streaming\u002Fffmpeg-gym","11.media-streaming\u002F03.ffmpeg-gym",{"title":3063,"path":3064,"stem":3065},"04. HLS Protocol: HTTP Live Streaming у Деталях","\u002Fmedia-streaming\u002Fhls-protocol","11.media-streaming\u002F04.hls-protocol",{"title":3067,"path":3068,"stem":3069},"05. DASH Protocol: Відкритий Стандарт","\u002Fmedia-streaming\u002Fdash-protocol","11.media-streaming\u002F05.dash-protocol",{"title":3071,"path":3072,"stem":3073},"06. Масштабування: CDN та Adaptive Bitrate","\u002Fmedia-streaming\u002Fcdn-and-adaptive-bitrate","11.media-streaming\u002F06.cdn-and-adaptive-bitrate",{"title":3075,"path":3076,"stem":3077},"07. Війна із Затримкою (Latency)","\u002Fmedia-streaming\u002Frealtime-latency","11.media-streaming\u002F07.realtime-latency",{"title":3079,"icon":3080,"path":3081,"stem":3082,"children":3083,"page":59},"HTML & CSS","i-devicon-html5","\u002Fhtml-css","12.html-css",[3084,3088,3092,3096,3100,3104,3108,3112,3116,3120,3124,3128,3132,3136,3140,3144,3148,3152,3156,3160,3164,3168,3172,3176,3180,3184,3188,3192,3196,3200],{"title":3085,"path":3086,"stem":3087},"Вступ до HTML. Структура документа","\u002Fhtml-css\u002Fintro-html-structure","12.html-css\u002F01.intro-html-structure",{"title":3089,"path":3090,"stem":3091},"Форматування тексту в HTML","\u002Fhtml-css\u002Fhtml-text-formatting","12.html-css\u002F02.html-text-formatting",{"title":3093,"path":3094,"stem":3095},"Посилання та зображення в HTML","\u002Fhtml-css\u002Fhtml-links-images","12.html-css\u002F03.html-links-images",{"title":3097,"path":3098,"stem":3099},"Списки та таблиці в HTML","\u002Fhtml-css\u002Fhtml-lists-tables","12.html-css\u002F04.html-lists-tables",{"title":3101,"path":3102,"stem":3103},"Форми в HTML","\u002Fhtml-css\u002Fhtml-forms","12.html-css\u002F05.html-forms",{"title":3105,"path":3106,"stem":3107},"Семантичні елементи HTML5","\u002Fhtml-css\u002Fhtml-semantic-elements","12.html-css\u002F06.html-semantic-elements",{"title":3109,"path":3110,"stem":3111},"Мультимедіа та розширені елементи HTML","\u002Fhtml-css\u002Fhtml-multimedia-advanced","12.html-css\u002F07.html-multimedia-advanced",{"title":3113,"path":3114,"stem":3115},"Мікророзмітка та SEO в HTML","\u002Fhtml-css\u002Fhtml-microdata-seo","12.html-css\u002F08.html-microdata-seo",{"title":3117,"path":3118,"stem":3119},"Вступ до CSS. Селектори та специфічність","\u002Fhtml-css\u002Fcss-intro-selectors","12.html-css\u002F09.css-intro-selectors",{"title":3121,"path":3122,"stem":3123},"Блокова модель CSS. Відступи. Box Sizing","\u002Fhtml-css\u002Fcss-box-model","12.html-css\u002F10.css-box-model",{"title":3125,"path":3126,"stem":3127},"Розміри у CSS: повний довідник одиниць і ключових слів","\u002Fhtml-css\u002F10a.css-sizing","12.html-css\u002F10a.css-sizing",{"title":3129,"path":3130,"stem":3131},"Типографіка в CSS. Шрифти та текст","\u002Fhtml-css\u002Fcss-typography","12.html-css\u002F11.css-typography",{"title":3133,"path":3134,"stem":3135},"Кольори та фони в CSS","\u002Fhtml-css\u002Fcss-colors-backgrounds","12.html-css\u002F12.css-colors-backgrounds",{"title":3137,"path":3138,"stem":3139},"Тіні та фільтри в CSS","\u002Fhtml-css\u002F12b.css-shadows-filters","12.html-css\u002F12b.css-shadows-filters",{"title":3141,"path":3142,"stem":3143},"CSS Flexbox: Фундамент гнучких макетів","\u002Fhtml-css\u002Fcss-flexbox-fundamentals","12.html-css\u002F13.css-flexbox-fundamentals",{"title":3145,"path":3146,"stem":3147},"CSS Flexbox: Вирівнювання та Позиціонування","\u002Fhtml-css\u002Fcss-flexbox-alignment-sizing-and-patterns","12.html-css\u002F14.css-flexbox-alignment-sizing-and-patterns",{"title":3149,"path":3150,"stem":3151},"CSS Grid. Двовимірний макет. Частина 1","\u002Fhtml-css\u002Fcss-layout-grid","12.html-css\u002F15.css-layout-grid",{"title":3153,"path":3154,"stem":3155},"CSS Grid. Двовимірний макет. Частина 2","\u002Fhtml-css\u002Fcss-layout-grid-advanced","12.html-css\u002F16.css-layout-grid-advanced",{"title":3157,"path":3158,"stem":3159},"Позиціонування в CSS. Z-index. Stacking Context","\u002Fhtml-css\u002Fcss-positioning","12.html-css\u002F17.css-positioning",{"title":3161,"path":3162,"stem":3163},"CSS Анімації та Переходи","\u002Fhtml-css\u002Fcss-animations-transitions","12.html-css\u002F18.css-animations-transitions",{"title":3165,"path":3166,"stem":3167},"Адаптивний дизайн. Media Queries. Частина 1","\u002Fhtml-css\u002Fcss-responsive-media-queries","12.html-css\u002F19.css-responsive-media-queries",{"title":3169,"path":3170,"stem":3171},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","\u002Fhtml-css\u002Fcss-responsive-advanced","12.html-css\u002F20.css-responsive-advanced",{"title":3173,"path":3174,"stem":3175},"CSS Custom Properties. Методології. Сучасний CSS","\u002Fhtml-css\u002Fcss-variables-methodologies","12.html-css\u002F21.css-variables-methodologies",{"title":3177,"path":3178,"stem":3179},"Сучасний CSS 2023–2025: Нові можливості","\u002Fhtml-css\u002Fcss-modern-features","12.html-css\u002F22.css-modern-features",{"title":3181,"path":3182,"stem":3183},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","\u002Fhtml-css\u002F22a.css-nesting-modern-syntax","12.html-css\u002F22a.css-nesting-modern-syntax",{"title":3185,"path":3186,"stem":3187},"CSS для форм та інтерактивних станів","\u002Fhtml-css\u002Fcss-forms-interactive-states","12.html-css\u002F23.css-forms-interactive-states",{"title":3189,"path":3190,"stem":3191},"Доступність у CSS (CSS Accessibility)","\u002Fhtml-css\u002Fcss-accessibility","12.html-css\u002F24.css-accessibility",{"title":3193,"path":3194,"stem":3195},"CSS-функції та сучасні sizing primitives","\u002Fhtml-css\u002Fcss-functions-sizing","12.html-css\u002F25.css-functions-sizing",{"title":3197,"path":3198,"stem":3199},"Rendering Pipeline і CSS Performance","\u002Fhtml-css\u002Fcss-rendering-performance","12.html-css\u002F26.css-rendering-performance",{"title":3201,"path":3202,"stem":3203},"CSS Best Practices: типові ситуації та правильні рішення","\u002Fhtml-css\u002Fcss-best-practices","12.html-css\u002F27.css-best-practices",{"title":3205,"path":3206,"stem":3207,"children":3208,"page":59},"AWS","\u002Faws","13.aws",[3209,3213,3217,3221,3225,3229,3233,3237,3241,3245,3249,3253,3257,3261,3265,3269,3273,3277],{"title":3210,"path":3211,"stem":3212},"Реєстрація AWS акаунту та студентські програми","\u002Faws\u002Faccount-registration","13.aws\u002F00.account-registration",{"title":3214,"path":3215,"stem":3216},"Вступ до хмарних обчислень та AWS","\u002Faws\u002Fintroduction-to-cloud","13.aws\u002F01.introduction-to-cloud",{"title":3218,"path":3219,"stem":3220},"AWS IAM — Identity and Access Management","\u002Faws\u002Fiam","13.aws\u002F02.iam",{"title":3222,"path":3223,"stem":3224},"AWS IAM CLI — Довідник команд","\u002Faws\u002F02a.iam-doc","13.aws\u002F02a.iam-doc",{"title":3226,"path":3227,"stem":3228},"Docker та контейнеризація в AWS — ECR, ECS та Fargate","\u002Faws\u002Fdocker-ecs","13.aws\u002F03.docker-ecs",{"title":3230,"path":3231,"stem":3232},"AWS ECR \u002F ECS CLI — Довідник команд","\u002Faws\u002F03a.docker-ecs-doc","13.aws\u002F03a.docker-ecs-doc",{"title":3234,"path":3235,"stem":3236},"Amazon EC2 — Elastic Compute Cloud","\u002Faws\u002Fec2","13.aws\u002F04.ec2",{"title":3238,"path":3239,"stem":3240},"AWS EC2 CLI — Довідник команд","\u002Faws\u002F04a.ec2-doc","13.aws\u002F04a.ec2-doc",{"title":3242,"path":3243,"stem":3244},"Elastic Load Balancing та Auto Scaling","\u002Faws\u002Falb-asg","13.aws\u002F05.alb-asg",{"title":3246,"path":3247,"stem":3248},"Amazon S3 — Simple Storage Service","\u002Faws\u002Fs3","13.aws\u002F06.s3",{"title":3250,"path":3251,"stem":3252},"Amazon CloudFront — Content Delivery Network","\u002Faws\u002Fcloudfront","13.aws\u002F07.cloudfront",{"title":3254,"path":3255,"stem":3256},"Amazon RDS — Relational Database Service","\u002Faws\u002Frds","13.aws\u002F08.rds",{"title":3258,"path":3259,"stem":3260},"Amazon DynamoDB — NoSQL Database","\u002Faws\u002Fdynamodb","13.aws\u002F09.dynamodb",{"title":3262,"path":3263,"stem":3264},"AWS Lambda та Serverless Compute","\u002Faws\u002Flambda","13.aws\u002F10.lambda",{"title":3266,"path":3267,"stem":3268},"Amazon Bedrock - Foundation Models, RAG та Agents","\u002Faws\u002Fbedrock","13.aws\u002F22.bedrock",{"title":3270,"path":3271,"stem":3272},"Amazon Rekognition - Комп'ютерний зір","\u002Faws\u002Frekognition","13.aws\u002F23.rekognition",{"title":3274,"path":3275,"stem":3276},"Amazon Textract - Інтелектуальний аналіз документів","\u002Faws\u002Ftextract","13.aws\u002F24.textract",{"title":3278,"path":3279,"stem":3280},"Amazon Polly, Transcribe, Comprehend та Translate","\u002Faws\u002Faudio-nlp-services","13.aws\u002F25.audio-nlp-services",{"title":3282,"path":3283,"stem":3284,"children":3285,"page":59},"Tailwind","\u002Ftailwind","21.tailwind",[3286,3290,3294,3298,3302,3306,3310,3314,3318,3322,3326,3330],{"title":3287,"path":3288,"stem":3289},"Що таке Tailwind CSS і навіщо він потрібен","\u002Ftailwind\u002Ftailwind-intro-philosophy","21.tailwind\u002F01.tailwind-intro-philosophy",{"title":3291,"path":3292,"stem":3293},"Встановлення та налаштування Tailwind CSS v4","\u002Ftailwind\u002Ftailwind-installation-setup","21.tailwind\u002F02.tailwind-installation-setup",{"title":3295,"path":3296,"stem":3297},"Utility-класи: основи та система Tailwind","\u002Ftailwind\u002Ftailwind-utility-classes-core","21.tailwind\u002F03.tailwind-utility-classes-core",{"title":3299,"path":3300,"stem":3301},"Layout: Flexbox та Grid через Tailwind","\u002Ftailwind\u002Ftailwind-flexbox-grid","21.tailwind\u002F04.tailwind-flexbox-grid",{"title":3303,"path":3304,"stem":3305},"Кастомізація теми через @theme у Tailwind v4","\u002Ftailwind\u002Ftailwind-theme-customization","21.tailwind\u002F05.tailwind-theme-customization",{"title":3307,"path":3308,"stem":3309},"Варіанти: hover, focus, responsive, dark mode та нові v4","\u002Ftailwind\u002Ftailwind-variants-states","21.tailwind\u002F06.tailwind-variants-states",{"title":3311,"path":3312,"stem":3313},"Типографіка та система кольорів у Tailwind v4","\u002Ftailwind\u002Ftailwind-typography-colors","21.tailwind\u002F07.tailwind-typography-colors",{"title":3315,"path":3316,"stem":3317},"Компоненти та повторюваність: @apply, @utility та патерни","\u002Ftailwind\u002Ftailwind-components-patterns","21.tailwind\u002F08.tailwind-components-patterns",{"title":3319,"path":3320,"stem":3321},"Темна тема та система дизайн-токенів у Tailwind v4","\u002Ftailwind\u002Ftailwind-dark-mode-theming","21.tailwind\u002F09.tailwind-dark-mode-theming",{"title":3323,"path":3324,"stem":3325},"Довільні значення та контейнерні запити у Tailwind v4","\u002Ftailwind\u002Ftailwind-arbitrary-container-queries","21.tailwind\u002F10.tailwind-arbitrary-container-queries",{"title":3327,"path":3328,"stem":3329},"Анімації, трансформації та 3D у Tailwind v4","\u002Ftailwind\u002Ftailwind-animations-transforms","21.tailwind\u002F11.tailwind-animations-transforms",{"title":3331,"path":3332,"stem":3333},"Tailwind CLI, PostCSS та інтеграція з фреймворками","\u002Ftailwind\u002Ftailwind-cli-tooling","21.tailwind\u002F12.tailwind-cli-tooling",{"title":3335,"path":3336,"stem":3337},"Тестування компонентів діаграм","\u002Ftest-components","98.test-components",{"id":3339,"title":3331,"body":3340,"description":9698,"extension":9699,"links":9700,"meta":9701,"navigation":3404,"path":3332,"seo":9702,"stem":3333,"__hash__":9703},"docs\u002F21.tailwind\u002F12.tailwind-cli-tooling.md",{"type":3341,"value":3342,"toc":9662},"minimark",[3343,3347,3352,3366,3472,3479,3482,3485,3489,3494,3504,3507,3535,3542,3553,3555,3559,3564,3614,3619,3627,3632,3780,3785,3867,3874,3960,3962,3966,4284,4292,4294,4298,4305,4333,4336,4376,4379,4408,4410,4414,4418,4424,4427,4448,4451,4505,4548,4551,4634,4642,4644,4648,4654,4677,4757,4840,4843,4888,4912,4917,4969,5045,5058,5158,5160,5164,5170,5203,5206,5224,5269,5327,5493,5507,5509,5513,5552,5620,5660,5712,5714,5718,5838,5840,5846,5850,5856,6010,6090,6092,6099,6115,6511,6513,6520,6525,6569,6572,6591,6659,6661,6669,6678,6903,6906,7004,8790,9300,9486,9489,9491,9495,9602,9605,9647,9649,9659],[3344,3345,3331],"h1",{"id":3346},"tailwind-cli-postcss-та-інтеграція-з-фреймворками",[3348,3349,3351],"h2",{"id":3350},"вступ-tailwind-v4-змінює-підхід-до-конфігурації","Вступ: Tailwind v4 змінює підхід до конфігурації",[3353,3354,3355,3356,3360,3361,3365],"p",{},"Одна з найрадикальніших змін Tailwind v4 — відмова від ",[3357,3358,3359],"code",{},"tailwind.config.js"," як єдиного джерела конфігурації на користь ",[3362,3363,3364],"strong",{},"CSS-файлу як точки входу",". У v3 конфігурація жила у JavaScript. У v4 — у CSS:",[3367,3368,3373],"pre",{"className":3369,"code":3370,"language":3371,"meta":3372,"style":3372},"language-css shiki shiki-themes light-plus dark-plus dark-plus","\u002F* v4: Весь Tailwind налаштовується тут *\u002F\n@import 'tailwindcss';\n\n@theme {\n    --color-brand: oklch(0.585 0.233 277);\n    --font-sans: 'Inter', system-ui, sans-serif;\n}\n\n@custom-variant dark (&:is(.dark *));\n","css","",[3357,3374,3375,3384,3399,3406,3415,3434,3452,3458,3463],{"__ignoreMap":3372},[3376,3377,3380],"span",{"class":3378,"line":3379},"line",1,[3376,3381,3383],{"class":3382},"spJ8K","\u002F* v4: Весь Tailwind налаштовується тут *\u002F\n",[3376,3385,3387,3391,3395],{"class":3378,"line":3386},2,[3376,3388,3390],{"class":3389},"s8xlr","@import",[3376,3392,3394],{"class":3393},"sbdoH"," 'tailwindcss'",[3376,3396,3398],{"class":3397},"sHH4Y",";\n",[3376,3400,3402],{"class":3378,"line":3401},3,[3376,3403,3405],{"emptyLinePlaceholder":3404},true,"\n",[3376,3407,3409,3412],{"class":3378,"line":3408},4,[3376,3410,3411],{"class":3389},"@theme",[3376,3413,3414],{"class":3397}," {\n",[3376,3416,3418,3421,3425,3428,3431],{"class":3378,"line":3417},5,[3376,3419,3420],{"class":3397},"    --color-brand: oklch(0",[3376,3422,3424],{"class":3423},"sqdDX",".585",[3376,3426,3427],{"class":3397}," 0",[3376,3429,3430],{"class":3423},".233",[3376,3432,3433],{"class":3397}," 277);\n",[3376,3435,3437,3440,3444,3447,3450],{"class":3378,"line":3436},6,[3376,3438,3439],{"class":3397},"    --font-sans: 'Inter', ",[3376,3441,3443],{"class":3442},"sKtos","system-ui",[3376,3445,3446],{"class":3397},", ",[3376,3448,3449],{"class":3442},"sans-serif",[3376,3451,3398],{"class":3397},[3376,3453,3455],{"class":3378,"line":3454},7,[3376,3456,3457],{"class":3397},"}\n",[3376,3459,3461],{"class":3378,"line":3460},8,[3376,3462,3405],{"emptyLinePlaceholder":3404},[3376,3464,3466,3469],{"class":3378,"line":3465},9,[3376,3467,3468],{"class":3389},"@custom-variant",[3376,3470,3471],{"class":3397}," dark (&:is(.dark *));\n",[3353,3473,3474,3475,3478],{},"Це не просто синтаксичні зміни — це зміна ",[3362,3476,3477],{},"архітектурної філософії",": конфігурація стилів живе поряд зі стилями, а не у окремому JavaScript-файлі, що вимагав знання API Tailwind.",[3353,3480,3481],{},"У цій статті розберемо всі способи підключення та налаштування Tailwind v4 для реальних проєктів.",[3483,3484],"hr",{},[3348,3486,3488],{"id":3487},"частина-і-tailwind-cli-автономна-збірка","Частина І. Tailwind CLI: автономна збірка",[3490,3491,3493],"h3",{"id":3492},"_11-що-таке-tailwind-cli-і-коли-він-потрібен","1.1. Що таке Tailwind CLI і коли він потрібен",[3353,3495,3496,3499,3500,3503],{},[3362,3497,3498],{},"Tailwind CLI"," — автономна утиліта командного рядка для компіляції Tailwind CSS без Node.js-проєкту, без webpack, без Vite. Вона містить вбудований компілятор і не потребує ",[3357,3501,3502],{},"package.json",".",[3353,3505,3506],{},"Коли використовувати CLI:",[3508,3509,3510,3517,3523,3529],"ul",{},[3511,3512,3513,3516],"li",{},[3362,3514,3515],{},"Статичні сайти",": HTML + CSS без JavaScript-фреймворку",[3511,3518,3519,3522],{},[3362,3520,3521],{},"Швидкі прототипи",": немає потреби в повноцінній збірці",[3511,3524,3525,3528],{},[3362,3526,3527],{},"Навчання",": зосередитися на CSS, без налаштування toolchain",[3511,3530,3531,3534],{},[3362,3532,3533],{},"Jekyll, Hugo, Eleventy",": генератори статичних сайтів",[3353,3536,3537,3538,3541],{},"Коли ",[3362,3539,3540],{},"не"," використовувати CLI:",[3508,3543,3544,3547,3550],{},[3511,3545,3546],{},"Проєкти з Vite\u002Fwebpack → використовуйте плагін",[3511,3548,3549],{},"Next.js\u002FNuxt → є власна інтеграція",[3511,3551,3552],{},"Потрібні PostCSS-плагіни (autoprefixer, postcss-import тощо)",[3483,3554],{},[3490,3556,3558],{"id":3557},"_12-встановлення-та-перший-запуск","1.2. Встановлення та перший запуск",[3353,3560,3561],{},[3362,3562,3563],{},"Варіант 1: через npm (рекомендований)",[3367,3565,3569],{"className":3566,"code":3567,"language":3568,"meta":3372,"style":3372},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","# Ініціалізація Node-проєкту (якщо ще немає)\nnpm init -y\n\n# Встановлення Tailwind CLI\nnpm install tailwindcss @tailwindcss\u002Fcli --save-dev\n","bash",[3357,3570,3571,3576,3589,3593,3598],{"__ignoreMap":3372},[3376,3572,3573],{"class":3378,"line":3379},[3376,3574,3575],{"class":3382},"# Ініціалізація Node-проєкту (якщо ще немає)\n",[3376,3577,3578,3582,3585],{"class":3378,"line":3386},[3376,3579,3581],{"class":3580},"s8Opu","npm",[3376,3583,3584],{"class":3393}," init",[3376,3586,3588],{"class":3587},"su1O8"," -y\n",[3376,3590,3591],{"class":3378,"line":3401},[3376,3592,3405],{"emptyLinePlaceholder":3404},[3376,3594,3595],{"class":3378,"line":3408},[3376,3596,3597],{"class":3382},"# Встановлення Tailwind CLI\n",[3376,3599,3600,3602,3605,3608,3611],{"class":3378,"line":3417},[3376,3601,3581],{"class":3580},[3376,3603,3604],{"class":3393}," install",[3376,3606,3607],{"class":3393}," tailwindcss",[3376,3609,3610],{"class":3393}," @tailwindcss\u002Fcli",[3376,3612,3613],{"class":3587}," --save-dev\n",[3353,3615,3616],{},[3362,3617,3618],{},"Структура проєкту:",[3367,3620,3625],{"className":3621,"code":3623,"language":3624},[3622],"language-text","my-project\u002F\n├── src\u002F\n│   ├── input.css       ← вхідний CSS-файл (з @import 'tailwindcss')\n│   └── index.html\n├── dist\u002F\n│   └── output.css      ← скомпільований CSS (генерується автоматично)\n└── package.json\n","text",[3357,3626,3623],{"__ignoreMap":3372},[3353,3628,3629],{},[3362,3630,3631],{},"Вхідний CSS-файл:",[3367,3633,3636],{"className":3369,"code":3634,"filename":3635,"language":3371,"meta":3372,"style":3372},"\u002F* Підключити всі шари Tailwind *\u002F\n@import \"tailwindcss\";\n\n\u002F* Власна конфігурація *\u002F\n@theme {\n    --font-sans: 'Inter', system-ui, sans-serif;\n    --color-brand: oklch(0.585 0.233 277);\n}\n\n\u002F* Базові глобальні стилі *\u002F\n@layer base {\n    body {\n        font-family: var(--font-sans);\n        background-color: oklch(0.984 0.003 247.858);\n    }\n}\n","src\u002Finput.css",[3357,3637,3638,3643,3652,3656,3661,3667,3679,3691,3695,3699,3705,3714,3722,3744,3769,3775],{"__ignoreMap":3372},[3376,3639,3640],{"class":3378,"line":3379},[3376,3641,3642],{"class":3382},"\u002F* Підключити всі шари Tailwind *\u002F\n",[3376,3644,3645,3647,3650],{"class":3378,"line":3386},[3376,3646,3390],{"class":3389},[3376,3648,3649],{"class":3393}," \"tailwindcss\"",[3376,3651,3398],{"class":3397},[3376,3653,3654],{"class":3378,"line":3401},[3376,3655,3405],{"emptyLinePlaceholder":3404},[3376,3657,3658],{"class":3378,"line":3408},[3376,3659,3660],{"class":3382},"\u002F* Власна конфігурація *\u002F\n",[3376,3662,3663,3665],{"class":3378,"line":3417},[3376,3664,3411],{"class":3389},[3376,3666,3414],{"class":3397},[3376,3668,3669,3671,3673,3675,3677],{"class":3378,"line":3436},[3376,3670,3439],{"class":3397},[3376,3672,3443],{"class":3442},[3376,3674,3446],{"class":3397},[3376,3676,3449],{"class":3442},[3376,3678,3398],{"class":3397},[3376,3680,3681,3683,3685,3687,3689],{"class":3378,"line":3454},[3376,3682,3420],{"class":3397},[3376,3684,3424],{"class":3423},[3376,3686,3427],{"class":3397},[3376,3688,3430],{"class":3423},[3376,3690,3433],{"class":3397},[3376,3692,3693],{"class":3378,"line":3460},[3376,3694,3457],{"class":3397},[3376,3696,3697],{"class":3378,"line":3465},[3376,3698,3405],{"emptyLinePlaceholder":3404},[3376,3700,3702],{"class":3378,"line":3701},10,[3376,3703,3704],{"class":3382},"\u002F* Базові глобальні стилі *\u002F\n",[3376,3706,3708,3711],{"class":3378,"line":3707},11,[3376,3709,3710],{"class":3389},"@layer",[3376,3712,3713],{"class":3397}," base {\n",[3376,3715,3717,3720],{"class":3378,"line":3716},12,[3376,3718,3719],{"class":3423},"    body",[3376,3721,3414],{"class":3397},[3376,3723,3725,3729,3732,3735,3738,3741],{"class":3378,"line":3724},13,[3376,3726,3728],{"class":3727},"sa4r_","        font-family",[3376,3730,3731],{"class":3397},": ",[3376,3733,3734],{"class":3580},"var",[3376,3736,3737],{"class":3397},"(",[3376,3739,3740],{"class":3727},"--font-sans",[3376,3742,3743],{"class":3397},");\n",[3376,3745,3747,3750,3752,3755,3757,3761,3764,3767],{"class":3378,"line":3746},14,[3376,3748,3749],{"class":3727},"        background-color",[3376,3751,3731],{"class":3397},[3376,3753,3754],{"class":3580},"oklch",[3376,3756,3737],{"class":3397},[3376,3758,3760],{"class":3759},"sJj4R","0.984",[3376,3762,3763],{"class":3759}," 0.003",[3376,3765,3766],{"class":3759}," 247.858",[3376,3768,3743],{"class":3397},[3376,3770,3772],{"class":3378,"line":3771},15,[3376,3773,3774],{"class":3397},"    }\n",[3376,3776,3778],{"class":3378,"line":3777},16,[3376,3779,3457],{"class":3397},[3353,3781,3782],{},[3362,3783,3784],{},"Перший запуск:",[3367,3786,3788],{"className":3566,"code":3787,"language":3568,"meta":3372,"style":3372},"# Одноразова збірка\nnpx @tailwindcss\u002Fcli -i src\u002Finput.css -o dist\u002Foutput.css\n\n# Watch mode: перекомпілювати при змінах\nnpx @tailwindcss\u002Fcli -i src\u002Finput.css -o dist\u002Foutput.css --watch\n\n# Мінімізований production-build\nnpx @tailwindcss\u002Fcli -i src\u002Finput.css -o dist\u002Foutput.css --minify\n",[3357,3789,3790,3795,3814,3818,3823,3841,3845,3850],{"__ignoreMap":3372},[3376,3791,3792],{"class":3378,"line":3379},[3376,3793,3794],{"class":3382},"# Одноразова збірка\n",[3376,3796,3797,3800,3802,3805,3808,3811],{"class":3378,"line":3386},[3376,3798,3799],{"class":3580},"npx",[3376,3801,3610],{"class":3393},[3376,3803,3804],{"class":3587}," -i",[3376,3806,3807],{"class":3393}," src\u002Finput.css",[3376,3809,3810],{"class":3587}," -o",[3376,3812,3813],{"class":3393}," dist\u002Foutput.css\n",[3376,3815,3816],{"class":3378,"line":3401},[3376,3817,3405],{"emptyLinePlaceholder":3404},[3376,3819,3820],{"class":3378,"line":3408},[3376,3821,3822],{"class":3382},"# Watch mode: перекомпілювати при змінах\n",[3376,3824,3825,3827,3829,3831,3833,3835,3838],{"class":3378,"line":3417},[3376,3826,3799],{"class":3580},[3376,3828,3610],{"class":3393},[3376,3830,3804],{"class":3587},[3376,3832,3807],{"class":3393},[3376,3834,3810],{"class":3587},[3376,3836,3837],{"class":3393}," dist\u002Foutput.css",[3376,3839,3840],{"class":3587}," --watch\n",[3376,3842,3843],{"class":3378,"line":3436},[3376,3844,3405],{"emptyLinePlaceholder":3404},[3376,3846,3847],{"class":3378,"line":3454},[3376,3848,3849],{"class":3382},"# Мінімізований production-build\n",[3376,3851,3852,3854,3856,3858,3860,3862,3864],{"class":3378,"line":3460},[3376,3853,3799],{"class":3580},[3376,3855,3610],{"class":3393},[3376,3857,3804],{"class":3587},[3376,3859,3807],{"class":3393},[3376,3861,3810],{"class":3587},[3376,3863,3837],{"class":3393},[3376,3865,3866],{"class":3587}," --minify\n",[3353,3868,3869],{},[3362,3870,3871,3873],{},[3357,3872,3502],{}," скрипти:",[3367,3875,3879],{"className":3876,"code":3877,"filename":3502,"language":3878,"meta":3372,"style":3372},"language-json shiki shiki-themes light-plus dark-plus dark-plus","{\n    \"scripts\": {\n        \"dev\": \"tailwindcss -i src\u002Finput.css -o dist\u002Foutput.css --watch\",\n        \"build\": \"tailwindcss -i src\u002Finput.css -o dist\u002Foutput.css --minify\"\n    },\n    \"devDependencies\": {\n        \"tailwindcss\": \"^4.0.0\",\n        \"@tailwindcss\u002Fcli\": \"^4.0.0\"\n    }\n}\n","json",[3357,3880,3881,3886,3895,3908,3918,3923,3930,3942,3952,3956],{"__ignoreMap":3372},[3376,3882,3883],{"class":3378,"line":3379},[3376,3884,3885],{"class":3397},"{\n",[3376,3887,3888,3892],{"class":3378,"line":3386},[3376,3889,3891],{"class":3890},"sLwNe","    \"scripts\"",[3376,3893,3894],{"class":3397},": {\n",[3376,3896,3897,3900,3902,3905],{"class":3378,"line":3401},[3376,3898,3899],{"class":3890},"        \"dev\"",[3376,3901,3731],{"class":3397},[3376,3903,3904],{"class":3393},"\"tailwindcss -i src\u002Finput.css -o dist\u002Foutput.css --watch\"",[3376,3906,3907],{"class":3397},",\n",[3376,3909,3910,3913,3915],{"class":3378,"line":3408},[3376,3911,3912],{"class":3890},"        \"build\"",[3376,3914,3731],{"class":3397},[3376,3916,3917],{"class":3393},"\"tailwindcss -i src\u002Finput.css -o dist\u002Foutput.css --minify\"\n",[3376,3919,3920],{"class":3378,"line":3417},[3376,3921,3922],{"class":3397},"    },\n",[3376,3924,3925,3928],{"class":3378,"line":3436},[3376,3926,3927],{"class":3890},"    \"devDependencies\"",[3376,3929,3894],{"class":3397},[3376,3931,3932,3935,3937,3940],{"class":3378,"line":3454},[3376,3933,3934],{"class":3890},"        \"tailwindcss\"",[3376,3936,3731],{"class":3397},[3376,3938,3939],{"class":3393},"\"^4.0.0\"",[3376,3941,3907],{"class":3397},[3376,3943,3944,3947,3949],{"class":3378,"line":3460},[3376,3945,3946],{"class":3890},"        \"@tailwindcss\u002Fcli\"",[3376,3948,3731],{"class":3397},[3376,3950,3951],{"class":3393},"\"^4.0.0\"\n",[3376,3953,3954],{"class":3378,"line":3465},[3376,3955,3774],{"class":3397},[3376,3957,3958],{"class":3378,"line":3701},[3376,3959,3457],{"class":3397},[3483,3961],{},[3490,3963,3965],{"id":3964},"_13-підключення-у-html","1.3. Підключення у HTML",[3367,3967,3972],{"className":3968,"code":3969,"filename":3970,"language":3971,"meta":3372,"style":3372},"language-html shiki shiki-themes light-plus dark-plus dark-plus","\u003C!DOCTYPE html>\n\u003Chtml lang=\"uk\">\n\u003Chead>\n    \u003Cmeta charset=\"UTF-8\">\n    \u003Cmeta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    \u003Ctitle>Мій проєкт\u003C\u002Ftitle>\n\n    \u003C!-- Підключити скомпільований CSS -->\n    \u003Clink rel=\"stylesheet\" href=\"..\u002Fdist\u002Foutput.css\">\n\u003C\u002Fhead>\n\u003Cbody class=\"min-h-screen bg-slate-50 p-8\">\n\n    \u003Cdiv class=\"max-w-2xl mx-auto\">\n        \u003Ch1 class=\"text-3xl font-black text-slate-900 mb-4\">Привіт, Tailwind v4!\u003C\u002Fh1>\n        \u003Cp class=\"text-slate-600 leading-relaxed\">\n            Цей текст стилізований через Tailwind CLI.\n        \u003C\u002Fp>\n        \u003Cbutton class=\"mt-4 px-6 py-3 bg-indigo-600 hover:bg-indigo-700\n                       text-white font-semibold rounded-xl transition-colors duration-200\">\n            Кнопка\n        \u003C\u002Fbutton>\n    \u003C\u002Fdiv>\n\n\u003C\u002Fbody>\n\u003C\u002Fhtml>\n","src\u002Findex.html","html",[3357,3973,3974,3989,4008,4017,4035,4059,4079,4083,4088,4113,4121,4138,4142,4158,4183,4198,4203,4213,4228,4236,4242,4251,4261,4266,4275],{"__ignoreMap":3372},[3376,3975,3976,3980,3983,3986],{"class":3378,"line":3379},[3376,3977,3979],{"class":3978},"s0P7L","\u003C!",[3376,3981,3982],{"class":3442},"DOCTYPE",[3376,3984,3985],{"class":3727}," html",[3376,3987,3988],{"class":3978},">\n",[3376,3990,3991,3994,3996,3999,4002,4006],{"class":3378,"line":3386},[3376,3992,3993],{"class":3978},"\u003C",[3376,3995,3971],{"class":3442},[3376,3997,3998],{"class":3727}," lang",[3376,4000,4001],{"class":3397},"=",[3376,4003,4005],{"class":4004},"su9tN","\"uk\"",[3376,4007,3988],{"class":3978},[3376,4009,4010,4012,4015],{"class":3378,"line":3401},[3376,4011,3993],{"class":3978},[3376,4013,4014],{"class":3442},"head",[3376,4016,3988],{"class":3978},[3376,4018,4019,4022,4025,4028,4030,4033],{"class":3378,"line":3408},[3376,4020,4021],{"class":3978},"    \u003C",[3376,4023,4024],{"class":3442},"meta",[3376,4026,4027],{"class":3727}," charset",[3376,4029,4001],{"class":3397},[3376,4031,4032],{"class":4004},"\"UTF-8\"",[3376,4034,3988],{"class":3978},[3376,4036,4037,4039,4041,4044,4046,4049,4052,4054,4057],{"class":3378,"line":3417},[3376,4038,4021],{"class":3978},[3376,4040,4024],{"class":3442},[3376,4042,4043],{"class":3727}," name",[3376,4045,4001],{"class":3397},[3376,4047,4048],{"class":4004},"\"viewport\"",[3376,4050,4051],{"class":3727}," content",[3376,4053,4001],{"class":3397},[3376,4055,4056],{"class":4004},"\"width=device-width, initial-scale=1.0\"",[3376,4058,3988],{"class":3978},[3376,4060,4061,4063,4066,4069,4072,4075,4077],{"class":3378,"line":3436},[3376,4062,4021],{"class":3978},[3376,4064,4065],{"class":3442},"title",[3376,4067,4068],{"class":3978},">",[3376,4070,4071],{"class":3397},"Мій проєкт",[3376,4073,4074],{"class":3978},"\u003C\u002F",[3376,4076,4065],{"class":3442},[3376,4078,3988],{"class":3978},[3376,4080,4081],{"class":3378,"line":3454},[3376,4082,3405],{"emptyLinePlaceholder":3404},[3376,4084,4085],{"class":3378,"line":3460},[3376,4086,4087],{"class":3382},"    \u003C!-- Підключити скомпільований CSS -->\n",[3376,4089,4090,4092,4095,4098,4100,4103,4106,4108,4111],{"class":3378,"line":3465},[3376,4091,4021],{"class":3978},[3376,4093,4094],{"class":3442},"link",[3376,4096,4097],{"class":3727}," rel",[3376,4099,4001],{"class":3397},[3376,4101,4102],{"class":4004},"\"stylesheet\"",[3376,4104,4105],{"class":3727}," href",[3376,4107,4001],{"class":3397},[3376,4109,4110],{"class":4004},"\"..\u002Fdist\u002Foutput.css\"",[3376,4112,3988],{"class":3978},[3376,4114,4115,4117,4119],{"class":3378,"line":3701},[3376,4116,4074],{"class":3978},[3376,4118,4014],{"class":3442},[3376,4120,3988],{"class":3978},[3376,4122,4123,4125,4128,4131,4133,4136],{"class":3378,"line":3707},[3376,4124,3993],{"class":3978},[3376,4126,4127],{"class":3442},"body",[3376,4129,4130],{"class":3727}," class",[3376,4132,4001],{"class":3397},[3376,4134,4135],{"class":4004},"\"min-h-screen bg-slate-50 p-8\"",[3376,4137,3988],{"class":3978},[3376,4139,4140],{"class":3378,"line":3716},[3376,4141,3405],{"emptyLinePlaceholder":3404},[3376,4143,4144,4146,4149,4151,4153,4156],{"class":3378,"line":3724},[3376,4145,4021],{"class":3978},[3376,4147,4148],{"class":3442},"div",[3376,4150,4130],{"class":3727},[3376,4152,4001],{"class":3397},[3376,4154,4155],{"class":4004},"\"max-w-2xl mx-auto\"",[3376,4157,3988],{"class":3978},[3376,4159,4160,4163,4165,4167,4169,4172,4174,4177,4179,4181],{"class":3378,"line":3746},[3376,4161,4162],{"class":3978},"        \u003C",[3376,4164,3344],{"class":3442},[3376,4166,4130],{"class":3727},[3376,4168,4001],{"class":3397},[3376,4170,4171],{"class":4004},"\"text-3xl font-black text-slate-900 mb-4\"",[3376,4173,4068],{"class":3978},[3376,4175,4176],{"class":3397},"Привіт, Tailwind v4!",[3376,4178,4074],{"class":3978},[3376,4180,3344],{"class":3442},[3376,4182,3988],{"class":3978},[3376,4184,4185,4187,4189,4191,4193,4196],{"class":3378,"line":3771},[3376,4186,4162],{"class":3978},[3376,4188,3353],{"class":3442},[3376,4190,4130],{"class":3727},[3376,4192,4001],{"class":3397},[3376,4194,4195],{"class":4004},"\"text-slate-600 leading-relaxed\"",[3376,4197,3988],{"class":3978},[3376,4199,4200],{"class":3378,"line":3777},[3376,4201,4202],{"class":3397},"            Цей текст стилізований через Tailwind CLI.\n",[3376,4204,4206,4209,4211],{"class":3378,"line":4205},17,[3376,4207,4208],{"class":3978},"        \u003C\u002F",[3376,4210,3353],{"class":3442},[3376,4212,3988],{"class":3978},[3376,4214,4216,4218,4221,4223,4225],{"class":3378,"line":4215},18,[3376,4217,4162],{"class":3978},[3376,4219,4220],{"class":3442},"button",[3376,4222,4130],{"class":3727},[3376,4224,4001],{"class":3397},[3376,4226,4227],{"class":4004},"\"mt-4 px-6 py-3 bg-indigo-600 hover:bg-indigo-700\n",[3376,4229,4231,4234],{"class":3378,"line":4230},19,[3376,4232,4233],{"class":4004},"                       text-white font-semibold rounded-xl transition-colors duration-200\"",[3376,4235,3988],{"class":3978},[3376,4237,4239],{"class":3378,"line":4238},20,[3376,4240,4241],{"class":3397},"            Кнопка\n",[3376,4243,4245,4247,4249],{"class":3378,"line":4244},21,[3376,4246,4208],{"class":3978},[3376,4248,4220],{"class":3442},[3376,4250,3988],{"class":3978},[3376,4252,4254,4257,4259],{"class":3378,"line":4253},22,[3376,4255,4256],{"class":3978},"    \u003C\u002F",[3376,4258,4148],{"class":3442},[3376,4260,3988],{"class":3978},[3376,4262,4264],{"class":3378,"line":4263},23,[3376,4265,3405],{"emptyLinePlaceholder":3404},[3376,4267,4269,4271,4273],{"class":3378,"line":4268},24,[3376,4270,4074],{"class":3978},[3376,4272,4127],{"class":3442},[3376,4274,3988],{"class":3978},[3376,4276,4278,4280,4282],{"class":3378,"line":4277},25,[3376,4279,4074],{"class":3978},[3376,4281,3971],{"class":3442},[3376,4283,3988],{"class":3978},[4285,4286,4287,4288,4291],"tip",{},"У watch mode Tailwind автоматично відстежує ",[3362,4289,4290],{},"всі HTML, JS та CSS файли"," у директорії проєкту. Scan відбувається за шаблонами у директорії проєкту — вам не потрібно вказувати шляхи вручну, як у v3.",[3483,4293],{},[3490,4295,4297],{"id":4296},"_14-як-tailwind-v4-знаходить-класи-для-генерації","1.4. Як Tailwind v4 знаходить класи для генерації",[3353,4299,4300,4301,4304],{},"У v3 потрібно було вказувати ",[3357,4302,4303],{},"content: ['.\u002Fsrc\u002F**\u002F*.html']"," у конфігурації. У v4 цього не потрібно — Tailwind автоматично сканує файли поряд із вхідним CSS:",[3367,4306,4308],{"className":3369,"code":4307,"filename":3635,"language":3371,"meta":3372,"style":3372},"\u002F* Без жодних налаштувань Tailwind сканує: *\u002F\n\u002F* - Всі .html, .js, .ts, .jsx, .tsx, .vue, .svelte файли у проєкті *\u002F\n\u002F* - За винятком node_modules, dist, .git *\u002F\n@import \"tailwindcss\";\n",[3357,4309,4310,4315,4320,4325],{"__ignoreMap":3372},[3376,4311,4312],{"class":3378,"line":3379},[3376,4313,4314],{"class":3382},"\u002F* Без жодних налаштувань Tailwind сканує: *\u002F\n",[3376,4316,4317],{"class":3378,"line":3386},[3376,4318,4319],{"class":3382},"\u002F* - Всі .html, .js, .ts, .jsx, .tsx, .vue, .svelte файли у проєкті *\u002F\n",[3376,4321,4322],{"class":3378,"line":3401},[3376,4323,4324],{"class":3382},"\u002F* - За винятком node_modules, dist, .git *\u002F\n",[3376,4326,4327,4329,4331],{"class":3378,"line":3408},[3376,4328,3390],{"class":3389},[3376,4330,3649],{"class":3393},[3376,4332,3398],{"class":3397},[3353,4334,4335],{},"Якщо потрібно явно вказати джерела (для нестандартних розширень або структур):",[3367,4337,4339],{"className":3369,"code":4338,"filename":3635,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Явне вказання джерел *\u002F\n@source \"..\u002Ftemplates\u002F**\u002F*.twig\";    \u002F* Twig-шаблони *\u002F\n@source \"..\u002Fviews\u002F**\u002F*.erb\";         \u002F* Rails ERB *\u002F\n@source \"..\u002Fcomponents\u002F**\u002F*.php\";    \u002F* PHP-компоненти *\u002F\n",[3357,4340,4341,4349,4353,4358,4366,4371],{"__ignoreMap":3372},[3376,4342,4343,4345,4347],{"class":3378,"line":3379},[3376,4344,3390],{"class":3389},[3376,4346,3649],{"class":3393},[3376,4348,3398],{"class":3397},[3376,4350,4351],{"class":3378,"line":3386},[3376,4352,3405],{"emptyLinePlaceholder":3404},[3376,4354,4355],{"class":3378,"line":3401},[3376,4356,4357],{"class":3382},"\u002F* Явне вказання джерел *\u002F\n",[3376,4359,4360,4363],{"class":3378,"line":3408},[3376,4361,4362],{"class":3389},"@source",[3376,4364,4365],{"class":3397}," \"..\u002Ftemplates\u002F**\u002F*.twig\";    \u002F* Twig-шаблони *\u002F\n",[3376,4367,4368],{"class":3378,"line":3417},[3376,4369,4370],{"class":3397},"@source \"..\u002Fviews\u002F**\u002F*.erb\";         \u002F* Rails ERB *\u002F\n",[3376,4372,4373],{"class":3378,"line":3436},[3376,4374,4375],{"class":3397},"@source \"..\u002Fcomponents\u002F**\u002F*.php\";    \u002F* PHP-компоненти *\u002F\n",[3353,4377,4378],{},"Або виключити директорії:",[3367,4380,4382],{"className":3369,"code":4381,"filename":3635,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Виключити конкретну директорію *\u002F\n@source not \"..\u002Flegacy\u002F**\";\n",[3357,4383,4384,4392,4396,4401],{"__ignoreMap":3372},[3376,4385,4386,4388,4390],{"class":3378,"line":3379},[3376,4387,3390],{"class":3389},[3376,4389,3649],{"class":3393},[3376,4391,3398],{"class":3397},[3376,4393,4394],{"class":3378,"line":3386},[3376,4395,3405],{"emptyLinePlaceholder":3404},[3376,4397,4398],{"class":3378,"line":3401},[3376,4399,4400],{"class":3382},"\u002F* Виключити конкретну директорію *\u002F\n",[3376,4402,4403,4405],{"class":3378,"line":3408},[3376,4404,4362],{"class":3389},[3376,4406,4407],{"class":3397}," not \"..\u002Flegacy\u002F**\";\n",[3483,4409],{},[3348,4411,4413],{"id":4412},"частина-іі-postcss-інтеграція-у-збірки","Частина ІІ. PostCSS: інтеграція у збірки",[3490,4415,4417],{"id":4416},"_21-tailwind-як-postcss-плагін","2.1. Tailwind як PostCSS-плагін",[3353,4419,4420,4423],{},[3362,4421,4422],{},"PostCSS"," — трансформатор CSS через плагіни. Tailwind v4 є PostCSS-плагіном — це означає, що його можна інтегрувати у будь-яку систему збірки, що підтримує PostCSS (webpack, Rollup, Parcel, Vite тощо).",[3353,4425,4426],{},"Встановлення:",[3367,4428,4430],{"className":3566,"code":4429,"language":3568,"meta":3372,"style":3372},"npm install tailwindcss @tailwindcss\u002Fpostcss postcss --save-dev\n",[3357,4431,4432],{"__ignoreMap":3372},[3376,4433,4434,4436,4438,4440,4443,4446],{"class":3378,"line":3379},[3376,4435,3581],{"class":3580},[3376,4437,3604],{"class":3393},[3376,4439,3607],{"class":3393},[3376,4441,4442],{"class":3393}," @tailwindcss\u002Fpostcss",[3376,4444,4445],{"class":3393}," postcss",[3376,4447,3613],{"class":3587},[3353,4449,4450],{},"Конфігурація PostCSS:",[3367,4452,4457],{"className":4453,"code":4454,"filename":4455,"language":4456,"meta":3372,"style":3372},"language-js shiki shiki-themes light-plus dark-plus dark-plus","\u002F\u002F CommonJS\nmodule.exports = {\n    plugins: {\n        '@tailwindcss\u002Fpostcss': {}\n    }\n}\n","postcss.config.js","js",[3357,4458,4459,4464,4478,4486,4497,4501],{"__ignoreMap":3372},[3376,4460,4461],{"class":3378,"line":3379},[3376,4462,4463],{"class":3382},"\u002F\u002F CommonJS\n",[3376,4465,4466,4470,4472,4475],{"class":3378,"line":3386},[3376,4467,4469],{"class":4468},"sN1BT","module",[3376,4471,3503],{"class":3397},[3376,4473,4474],{"class":4468},"exports",[3376,4476,4477],{"class":3397}," = {\n",[3376,4479,4480,4484],{"class":3378,"line":3401},[3376,4481,4483],{"class":4482},"siwwj","    plugins:",[3376,4485,3414],{"class":3397},[3376,4487,4488,4491,4494],{"class":3378,"line":3408},[3376,4489,4490],{"class":3393},"        '@tailwindcss\u002Fpostcss'",[3376,4492,4493],{"class":4482},":",[3376,4495,4496],{"class":3397}," {}\n",[3376,4498,4499],{"class":3378,"line":3417},[3376,4500,3774],{"class":3397},[3376,4502,4503],{"class":3378,"line":3436},[3376,4504,3457],{"class":3397},[3367,4506,4509],{"className":4453,"code":4507,"filename":4508,"language":4456,"meta":3372,"style":3372},"\u002F\u002F ESM\nexport default {\n    plugins: {\n        '@tailwindcss\u002Fpostcss': {}\n    }\n}\n","postcss.config.mjs",[3357,4510,4511,4516,4526,4532,4540,4544],{"__ignoreMap":3372},[3376,4512,4513],{"class":3378,"line":3379},[3376,4514,4515],{"class":3382},"\u002F\u002F ESM\n",[3376,4517,4518,4521,4524],{"class":3378,"line":3386},[3376,4519,4520],{"class":3389},"export",[3376,4522,4523],{"class":3389}," default",[3376,4525,3414],{"class":3397},[3376,4527,4528,4530],{"class":3378,"line":3401},[3376,4529,4483],{"class":4482},[3376,4531,3414],{"class":3397},[3376,4533,4534,4536,4538],{"class":3378,"line":3408},[3376,4535,4490],{"class":3393},[3376,4537,4493],{"class":4482},[3376,4539,4496],{"class":3397},[3376,4541,4542],{"class":3378,"line":3417},[3376,4543,3774],{"class":3397},[3376,4545,4546],{"class":3378,"line":3436},[3376,4547,3457],{"class":3397},[3353,4549,4550],{},"Або об'єктний синтаксис:",[3367,4552,4554],{"className":4453,"code":4553,"filename":4455,"language":4456,"meta":3372,"style":3372},"const tailwindcss = require('@tailwindcss\u002Fpostcss')\n\nmodule.exports = {\n    plugins: [\n        tailwindcss(),\n        \u002F\u002F Інші PostCSS плагіни після Tailwind:\n        require('autoprefixer'),\n    ]\n}\n",[3357,4555,4556,4578,4582,4592,4599,4607,4612,4625,4630],{"__ignoreMap":3372},[3376,4557,4558,4561,4564,4567,4570,4572,4575],{"class":3378,"line":3379},[3376,4559,4560],{"class":3587},"const",[3376,4562,3607],{"class":4563},"s-QsJ",[3376,4565,4566],{"class":3397}," = ",[3376,4568,4569],{"class":3580},"require",[3376,4571,3737],{"class":3397},[3376,4573,4574],{"class":3393},"'@tailwindcss\u002Fpostcss'",[3376,4576,4577],{"class":3397},")\n",[3376,4579,4580],{"class":3378,"line":3386},[3376,4581,3405],{"emptyLinePlaceholder":3404},[3376,4583,4584,4586,4588,4590],{"class":3378,"line":3401},[3376,4585,4469],{"class":4468},[3376,4587,3503],{"class":3397},[3376,4589,4474],{"class":4468},[3376,4591,4477],{"class":3397},[3376,4593,4594,4596],{"class":3378,"line":3408},[3376,4595,4483],{"class":4482},[3376,4597,4598],{"class":3397}," [\n",[3376,4600,4601,4604],{"class":3378,"line":3417},[3376,4602,4603],{"class":3580},"        tailwindcss",[3376,4605,4606],{"class":3397},"(),\n",[3376,4608,4609],{"class":3378,"line":3436},[3376,4610,4611],{"class":3382},"        \u002F\u002F Інші PostCSS плагіни після Tailwind:\n",[3376,4613,4614,4617,4619,4622],{"class":3378,"line":3454},[3376,4615,4616],{"class":3580},"        require",[3376,4618,3737],{"class":3397},[3376,4620,4621],{"class":3393},"'autoprefixer'",[3376,4623,4624],{"class":3397},"),\n",[3376,4626,4627],{"class":3378,"line":3460},[3376,4628,4629],{"class":3397},"    ]\n",[3376,4631,4632],{"class":3378,"line":3465},[3376,4633,3457],{"class":3397},[4635,4636,4637,4638,4641],"note",{},"У Tailwind v4 ",[3362,4639,4640],{},"autoprefixer здебільшого не потрібен"," — Tailwind вже додає необхідні vendor-префікси для CSS-властивостей, що їх потребують. Однак для максимальної сумісності зі старими браузерами — залиште autoprefixer.",[3483,4643],{},[3490,4645,4647],{"id":4646},"_22-інтеграція-з-vite","2.2. Інтеграція з Vite",[3353,4649,4650,4653],{},[3362,4651,4652],{},"Vite"," — найпопулярніший bundler для сучасних проєктів. Tailwind v4 має офіційний Vite-плагін, який є швидшим за PostCSS-варіант:",[3367,4655,4657],{"className":3566,"code":4656,"language":3568,"meta":3372,"style":3372},"# Встановлення\nnpm install tailwindcss @tailwindcss\u002Fvite --save-dev\n",[3357,4658,4659,4664],{"__ignoreMap":3372},[3376,4660,4661],{"class":3378,"line":3379},[3376,4662,4663],{"class":3382},"# Встановлення\n",[3376,4665,4666,4668,4670,4672,4675],{"class":3378,"line":3386},[3376,4667,3581],{"class":3580},[3376,4669,3604],{"class":3393},[3376,4671,3607],{"class":3393},[3376,4673,4674],{"class":3393}," @tailwindcss\u002Fvite",[3376,4676,3613],{"class":3587},[3367,4678,4681],{"className":4453,"code":4679,"filename":4680,"language":4456,"meta":3372,"style":3372},"import { defineConfig } from 'vite'\nimport tailwindcss from '@tailwindcss\u002Fvite'\n\nexport default defineConfig({\n    plugins: [\n        tailwindcss(),\n        \u002F\u002F Інші Vite-плагіни...\n    ]\n})\n","vite.config.js",[3357,4682,4683,4703,4715,4719,4731,4737,4743,4748,4752],{"__ignoreMap":3372},[3376,4684,4685,4688,4691,4694,4697,4700],{"class":3378,"line":3379},[3376,4686,4687],{"class":3389},"import",[3376,4689,4690],{"class":3397}," { ",[3376,4692,4693],{"class":4482},"defineConfig",[3376,4695,4696],{"class":3397}," } ",[3376,4698,4699],{"class":3389},"from",[3376,4701,4702],{"class":3393}," 'vite'\n",[3376,4704,4705,4707,4709,4712],{"class":3378,"line":3386},[3376,4706,4687],{"class":3389},[3376,4708,3607],{"class":4482},[3376,4710,4711],{"class":3389}," from",[3376,4713,4714],{"class":3393}," '@tailwindcss\u002Fvite'\n",[3376,4716,4717],{"class":3378,"line":3401},[3376,4718,3405],{"emptyLinePlaceholder":3404},[3376,4720,4721,4723,4725,4728],{"class":3378,"line":3408},[3376,4722,4520],{"class":3389},[3376,4724,4523],{"class":3389},[3376,4726,4727],{"class":3580}," defineConfig",[3376,4729,4730],{"class":3397},"({\n",[3376,4732,4733,4735],{"class":3378,"line":3417},[3376,4734,4483],{"class":4482},[3376,4736,4598],{"class":3397},[3376,4738,4739,4741],{"class":3378,"line":3436},[3376,4740,4603],{"class":3580},[3376,4742,4606],{"class":3397},[3376,4744,4745],{"class":3378,"line":3454},[3376,4746,4747],{"class":3382},"        \u002F\u002F Інші Vite-плагіни...\n",[3376,4749,4750],{"class":3378,"line":3460},[3376,4751,4629],{"class":3397},[3376,4753,4754],{"class":3378,"line":3465},[3376,4755,4756],{"class":3397},"})\n",[3367,4758,4761],{"className":4453,"code":4759,"filename":4760,"language":4456,"meta":3372,"style":3372},"import { defineConfig } from 'vite'\nimport tailwindcss from '@tailwindcss\u002Fvite'\nimport react from '@vitejs\u002Fplugin-react'\n\nexport default defineConfig({\n    plugins: [\n        tailwindcss(),\n        react(),\n    ]\n})\n","vite.config.ts",[3357,4762,4763,4777,4787,4799,4803,4813,4819,4825,4832,4836],{"__ignoreMap":3372},[3376,4764,4765,4767,4769,4771,4773,4775],{"class":3378,"line":3379},[3376,4766,4687],{"class":3389},[3376,4768,4690],{"class":3397},[3376,4770,4693],{"class":4482},[3376,4772,4696],{"class":3397},[3376,4774,4699],{"class":3389},[3376,4776,4702],{"class":3393},[3376,4778,4779,4781,4783,4785],{"class":3378,"line":3386},[3376,4780,4687],{"class":3389},[3376,4782,3607],{"class":4482},[3376,4784,4711],{"class":3389},[3376,4786,4714],{"class":3393},[3376,4788,4789,4791,4794,4796],{"class":3378,"line":3401},[3376,4790,4687],{"class":3389},[3376,4792,4793],{"class":4482}," react",[3376,4795,4711],{"class":3389},[3376,4797,4798],{"class":3393}," '@vitejs\u002Fplugin-react'\n",[3376,4800,4801],{"class":3378,"line":3408},[3376,4802,3405],{"emptyLinePlaceholder":3404},[3376,4804,4805,4807,4809,4811],{"class":3378,"line":3417},[3376,4806,4520],{"class":3389},[3376,4808,4523],{"class":3389},[3376,4810,4727],{"class":3580},[3376,4812,4730],{"class":3397},[3376,4814,4815,4817],{"class":3378,"line":3436},[3376,4816,4483],{"class":4482},[3376,4818,4598],{"class":3397},[3376,4820,4821,4823],{"class":3378,"line":3454},[3376,4822,4603],{"class":3580},[3376,4824,4606],{"class":3397},[3376,4826,4827,4830],{"class":3378,"line":3460},[3376,4828,4829],{"class":3580},"        react",[3376,4831,4606],{"class":3397},[3376,4833,4834],{"class":3378,"line":3465},[3376,4835,4629],{"class":3397},[3376,4837,4838],{"class":3378,"line":3701},[3376,4839,4756],{"class":3397},[3353,4841,4842],{},"CSS-файл підключається звичайним імпортом:",[3367,4844,4847],{"className":3369,"code":4845,"filename":4846,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Ваша конфігурація *\u002F\n@theme {\n    --font-sans: 'Inter', system-ui, sans-serif;\n}\n","src\u002Findex.css",[3357,4848,4849,4857,4861,4866,4872,4884],{"__ignoreMap":3372},[3376,4850,4851,4853,4855],{"class":3378,"line":3379},[3376,4852,3390],{"class":3389},[3376,4854,3649],{"class":3393},[3376,4856,3398],{"class":3397},[3376,4858,4859],{"class":3378,"line":3386},[3376,4860,3405],{"emptyLinePlaceholder":3404},[3376,4862,4863],{"class":3378,"line":3401},[3376,4864,4865],{"class":3382},"\u002F* Ваша конфігурація *\u002F\n",[3376,4867,4868,4870],{"class":3378,"line":3408},[3376,4869,3411],{"class":3389},[3376,4871,3414],{"class":3397},[3376,4873,4874,4876,4878,4880,4882],{"class":3378,"line":3417},[3376,4875,3439],{"class":3397},[3376,4877,3443],{"class":3442},[3376,4879,3446],{"class":3397},[3376,4881,3449],{"class":3442},[3376,4883,3398],{"class":3397},[3376,4885,4886],{"class":3378,"line":3436},[3376,4887,3457],{"class":3397},[3367,4889,4892],{"className":4453,"code":4890,"filename":4891,"language":4456,"meta":3372,"style":3372},"import '.\u002Findex.css'\n\u002F\u002F або у main.ts:\nimport '.\u002Findex.css'\n","src\u002Fmain.js",[3357,4893,4894,4901,4906],{"__ignoreMap":3372},[3376,4895,4896,4898],{"class":3378,"line":3379},[3376,4897,4687],{"class":3389},[3376,4899,4900],{"class":3393}," '.\u002Findex.css'\n",[3376,4902,4903],{"class":3378,"line":3386},[3376,4904,4905],{"class":3382},"\u002F\u002F або у main.ts:\n",[3376,4907,4908,4910],{"class":3378,"line":3401},[3376,4909,4687],{"class":3389},[3376,4911,4900],{"class":3393},[3353,4913,4914],{},[3362,4915,4916],{},"Vite + React (повний приклад):",[3367,4918,4920],{"className":3566,"code":4919,"language":3568,"meta":3372,"style":3372},"# Новий проєкт\nnpm create vite@latest my-app -- --template react\ncd my-app\nnpm install tailwindcss @tailwindcss\u002Fvite --save-dev\n",[3357,4921,4922,4927,4949,4957],{"__ignoreMap":3372},[3376,4923,4924],{"class":3378,"line":3379},[3376,4925,4926],{"class":3382},"# Новий проєкт\n",[3376,4928,4929,4931,4934,4937,4940,4943,4946],{"class":3378,"line":3386},[3376,4930,3581],{"class":3580},[3376,4932,4933],{"class":3393}," create",[3376,4935,4936],{"class":3393}," vite@latest",[3376,4938,4939],{"class":3393}," my-app",[3376,4941,4942],{"class":3587}," --",[3376,4944,4945],{"class":3587}," --template",[3376,4947,4948],{"class":3393}," react\n",[3376,4950,4951,4954],{"class":3378,"line":3401},[3376,4952,4953],{"class":3580},"cd",[3376,4955,4956],{"class":3393}," my-app\n",[3376,4958,4959,4961,4963,4965,4967],{"class":3378,"line":3408},[3376,4960,3581],{"class":3580},[3376,4962,3604],{"class":3393},[3376,4964,3607],{"class":3393},[3376,4966,4674],{"class":3393},[3376,4968,3613],{"class":3587},[3367,4970,4972],{"className":4453,"code":4971,"filename":4680,"language":4456,"meta":3372,"style":3372},"import { defineConfig } from 'vite'\nimport react from '@vitejs\u002Fplugin-react'\nimport tailwindcss from '@tailwindcss\u002Fvite'\n\nexport default defineConfig({\n    plugins: [tailwindcss(), react()]\n})\n",[3357,4973,4974,4988,4998,5008,5012,5022,5041],{"__ignoreMap":3372},[3376,4975,4976,4978,4980,4982,4984,4986],{"class":3378,"line":3379},[3376,4977,4687],{"class":3389},[3376,4979,4690],{"class":3397},[3376,4981,4693],{"class":4482},[3376,4983,4696],{"class":3397},[3376,4985,4699],{"class":3389},[3376,4987,4702],{"class":3393},[3376,4989,4990,4992,4994,4996],{"class":3378,"line":3386},[3376,4991,4687],{"class":3389},[3376,4993,4793],{"class":4482},[3376,4995,4711],{"class":3389},[3376,4997,4798],{"class":3393},[3376,4999,5000,5002,5004,5006],{"class":3378,"line":3401},[3376,5001,4687],{"class":3389},[3376,5003,3607],{"class":4482},[3376,5005,4711],{"class":3389},[3376,5007,4714],{"class":3393},[3376,5009,5010],{"class":3378,"line":3408},[3376,5011,3405],{"emptyLinePlaceholder":3404},[3376,5013,5014,5016,5018,5020],{"class":3378,"line":3417},[3376,5015,4520],{"class":3389},[3376,5017,4523],{"class":3389},[3376,5019,4727],{"class":3580},[3376,5021,4730],{"class":3397},[3376,5023,5024,5026,5029,5032,5035,5038],{"class":3378,"line":3436},[3376,5025,4483],{"class":4482},[3376,5027,5028],{"class":3397}," [",[3376,5030,5031],{"class":3580},"tailwindcss",[3376,5033,5034],{"class":3397},"(), ",[3376,5036,5037],{"class":3580},"react",[3376,5039,5040],{"class":3397},"()]\n",[3376,5042,5043],{"class":3378,"line":3454},[3376,5044,4756],{"class":3397},[3367,5046,5048],{"className":3369,"code":5047,"filename":4846,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n",[3357,5049,5050],{"__ignoreMap":3372},[3376,5051,5052,5054,5056],{"class":3378,"line":3379},[3376,5053,3390],{"class":3389},[3376,5055,3649],{"class":3393},[3376,5057,3398],{"class":3397},[3367,5059,5064],{"className":5060,"code":5061,"filename":5062,"language":5063,"meta":3372,"style":3372},"language-jsx shiki shiki-themes light-plus dark-plus dark-plus","import '.\u002Findex.css'\n\nfunction App() {\n    return (\n        \u003Cdiv className=\"min-h-screen bg-slate-50 flex items-center justify-center\">\n            \u003Ch1 className=\"text-3xl font-black text-slate-900\">\n                Tailwind v4 + React\n            \u003C\u002Fh1>\n        \u003C\u002Fdiv>\n    )\n}\n","src\u002FApp.jsx","jsx",[3357,5065,5066,5072,5076,5087,5095,5111,5127,5132,5141,5149,5154],{"__ignoreMap":3372},[3376,5067,5068,5070],{"class":3378,"line":3379},[3376,5069,4687],{"class":3389},[3376,5071,4900],{"class":3393},[3376,5073,5074],{"class":3378,"line":3386},[3376,5075,3405],{"emptyLinePlaceholder":3404},[3376,5077,5078,5081,5084],{"class":3378,"line":3401},[3376,5079,5080],{"class":3587},"function",[3376,5082,5083],{"class":3580}," App",[3376,5085,5086],{"class":3397},"() {\n",[3376,5088,5089,5092],{"class":3378,"line":3408},[3376,5090,5091],{"class":3389},"    return",[3376,5093,5094],{"class":3397}," (\n",[3376,5096,5097,5099,5101,5104,5106,5109],{"class":3378,"line":3417},[3376,5098,4162],{"class":3978},[3376,5100,4148],{"class":3442},[3376,5102,5103],{"class":3727}," className",[3376,5105,4001],{"class":3397},[3376,5107,5108],{"class":3393},"\"min-h-screen bg-slate-50 flex items-center justify-center\"",[3376,5110,3988],{"class":3978},[3376,5112,5113,5116,5118,5120,5122,5125],{"class":3378,"line":3436},[3376,5114,5115],{"class":3978},"            \u003C",[3376,5117,3344],{"class":3442},[3376,5119,5103],{"class":3727},[3376,5121,4001],{"class":3397},[3376,5123,5124],{"class":3393},"\"text-3xl font-black text-slate-900\"",[3376,5126,3988],{"class":3978},[3376,5128,5129],{"class":3378,"line":3454},[3376,5130,5131],{"class":3397},"                Tailwind v4 + React\n",[3376,5133,5134,5137,5139],{"class":3378,"line":3460},[3376,5135,5136],{"class":3978},"            \u003C\u002F",[3376,5138,3344],{"class":3442},[3376,5140,3988],{"class":3978},[3376,5142,5143,5145,5147],{"class":3378,"line":3465},[3376,5144,4208],{"class":3978},[3376,5146,4148],{"class":3442},[3376,5148,3988],{"class":3978},[3376,5150,5151],{"class":3378,"line":3701},[3376,5152,5153],{"class":3397},"    )\n",[3376,5155,5156],{"class":3378,"line":3707},[3376,5157,3457],{"class":3397},[3483,5159],{},[3490,5161,5163],{"id":5162},"_23-інтеграція-з-nextjs","2.3. Інтеграція з Next.js",[3353,5165,5166,5167,4493],{},"Next.js 14+ має вбудовану підтримку Tailwind v4 через ",[3357,5168,5169],{},"@tailwindcss\u002Fpostcss",[3367,5171,5173],{"className":3566,"code":5172,"language":3568,"meta":3372,"style":3372},"# Новий Next.js проєкт із Tailwind\nnpx create-next-app@latest my-app --tailwind\ncd my-app\n# Tailwind вже підключений!\n",[3357,5174,5175,5180,5192,5198],{"__ignoreMap":3372},[3376,5176,5177],{"class":3378,"line":3379},[3376,5178,5179],{"class":3382},"# Новий Next.js проєкт із Tailwind\n",[3376,5181,5182,5184,5187,5189],{"class":3378,"line":3386},[3376,5183,3799],{"class":3580},[3376,5185,5186],{"class":3393}," create-next-app@latest",[3376,5188,4939],{"class":3393},[3376,5190,5191],{"class":3587}," --tailwind\n",[3376,5193,5194,5196],{"class":3378,"line":3401},[3376,5195,4953],{"class":3580},[3376,5197,4956],{"class":3393},[3376,5199,5200],{"class":3378,"line":3408},[3376,5201,5202],{"class":3382},"# Tailwind вже підключений!\n",[3353,5204,5205],{},"Якщо додаєте до існуючого проєкту:",[3367,5207,5208],{"className":3566,"code":4429,"language":3568,"meta":3372,"style":3372},[3357,5209,5210],{"__ignoreMap":3372},[3376,5211,5212,5214,5216,5218,5220,5222],{"class":3378,"line":3379},[3376,5213,3581],{"class":3580},[3376,5215,3604],{"class":3393},[3376,5217,3607],{"class":3393},[3376,5219,4442],{"class":3393},[3376,5221,4445],{"class":3393},[3376,5223,3613],{"class":3587},[3367,5225,5227],{"className":4453,"code":5226,"filename":4508,"language":4456,"meta":3372,"style":3372},"const config = {\n    plugins: {\n        '@tailwindcss\u002Fpostcss': {}\n    }\n}\nexport default config\n",[3357,5228,5229,5238,5244,5252,5256,5260],{"__ignoreMap":3372},[3376,5230,5231,5233,5236],{"class":3378,"line":3379},[3376,5232,4560],{"class":3587},[3376,5234,5235],{"class":4563}," config",[3376,5237,4477],{"class":3397},[3376,5239,5240,5242],{"class":3378,"line":3386},[3376,5241,4483],{"class":4482},[3376,5243,3414],{"class":3397},[3376,5245,5246,5248,5250],{"class":3378,"line":3401},[3376,5247,4490],{"class":3393},[3376,5249,4493],{"class":4482},[3376,5251,4496],{"class":3397},[3376,5253,5254],{"class":3378,"line":3408},[3376,5255,3774],{"class":3397},[3376,5257,5258],{"class":3378,"line":3417},[3376,5259,3457],{"class":3397},[3376,5261,5262,5264,5266],{"class":3378,"line":3436},[3376,5263,4520],{"class":3389},[3376,5265,4523],{"class":3389},[3376,5267,5268],{"class":4482}," config\n",[3367,5270,5273],{"className":3369,"code":5271,"filename":5272,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Ваша тема *\u002F\n@theme {\n    --font-sans: var(--font-inter), system-ui, sans-serif;\n    --color-brand: oklch(0.585 0.233 277);\n}\n","app\u002Fglobals.css",[3357,5274,5275,5283,5287,5292,5298,5311,5323],{"__ignoreMap":3372},[3376,5276,5277,5279,5281],{"class":3378,"line":3379},[3376,5278,3390],{"class":3389},[3376,5280,3649],{"class":3393},[3376,5282,3398],{"class":3397},[3376,5284,5285],{"class":3378,"line":3386},[3376,5286,3405],{"emptyLinePlaceholder":3404},[3376,5288,5289],{"class":3378,"line":3401},[3376,5290,5291],{"class":3382},"\u002F* Ваша тема *\u002F\n",[3376,5293,5294,5296],{"class":3378,"line":3408},[3376,5295,3411],{"class":3389},[3376,5297,3414],{"class":3397},[3376,5299,5300,5303,5305,5307,5309],{"class":3378,"line":3417},[3376,5301,5302],{"class":3397},"    --font-sans: var(--font-inter), ",[3376,5304,3443],{"class":3442},[3376,5306,3446],{"class":3397},[3376,5308,3449],{"class":3442},[3376,5310,3398],{"class":3397},[3376,5312,5313,5315,5317,5319,5321],{"class":3378,"line":3436},[3376,5314,3420],{"class":3397},[3376,5316,3424],{"class":3423},[3376,5318,3427],{"class":3397},[3376,5320,3430],{"class":3423},[3376,5322,3433],{"class":3397},[3376,5324,5325],{"class":3378,"line":3454},[3376,5326,3457],{"class":3397},[3367,5328,5331],{"className":5060,"code":5329,"filename":5330,"language":5063,"meta":3372,"style":3372},"import { Inter } from 'next\u002Ffont\u002Fgoogle'\nimport '.\u002Fglobals.css'\n\nconst inter = Inter({ subsets: ['latin'], variable: '--font-inter' })\n\nexport default function RootLayout({ children }) {\n    return (\n        \u003Chtml lang=\"uk\" className={inter.variable}>\n            \u003Cbody>{children}\u003C\u002Fbody>\n        \u003C\u002Fhtml>\n    )\n}\n","app\u002Flayout.jsx",[3357,5332,5333,5349,5356,5360,5394,5398,5418,5424,5457,5477,5485,5489],{"__ignoreMap":3372},[3376,5334,5335,5337,5339,5342,5344,5346],{"class":3378,"line":3379},[3376,5336,4687],{"class":3389},[3376,5338,4690],{"class":3397},[3376,5340,5341],{"class":4482},"Inter",[3376,5343,4696],{"class":3397},[3376,5345,4699],{"class":3389},[3376,5347,5348],{"class":3393}," 'next\u002Ffont\u002Fgoogle'\n",[3376,5350,5351,5353],{"class":3378,"line":3386},[3376,5352,4687],{"class":3389},[3376,5354,5355],{"class":3393}," '.\u002Fglobals.css'\n",[3376,5357,5358],{"class":3378,"line":3401},[3376,5359,3405],{"emptyLinePlaceholder":3404},[3376,5361,5362,5364,5367,5369,5371,5374,5377,5379,5382,5385,5388,5391],{"class":3378,"line":3408},[3376,5363,4560],{"class":3587},[3376,5365,5366],{"class":4563}," inter",[3376,5368,4566],{"class":3397},[3376,5370,5341],{"class":3580},[3376,5372,5373],{"class":3397},"({ ",[3376,5375,5376],{"class":4482},"subsets:",[3376,5378,5028],{"class":3397},[3376,5380,5381],{"class":3393},"'latin'",[3376,5383,5384],{"class":3397},"], ",[3376,5386,5387],{"class":4482},"variable:",[3376,5389,5390],{"class":3393}," '--font-inter'",[3376,5392,5393],{"class":3397}," })\n",[3376,5395,5396],{"class":3378,"line":3417},[3376,5397,3405],{"emptyLinePlaceholder":3404},[3376,5399,5400,5402,5404,5407,5410,5412,5415],{"class":3378,"line":3436},[3376,5401,4520],{"class":3389},[3376,5403,4523],{"class":3389},[3376,5405,5406],{"class":3587}," function",[3376,5408,5409],{"class":3580}," RootLayout",[3376,5411,5373],{"class":3397},[3376,5413,5414],{"class":4482},"children",[3376,5416,5417],{"class":3397}," }) {\n",[3376,5419,5420,5422],{"class":3378,"line":3454},[3376,5421,5091],{"class":3389},[3376,5423,5094],{"class":3397},[3376,5425,5426,5428,5430,5432,5434,5436,5438,5440,5443,5446,5449,5452,5455],{"class":3378,"line":3460},[3376,5427,4162],{"class":3978},[3376,5429,3971],{"class":3442},[3376,5431,3998],{"class":3727},[3376,5433,4001],{"class":3397},[3376,5435,4005],{"class":3393},[3376,5437,5103],{"class":3727},[3376,5439,4001],{"class":3397},[3376,5441,5442],{"class":3587},"{",[3376,5444,5445],{"class":4482},"inter",[3376,5447,3503],{"class":5448},"sD7JJ",[3376,5450,5451],{"class":4482},"variable",[3376,5453,5454],{"class":3587},"}",[3376,5456,3988],{"class":3978},[3376,5458,5459,5461,5463,5465,5467,5469,5471,5473,5475],{"class":3378,"line":3465},[3376,5460,5115],{"class":3978},[3376,5462,4127],{"class":3442},[3376,5464,4068],{"class":3978},[3376,5466,5442],{"class":3587},[3376,5468,5414],{"class":4482},[3376,5470,5454],{"class":3587},[3376,5472,4074],{"class":3978},[3376,5474,4127],{"class":3442},[3376,5476,3988],{"class":3978},[3376,5478,5479,5481,5483],{"class":3378,"line":3701},[3376,5480,4208],{"class":3978},[3376,5482,3971],{"class":3442},[3376,5484,3988],{"class":3978},[3376,5486,5487],{"class":3378,"line":3707},[3376,5488,5153],{"class":3397},[3376,5490,5491],{"class":3378,"line":3716},[3376,5492,3457],{"class":3397},[4285,5494,5495,5496,5499,5500,5502,5503,5506],{},"Зверніть: Next.js Google Fonts підключає шрифт через CSS-змінну (",[3357,5497,5498],{},"--font-inter","). У ",[3357,5501,3411],{}," ми посилаємося на цю змінну через ",[3357,5504,5505],{},"var(--font-inter)"," — так шрифт правильно підхоплюється як частиною дизайн-системи.",[3483,5508],{},[3490,5510,5512],{"id":5511},"_24-інтеграція-з-nuxt-3","2.4. Інтеграція з Nuxt 3",[3367,5514,5516],{"className":3566,"code":5515,"language":3568,"meta":3372,"style":3372},"# Новий Nuxt проєкт\nnpx nuxi@latest init my-app\ncd my-app\nnpm install tailwindcss @tailwindcss\u002Fvite --save-dev\n",[3357,5517,5518,5523,5534,5540],{"__ignoreMap":3372},[3376,5519,5520],{"class":3378,"line":3379},[3376,5521,5522],{"class":3382},"# Новий Nuxt проєкт\n",[3376,5524,5525,5527,5530,5532],{"class":3378,"line":3386},[3376,5526,3799],{"class":3580},[3376,5528,5529],{"class":3393}," nuxi@latest",[3376,5531,3584],{"class":3393},[3376,5533,4956],{"class":3393},[3376,5535,5536,5538],{"class":3378,"line":3401},[3376,5537,4953],{"class":3580},[3376,5539,4956],{"class":3393},[3376,5541,5542,5544,5546,5548,5550],{"class":3378,"line":3408},[3376,5543,3581],{"class":3580},[3376,5545,3604],{"class":3393},[3376,5547,3607],{"class":3393},[3376,5549,4674],{"class":3393},[3376,5551,3613],{"class":3587},[3367,5553,5558],{"className":5554,"code":5555,"filename":5556,"language":5557,"meta":3372,"style":3372},"language-ts shiki shiki-themes light-plus dark-plus dark-plus","import tailwindcss from '@tailwindcss\u002Fvite'\n\nexport default defineNuxtConfig({\n    vite: {\n        plugins: [\n            tailwindcss()\n        ]\n    }\n})\n","nuxt.config.ts","ts",[3357,5559,5560,5570,5574,5585,5592,5599,5607,5612,5616],{"__ignoreMap":3372},[3376,5561,5562,5564,5566,5568],{"class":3378,"line":3379},[3376,5563,4687],{"class":3389},[3376,5565,3607],{"class":4482},[3376,5567,4711],{"class":3389},[3376,5569,4714],{"class":3393},[3376,5571,5572],{"class":3378,"line":3386},[3376,5573,3405],{"emptyLinePlaceholder":3404},[3376,5575,5576,5578,5580,5583],{"class":3378,"line":3401},[3376,5577,4520],{"class":3389},[3376,5579,4523],{"class":3389},[3376,5581,5582],{"class":3580}," defineNuxtConfig",[3376,5584,4730],{"class":3397},[3376,5586,5587,5590],{"class":3378,"line":3408},[3376,5588,5589],{"class":4482},"    vite:",[3376,5591,3414],{"class":3397},[3376,5593,5594,5597],{"class":3378,"line":3417},[3376,5595,5596],{"class":4482},"        plugins:",[3376,5598,4598],{"class":3397},[3376,5600,5601,5604],{"class":3378,"line":3436},[3376,5602,5603],{"class":3580},"            tailwindcss",[3376,5605,5606],{"class":3397},"()\n",[3376,5608,5609],{"class":3378,"line":3454},[3376,5610,5611],{"class":3397},"        ]\n",[3376,5613,5614],{"class":3378,"line":3460},[3376,5615,3774],{"class":3397},[3376,5617,5618],{"class":3378,"line":3465},[3376,5619,4756],{"class":3397},[3367,5621,5624],{"className":3369,"code":5622,"filename":5623,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n@theme {\n    --color-brand: oklch(0.585 0.233 277);\n}\n","assets\u002Fcss\u002Fmain.css",[3357,5625,5626,5634,5638,5644,5656],{"__ignoreMap":3372},[3376,5627,5628,5630,5632],{"class":3378,"line":3379},[3376,5629,3390],{"class":3389},[3376,5631,3649],{"class":3393},[3376,5633,3398],{"class":3397},[3376,5635,5636],{"class":3378,"line":3386},[3376,5637,3405],{"emptyLinePlaceholder":3404},[3376,5639,5640,5642],{"class":3378,"line":3401},[3376,5641,3411],{"class":3389},[3376,5643,3414],{"class":3397},[3376,5645,5646,5648,5650,5652,5654],{"class":3378,"line":3408},[3376,5647,3420],{"class":3397},[3376,5649,3424],{"class":3423},[3376,5651,3427],{"class":3397},[3376,5653,3430],{"class":3423},[3376,5655,3433],{"class":3397},[3376,5657,5658],{"class":3378,"line":3417},[3376,5659,3457],{"class":3397},[3367,5661,5663],{"className":5554,"code":5662,"filename":5556,"language":5557,"meta":3372,"style":3372},"export default defineNuxtConfig({\n    css: ['~\u002Fassets\u002Fcss\u002Fmain.css'],\n    vite: {\n        plugins: [tailwindcss()]\n    }\n})\n",[3357,5664,5665,5675,5688,5694,5704,5708],{"__ignoreMap":3372},[3376,5666,5667,5669,5671,5673],{"class":3378,"line":3379},[3376,5668,4520],{"class":3389},[3376,5670,4523],{"class":3389},[3376,5672,5582],{"class":3580},[3376,5674,4730],{"class":3397},[3376,5676,5677,5680,5682,5685],{"class":3378,"line":3386},[3376,5678,5679],{"class":4482},"    css:",[3376,5681,5028],{"class":3397},[3376,5683,5684],{"class":3393},"'~\u002Fassets\u002Fcss\u002Fmain.css'",[3376,5686,5687],{"class":3397},"],\n",[3376,5689,5690,5692],{"class":3378,"line":3401},[3376,5691,5589],{"class":4482},[3376,5693,3414],{"class":3397},[3376,5695,5696,5698,5700,5702],{"class":3378,"line":3408},[3376,5697,5596],{"class":4482},[3376,5699,5028],{"class":3397},[3376,5701,5031],{"class":3580},[3376,5703,5040],{"class":3397},[3376,5705,5706],{"class":3378,"line":3417},[3376,5707,3774],{"class":3397},[3376,5709,5710],{"class":3378,"line":3436},[3376,5711,4756],{"class":3397},[3483,5713],{},[3490,5715,5717],{"id":5716},"_25-порівняльна-таблиця-методів-підключення","2.5. Порівняльна таблиця методів підключення",[5719,5720,5721,5740],"table",{},[5722,5723,5724],"thead",{},[5725,5726,5727,5731,5734,5737],"tr",{},[5728,5729,5730],"th",{},"Метод",[5728,5732,5733],{},"Коли використовувати",[5728,5735,5736],{},"Швидкість",[5728,5738,5739],{},"Складність",[5741,5742,5743,5765,5780,5795,5810,5824],"tbody",{},[5725,5744,5745,5756,5759,5762],{},[5746,5747,5748,5751,5752,5755],"td",{},[3362,5749,5750],{},"CDN"," (",[3357,5753,5754],{},"\u003Cscript src=\"cdn.tailwindcss.com\">",")",[5746,5757,5758],{},"Тільки для прототипів",[5746,5760,5761],{},"Немає збірки",[5746,5763,5764],{},"Нульова",[5725,5766,5767,5771,5774,5777],{},[5746,5768,5769],{},[3362,5770,3498],{},[5746,5772,5773],{},"Статичні сайти, без bundler",[5746,5775,5776],{},"Висока",[5746,5778,5779],{},"Низька",[5725,5781,5782,5787,5790,5792],{},[5746,5783,5784],{},[3362,5785,5786],{},"PostCSS-плагін",[5746,5788,5789],{},"Webpack, Rollup, Parcel",[5746,5791,5776],{},[5746,5793,5794],{},"Середня",[5725,5796,5797,5802,5805,5808],{},[5746,5798,5799],{},[3362,5800,5801],{},"Vite-плагін",[5746,5803,5804],{},"Vite, React, Vue, Svelte",[5746,5806,5807],{},"Найвища",[5746,5809,5779],{},[5725,5811,5812,5817,5820,5822],{},[5746,5813,5814],{},[3362,5815,5816],{},"Next.js",[5746,5818,5819],{},"Next.js застосунки",[5746,5821,5776],{},[5746,5823,5779],{},[5725,5825,5826,5831,5834,5836],{},[5746,5827,5828],{},[3362,5829,5830],{},"Nuxt",[5746,5832,5833],{},"Nuxt застосунки",[5746,5835,5776],{},[5746,5837,5779],{},[3483,5839],{},[3348,5841,5843,5844],{"id":5842},"частина-ііі-css-файл-замість-tailwindconfigjs","Частина ІІІ. CSS-файл замість ",[3357,5845,3359],{},[3490,5847,5849],{"id":5848},"_31-що-де-налаштовується","3.1. Що де налаштовується",[3353,5851,5852,5853,5855],{},"У v4 всі налаштування, що раніше жили у ",[3357,5854,3359],{},", переїхали у CSS:",[3367,5857,5859],{"className":4453,"code":5858,"language":4456,"meta":3372,"style":3372},"\u002F\u002F tailwind.config.js (v3 — застарілий підхід)\nmodule.exports = {\n    content: ['.\u002Fsrc\u002F**\u002F*.{html,js}'],\n    theme: {\n        extend: {\n            colors: {\n                brand: '#4f46e5',\n            },\n            fontFamily: {\n                sans: ['Inter', 'system-ui'],\n            },\n            borderRadius: {\n                '4xl': '2rem',\n            }\n        }\n    },\n    plugins: [\n        require('@tailwindcss\u002Ftypography'),\n    ]\n}\n",[3357,5860,5861,5866,5876,5888,5895,5902,5909,5919,5924,5931,5948,5952,5959,5971,5976,5981,5985,5991,6002,6006],{"__ignoreMap":3372},[3376,5862,5863],{"class":3378,"line":3379},[3376,5864,5865],{"class":3382},"\u002F\u002F tailwind.config.js (v3 — застарілий підхід)\n",[3376,5867,5868,5870,5872,5874],{"class":3378,"line":3386},[3376,5869,4469],{"class":4468},[3376,5871,3503],{"class":3397},[3376,5873,4474],{"class":4468},[3376,5875,4477],{"class":3397},[3376,5877,5878,5881,5883,5886],{"class":3378,"line":3401},[3376,5879,5880],{"class":4482},"    content:",[3376,5882,5028],{"class":3397},[3376,5884,5885],{"class":3393},"'.\u002Fsrc\u002F**\u002F*.{html,js}'",[3376,5887,5687],{"class":3397},[3376,5889,5890,5893],{"class":3378,"line":3408},[3376,5891,5892],{"class":4482},"    theme:",[3376,5894,3414],{"class":3397},[3376,5896,5897,5900],{"class":3378,"line":3417},[3376,5898,5899],{"class":4482},"        extend:",[3376,5901,3414],{"class":3397},[3376,5903,5904,5907],{"class":3378,"line":3436},[3376,5905,5906],{"class":4482},"            colors:",[3376,5908,3414],{"class":3397},[3376,5910,5911,5914,5917],{"class":3378,"line":3454},[3376,5912,5913],{"class":4482},"                brand:",[3376,5915,5916],{"class":3393}," '#4f46e5'",[3376,5918,3907],{"class":3397},[3376,5920,5921],{"class":3378,"line":3460},[3376,5922,5923],{"class":3397},"            },\n",[3376,5925,5926,5929],{"class":3378,"line":3465},[3376,5927,5928],{"class":4482},"            fontFamily:",[3376,5930,3414],{"class":3397},[3376,5932,5933,5936,5938,5941,5943,5946],{"class":3378,"line":3701},[3376,5934,5935],{"class":4482},"                sans:",[3376,5937,5028],{"class":3397},[3376,5939,5940],{"class":3393},"'Inter'",[3376,5942,3446],{"class":3397},[3376,5944,5945],{"class":3393},"'system-ui'",[3376,5947,5687],{"class":3397},[3376,5949,5950],{"class":3378,"line":3707},[3376,5951,5923],{"class":3397},[3376,5953,5954,5957],{"class":3378,"line":3716},[3376,5955,5956],{"class":4482},"            borderRadius:",[3376,5958,3414],{"class":3397},[3376,5960,5961,5964,5966,5969],{"class":3378,"line":3724},[3376,5962,5963],{"class":3393},"                '4xl'",[3376,5965,4493],{"class":4482},[3376,5967,5968],{"class":3393}," '2rem'",[3376,5970,3907],{"class":3397},[3376,5972,5973],{"class":3378,"line":3746},[3376,5974,5975],{"class":3397},"            }\n",[3376,5977,5978],{"class":3378,"line":3771},[3376,5979,5980],{"class":3397},"        }\n",[3376,5982,5983],{"class":3378,"line":3777},[3376,5984,3922],{"class":3397},[3376,5986,5987,5989],{"class":3378,"line":4205},[3376,5988,4483],{"class":4482},[3376,5990,4598],{"class":3397},[3376,5992,5993,5995,5997,6000],{"class":3378,"line":4215},[3376,5994,4616],{"class":3580},[3376,5996,3737],{"class":3397},[3376,5998,5999],{"class":3393},"'@tailwindcss\u002Ftypography'",[3376,6001,4624],{"class":3397},[3376,6003,6004],{"class":3378,"line":4230},[3376,6005,4629],{"class":3397},[3376,6007,6008],{"class":3378,"line":4238},[3376,6009,3457],{"class":3397},[3367,6011,6014],{"className":3369,"code":6012,"filename":6013,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Колір бренду *\u002F\n@theme {\n    --color-brand: oklch(0.585 0.233 277);\n    --font-family-sans: 'Inter', system-ui, sans-serif;\n    --radius-4xl: 2rem;\n}\n\n\u002F* Плагіни: через @import або @plugin *\u002F\n@plugin \"@tailwindcss\u002Ftypography\";\n","src\u002Finput.css (v4 — новий підхід)",[3357,6015,6016,6024,6028,6033,6039,6051,6064,6069,6073,6077,6082],{"__ignoreMap":3372},[3376,6017,6018,6020,6022],{"class":3378,"line":3379},[3376,6019,3390],{"class":3389},[3376,6021,3649],{"class":3393},[3376,6023,3398],{"class":3397},[3376,6025,6026],{"class":3378,"line":3386},[3376,6027,3405],{"emptyLinePlaceholder":3404},[3376,6029,6030],{"class":3378,"line":3401},[3376,6031,6032],{"class":3382},"\u002F* Колір бренду *\u002F\n",[3376,6034,6035,6037],{"class":3378,"line":3408},[3376,6036,3411],{"class":3389},[3376,6038,3414],{"class":3397},[3376,6040,6041,6043,6045,6047,6049],{"class":3378,"line":3417},[3376,6042,3420],{"class":3397},[3376,6044,3424],{"class":3423},[3376,6046,3427],{"class":3397},[3376,6048,3430],{"class":3423},[3376,6050,3433],{"class":3397},[3376,6052,6053,6056,6058,6060,6062],{"class":3378,"line":3436},[3376,6054,6055],{"class":3397},"    --font-family-sans: 'Inter', ",[3376,6057,3443],{"class":3442},[3376,6059,3446],{"class":3397},[3376,6061,3449],{"class":3442},[3376,6063,3398],{"class":3397},[3376,6065,6066],{"class":3378,"line":3454},[3376,6067,6068],{"class":3397},"    --radius-4xl: 2rem;\n",[3376,6070,6071],{"class":3378,"line":3460},[3376,6072,3457],{"class":3397},[3376,6074,6075],{"class":3378,"line":3465},[3376,6076,3405],{"emptyLinePlaceholder":3404},[3376,6078,6079],{"class":3378,"line":3701},[3376,6080,6081],{"class":3382},"\u002F* Плагіни: через @import або @plugin *\u002F\n",[3376,6083,6084,6087],{"class":3378,"line":3707},[3376,6085,6086],{"class":3389},"@plugin",[3376,6088,6089],{"class":3397}," \"@tailwindcss\u002Ftypography\";\n",[3483,6091],{},[3490,6093,6095,6096,6098],{"id":6094},"_32-theme-повна-анатомія","3.2. ",[3357,6097,3411],{},": повна анатомія",[3353,6100,6101,6103,6104,6107,6108,6111,6112,6114],{},[3357,6102,3411],{}," — аналог ",[3357,6105,6106],{},"theme.extend"," у v3, але більш потужний. Будь-який ",[3357,6109,6110],{},"--*"," токен у ",[3357,6113,3411],{}," стає utility-класом:",[3367,6116,6119],{"className":3369,"code":6117,"filename":6118,"language":3371,"meta":3372,"style":3372},"@theme {\n    \u002F* ═══ Кольори ════════════════════════════════════════════ *\u002F\n    --color-brand-50:  oklch(0.971 0.015 280);\n    --color-brand-100: oklch(0.943 0.030 280);\n    --color-brand-500: oklch(0.585 0.233 277);\n    --color-brand-600: oklch(0.511 0.262 277);\n    --color-brand-900: oklch(0.257 0.090 281);\n\n    \u002F* → генерує: bg-brand-50, text-brand-500, border-brand-600 *\u002F\n\n    \u002F* ═══ Шрифти ══════════════════════════════════════════════ *\u002F\n    --font-family-sans:  'Inter Variable', system-ui, sans-serif;\n    --font-family-mono:  'JetBrains Mono', 'Fira Code', monospace;\n    --font-family-serif: 'Playfair Display', Georgia, serif;\n\n    \u002F* → генерує: font-sans, font-mono, font-serif *\u002F\n\n    \u002F* ═══ Spacing (доповнення до стандартного) ════════════════ *\u002F\n    --spacing-18:  4.5rem;   \u002F* → p-18, m-18, gap-18... *\u002F\n    --spacing-88:  22rem;\n    --spacing-128: 32rem;\n\n    \u002F* ═══ Border radius ══════════════════════════════════════ *\u002F\n    --radius-4xl: 2rem;      \u002F* → rounded-4xl *\u002F\n    --radius-5xl: 2.5rem;    \u002F* → rounded-5xl *\u002F\n\n    \u002F* ═══ Box shadows ════════════════════════════════════════ *\u002F\n    --shadow-glow-sm: 0 0 8px oklch(0.585 0.233 277 \u002F 0.3);\n    --shadow-glow-md: 0 0 20px oklch(0.585 0.233 277 \u002F 0.4);\n\n    \u002F* → генерує: shadow-glow-sm, shadow-glow-md *\u002F\n\n    \u002F* ═══ Анімації ═══════════════════════════════════════════ *\u002F\n    --animate-fade-in:    fade-in 0.4s ease-out;\n    --animate-fade-in-up: fade-in-up 0.5s ease-out;\n    --animate-shake:      shake 0.5s ease-in-out;\n\n    \u002F* → генерує: animate-fade-in, animate-fade-in-up, animate-shake *\u002F\n\n    \u002F* ═══ Breakpoints ════════════════════════════════════════ *\u002F\n    --breakpoint-xs: 480px;  \u002F* → xs: варіант *\u002F\n    --breakpoint-3xl: 1920px;\u002F* → 3xl: варіант *\u002F\n\n    \u002F* ═══ Z-index (за іменами) ══════════════════════════════ *\u002F\n    --z-index-modal:    1000;\n    --z-index-tooltip:  1100;\n    --z-index-overlay:  900;\n    \u002F* → генерує: z-modal, z-tooltip, z-overlay *\u002F\n}\n","src\u002Fstyles\u002Ftheme.css",[3357,6120,6121,6127,6132,6148,6163,6176,6191,6207,6211,6216,6220,6225,6238,6243,6248,6252,6257,6261,6266,6274,6279,6284,6288,6293,6301,6309,6314,6320,6340,6359,6364,6370,6375,6381,6400,6418,6431,6436,6442,6447,6453,6462,6471,6476,6482,6488,6494,6500,6506],{"__ignoreMap":3372},[3376,6122,6123,6125],{"class":3378,"line":3379},[3376,6124,3411],{"class":3389},[3376,6126,3414],{"class":3397},[3376,6128,6129],{"class":3378,"line":3386},[3376,6130,6131],{"class":3382},"    \u002F* ═══ Кольори ════════════════════════════════════════════ *\u002F\n",[3376,6133,6134,6137,6140,6142,6145],{"class":3378,"line":3401},[3376,6135,6136],{"class":3397},"    --color-brand-50:  oklch(0",[3376,6138,6139],{"class":3423},".971",[3376,6141,3427],{"class":3397},[3376,6143,6144],{"class":3423},".015",[3376,6146,6147],{"class":3397}," 280);\n",[3376,6149,6150,6153,6156,6158,6161],{"class":3378,"line":3408},[3376,6151,6152],{"class":3397},"    --color-brand-100: oklch(0",[3376,6154,6155],{"class":3423},".943",[3376,6157,3427],{"class":3397},[3376,6159,6160],{"class":3423},".030",[3376,6162,6147],{"class":3397},[3376,6164,6165,6168,6170,6172,6174],{"class":3378,"line":3417},[3376,6166,6167],{"class":3397},"    --color-brand-500: oklch(0",[3376,6169,3424],{"class":3423},[3376,6171,3427],{"class":3397},[3376,6173,3430],{"class":3423},[3376,6175,3433],{"class":3397},[3376,6177,6178,6181,6184,6186,6189],{"class":3378,"line":3436},[3376,6179,6180],{"class":3397},"    --color-brand-600: oklch(0",[3376,6182,6183],{"class":3423},".511",[3376,6185,3427],{"class":3397},[3376,6187,6188],{"class":3423},".262",[3376,6190,3433],{"class":3397},[3376,6192,6193,6196,6199,6201,6204],{"class":3378,"line":3454},[3376,6194,6195],{"class":3397},"    --color-brand-900: oklch(0",[3376,6197,6198],{"class":3423},".257",[3376,6200,3427],{"class":3397},[3376,6202,6203],{"class":3423},".090",[3376,6205,6206],{"class":3397}," 281);\n",[3376,6208,6209],{"class":3378,"line":3460},[3376,6210,3405],{"emptyLinePlaceholder":3404},[3376,6212,6213],{"class":3378,"line":3465},[3376,6214,6215],{"class":3382},"    \u002F* → генерує: bg-brand-50, text-brand-500, border-brand-600 *\u002F\n",[3376,6217,6218],{"class":3378,"line":3701},[3376,6219,3405],{"emptyLinePlaceholder":3404},[3376,6221,6222],{"class":3378,"line":3707},[3376,6223,6224],{"class":3382},"    \u002F* ═══ Шрифти ══════════════════════════════════════════════ *\u002F\n",[3376,6226,6227,6230,6232,6234,6236],{"class":3378,"line":3716},[3376,6228,6229],{"class":3397},"    --font-family-sans:  'Inter Variable', ",[3376,6231,3443],{"class":3442},[3376,6233,3446],{"class":3397},[3376,6235,3449],{"class":3442},[3376,6237,3398],{"class":3397},[3376,6239,6240],{"class":3378,"line":3724},[3376,6241,6242],{"class":3397},"    --font-family-mono:  'JetBrains Mono', 'Fira Code', monospace;\n",[3376,6244,6245],{"class":3378,"line":3746},[3376,6246,6247],{"class":3397},"    --font-family-serif: 'Playfair Display', Georgia, serif;\n",[3376,6249,6250],{"class":3378,"line":3771},[3376,6251,3405],{"emptyLinePlaceholder":3404},[3376,6253,6254],{"class":3378,"line":3777},[3376,6255,6256],{"class":3382},"    \u002F* → генерує: font-sans, font-mono, font-serif *\u002F\n",[3376,6258,6259],{"class":3378,"line":4205},[3376,6260,3405],{"emptyLinePlaceholder":3404},[3376,6262,6263],{"class":3378,"line":4215},[3376,6264,6265],{"class":3382},"    \u002F* ═══ Spacing (доповнення до стандартного) ════════════════ *\u002F\n",[3376,6267,6268,6271],{"class":3378,"line":4230},[3376,6269,6270],{"class":3397},"    --spacing-18:  4.5rem;   ",[3376,6272,6273],{"class":3382},"\u002F* → p-18, m-18, gap-18... *\u002F\n",[3376,6275,6276],{"class":3378,"line":4238},[3376,6277,6278],{"class":3397},"    --spacing-88:  22rem;\n",[3376,6280,6281],{"class":3378,"line":4244},[3376,6282,6283],{"class":3397},"    --spacing-128: 32rem;\n",[3376,6285,6286],{"class":3378,"line":4253},[3376,6287,3405],{"emptyLinePlaceholder":3404},[3376,6289,6290],{"class":3378,"line":4263},[3376,6291,6292],{"class":3382},"    \u002F* ═══ Border radius ══════════════════════════════════════ *\u002F\n",[3376,6294,6295,6298],{"class":3378,"line":4268},[3376,6296,6297],{"class":3397},"    --radius-4xl: 2rem;      ",[3376,6299,6300],{"class":3382},"\u002F* → rounded-4xl *\u002F\n",[3376,6302,6303,6306],{"class":3378,"line":4277},[3376,6304,6305],{"class":3397},"    --radius-5xl: 2.5rem;    ",[3376,6307,6308],{"class":3382},"\u002F* → rounded-5xl *\u002F\n",[3376,6310,6312],{"class":3378,"line":6311},26,[3376,6313,3405],{"emptyLinePlaceholder":3404},[3376,6315,6317],{"class":3378,"line":6316},27,[3376,6318,6319],{"class":3382},"    \u002F* ═══ Box shadows ════════════════════════════════════════ *\u002F\n",[3376,6321,6323,6326,6328,6330,6332,6335,6338],{"class":3378,"line":6322},28,[3376,6324,6325],{"class":3397},"    --shadow-glow-sm: 0 0 8px oklch(0",[3376,6327,3424],{"class":3423},[3376,6329,3427],{"class":3397},[3376,6331,3430],{"class":3423},[3376,6333,6334],{"class":3397}," 277 \u002F 0",[3376,6336,6337],{"class":3423},".3",[3376,6339,3743],{"class":3397},[3376,6341,6343,6346,6348,6350,6352,6354,6357],{"class":3378,"line":6342},29,[3376,6344,6345],{"class":3397},"    --shadow-glow-md: 0 0 20px oklch(0",[3376,6347,3424],{"class":3423},[3376,6349,3427],{"class":3397},[3376,6351,3430],{"class":3423},[3376,6353,6334],{"class":3397},[3376,6355,6356],{"class":3423},".4",[3376,6358,3743],{"class":3397},[3376,6360,6362],{"class":3378,"line":6361},30,[3376,6363,3405],{"emptyLinePlaceholder":3404},[3376,6365,6367],{"class":3378,"line":6366},31,[3376,6368,6369],{"class":3382},"    \u002F* → генерує: shadow-glow-sm, shadow-glow-md *\u002F\n",[3376,6371,6373],{"class":3378,"line":6372},32,[3376,6374,3405],{"emptyLinePlaceholder":3404},[3376,6376,6378],{"class":3378,"line":6377},33,[3376,6379,6380],{"class":3382},"    \u002F* ═══ Анімації ═══════════════════════════════════════════ *\u002F\n",[3376,6382,6384,6387,6390,6392,6395,6398],{"class":3378,"line":6383},34,[3376,6385,6386],{"class":3397},"    --animate-fade-in:    ",[3376,6388,6389],{"class":3442},"fade-in",[3376,6391,3427],{"class":3397},[3376,6393,6394],{"class":3423},".4s",[3376,6396,6397],{"class":3442}," ease-out",[3376,6399,3398],{"class":3397},[3376,6401,6403,6406,6409,6411,6414,6416],{"class":3378,"line":6402},35,[3376,6404,6405],{"class":3397},"    --animate-fade-in-up: ",[3376,6407,6408],{"class":3442},"fade-in-up",[3376,6410,3427],{"class":3397},[3376,6412,6413],{"class":3423},".5s",[3376,6415,6397],{"class":3442},[3376,6417,3398],{"class":3397},[3376,6419,6421,6424,6426,6429],{"class":3378,"line":6420},36,[3376,6422,6423],{"class":3397},"    --animate-shake:      shake 0",[3376,6425,6413],{"class":3423},[3376,6427,6428],{"class":3442}," ease-in-out",[3376,6430,3398],{"class":3397},[3376,6432,6434],{"class":3378,"line":6433},37,[3376,6435,3405],{"emptyLinePlaceholder":3404},[3376,6437,6439],{"class":3378,"line":6438},38,[3376,6440,6441],{"class":3382},"    \u002F* → генерує: animate-fade-in, animate-fade-in-up, animate-shake *\u002F\n",[3376,6443,6445],{"class":3378,"line":6444},39,[3376,6446,3405],{"emptyLinePlaceholder":3404},[3376,6448,6450],{"class":3378,"line":6449},40,[3376,6451,6452],{"class":3382},"    \u002F* ═══ Breakpoints ════════════════════════════════════════ *\u002F\n",[3376,6454,6456,6459],{"class":3378,"line":6455},41,[3376,6457,6458],{"class":3397},"    --breakpoint-xs: 480px;  ",[3376,6460,6461],{"class":3382},"\u002F* → xs: варіант *\u002F\n",[3376,6463,6465,6468],{"class":3378,"line":6464},42,[3376,6466,6467],{"class":3397},"    --breakpoint-3xl: 1920px;",[3376,6469,6470],{"class":3382},"\u002F* → 3xl: варіант *\u002F\n",[3376,6472,6474],{"class":3378,"line":6473},43,[3376,6475,3405],{"emptyLinePlaceholder":3404},[3376,6477,6479],{"class":3378,"line":6478},44,[3376,6480,6481],{"class":3382},"    \u002F* ═══ Z-index (за іменами) ══════════════════════════════ *\u002F\n",[3376,6483,6485],{"class":3378,"line":6484},45,[3376,6486,6487],{"class":3397},"    --z-index-modal:    1000;\n",[3376,6489,6491],{"class":3378,"line":6490},46,[3376,6492,6493],{"class":3397},"    --z-index-tooltip:  1100;\n",[3376,6495,6497],{"class":3378,"line":6496},47,[3376,6498,6499],{"class":3397},"    --z-index-overlay:  900;\n",[3376,6501,6503],{"class":3378,"line":6502},48,[3376,6504,6505],{"class":3382},"    \u002F* → генерує: z-modal, z-tooltip, z-overlay *\u002F\n",[3376,6507,6509],{"class":3378,"line":6508},49,[3376,6510,3457],{"class":3397},[3483,6512],{},[3490,6514,6516,6517,6519],{"id":6515},"_33-plugin-підключення-офіційних-плагінів","3.3. ",[3357,6518,6086],{},": підключення офіційних плагінів",[3353,6521,6522,6523,4493],{},"Офіційні плагіни Tailwind підключаються через ",[3357,6524,6086],{},[3367,6526,6528],{"className":3369,"code":6527,"filename":3635,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Офіційні плагіни *\u002F\n@plugin \"@tailwindcss\u002Ftypography\";    \u002F* prose, prose-lg... *\u002F\n@plugin \"@tailwindcss\u002Fforms\";         \u002F* кращі стилі форм *\u002F\n@plugin \"@tailwindcss\u002Faspect-ratio\";  \u002F* aspect-w-16, aspect-h-9 *\u002F\n@plugin \"@tailwindcss\u002Fcontainer-queries\"; \u002F* @container в v3 *\u002F\n",[3357,6529,6530,6538,6542,6547,6554,6559,6564],{"__ignoreMap":3372},[3376,6531,6532,6534,6536],{"class":3378,"line":3379},[3376,6533,3390],{"class":3389},[3376,6535,3649],{"class":3393},[3376,6537,3398],{"class":3397},[3376,6539,6540],{"class":3378,"line":3386},[3376,6541,3405],{"emptyLinePlaceholder":3404},[3376,6543,6544],{"class":3378,"line":3401},[3376,6545,6546],{"class":3382},"\u002F* Офіційні плагіни *\u002F\n",[3376,6548,6549,6551],{"class":3378,"line":3408},[3376,6550,6086],{"class":3389},[3376,6552,6553],{"class":3397}," \"@tailwindcss\u002Ftypography\";    \u002F* prose, prose-lg... *\u002F\n",[3376,6555,6556],{"class":3378,"line":3417},[3376,6557,6558],{"class":3397},"@plugin \"@tailwindcss\u002Fforms\";         \u002F* кращі стилі форм *\u002F\n",[3376,6560,6561],{"class":3378,"line":3436},[3376,6562,6563],{"class":3397},"@plugin \"@tailwindcss\u002Faspect-ratio\";  \u002F* aspect-w-16, aspect-h-9 *\u002F\n",[3376,6565,6566],{"class":3378,"line":3454},[3376,6567,6568],{"class":3397},"@plugin \"@tailwindcss\u002Fcontainer-queries\"; \u002F* @container в v3 *\u002F\n",[3353,6570,6571],{},"Встановлення плагінів:",[3367,6573,6575],{"className":3566,"code":6574,"language":3568,"meta":3372,"style":3372},"npm install @tailwindcss\u002Ftypography @tailwindcss\u002Fforms --save-dev\n",[3357,6576,6577],{"__ignoreMap":3372},[3376,6578,6579,6581,6583,6586,6589],{"class":3378,"line":3379},[3376,6580,3581],{"class":3580},[3376,6582,3604],{"class":3393},[3376,6584,6585],{"class":3393}," @tailwindcss\u002Ftypography",[3376,6587,6588],{"class":3393}," @tailwindcss\u002Fforms",[3376,6590,3613],{"class":3587},[3367,6592,6594],{"className":3968,"code":6593,"language":3971,"meta":3372,"style":3372},"\u003C!-- Після підключення @tailwindcss\u002Ftypography: -->\n\u003Carticle class=\"prose prose-slate lg:prose-xl prose-headings:font-black\">\n    \u003Ch1>Заголовок\u003C\u002Fh1>\n    \u003Cp>Красиво стилізований текст...\u003C\u002Fp>\n\u003C\u002Farticle>\n",[3357,6595,6596,6601,6617,6634,6651],{"__ignoreMap":3372},[3376,6597,6598],{"class":3378,"line":3379},[3376,6599,6600],{"class":3382},"\u003C!-- Після підключення @tailwindcss\u002Ftypography: -->\n",[3376,6602,6603,6605,6608,6610,6612,6615],{"class":3378,"line":3386},[3376,6604,3993],{"class":3978},[3376,6606,6607],{"class":3442},"article",[3376,6609,4130],{"class":3727},[3376,6611,4001],{"class":3397},[3376,6613,6614],{"class":4004},"\"prose prose-slate lg:prose-xl prose-headings:font-black\"",[3376,6616,3988],{"class":3978},[3376,6618,6619,6621,6623,6625,6628,6630,6632],{"class":3378,"line":3401},[3376,6620,4021],{"class":3978},[3376,6622,3344],{"class":3442},[3376,6624,4068],{"class":3978},[3376,6626,6627],{"class":3397},"Заголовок",[3376,6629,4074],{"class":3978},[3376,6631,3344],{"class":3442},[3376,6633,3988],{"class":3978},[3376,6635,6636,6638,6640,6642,6645,6647,6649],{"class":3378,"line":3408},[3376,6637,4021],{"class":3978},[3376,6639,3353],{"class":3442},[3376,6641,4068],{"class":3978},[3376,6643,6644],{"class":3397},"Красиво стилізований текст...",[3376,6646,4074],{"class":3978},[3376,6648,3353],{"class":3442},[3376,6650,3988],{"class":3978},[3376,6652,6653,6655,6657],{"class":3378,"line":3417},[3376,6654,4074],{"class":3978},[3376,6656,6607],{"class":3442},[3376,6658,3988],{"class":3978},[3483,6660],{},[3490,6662,6664,6665,6668],{"id":6663},"_34-utility-власні-утиліти","3.4. ",[3357,6666,6667],{},"@utility",": власні утиліти",[3353,6670,6671,6672,6674,6675,4493],{},"У v4 власні утиліти визначаються через ",[3357,6673,6667],{}," замість ",[3357,6676,6677],{},"@layer utilities",[3367,6679,6682],{"className":3369,"code":6680,"filename":6681,"language":3371,"meta":3372,"style":3372},"\u002F* Власна утиліта — стає повноцінним класом із підтримкою hover:, dark:, etc. *\u002F\n\n@utility truncate-2 {\n    overflow: hidden;\n    display: -webkit-box;\n    -webkit-line-clamp: 2;\n    -webkit-box-orient: vertical;\n}\n\n@utility truncate-3 {\n    overflow: hidden;\n    display: -webkit-box;\n    -webkit-line-clamp: 3;\n    -webkit-box-orient: vertical;\n}\n\n\u002F* Glassmorphism *\u002F\n@utility glass {\n    background: oklch(1 0 0 \u002F 0.1);\n    backdrop-filter: blur(12px) saturate(180%);\n    border: 1px solid oklch(1 0 0 \u002F 0.2);\n}\n\n\u002F* Fluid container *\u002F\n@utility container-fluid {\n    width: 100%;\n    max-width: 80rem;\n    margin-inline: auto;\n    padding-inline: clamp(1rem, 3vw, 3rem);\n}\n\n\u002F* Aspect ratios (якщо не використовуєте плагін) *\u002F\n@utility aspect-video {\n    aspect-ratio: 16 \u002F 9;\n}\n\n@utility aspect-square {\n    aspect-ratio: 1 \u002F 1;\n}\n","src\u002Fstyles\u002Futilities.css",[3357,6683,6684,6689,6693,6700,6705,6710,6715,6720,6724,6728,6735,6739,6743,6748,6752,6756,6760,6765,6772,6782,6790,6800,6804,6808,6813,6820,6825,6833,6841,6849,6853,6857,6862,6869,6877,6881,6885,6892,6899],{"__ignoreMap":3372},[3376,6685,6686],{"class":3378,"line":3379},[3376,6687,6688],{"class":3382},"\u002F* Власна утиліта — стає повноцінним класом із підтримкою hover:, dark:, etc. *\u002F\n",[3376,6690,6691],{"class":3378,"line":3386},[3376,6692,3405],{"emptyLinePlaceholder":3404},[3376,6694,6695,6697],{"class":3378,"line":3401},[3376,6696,6667],{"class":3389},[3376,6698,6699],{"class":3397}," truncate-2 {\n",[3376,6701,6702],{"class":3378,"line":3408},[3376,6703,6704],{"class":3397},"    overflow: hidden;\n",[3376,6706,6707],{"class":3378,"line":3417},[3376,6708,6709],{"class":3397},"    display: -webkit-box;\n",[3376,6711,6712],{"class":3378,"line":3436},[3376,6713,6714],{"class":3397},"    -webkit-line-clamp: 2;\n",[3376,6716,6717],{"class":3378,"line":3454},[3376,6718,6719],{"class":3397},"    -webkit-box-orient: vertical;\n",[3376,6721,6722],{"class":3378,"line":3460},[3376,6723,3457],{"class":3397},[3376,6725,6726],{"class":3378,"line":3465},[3376,6727,3405],{"emptyLinePlaceholder":3404},[3376,6729,6730,6732],{"class":3378,"line":3701},[3376,6731,6667],{"class":3389},[3376,6733,6734],{"class":3397}," truncate-3 {\n",[3376,6736,6737],{"class":3378,"line":3707},[3376,6738,6704],{"class":3397},[3376,6740,6741],{"class":3378,"line":3716},[3376,6742,6709],{"class":3397},[3376,6744,6745],{"class":3378,"line":3724},[3376,6746,6747],{"class":3397},"    -webkit-line-clamp: 3;\n",[3376,6749,6750],{"class":3378,"line":3746},[3376,6751,6719],{"class":3397},[3376,6753,6754],{"class":3378,"line":3771},[3376,6755,3457],{"class":3397},[3376,6757,6758],{"class":3378,"line":3777},[3376,6759,3405],{"emptyLinePlaceholder":3404},[3376,6761,6762],{"class":3378,"line":4205},[3376,6763,6764],{"class":3382},"\u002F* Glassmorphism *\u002F\n",[3376,6766,6767,6769],{"class":3378,"line":4215},[3376,6768,6667],{"class":3389},[3376,6770,6771],{"class":3397}," glass {\n",[3376,6773,6774,6777,6780],{"class":3378,"line":4230},[3376,6775,6776],{"class":3397},"    background: oklch(1 0 0 \u002F 0",[3376,6778,6779],{"class":3423},".1",[3376,6781,3743],{"class":3397},[3376,6783,6784,6787],{"class":3378,"line":4238},[3376,6785,6786],{"class":3442},"    backdrop-filter",[3376,6788,6789],{"class":3397},": blur(12px) saturate(180%);\n",[3376,6791,6792,6795,6798],{"class":3378,"line":4244},[3376,6793,6794],{"class":3397},"    border: 1px solid oklch(1 0 0 \u002F 0",[3376,6796,6797],{"class":3423},".2",[3376,6799,3743],{"class":3397},[3376,6801,6802],{"class":3378,"line":4253},[3376,6803,3457],{"class":3397},[3376,6805,6806],{"class":3378,"line":4263},[3376,6807,3405],{"emptyLinePlaceholder":3404},[3376,6809,6810],{"class":3378,"line":4268},[3376,6811,6812],{"class":3382},"\u002F* Fluid container *\u002F\n",[3376,6814,6815,6817],{"class":3378,"line":4277},[3376,6816,6667],{"class":3389},[3376,6818,6819],{"class":3397}," container-fluid {\n",[3376,6821,6822],{"class":3378,"line":6311},[3376,6823,6824],{"class":3397},"    width: 100%;\n",[3376,6826,6827,6830],{"class":3378,"line":6316},[3376,6828,6829],{"class":3442},"    max-width",[3376,6831,6832],{"class":3397},": 80rem;\n",[3376,6834,6835,6838],{"class":3378,"line":6322},[3376,6836,6837],{"class":3442},"    margin-inline",[3376,6839,6840],{"class":3397},": auto;\n",[3376,6842,6843,6846],{"class":3378,"line":6342},[3376,6844,6845],{"class":3442},"    padding-inline",[3376,6847,6848],{"class":3397},": clamp(1rem, 3vw, 3rem);\n",[3376,6850,6851],{"class":3378,"line":6361},[3376,6852,3457],{"class":3397},[3376,6854,6855],{"class":3378,"line":6366},[3376,6856,3405],{"emptyLinePlaceholder":3404},[3376,6858,6859],{"class":3378,"line":6372},[3376,6860,6861],{"class":3382},"\u002F* Aspect ratios (якщо не використовуєте плагін) *\u002F\n",[3376,6863,6864,6866],{"class":3378,"line":6377},[3376,6865,6667],{"class":3389},[3376,6867,6868],{"class":3397}," aspect-video {\n",[3376,6870,6871,6874],{"class":3378,"line":6383},[3376,6872,6873],{"class":3442},"    aspect-ratio",[3376,6875,6876],{"class":3397},": 16 \u002F 9;\n",[3376,6878,6879],{"class":3378,"line":6402},[3376,6880,3457],{"class":3397},[3376,6882,6883],{"class":3378,"line":6420},[3376,6884,3405],{"emptyLinePlaceholder":3404},[3376,6886,6887,6889],{"class":3378,"line":6433},[3376,6888,6667],{"class":3389},[3376,6890,6891],{"class":3397}," aspect-square {\n",[3376,6893,6894,6896],{"class":3378,"line":6438},[3376,6895,6873],{"class":3442},[3376,6897,6898],{"class":3397},": 1 \u002F 1;\n",[3376,6900,6901],{"class":3378,"line":6444},[3376,6902,3457],{"class":3397},[3353,6904,6905],{},"Використання:",[3367,6907,6909],{"className":3968,"code":6908,"language":3971,"meta":3372,"style":3372},"\u003Cp class=\"truncate-2 hover:truncate-3 transition-all\">\n    Довгий текст, що обрізається до 2 рядків, а при hover — до 3.\n\u003C\u002Fp>\n\n\u003Cdiv class=\"glass rounded-2xl p-6\">\n    Glassmorphism-контейнер\n\u003C\u002Fdiv>\n\n\u003Cmain class=\"container-fluid\">\n    Основний контент\n\u003C\u002Fmain>\n",[3357,6910,6911,6926,6931,6939,6943,6958,6963,6971,6975,6991,6996],{"__ignoreMap":3372},[3376,6912,6913,6915,6917,6919,6921,6924],{"class":3378,"line":3379},[3376,6914,3993],{"class":3978},[3376,6916,3353],{"class":3442},[3376,6918,4130],{"class":3727},[3376,6920,4001],{"class":3397},[3376,6922,6923],{"class":4004},"\"truncate-2 hover:truncate-3 transition-all\"",[3376,6925,3988],{"class":3978},[3376,6927,6928],{"class":3378,"line":3386},[3376,6929,6930],{"class":3397},"    Довгий текст, що обрізається до 2 рядків, а при hover — до 3.\n",[3376,6932,6933,6935,6937],{"class":3378,"line":3401},[3376,6934,4074],{"class":3978},[3376,6936,3353],{"class":3442},[3376,6938,3988],{"class":3978},[3376,6940,6941],{"class":3378,"line":3408},[3376,6942,3405],{"emptyLinePlaceholder":3404},[3376,6944,6945,6947,6949,6951,6953,6956],{"class":3378,"line":3417},[3376,6946,3993],{"class":3978},[3376,6948,4148],{"class":3442},[3376,6950,4130],{"class":3727},[3376,6952,4001],{"class":3397},[3376,6954,6955],{"class":4004},"\"glass rounded-2xl p-6\"",[3376,6957,3988],{"class":3978},[3376,6959,6960],{"class":3378,"line":3436},[3376,6961,6962],{"class":3397},"    Glassmorphism-контейнер\n",[3376,6964,6965,6967,6969],{"class":3378,"line":3454},[3376,6966,4074],{"class":3978},[3376,6968,4148],{"class":3442},[3376,6970,3988],{"class":3978},[3376,6972,6973],{"class":3378,"line":3460},[3376,6974,3405],{"emptyLinePlaceholder":3404},[3376,6976,6977,6979,6982,6984,6986,6989],{"class":3378,"line":3465},[3376,6978,3993],{"class":3978},[3376,6980,6981],{"class":3442},"main",[3376,6983,4130],{"class":3727},[3376,6985,4001],{"class":3397},[3376,6987,6988],{"class":4004},"\"container-fluid\"",[3376,6990,3988],{"class":3978},[3376,6992,6993],{"class":3378,"line":3701},[3376,6994,6995],{"class":3397},"    Основний контент\n",[3376,6997,6998,7000,7002],{"class":3378,"line":3707},[3376,6999,4074],{"class":3978},[3376,7001,6981],{"class":3442},[3376,7003,3988],{"class":3978},[7005,7006,7008,7857,7859,7863,7867,7870,7902,7961,7964,7984,7986,7992,7997,8058,8063,8066,8115,8121,8166,8182,8184,8188,8194,8196,8216,8221,8229,8421,8423,8431,8434,8483,8490,8492,8511,8595,8628,8630,8634],"html-preview",{":tailwind":7007},"true",[3367,7009,7011],{"className":3968,"code":7010,"language":3971,"meta":3372,"style":3372},"\u003C!DOCTYPE html>\n\u003Chtml lang=\"uk\">\n\u003Chead>\n\u003Cmeta charset=\"UTF-8\">\n\u003Cscript src=\"https:\u002F\u002Fcdn.tailwindcss.com\">\u003C\u002Fscript>\n\u003Clink href=\"https:\u002F\u002Ffonts.googleapis.com\u002Fcss2?family=Inter:wght@400;500;600;700&display=swap\" rel=\"stylesheet\">\n\u003Cstyle>\n    \u002F* Simulated custom utilities defined via @utility *\u002F\n    .glass {\n        background: rgba(255, 255, 255, 0.45);\n        backdrop-filter: blur(12px) saturate(180%);\n        -webkit-backdrop-filter: blur(12px) saturate(180%);\n        border: 1px solid rgba(255, 255, 255, 0.3);\n    }\n    \n    .truncate-2 {\n        display: -webkit-box;\n        -webkit-line-clamp: 2;\n        -webkit-box-orient: vertical;\n        overflow: hidden;\n        transition: -webkit-line-clamp 0.2s ease;\n    }\n    .truncate-2:hover {\n        -webkit-line-clamp: 5;\n    }\n\n    .container-fluid {\n        width: 100%;\n        max-width: 80rem;\n        margin-left: auto;\n        margin-right: auto;\n        padding-left: clamp(1rem, 3vw, 3rem);\n        padding-right: clamp(1rem, 3vw, 3rem);\n    }\n\n    .aspect-video {\n        aspect-ratio: 16 \u002F 9;\n    }\n\u003C\u002Fstyle>\n\u003C\u002Fhead>\n\u003Cbody class=\"p-6 bg-slate-100\" style=\"font-family: 'Inter', system-ui, sans-serif;\">\n    \u003C!-- fluid container -->\n    \u003Cdiv class=\"container-fluid\">\n        \u003Cdiv class=\"max-w-md mx-auto space-y-4\">\n            \u003Cp class=\"text-xs font-bold text-slate-400 uppercase tracking-widest text-center\">Custom @utility Showcase\u003C\u002Fp>\n            \n            \u003C!-- Glass card -->\n            \u003Cdiv class=\"glass rounded-2xl p-6 shadow-lg border border-white\u002F40\">\n                \u003Ch4 class=\"text-sm font-bold text-slate-800 mb-2\">Картка з кастомними утилітами\u003C\u002Fh4>\n                \n                \u003C!-- Aspect Video Simulator -->\n                \u003Cdiv class=\"aspect-video w-full bg-slate-900\u002F10 rounded-xl mb-4 flex items-center justify-center text-slate-600 border border-slate-300\u002F30 font-semibold relative overflow-hidden\">\n                    \u003Cdiv class=\"absolute inset-0 bg-gradient-to-br from-indigo-500\u002F20 to-purple-500\u002F20\">\u003C\u002Fdiv>\n                    \u003Cspan class=\"z-10 text-xs font-mono uppercase tracking-wider bg-white\u002F80 px-2.5 py-1 rounded-full shadow-sm\">aspect-video\u003C\u002Fspan>\n                \u003C\u002Fdiv>\n\n                \u003C!-- Truncated Text -->\n                \u003Cdiv class=\"bg-white\u002F60 rounded-xl p-3 border border-white\u002F20 cursor-pointer\">\n                    \u003Cp class=\"text-xs font-bold uppercase tracking-wider text-slate-400 mb-1\">Наведіть курсор, щоб розгорнути:\u003C\u002Fp>\n                    \u003Cp class=\"truncate-2 text-xs text-slate-600 leading-relaxed\">\n                        Цей текст автоматично обрізається до двох рядків завдяки кастомній утиліті truncate-2. Якщо ви наведете на нього курсор, спрацює CSS-правило розширення лінії, і ви зможете прочитати весь абзац повністю, що дуже зручно для компактного відображення карток блогу або описів товарів без зайвого JavaScript.\n                    \u003C\u002Fp>\n                \u003C\u002Fdiv>\n            \u003C\u002Fdiv>\n        \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n\u003C\u002Fbody>\n\u003C\u002Fhtml>\n",[3357,7012,7013,7023,7037,7045,7059,7081,7102,7111,7116,7123,7153,7181,7204,7240,7244,7249,7256,7264,7276,7288,7300,7316,7320,7327,7338,7342,7346,7353,7365,7377,7389,7400,7427,7450,7454,7458,7465,7483,7487,7495,7503,7526,7531,7545,7560,7584,7589,7594,7609,7635,7641,7647,7663,7684,7709,7719,7724,7730,7746,7771,7787,7793,7803,7812,7821,7830,7839,7848],{"__ignoreMap":3372},[3376,7014,7015,7017,7019,7021],{"class":3378,"line":3379},[3376,7016,3979],{"class":3978},[3376,7018,3982],{"class":3442},[3376,7020,3985],{"class":3727},[3376,7022,3988],{"class":3978},[3376,7024,7025,7027,7029,7031,7033,7035],{"class":3378,"line":3386},[3376,7026,3993],{"class":3978},[3376,7028,3971],{"class":3442},[3376,7030,3998],{"class":3727},[3376,7032,4001],{"class":3397},[3376,7034,4005],{"class":4004},[3376,7036,3988],{"class":3978},[3376,7038,7039,7041,7043],{"class":3378,"line":3401},[3376,7040,3993],{"class":3978},[3376,7042,4014],{"class":3442},[3376,7044,3988],{"class":3978},[3376,7046,7047,7049,7051,7053,7055,7057],{"class":3378,"line":3408},[3376,7048,3993],{"class":3978},[3376,7050,4024],{"class":3442},[3376,7052,4027],{"class":3727},[3376,7054,4001],{"class":3397},[3376,7056,4032],{"class":4004},[3376,7058,3988],{"class":3978},[3376,7060,7061,7063,7066,7069,7071,7074,7077,7079],{"class":3378,"line":3417},[3376,7062,3993],{"class":3978},[3376,7064,7065],{"class":3442},"script",[3376,7067,7068],{"class":3727}," src",[3376,7070,4001],{"class":5448},[3376,7072,7073],{"class":4004},"\"https:\u002F\u002Fcdn.tailwindcss.com\"",[3376,7075,7076],{"class":3978},">\u003C\u002F",[3376,7078,7065],{"class":3442},[3376,7080,3988],{"class":3978},[3376,7082,7083,7085,7087,7089,7091,7094,7096,7098,7100],{"class":3378,"line":3436},[3376,7084,3993],{"class":3978},[3376,7086,4094],{"class":3442},[3376,7088,4105],{"class":3727},[3376,7090,4001],{"class":3397},[3376,7092,7093],{"class":4004},"\"https:\u002F\u002Ffonts.googleapis.com\u002Fcss2?family=Inter:wght@400;500;600;700&display=swap\"",[3376,7095,4097],{"class":3727},[3376,7097,4001],{"class":3397},[3376,7099,4102],{"class":4004},[3376,7101,3988],{"class":3978},[3376,7103,7104,7106,7109],{"class":3378,"line":3454},[3376,7105,3993],{"class":3978},[3376,7107,7108],{"class":3442},"style",[3376,7110,3988],{"class":3978},[3376,7112,7113],{"class":3378,"line":3460},[3376,7114,7115],{"class":3382},"    \u002F* Simulated custom utilities defined via @utility *\u002F\n",[3376,7117,7118,7121],{"class":3378,"line":3465},[3376,7119,7120],{"class":3423},"    .glass",[3376,7122,3414],{"class":5448},[3376,7124,7125,7128,7130,7133,7135,7138,7140,7142,7144,7146,7148,7151],{"class":3378,"line":3701},[3376,7126,7127],{"class":3727},"        background",[3376,7129,3731],{"class":5448},[3376,7131,7132],{"class":3580},"rgba",[3376,7134,3737],{"class":5448},[3376,7136,7137],{"class":3759},"255",[3376,7139,3446],{"class":5448},[3376,7141,7137],{"class":3759},[3376,7143,3446],{"class":5448},[3376,7145,7137],{"class":3759},[3376,7147,3446],{"class":5448},[3376,7149,7150],{"class":3759},"0.45",[3376,7152,3743],{"class":5448},[3376,7154,7155,7158,7160,7163,7165,7168,7171,7174,7176,7179],{"class":3378,"line":3707},[3376,7156,7157],{"class":3727},"        backdrop-filter",[3376,7159,3731],{"class":5448},[3376,7161,7162],{"class":3580},"blur",[3376,7164,3737],{"class":5448},[3376,7166,7167],{"class":3759},"12px",[3376,7169,7170],{"class":5448},") ",[3376,7172,7173],{"class":3580},"saturate",[3376,7175,3737],{"class":5448},[3376,7177,7178],{"class":3759},"180%",[3376,7180,3743],{"class":5448},[3376,7182,7183,7186,7188,7190,7192,7194,7196,7198,7200,7202],{"class":3378,"line":3716},[3376,7184,7185],{"class":3727},"        -webkit-backdrop-filter",[3376,7187,3731],{"class":5448},[3376,7189,7162],{"class":3580},[3376,7191,3737],{"class":5448},[3376,7193,7167],{"class":3759},[3376,7195,7170],{"class":5448},[3376,7197,7173],{"class":3580},[3376,7199,3737],{"class":5448},[3376,7201,7178],{"class":3759},[3376,7203,3743],{"class":5448},[3376,7205,7206,7209,7211,7214,7218,7221,7223,7225,7227,7229,7231,7233,7235,7238],{"class":3378,"line":3724},[3376,7207,7208],{"class":3727},"        border",[3376,7210,3731],{"class":5448},[3376,7212,7213],{"class":3759},"1px",[3376,7215,7217],{"class":7216},"sDUd3"," solid",[3376,7219,7220],{"class":3580}," rgba",[3376,7222,3737],{"class":5448},[3376,7224,7137],{"class":3759},[3376,7226,3446],{"class":5448},[3376,7228,7137],{"class":3759},[3376,7230,3446],{"class":5448},[3376,7232,7137],{"class":3759},[3376,7234,3446],{"class":5448},[3376,7236,7237],{"class":3759},"0.3",[3376,7239,3743],{"class":5448},[3376,7241,7242],{"class":3378,"line":3746},[3376,7243,3774],{"class":5448},[3376,7245,7246],{"class":3378,"line":3771},[3376,7247,7248],{"class":5448},"    \n",[3376,7250,7251,7254],{"class":3378,"line":3777},[3376,7252,7253],{"class":3423},"    .truncate-2",[3376,7255,3414],{"class":5448},[3376,7257,7258,7261],{"class":3378,"line":4205},[3376,7259,7260],{"class":3727},"        display",[3376,7262,7263],{"class":5448},": -webkit-box;\n",[3376,7265,7266,7269,7271,7274],{"class":3378,"line":4215},[3376,7267,7268],{"class":3727},"        -webkit-line-clamp",[3376,7270,3731],{"class":5448},[3376,7272,7273],{"class":3759},"2",[3376,7275,3398],{"class":5448},[3376,7277,7278,7281,7283,7286],{"class":3378,"line":4230},[3376,7279,7280],{"class":3727},"        -webkit-box-orient",[3376,7282,3731],{"class":5448},[3376,7284,7285],{"class":7216},"vertical",[3376,7287,3398],{"class":5448},[3376,7289,7290,7293,7295,7298],{"class":3378,"line":4238},[3376,7291,7292],{"class":3727},"        overflow",[3376,7294,3731],{"class":5448},[3376,7296,7297],{"class":7216},"hidden",[3376,7299,3398],{"class":5448},[3376,7301,7302,7305,7308,7311,7314],{"class":3378,"line":4244},[3376,7303,7304],{"class":3727},"        transition",[3376,7306,7307],{"class":5448},": -webkit-line-clamp ",[3376,7309,7310],{"class":3759},"0.2s",[3376,7312,7313],{"class":7216}," ease",[3376,7315,3398],{"class":5448},[3376,7317,7318],{"class":3378,"line":4253},[3376,7319,3774],{"class":5448},[3376,7321,7322,7325],{"class":3378,"line":4263},[3376,7323,7324],{"class":3423},"    .truncate-2:hover",[3376,7326,3414],{"class":5448},[3376,7328,7329,7331,7333,7336],{"class":3378,"line":4268},[3376,7330,7268],{"class":3727},[3376,7332,3731],{"class":5448},[3376,7334,7335],{"class":3759},"5",[3376,7337,3398],{"class":5448},[3376,7339,7340],{"class":3378,"line":4277},[3376,7341,3774],{"class":5448},[3376,7343,7344],{"class":3378,"line":6311},[3376,7345,3405],{"emptyLinePlaceholder":3404},[3376,7347,7348,7351],{"class":3378,"line":6316},[3376,7349,7350],{"class":3423},"    .container-fluid",[3376,7352,3414],{"class":5448},[3376,7354,7355,7358,7360,7363],{"class":3378,"line":6322},[3376,7356,7357],{"class":3727},"        width",[3376,7359,3731],{"class":5448},[3376,7361,7362],{"class":3759},"100%",[3376,7364,3398],{"class":5448},[3376,7366,7367,7370,7372,7375],{"class":3378,"line":6342},[3376,7368,7369],{"class":3727},"        max-width",[3376,7371,3731],{"class":5448},[3376,7373,7374],{"class":3759},"80rem",[3376,7376,3398],{"class":5448},[3376,7378,7379,7382,7384,7387],{"class":3378,"line":6361},[3376,7380,7381],{"class":3727},"        margin-left",[3376,7383,3731],{"class":5448},[3376,7385,7386],{"class":7216},"auto",[3376,7388,3398],{"class":5448},[3376,7390,7391,7394,7396,7398],{"class":3378,"line":6366},[3376,7392,7393],{"class":3727},"        margin-right",[3376,7395,3731],{"class":5448},[3376,7397,7386],{"class":7216},[3376,7399,3398],{"class":5448},[3376,7401,7402,7405,7407,7410,7412,7415,7417,7420,7422,7425],{"class":3378,"line":6372},[3376,7403,7404],{"class":3727},"        padding-left",[3376,7406,3731],{"class":5448},[3376,7408,7409],{"class":3580},"clamp",[3376,7411,3737],{"class":5448},[3376,7413,7414],{"class":3759},"1rem",[3376,7416,3446],{"class":5448},[3376,7418,7419],{"class":3759},"3vw",[3376,7421,3446],{"class":5448},[3376,7423,7424],{"class":3759},"3rem",[3376,7426,3743],{"class":5448},[3376,7428,7429,7432,7434,7436,7438,7440,7442,7444,7446,7448],{"class":3378,"line":6377},[3376,7430,7431],{"class":3727},"        padding-right",[3376,7433,3731],{"class":5448},[3376,7435,7409],{"class":3580},[3376,7437,3737],{"class":5448},[3376,7439,7414],{"class":3759},[3376,7441,3446],{"class":5448},[3376,7443,7419],{"class":3759},[3376,7445,3446],{"class":5448},[3376,7447,7424],{"class":3759},[3376,7449,3743],{"class":5448},[3376,7451,7452],{"class":3378,"line":6383},[3376,7453,3774],{"class":5448},[3376,7455,7456],{"class":3378,"line":6402},[3376,7457,3405],{"emptyLinePlaceholder":3404},[3376,7459,7460,7463],{"class":3378,"line":6420},[3376,7461,7462],{"class":3423},"    .aspect-video",[3376,7464,3414],{"class":5448},[3376,7466,7467,7470,7472,7475,7478,7481],{"class":3378,"line":6433},[3376,7468,7469],{"class":3727},"        aspect-ratio",[3376,7471,3731],{"class":5448},[3376,7473,7474],{"class":3759},"16",[3376,7476,7477],{"class":5448}," \u002F ",[3376,7479,7480],{"class":3759},"9",[3376,7482,3398],{"class":5448},[3376,7484,7485],{"class":3378,"line":6438},[3376,7486,3774],{"class":5448},[3376,7488,7489,7491,7493],{"class":3378,"line":6444},[3376,7490,4074],{"class":3978},[3376,7492,7108],{"class":3442},[3376,7494,3988],{"class":3978},[3376,7496,7497,7499,7501],{"class":3378,"line":6449},[3376,7498,4074],{"class":3978},[3376,7500,4014],{"class":3442},[3376,7502,3988],{"class":3978},[3376,7504,7505,7507,7509,7511,7513,7516,7519,7521,7524],{"class":3378,"line":6455},[3376,7506,3993],{"class":3978},[3376,7508,4127],{"class":3442},[3376,7510,4130],{"class":3727},[3376,7512,4001],{"class":3397},[3376,7514,7515],{"class":4004},"\"p-6 bg-slate-100\"",[3376,7517,7518],{"class":3727}," style",[3376,7520,4001],{"class":3397},[3376,7522,7523],{"class":4004},"\"font-family: 'Inter', system-ui, sans-serif;\"",[3376,7525,3988],{"class":3978},[3376,7527,7528],{"class":3378,"line":6464},[3376,7529,7530],{"class":3382},"    \u003C!-- fluid container -->\n",[3376,7532,7533,7535,7537,7539,7541,7543],{"class":3378,"line":6473},[3376,7534,4021],{"class":3978},[3376,7536,4148],{"class":3442},[3376,7538,4130],{"class":3727},[3376,7540,4001],{"class":3397},[3376,7542,6988],{"class":4004},[3376,7544,3988],{"class":3978},[3376,7546,7547,7549,7551,7553,7555,7558],{"class":3378,"line":6478},[3376,7548,4162],{"class":3978},[3376,7550,4148],{"class":3442},[3376,7552,4130],{"class":3727},[3376,7554,4001],{"class":3397},[3376,7556,7557],{"class":4004},"\"max-w-md mx-auto space-y-4\"",[3376,7559,3988],{"class":3978},[3376,7561,7562,7564,7566,7568,7570,7573,7575,7578,7580,7582],{"class":3378,"line":6484},[3376,7563,5115],{"class":3978},[3376,7565,3353],{"class":3442},[3376,7567,4130],{"class":3727},[3376,7569,4001],{"class":3397},[3376,7571,7572],{"class":4004},"\"text-xs font-bold text-slate-400 uppercase tracking-widest text-center\"",[3376,7574,4068],{"class":3978},[3376,7576,7577],{"class":3397},"Custom @utility Showcase",[3376,7579,4074],{"class":3978},[3376,7581,3353],{"class":3442},[3376,7583,3988],{"class":3978},[3376,7585,7586],{"class":3378,"line":6490},[3376,7587,7588],{"class":3397},"            \n",[3376,7590,7591],{"class":3378,"line":6496},[3376,7592,7593],{"class":3382},"            \u003C!-- Glass card -->\n",[3376,7595,7596,7598,7600,7602,7604,7607],{"class":3378,"line":6502},[3376,7597,5115],{"class":3978},[3376,7599,4148],{"class":3442},[3376,7601,4130],{"class":3727},[3376,7603,4001],{"class":3397},[3376,7605,7606],{"class":4004},"\"glass rounded-2xl p-6 shadow-lg border border-white\u002F40\"",[3376,7608,3988],{"class":3978},[3376,7610,7611,7614,7617,7619,7621,7624,7626,7629,7631,7633],{"class":3378,"line":6508},[3376,7612,7613],{"class":3978},"                \u003C",[3376,7615,7616],{"class":3442},"h4",[3376,7618,4130],{"class":3727},[3376,7620,4001],{"class":3397},[3376,7622,7623],{"class":4004},"\"text-sm font-bold text-slate-800 mb-2\"",[3376,7625,4068],{"class":3978},[3376,7627,7628],{"class":3397},"Картка з кастомними утилітами",[3376,7630,4074],{"class":3978},[3376,7632,7616],{"class":3442},[3376,7634,3988],{"class":3978},[3376,7636,7638],{"class":3378,"line":7637},50,[3376,7639,7640],{"class":3397},"                \n",[3376,7642,7644],{"class":3378,"line":7643},51,[3376,7645,7646],{"class":3382},"                \u003C!-- Aspect Video Simulator -->\n",[3376,7648,7650,7652,7654,7656,7658,7661],{"class":3378,"line":7649},52,[3376,7651,7613],{"class":3978},[3376,7653,4148],{"class":3442},[3376,7655,4130],{"class":3727},[3376,7657,4001],{"class":3397},[3376,7659,7660],{"class":4004},"\"aspect-video w-full bg-slate-900\u002F10 rounded-xl mb-4 flex items-center justify-center text-slate-600 border border-slate-300\u002F30 font-semibold relative overflow-hidden\"",[3376,7662,3988],{"class":3978},[3376,7664,7666,7669,7671,7673,7675,7678,7680,7682],{"class":3378,"line":7665},53,[3376,7667,7668],{"class":3978},"                    \u003C",[3376,7670,4148],{"class":3442},[3376,7672,4130],{"class":3727},[3376,7674,4001],{"class":3397},[3376,7676,7677],{"class":4004},"\"absolute inset-0 bg-gradient-to-br from-indigo-500\u002F20 to-purple-500\u002F20\"",[3376,7679,7076],{"class":3978},[3376,7681,4148],{"class":3442},[3376,7683,3988],{"class":3978},[3376,7685,7687,7689,7691,7693,7695,7698,7700,7703,7705,7707],{"class":3378,"line":7686},54,[3376,7688,7668],{"class":3978},[3376,7690,3376],{"class":3442},[3376,7692,4130],{"class":3727},[3376,7694,4001],{"class":3397},[3376,7696,7697],{"class":4004},"\"z-10 text-xs font-mono uppercase tracking-wider bg-white\u002F80 px-2.5 py-1 rounded-full shadow-sm\"",[3376,7699,4068],{"class":3978},[3376,7701,7702],{"class":3397},"aspect-video",[3376,7704,4074],{"class":3978},[3376,7706,3376],{"class":3442},[3376,7708,3988],{"class":3978},[3376,7710,7712,7715,7717],{"class":3378,"line":7711},55,[3376,7713,7714],{"class":3978},"                \u003C\u002F",[3376,7716,4148],{"class":3442},[3376,7718,3988],{"class":3978},[3376,7720,7722],{"class":3378,"line":7721},56,[3376,7723,3405],{"emptyLinePlaceholder":3404},[3376,7725,7727],{"class":3378,"line":7726},57,[3376,7728,7729],{"class":3382},"                \u003C!-- Truncated Text -->\n",[3376,7731,7733,7735,7737,7739,7741,7744],{"class":3378,"line":7732},58,[3376,7734,7613],{"class":3978},[3376,7736,4148],{"class":3442},[3376,7738,4130],{"class":3727},[3376,7740,4001],{"class":3397},[3376,7742,7743],{"class":4004},"\"bg-white\u002F60 rounded-xl p-3 border border-white\u002F20 cursor-pointer\"",[3376,7745,3988],{"class":3978},[3376,7747,7749,7751,7753,7755,7757,7760,7762,7765,7767,7769],{"class":3378,"line":7748},59,[3376,7750,7668],{"class":3978},[3376,7752,3353],{"class":3442},[3376,7754,4130],{"class":3727},[3376,7756,4001],{"class":3397},[3376,7758,7759],{"class":4004},"\"text-xs font-bold uppercase tracking-wider text-slate-400 mb-1\"",[3376,7761,4068],{"class":3978},[3376,7763,7764],{"class":3397},"Наведіть курсор, щоб розгорнути:",[3376,7766,4074],{"class":3978},[3376,7768,3353],{"class":3442},[3376,7770,3988],{"class":3978},[3376,7772,7774,7776,7778,7780,7782,7785],{"class":3378,"line":7773},60,[3376,7775,7668],{"class":3978},[3376,7777,3353],{"class":3442},[3376,7779,4130],{"class":3727},[3376,7781,4001],{"class":3397},[3376,7783,7784],{"class":4004},"\"truncate-2 text-xs text-slate-600 leading-relaxed\"",[3376,7786,3988],{"class":3978},[3376,7788,7790],{"class":3378,"line":7789},61,[3376,7791,7792],{"class":3397},"                        Цей текст автоматично обрізається до двох рядків завдяки кастомній утиліті truncate-2. Якщо ви наведете на нього курсор, спрацює CSS-правило розширення лінії, і ви зможете прочитати весь абзац повністю, що дуже зручно для компактного відображення карток блогу або описів товарів без зайвого JavaScript.\n",[3376,7794,7796,7799,7801],{"class":3378,"line":7795},62,[3376,7797,7798],{"class":3978},"                    \u003C\u002F",[3376,7800,3353],{"class":3442},[3376,7802,3988],{"class":3978},[3376,7804,7806,7808,7810],{"class":3378,"line":7805},63,[3376,7807,7714],{"class":3978},[3376,7809,4148],{"class":3442},[3376,7811,3988],{"class":3978},[3376,7813,7815,7817,7819],{"class":3378,"line":7814},64,[3376,7816,5136],{"class":3978},[3376,7818,4148],{"class":3442},[3376,7820,3988],{"class":3978},[3376,7822,7824,7826,7828],{"class":3378,"line":7823},65,[3376,7825,4208],{"class":3978},[3376,7827,4148],{"class":3442},[3376,7829,3988],{"class":3978},[3376,7831,7833,7835,7837],{"class":3378,"line":7832},66,[3376,7834,4256],{"class":3978},[3376,7836,4148],{"class":3442},[3376,7838,3988],{"class":3978},[3376,7840,7842,7844,7846],{"class":3378,"line":7841},67,[3376,7843,4074],{"class":3978},[3376,7845,4127],{"class":3442},[3376,7847,3988],{"class":3978},[3376,7849,7851,7853,7855],{"class":3378,"line":7850},68,[3376,7852,4074],{"class":3978},[3376,7854,3971],{"class":3442},[3376,7856,3988],{"class":3978},[3483,7858],{},[3348,7860,7862],{"id":7861},"частина-iv-production-оптимізація","Частина IV. Production-оптимізація",[3490,7864,7866],{"id":7865},"_41-як-tailwind-генерує-css-у-v4","4.1. Як Tailwind генерує CSS у v4",[3353,7868,7869],{},"У Tailwind v4 повністю переписано движок генерації CSS. Ключові зміни порівняно з v3:",[3508,7871,7872,7885,7891],{},[3511,7873,7874,7880,7881,7884],{},[3362,7875,7876,7877],{},"Не потрібен ",[3357,7878,7879],{},"purge",": CSS генерується ",[3362,7882,7883],{},"тільки для класів, що реально використовуються"," — завжди, не тільки у production",[3511,7886,7887,7890],{},[3362,7888,7889],{},"Інкрементальна збірка",": при зміні файлу перекомпілюється лише те, що змінилося",[3511,7892,7893,7898,7899,7901],{},[3362,7894,7895,7896],{},"Без ",[3357,7897,3359],{},": вся конфігурація у CSS — JIT-движок читає ",[3357,7900,3411],{}," напряму",[3367,7903,7905],{"className":3566,"code":7904,"language":3568,"meta":3372,"style":3372},"# Development: повна швидкість, source maps\nnpm run dev\n\n# Production: мінімізація + оптимізація\nnpx @tailwindcss\u002Fcli -i src\u002Finput.css -o dist\u002Foutput.css --minify\n# або через Vite:\nnpm run build\n",[3357,7906,7907,7912,7922,7926,7931,7947,7952],{"__ignoreMap":3372},[3376,7908,7909],{"class":3378,"line":3379},[3376,7910,7911],{"class":3382},"# Development: повна швидкість, source maps\n",[3376,7913,7914,7916,7919],{"class":3378,"line":3386},[3376,7915,3581],{"class":3580},[3376,7917,7918],{"class":3393}," run",[3376,7920,7921],{"class":3393}," dev\n",[3376,7923,7924],{"class":3378,"line":3401},[3376,7925,3405],{"emptyLinePlaceholder":3404},[3376,7927,7928],{"class":3378,"line":3408},[3376,7929,7930],{"class":3382},"# Production: мінімізація + оптимізація\n",[3376,7932,7933,7935,7937,7939,7941,7943,7945],{"class":3378,"line":3417},[3376,7934,3799],{"class":3580},[3376,7936,3610],{"class":3393},[3376,7938,3804],{"class":3587},[3376,7940,3807],{"class":3393},[3376,7942,3810],{"class":3587},[3376,7944,3837],{"class":3393},[3376,7946,3866],{"class":3587},[3376,7948,7949],{"class":3378,"line":3436},[3376,7950,7951],{"class":3382},"# або через Vite:\n",[3376,7953,7954,7956,7958],{"class":3378,"line":3454},[3376,7955,3581],{"class":3580},[3376,7957,7918],{"class":3393},[3376,7959,7960],{"class":3393}," build\n",[3353,7962,7963],{},"Типовий розмір production CSS:",[3508,7965,7966,7972,7978],{},[3511,7967,7968,7971],{},[3362,7969,7970],{},"Базовий reset + мінімальний UI",": ~8-15 KB (gzip)",[3511,7973,7974,7977],{},[3362,7975,7976],{},"Повноцінний застосунок з багатьма компонентами",": ~20-50 KB (gzip)",[3511,7979,7980,7983],{},[3362,7981,7982],{},"Без purge (всі класи)",": ~4-5 MB (тільки для dev!)",[3483,7985],{},[3490,7987,7989,7990],{"id":7988},"_42-оптимізація-через-source","4.2. Оптимізація через ",[3357,7991,4362],{},[3353,7993,7994,7995,4493],{},"Якщо Tailwind генерує класи, яких немає у вашому проєкті — перевірте конфігурацію ",[3357,7996,4362],{},[3367,7998,8000],{"className":3369,"code":7999,"filename":3635,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Явно вказати де шукати класи *\u002F\n@source \".\u002Fsrc\u002F**\u002F*.{html,js,ts,jsx,tsx,vue,svelte}\";\n\n\u002F* Виключити legacу-код *\u002F\n@source not \".\u002Fsrc\u002Flegacy\u002F**\";\n\n\u002F* Додати зовнішні пакунки (UI-бібліотеки) *\u002F\n@source \"..\u002F..\u002Fnode_modules\u002F@my-ui-lib\u002Fcomponents\u002F**\u002F*.js\";\n",[3357,8001,8002,8010,8014,8019,8026,8030,8035,8042,8046,8051],{"__ignoreMap":3372},[3376,8003,8004,8006,8008],{"class":3378,"line":3379},[3376,8005,3390],{"class":3389},[3376,8007,3649],{"class":3393},[3376,8009,3398],{"class":3397},[3376,8011,8012],{"class":3378,"line":3386},[3376,8013,3405],{"emptyLinePlaceholder":3404},[3376,8015,8016],{"class":3378,"line":3401},[3376,8017,8018],{"class":3382},"\u002F* Явно вказати де шукати класи *\u002F\n",[3376,8020,8021,8023],{"class":3378,"line":3408},[3376,8022,4362],{"class":3389},[3376,8024,8025],{"class":3397}," \".\u002Fsrc\u002F**\u002F*.{html,js,ts,jsx,tsx,vue,svelte}\";\n",[3376,8027,8028],{"class":3378,"line":3417},[3376,8029,3405],{"emptyLinePlaceholder":3404},[3376,8031,8032],{"class":3378,"line":3436},[3376,8033,8034],{"class":3382},"\u002F* Виключити legacу-код *\u002F\n",[3376,8036,8037,8039],{"class":3378,"line":3454},[3376,8038,4362],{"class":3389},[3376,8040,8041],{"class":3397}," not \".\u002Fsrc\u002Flegacy\u002F**\";\n",[3376,8043,8044],{"class":3378,"line":3460},[3376,8045,3405],{"emptyLinePlaceholder":3404},[3376,8047,8048],{"class":3378,"line":3465},[3376,8049,8050],{"class":3382},"\u002F* Додати зовнішні пакунки (UI-бібліотеки) *\u002F\n",[3376,8052,8053,8055],{"class":3378,"line":3701},[3376,8054,4362],{"class":3389},[3376,8056,8057],{"class":3397}," \"..\u002F..\u002Fnode_modules\u002F@my-ui-lib\u002Fcomponents\u002F**\u002F*.js\";\n",[3353,8059,8060],{},[3362,8061,8062],{},"Safelist: класи, що генеруються динамічно",[3353,8064,8065],{},"Якщо ваш JS генерує класи динамічно (наприклад, з масиву рядків), Tailwind не зможе їх знайти при скануванні:",[3367,8067,8069],{"className":4453,"code":8068,"language":4456,"meta":3372,"style":3372},"\u002F\u002F ❌ Tailwind не побачить ці класи\nconst color = getColorFromAPI()\nconst className = `bg-${color}-500` \u002F\u002F 'bg-red-500', 'bg-blue-500'...\n",[3357,8070,8071,8076,8090],{"__ignoreMap":3372},[3376,8072,8073],{"class":3378,"line":3379},[3376,8074,8075],{"class":3382},"\u002F\u002F ❌ Tailwind не побачить ці класи\n",[3376,8077,8078,8080,8083,8085,8088],{"class":3378,"line":3386},[3376,8079,4560],{"class":3587},[3376,8081,8082],{"class":4563}," color",[3376,8084,4566],{"class":3397},[3376,8086,8087],{"class":3580},"getColorFromAPI",[3376,8089,5606],{"class":3397},[3376,8091,8092,8094,8096,8098,8101,8104,8107,8109,8112],{"class":3378,"line":3401},[3376,8093,4560],{"class":3587},[3376,8095,5103],{"class":4563},[3376,8097,4566],{"class":3397},[3376,8099,8100],{"class":3393},"`bg-",[3376,8102,8103],{"class":3587},"${",[3376,8105,8106],{"class":4482},"color",[3376,8108,5454],{"class":3587},[3376,8110,8111],{"class":3393},"-500`",[3376,8113,8114],{"class":3382}," \u002F\u002F 'bg-red-500', 'bg-blue-500'...\n",[3353,8116,8117,8118,4493],{},"Рішення — ",[3357,8119,8120],{},"@source inline()",[3367,8122,8124],{"className":3369,"code":8123,"filename":3635,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Явно додати класи до генерації *\u002F\n@source inline(\"bg-red-500 bg-blue-500 bg-green-500 bg-yellow-500\");\n\n\u002F* Або через шаблон *\u002F\n@source inline(\"{bg,text,border}-{red,blue,green,yellow}-{400,500,600}\");\n",[3357,8125,8126,8134,8138,8143,8150,8154,8159],{"__ignoreMap":3372},[3376,8127,8128,8130,8132],{"class":3378,"line":3379},[3376,8129,3390],{"class":3389},[3376,8131,3649],{"class":3393},[3376,8133,3398],{"class":3397},[3376,8135,8136],{"class":3378,"line":3386},[3376,8137,3405],{"emptyLinePlaceholder":3404},[3376,8139,8140],{"class":3378,"line":3401},[3376,8141,8142],{"class":3382},"\u002F* Явно додати класи до генерації *\u002F\n",[3376,8144,8145,8147],{"class":3378,"line":3408},[3376,8146,4362],{"class":3389},[3376,8148,8149],{"class":3397}," inline(\"bg-red-500 bg-blue-500 bg-green-500 bg-yellow-500\");\n",[3376,8151,8152],{"class":3378,"line":3417},[3376,8153,3405],{"emptyLinePlaceholder":3404},[3376,8155,8156],{"class":3378,"line":3436},[3376,8157,8158],{"class":3382},"\u002F* Або через шаблон *\u002F\n",[3376,8160,8161,8163],{"class":3378,"line":3454},[3376,8162,4362],{"class":3389},[3376,8164,8165],{"class":3397}," inline(\"{bg,text,border}-{red,blue,green,yellow}-{400,500,600}\");\n",[8167,8168,8169,8170,8173,8174,8177,8178,8181],"warning",{},"Не використовуйте ",[3357,8171,8172],{},"@source inline(\"bg-{*}-500\")"," з ",[3357,8175,8176],{},"*"," — це додасть ",[3362,8179,8180],{},"всі"," кольори до bundle. Вказуйте тільки ті, що реально використовуються.",[3483,8183],{},[3490,8185,8187],{"id":8186},"_43-налаштування-intellisense-у-vs-code","4.3. Налаштування IntelliSense у VS Code",[3353,8189,8190,8193],{},[3362,8191,8192],{},"Tailwind CSS IntelliSense"," — офіційне розширення VS Code, що дає автодоповнення класів, підказки значень та попередній перегляд прямо у редакторі.",[3353,8195,4426],{},[3367,8197,8199],{"className":3566,"code":8198,"language":3568,"meta":3372,"style":3372},"# Через CLI VS Code\ncode --install-extension bradlc.vscode-tailwindcss\n",[3357,8200,8201,8206],{"__ignoreMap":3372},[3376,8202,8203],{"class":3378,"line":3379},[3376,8204,8205],{"class":3382},"# Через CLI VS Code\n",[3376,8207,8208,8210,8213],{"class":3378,"line":3386},[3376,8209,3357],{"class":3580},[3376,8211,8212],{"class":3587}," --install-extension",[3376,8214,8215],{"class":3393}," bradlc.vscode-tailwindcss\n",[3353,8217,8218,8219,3503],{},"Або через Extensions panel: пошук ",[3357,8220,8192],{},[3353,8222,8223],{},[3362,8224,8225,8226,4493],{},"Налаштування ",[3357,8227,8228],{},".vscode\u002Fsettings.json",[3367,8230,8232],{"className":3876,"code":8231,"filename":8228,"language":3878,"meta":3372,"style":3372},"{\n    \u002F\u002F Автодоповнення у атрибуті class\n    \"editor.quickSuggestions\": {\n        \"strings\": \"on\"\n    },\n\n    \u002F\u002F Де шукати Tailwind-класи (для кастомних атрибутів)\n    \"tailwindCSS.classAttributes\": [\n        \"class\",\n        \"className\",\n        \"tw\",\n        \"classNames\"\n    ],\n\n    \u002F\u002F Файли, що мають підтримку IntelliSense\n    \"tailwindCSS.includeLanguages\": {\n        \"plaintext\": \"html\",\n        \"vue\": \"html\",\n        \"javascriptreact\": \"javascript\",\n        \"typescriptreact\": \"typescript\"\n    },\n\n    \u002F\u002F Показувати кольоровий квадратик у класах з кольором\n    \"editor.colorDecoratorsLimit\": 1000,\n\n    \u002F\u002F Сортування класів (через prettier-plugin-tailwindcss)\n    \"editor.formatOnSave\": true\n}\n",[3357,8233,8234,8238,8243,8250,8260,8264,8268,8273,8281,8288,8295,8302,8307,8312,8316,8321,8328,8340,8351,8363,8373,8377,8381,8386,8398,8402,8407,8417],{"__ignoreMap":3372},[3376,8235,8236],{"class":3378,"line":3379},[3376,8237,3885],{"class":3397},[3376,8239,8240],{"class":3378,"line":3386},[3376,8241,8242],{"class":3382},"    \u002F\u002F Автодоповнення у атрибуті class\n",[3376,8244,8245,8248],{"class":3378,"line":3401},[3376,8246,8247],{"class":3890},"    \"editor.quickSuggestions\"",[3376,8249,3894],{"class":3397},[3376,8251,8252,8255,8257],{"class":3378,"line":3408},[3376,8253,8254],{"class":3890},"        \"strings\"",[3376,8256,3731],{"class":3397},[3376,8258,8259],{"class":3393},"\"on\"\n",[3376,8261,8262],{"class":3378,"line":3417},[3376,8263,3922],{"class":3397},[3376,8265,8266],{"class":3378,"line":3436},[3376,8267,3405],{"emptyLinePlaceholder":3404},[3376,8269,8270],{"class":3378,"line":3454},[3376,8271,8272],{"class":3382},"    \u002F\u002F Де шукати Tailwind-класи (для кастомних атрибутів)\n",[3376,8274,8275,8278],{"class":3378,"line":3460},[3376,8276,8277],{"class":3890},"    \"tailwindCSS.classAttributes\"",[3376,8279,8280],{"class":3397},": [\n",[3376,8282,8283,8286],{"class":3378,"line":3465},[3376,8284,8285],{"class":3393},"        \"class\"",[3376,8287,3907],{"class":3397},[3376,8289,8290,8293],{"class":3378,"line":3701},[3376,8291,8292],{"class":3393},"        \"className\"",[3376,8294,3907],{"class":3397},[3376,8296,8297,8300],{"class":3378,"line":3707},[3376,8298,8299],{"class":3393},"        \"tw\"",[3376,8301,3907],{"class":3397},[3376,8303,8304],{"class":3378,"line":3716},[3376,8305,8306],{"class":3393},"        \"classNames\"\n",[3376,8308,8309],{"class":3378,"line":3724},[3376,8310,8311],{"class":3397},"    ],\n",[3376,8313,8314],{"class":3378,"line":3746},[3376,8315,3405],{"emptyLinePlaceholder":3404},[3376,8317,8318],{"class":3378,"line":3771},[3376,8319,8320],{"class":3382},"    \u002F\u002F Файли, що мають підтримку IntelliSense\n",[3376,8322,8323,8326],{"class":3378,"line":3777},[3376,8324,8325],{"class":3890},"    \"tailwindCSS.includeLanguages\"",[3376,8327,3894],{"class":3397},[3376,8329,8330,8333,8335,8338],{"class":3378,"line":4205},[3376,8331,8332],{"class":3890},"        \"plaintext\"",[3376,8334,3731],{"class":3397},[3376,8336,8337],{"class":3393},"\"html\"",[3376,8339,3907],{"class":3397},[3376,8341,8342,8345,8347,8349],{"class":3378,"line":4215},[3376,8343,8344],{"class":3890},"        \"vue\"",[3376,8346,3731],{"class":3397},[3376,8348,8337],{"class":3393},[3376,8350,3907],{"class":3397},[3376,8352,8353,8356,8358,8361],{"class":3378,"line":4230},[3376,8354,8355],{"class":3890},"        \"javascriptreact\"",[3376,8357,3731],{"class":3397},[3376,8359,8360],{"class":3393},"\"javascript\"",[3376,8362,3907],{"class":3397},[3376,8364,8365,8368,8370],{"class":3378,"line":4238},[3376,8366,8367],{"class":3890},"        \"typescriptreact\"",[3376,8369,3731],{"class":3397},[3376,8371,8372],{"class":3393},"\"typescript\"\n",[3376,8374,8375],{"class":3378,"line":4244},[3376,8376,3922],{"class":3397},[3376,8378,8379],{"class":3378,"line":4253},[3376,8380,3405],{"emptyLinePlaceholder":3404},[3376,8382,8383],{"class":3378,"line":4263},[3376,8384,8385],{"class":3382},"    \u002F\u002F Показувати кольоровий квадратик у класах з кольором\n",[3376,8387,8388,8391,8393,8396],{"class":3378,"line":4268},[3376,8389,8390],{"class":3890},"    \"editor.colorDecoratorsLimit\"",[3376,8392,3731],{"class":3397},[3376,8394,8395],{"class":3759},"1000",[3376,8397,3907],{"class":3397},[3376,8399,8400],{"class":3378,"line":4277},[3376,8401,3405],{"emptyLinePlaceholder":3404},[3376,8403,8404],{"class":3378,"line":6311},[3376,8405,8406],{"class":3382},"    \u002F\u002F Сортування класів (через prettier-plugin-tailwindcss)\n",[3376,8408,8409,8412,8414],{"class":3378,"line":6316},[3376,8410,8411],{"class":3890},"    \"editor.formatOnSave\"",[3376,8413,3731],{"class":3397},[3376,8415,8416],{"class":3587},"true\n",[3376,8418,8419],{"class":3378,"line":6322},[3376,8420,3457],{"class":3397},[3483,8422],{},[3490,8424,8426,8427,8430],{"id":8425},"_44-prettier-plugin-tailwindcss-автосортування-класів","4.4. ",[3357,8428,8429],{},"prettier-plugin-tailwindcss",": автосортування класів",[3353,8432,8433],{},"Довгі рядки Tailwind-класів швидко стають нечитабельними:",[3367,8435,8437],{"className":3968,"code":8436,"language":3971,"meta":3372,"style":3372},"\u003C!-- ❌ Без сортування: хаотичний порядок -->\n\u003Cdiv class=\"text-white px-4 rounded-xl bg-indigo-600 hover:bg-indigo-700 font-bold py-2 transition-colors duration-200 text-sm\">\n\n\u003C!-- ✅ Після сортування: логічний порядок -->\n\u003Cdiv class=\"rounded-xl bg-indigo-600 px-4 py-2 text-sm font-bold text-white transition-colors duration-200 hover:bg-indigo-700\">\n",[3357,8438,8439,8444,8459,8463,8468],{"__ignoreMap":3372},[3376,8440,8441],{"class":3378,"line":3379},[3376,8442,8443],{"class":3382},"\u003C!-- ❌ Без сортування: хаотичний порядок -->\n",[3376,8445,8446,8448,8450,8452,8454,8457],{"class":3378,"line":3386},[3376,8447,3993],{"class":3978},[3376,8449,4148],{"class":3442},[3376,8451,4130],{"class":3727},[3376,8453,4001],{"class":3397},[3376,8455,8456],{"class":4004},"\"text-white px-4 rounded-xl bg-indigo-600 hover:bg-indigo-700 font-bold py-2 transition-colors duration-200 text-sm\"",[3376,8458,3988],{"class":3978},[3376,8460,8461],{"class":3378,"line":3401},[3376,8462,3405],{"emptyLinePlaceholder":3404},[3376,8464,8465],{"class":3378,"line":3408},[3376,8466,8467],{"class":3382},"\u003C!-- ✅ Після сортування: логічний порядок -->\n",[3376,8469,8470,8472,8474,8476,8478,8481],{"class":3378,"line":3417},[3376,8471,3993],{"class":3978},[3376,8473,4148],{"class":3442},[3376,8475,4130],{"class":3727},[3376,8477,4001],{"class":3397},[3376,8479,8480],{"class":4004},"\"rounded-xl bg-indigo-600 px-4 py-2 text-sm font-bold text-white transition-colors duration-200 hover:bg-indigo-700\"",[3376,8482,3988],{"class":3978},[3353,8484,8485,8486,8489],{},"Плагін сортує класи за ",[3362,8487,8488],{},"офіційно рекомендованим порядком"," Tailwind (layout → sizing → spacing → typography → visual → interactive).",[3353,8491,4426],{},[3367,8493,8495],{"className":3566,"code":8494,"language":3568,"meta":3372,"style":3372},"npm install prettier prettier-plugin-tailwindcss --save-dev\n",[3357,8496,8497],{"__ignoreMap":3372},[3376,8498,8499,8501,8503,8506,8509],{"class":3378,"line":3379},[3376,8500,3581],{"class":3580},[3376,8502,3604],{"class":3393},[3376,8504,8505],{"class":3393}," prettier",[3376,8507,8508],{"class":3393}," prettier-plugin-tailwindcss",[3376,8510,3613],{"class":3587},[3367,8512,8515],{"className":3876,"code":8513,"filename":8514,"language":3878,"meta":3372,"style":3372},"{\n    \"plugins\": [\"prettier-plugin-tailwindcss\"],\n    \"tailwindStylesheet\": \".\u002Fsrc\u002Finput.css\",\n    \"singleQuote\": true,\n    \"semi\": false,\n    \"tabWidth\": 4,\n    \"printWidth\": 100\n}\n",".prettierrc",[3357,8516,8517,8521,8534,8546,8557,8569,8581,8591],{"__ignoreMap":3372},[3376,8518,8519],{"class":3378,"line":3379},[3376,8520,3885],{"class":3397},[3376,8522,8523,8526,8529,8532],{"class":3378,"line":3386},[3376,8524,8525],{"class":3890},"    \"plugins\"",[3376,8527,8528],{"class":3397},": [",[3376,8530,8531],{"class":3393},"\"prettier-plugin-tailwindcss\"",[3376,8533,5687],{"class":3397},[3376,8535,8536,8539,8541,8544],{"class":3378,"line":3401},[3376,8537,8538],{"class":3890},"    \"tailwindStylesheet\"",[3376,8540,3731],{"class":3397},[3376,8542,8543],{"class":3393},"\".\u002Fsrc\u002Finput.css\"",[3376,8545,3907],{"class":3397},[3376,8547,8548,8551,8553,8555],{"class":3378,"line":3408},[3376,8549,8550],{"class":3890},"    \"singleQuote\"",[3376,8552,3731],{"class":3397},[3376,8554,7007],{"class":3587},[3376,8556,3907],{"class":3397},[3376,8558,8559,8562,8564,8567],{"class":3378,"line":3417},[3376,8560,8561],{"class":3890},"    \"semi\"",[3376,8563,3731],{"class":3397},[3376,8565,8566],{"class":3587},"false",[3376,8568,3907],{"class":3397},[3376,8570,8571,8574,8576,8579],{"class":3378,"line":3436},[3376,8572,8573],{"class":3890},"    \"tabWidth\"",[3376,8575,3731],{"class":3397},[3376,8577,8578],{"class":3759},"4",[3376,8580,3907],{"class":3397},[3376,8582,8583,8586,8588],{"class":3378,"line":3454},[3376,8584,8585],{"class":3890},"    \"printWidth\"",[3376,8587,3731],{"class":3397},[3376,8589,8590],{"class":3759},"100\n",[3376,8592,8593],{"class":3378,"line":3460},[3376,8594,3457],{"class":3397},[3367,8596,8598],{"className":3876,"code":8597,"filename":3502,"language":3878,"meta":3372,"style":3372},"{\n    \"scripts\": {\n        \"format\": \"prettier --write .\"\n    }\n}\n",[3357,8599,8600,8604,8610,8620,8624],{"__ignoreMap":3372},[3376,8601,8602],{"class":3378,"line":3379},[3376,8603,3885],{"class":3397},[3376,8605,8606,8608],{"class":3378,"line":3386},[3376,8607,3891],{"class":3890},[3376,8609,3894],{"class":3397},[3376,8611,8612,8615,8617],{"class":3378,"line":3401},[3376,8613,8614],{"class":3890},"        \"format\"",[3376,8616,3731],{"class":3397},[3376,8618,8619],{"class":3393},"\"prettier --write .\"\n",[3376,8621,8622],{"class":3378,"line":3408},[3376,8623,3774],{"class":3397},[3376,8625,8626],{"class":3378,"line":3417},[3376,8627,3457],{"class":3397},[3483,8629],{},[3348,8631,8633],{"id":8632},"частина-v-завдання-для-самоперевірки","Частина V. Завдання для самоперевірки",[8635,8636,8637],"accordion",{},[8638,8639,8641,8646,8649,8707,8709,8714,8728,8752,8754,8759,8769,8787],"accordion-item",{"label":8640},"Рівень 1: Базовий — налаштування",[3353,8642,8643],{},[3362,8644,8645],{},"Завдання 1.1. Tailwind CLI.",[3353,8647,8648],{},"Налаштуйте статичний сайт із Tailwind CLI:",[8650,8651,8652,8660,8669,8679,8691,8700],"ol",{},[3511,8653,8654,8655,8173,8657],{},"Створіть ",[3357,8656,3502],{},[3357,8658,8659],{},"npm init -y",[3511,8661,8662,8663,8665,8666],{},"Встановіть ",[3357,8664,5031],{}," та ",[3357,8667,8668],{},"@tailwindcss\u002Fcli",[3511,8670,8654,8671,8173,8673,8676,8677],{},[3357,8672,3635],{},[3357,8674,8675],{},"@import \"tailwindcss\""," та кастомним кольором у ",[3357,8678,3411],{},[3511,8680,8681,8682,8665,8685,8688,8689],{},"Додайте скрипти ",[3357,8683,8684],{},"dev",[3357,8686,8687],{},"build"," у ",[3357,8690,3502],{},[3511,8692,8654,8693,8696,8697],{},[3357,8694,8695],{},"index.html",", що підключає ",[3357,8698,8699],{},"dist\u002Foutput.css",[3511,8701,8702,8703,8706],{},"Запустіть ",[3357,8704,8705],{},"npm run dev"," і переконайтеся, що зміни у HTML одразу відображаються у CSS",[3483,8708],{},[3353,8710,8711],{},[3362,8712,8713],{},"Завдання 1.2. Vite + Tailwind.",[3353,8715,8716,8717,8720,8721,8723,8724,8727],{},"Ініціалізуйте Vite-проєкт (шаблон ",[3357,8718,8719],{},"vanilla"," або ",[3357,8722,5037],{},"), підключіть Tailwind v4 через ",[3357,8725,8726],{},"@tailwindcss\u002Fvite",". Переконайтеся, що:",[3508,8729,8730,8735,8743,8749],{},[3511,8731,8732,8734],{},[3357,8733,4680],{}," містить плагін",[3511,8736,8737,8740,8741],{},[3357,8738,8739],{},"src\u002Fstyle.css"," підключає ",[3357,8742,8675],{},[3511,8744,8745,8748],{},[3357,8746,8747],{},"main.js\u002Fmain.jsx"," імпортує CSS-файл",[3511,8750,8751],{},"У браузері Tailwind-класи застосовуються",[3483,8753],{},[3353,8755,8756],{},[3362,8757,8758],{},"Завдання 1.3. Аналіз розміру bundle.",[3353,8760,8761,8762,8765,8766,4493],{},"Для Vite-проєкту запустіть ",[3357,8763,8764],{},"npm run build"," і порівняйте розмір ",[3357,8767,8768],{},"dist\u002Fassets\u002F*.css",[8650,8770,8771,8780],{},[3511,8772,7895,8773,8776,8777,5755],{},[3357,8774,8775],{},"--minify"," (або з ",[3357,8778,8779],{},"mode: 'development'",[3511,8781,8782,8783,8786],{},"З ",[3357,8784,8785],{},"mode: 'production'"," (мінімізація включена автоматично)",[3353,8788,8789],{},"Скільки місця займає ваш CSS? Скільки після gzip (перевірте у DevTools → Network → Response Headers → Content-Encoding)?",[8638,8791,8793,8801,8807,9216,9229,9231,9239,9244,9287],{"label":8792},"Рівень 2: Практика — конфігурація",[3353,8794,8795],{},[3362,8796,8797,8798,8800],{},"Завдання 2.1. Перенесення ",[3357,8799,3359],{}," → CSS.",[3353,8802,8803,8804,8806],{},"Візьміть наступний ",[3357,8805,3359],{}," і перетворіть його у v4 CSS-конфігурацію:",[3367,8808,8810],{"className":4453,"code":8809,"language":4456,"meta":3372,"style":3372},"\u002F\u002F tailwind.config.js (v3)\nmodule.exports = {\n    theme: {\n        extend: {\n            colors: {\n                primary: {\n                    50: '#eff6ff',\n                    500: '#3b82f6',\n                    900: '#1e3a8a',\n                },\n                accent: '#f59e0b',\n            },\n            fontFamily: {\n                heading: ['Poppins', 'sans-serif'],\n                body:    ['Inter', 'sans-serif'],\n            },\n            spacing: {\n                '128': '32rem',\n                '144': '36rem',\n            },\n            borderRadius: {\n                '4xl': '2rem',\n            },\n            boxShadow: {\n                'glow': '0 0 20px rgba(59, 130, 246, 0.4)',\n            },\n            animation: {\n                'fade-in': 'fadeIn 0.5s ease-out',\n                'slide-up': 'slideUp 0.4s ease-out',\n            },\n            keyframes: {\n                fadeIn: {\n                    '0%': { opacity: '0' },\n                    '100%': { opacity: '1' },\n                },\n                slideUp: {\n                    '0%': { transform: 'translateY(20px)', opacity: '0' },\n                    '100%': { transform: 'translateY(0)', opacity: '1' },\n                },\n            }\n        }\n    },\n    plugins: [\n        require('@tailwindcss\u002Ftypography'),\n        require('@tailwindcss\u002Fforms'),\n    ]\n}\n",[3357,8811,8812,8817,8827,8833,8839,8845,8852,8864,8876,8888,8893,8903,8907,8913,8930,8946,8950,8957,8969,8981,8985,8991,9001,9005,9012,9024,9028,9035,9047,9059,9063,9070,9077,9095,9111,9115,9122,9144,9165,9169,9173,9177,9181,9187,9197,9208,9212],{"__ignoreMap":3372},[3376,8813,8814],{"class":3378,"line":3379},[3376,8815,8816],{"class":3382},"\u002F\u002F tailwind.config.js (v3)\n",[3376,8818,8819,8821,8823,8825],{"class":3378,"line":3386},[3376,8820,4469],{"class":4468},[3376,8822,3503],{"class":3397},[3376,8824,4474],{"class":4468},[3376,8826,4477],{"class":3397},[3376,8828,8829,8831],{"class":3378,"line":3401},[3376,8830,5892],{"class":4482},[3376,8832,3414],{"class":3397},[3376,8834,8835,8837],{"class":3378,"line":3408},[3376,8836,5899],{"class":4482},[3376,8838,3414],{"class":3397},[3376,8840,8841,8843],{"class":3378,"line":3417},[3376,8842,5906],{"class":4482},[3376,8844,3414],{"class":3397},[3376,8846,8847,8850],{"class":3378,"line":3436},[3376,8848,8849],{"class":4482},"                primary:",[3376,8851,3414],{"class":3397},[3376,8853,8854,8857,8859,8862],{"class":3378,"line":3454},[3376,8855,8856],{"class":3759},"                    50",[3376,8858,4493],{"class":4482},[3376,8860,8861],{"class":3393}," '#eff6ff'",[3376,8863,3907],{"class":3397},[3376,8865,8866,8869,8871,8874],{"class":3378,"line":3460},[3376,8867,8868],{"class":3759},"                    500",[3376,8870,4493],{"class":4482},[3376,8872,8873],{"class":3393}," '#3b82f6'",[3376,8875,3907],{"class":3397},[3376,8877,8878,8881,8883,8886],{"class":3378,"line":3465},[3376,8879,8880],{"class":3759},"                    900",[3376,8882,4493],{"class":4482},[3376,8884,8885],{"class":3393}," '#1e3a8a'",[3376,8887,3907],{"class":3397},[3376,8889,8890],{"class":3378,"line":3701},[3376,8891,8892],{"class":3397},"                },\n",[3376,8894,8895,8898,8901],{"class":3378,"line":3707},[3376,8896,8897],{"class":4482},"                accent:",[3376,8899,8900],{"class":3393}," '#f59e0b'",[3376,8902,3907],{"class":3397},[3376,8904,8905],{"class":3378,"line":3716},[3376,8906,5923],{"class":3397},[3376,8908,8909,8911],{"class":3378,"line":3724},[3376,8910,5928],{"class":4482},[3376,8912,3414],{"class":3397},[3376,8914,8915,8918,8920,8923,8925,8928],{"class":3378,"line":3746},[3376,8916,8917],{"class":4482},"                heading:",[3376,8919,5028],{"class":3397},[3376,8921,8922],{"class":3393},"'Poppins'",[3376,8924,3446],{"class":3397},[3376,8926,8927],{"class":3393},"'sans-serif'",[3376,8929,5687],{"class":3397},[3376,8931,8932,8935,8938,8940,8942,8944],{"class":3378,"line":3771},[3376,8933,8934],{"class":4482},"                body:",[3376,8936,8937],{"class":3397},"    [",[3376,8939,5940],{"class":3393},[3376,8941,3446],{"class":3397},[3376,8943,8927],{"class":3393},[3376,8945,5687],{"class":3397},[3376,8947,8948],{"class":3378,"line":3777},[3376,8949,5923],{"class":3397},[3376,8951,8952,8955],{"class":3378,"line":4205},[3376,8953,8954],{"class":4482},"            spacing:",[3376,8956,3414],{"class":3397},[3376,8958,8959,8962,8964,8967],{"class":3378,"line":4215},[3376,8960,8961],{"class":3393},"                '128'",[3376,8963,4493],{"class":4482},[3376,8965,8966],{"class":3393}," '32rem'",[3376,8968,3907],{"class":3397},[3376,8970,8971,8974,8976,8979],{"class":3378,"line":4230},[3376,8972,8973],{"class":3393},"                '144'",[3376,8975,4493],{"class":4482},[3376,8977,8978],{"class":3393}," '36rem'",[3376,8980,3907],{"class":3397},[3376,8982,8983],{"class":3378,"line":4238},[3376,8984,5923],{"class":3397},[3376,8986,8987,8989],{"class":3378,"line":4244},[3376,8988,5956],{"class":4482},[3376,8990,3414],{"class":3397},[3376,8992,8993,8995,8997,8999],{"class":3378,"line":4253},[3376,8994,5963],{"class":3393},[3376,8996,4493],{"class":4482},[3376,8998,5968],{"class":3393},[3376,9000,3907],{"class":3397},[3376,9002,9003],{"class":3378,"line":4263},[3376,9004,5923],{"class":3397},[3376,9006,9007,9010],{"class":3378,"line":4268},[3376,9008,9009],{"class":4482},"            boxShadow:",[3376,9011,3414],{"class":3397},[3376,9013,9014,9017,9019,9022],{"class":3378,"line":4277},[3376,9015,9016],{"class":3393},"                'glow'",[3376,9018,4493],{"class":4482},[3376,9020,9021],{"class":3393}," '0 0 20px rgba(59, 130, 246, 0.4)'",[3376,9023,3907],{"class":3397},[3376,9025,9026],{"class":3378,"line":6311},[3376,9027,5923],{"class":3397},[3376,9029,9030,9033],{"class":3378,"line":6316},[3376,9031,9032],{"class":4482},"            animation:",[3376,9034,3414],{"class":3397},[3376,9036,9037,9040,9042,9045],{"class":3378,"line":6322},[3376,9038,9039],{"class":3393},"                'fade-in'",[3376,9041,4493],{"class":4482},[3376,9043,9044],{"class":3393}," 'fadeIn 0.5s ease-out'",[3376,9046,3907],{"class":3397},[3376,9048,9049,9052,9054,9057],{"class":3378,"line":6342},[3376,9050,9051],{"class":3393},"                'slide-up'",[3376,9053,4493],{"class":4482},[3376,9055,9056],{"class":3393}," 'slideUp 0.4s ease-out'",[3376,9058,3907],{"class":3397},[3376,9060,9061],{"class":3378,"line":6361},[3376,9062,5923],{"class":3397},[3376,9064,9065,9068],{"class":3378,"line":6366},[3376,9066,9067],{"class":4482},"            keyframes:",[3376,9069,3414],{"class":3397},[3376,9071,9072,9075],{"class":3378,"line":6372},[3376,9073,9074],{"class":4482},"                fadeIn:",[3376,9076,3414],{"class":3397},[3376,9078,9079,9082,9084,9086,9089,9092],{"class":3378,"line":6377},[3376,9080,9081],{"class":3393},"                    '0%'",[3376,9083,4493],{"class":4482},[3376,9085,4690],{"class":3397},[3376,9087,9088],{"class":4482},"opacity:",[3376,9090,9091],{"class":3393}," '0'",[3376,9093,9094],{"class":3397}," },\n",[3376,9096,9097,9100,9102,9104,9106,9109],{"class":3378,"line":6383},[3376,9098,9099],{"class":3393},"                    '100%'",[3376,9101,4493],{"class":4482},[3376,9103,4690],{"class":3397},[3376,9105,9088],{"class":4482},[3376,9107,9108],{"class":3393}," '1'",[3376,9110,9094],{"class":3397},[3376,9112,9113],{"class":3378,"line":6402},[3376,9114,8892],{"class":3397},[3376,9116,9117,9120],{"class":3378,"line":6420},[3376,9118,9119],{"class":4482},"                slideUp:",[3376,9121,3414],{"class":3397},[3376,9123,9124,9126,9128,9130,9133,9136,9138,9140,9142],{"class":3378,"line":6433},[3376,9125,9081],{"class":3393},[3376,9127,4493],{"class":4482},[3376,9129,4690],{"class":3397},[3376,9131,9132],{"class":4482},"transform:",[3376,9134,9135],{"class":3393}," 'translateY(20px)'",[3376,9137,3446],{"class":3397},[3376,9139,9088],{"class":4482},[3376,9141,9091],{"class":3393},[3376,9143,9094],{"class":3397},[3376,9145,9146,9148,9150,9152,9154,9157,9159,9161,9163],{"class":3378,"line":6438},[3376,9147,9099],{"class":3393},[3376,9149,4493],{"class":4482},[3376,9151,4690],{"class":3397},[3376,9153,9132],{"class":4482},[3376,9155,9156],{"class":3393}," 'translateY(0)'",[3376,9158,3446],{"class":3397},[3376,9160,9088],{"class":4482},[3376,9162,9108],{"class":3393},[3376,9164,9094],{"class":3397},[3376,9166,9167],{"class":3378,"line":6444},[3376,9168,8892],{"class":3397},[3376,9170,9171],{"class":3378,"line":6449},[3376,9172,5975],{"class":3397},[3376,9174,9175],{"class":3378,"line":6455},[3376,9176,5980],{"class":3397},[3376,9178,9179],{"class":3378,"line":6464},[3376,9180,3922],{"class":3397},[3376,9182,9183,9185],{"class":3378,"line":6473},[3376,9184,4483],{"class":4482},[3376,9186,4598],{"class":3397},[3376,9188,9189,9191,9193,9195],{"class":3378,"line":6478},[3376,9190,4616],{"class":3580},[3376,9192,3737],{"class":3397},[3376,9194,5999],{"class":3393},[3376,9196,4624],{"class":3397},[3376,9198,9199,9201,9203,9206],{"class":3378,"line":6484},[3376,9200,4616],{"class":3580},[3376,9202,3737],{"class":3397},[3376,9204,9205],{"class":3393},"'@tailwindcss\u002Fforms'",[3376,9207,4624],{"class":3397},[3376,9209,9210],{"class":3378,"line":6490},[3376,9211,4629],{"class":3397},[3376,9213,9214],{"class":3378,"line":6496},[3376,9215,3457],{"class":3397},[3353,9217,9218,9219,9221,9222,3446,9224,3446,9227,3503],{},"Результат — повноцінний ",[3357,9220,3635],{}," із ",[3357,9223,3411],{},[3357,9225,9226],{},"@keyframes",[3357,9228,6086],{},[3483,9230],{},[3353,9232,9233],{},[3362,9234,9235,9236,9238],{},"Завдання 2.2. ",[3357,9237,6667],{}," для компонентної бібліотеки.",[3353,9240,8654,9241,9243],{},[3357,9242,6681],{}," з набором кастомних утиліт:",[8650,9245,9246,9252,9258,9264,9270,9279],{},[3511,9247,9248,9251],{},[3357,9249,9250],{},"truncate-{1-6}"," — обрізання тексту до N рядків",[3511,9253,9254,9257],{},[3357,9255,9256],{},"glass"," — glassmorphism ефект (backdrop-filter)",[3511,9259,9260,9263],{},[3357,9261,9262],{},"container-{sm,md,lg,xl}"," — контейнер із різною максимальною шириною та fluid padding",[3511,9265,9266,9269],{},[3357,9267,9268],{},"hide-scrollbar"," — сховати scrollbar (cross-browser)",[3511,9271,9272,9275,9276],{},[3357,9273,9274],{},"text-balance"," — ",[3357,9277,9278],{},"text-wrap: balance",[3511,9280,9281,9275,9284],{},[3357,9282,9283],{},"clickable",[3357,9285,9286],{},"cursor-pointer + select-none + active:scale-95",[3353,9288,9289,9290,3446,9293,3446,9296,9299],{},"Переконайтеся, що всі утиліти підтримують ",[3357,9291,9292],{},"hover:",[3357,9294,9295],{},"dark:",[3357,9297,9298],{},"md:"," варіанти.",[8638,9301,9303,9308,9311,9317,9323,9483],{"label":9302},"Рівень 3: Архітектура — production проєкт",[3353,9304,9305],{},[3362,9306,9307],{},"Завдання 3.1. Повна структура CSS для великого проєкту.",[3353,9309,9310],{},"Організуйте CSS великого SaaS-застосунку за наступною структурою:",[3367,9312,9315],{"className":9313,"code":9314,"language":3624},[3622],"src\u002Fstyles\u002F\n├── main.css              ← точка входу: @import всього\n├── theme\u002F\n│   ├── primitives.css    ← @theme з кольорами\n│   ├── semantic.css      ← :root + .dark токени\n│   ├── typography.css    ← @theme з шрифтами + @font-face\n│   └── animations.css    ← @keyframes + @theme animate-*\n├── base\u002F\n│   ├── reset.css         ← @layer base: normalize\n│   └── global.css        ← @layer base: body, links, headings\n├── components\u002F\n│   ├── buttons.css       ← @utility btn-*, @layer components\n│   ├── cards.css\n│   ├── forms.css\n│   └── badges.css\n└── utilities\u002F\n    ├── layout.css        ← @utility container-*, grid-*\n    └── text.css          ← @utility truncate-*, text-*\n",[3357,9316,9314],{"__ignoreMap":3372},[3353,9318,9319,9320,4493],{},"Де ",[3357,9321,9322],{},"main.css",[3367,9324,9326],{"className":3369,"code":9325,"language":3371,"meta":3372,"style":3372},"@import \"tailwindcss\";\n\n\u002F* Теми *\u002F\n@import \".\u002Ftheme\u002Fprimitives.css\";\n@import \".\u002Ftheme\u002Fsemantic.css\";\n@import \".\u002Ftheme\u002Ftypography.css\";\n@import \".\u002Ftheme\u002Fanimations.css\";\n\n\u002F* База *\u002F\n@import \".\u002Fbase\u002Freset.css\";\n@import \".\u002Fbase\u002Fglobal.css\";\n\n\u002F* Компоненти *\u002F\n@import \".\u002Fcomponents\u002Fbuttons.css\";\n\u002F* ... *\u002F\n\n\u002F* Утиліти *\u002F\n@import \".\u002Futilities\u002Flayout.css\";\n\u002F* ... *\u002F\n\n\u002F* Плагіни *\u002F\n@plugin \"@tailwindcss\u002Ftypography\";\n\n\u002F* Варіанти *\u002F\n@custom-variant dark (&:is(.dark *));\n",[3357,9327,9328,9336,9340,9345,9354,9363,9372,9381,9385,9390,9399,9408,9412,9417,9426,9431,9435,9440,9449,9453,9457,9462,9468,9472,9477],{"__ignoreMap":3372},[3376,9329,9330,9332,9334],{"class":3378,"line":3379},[3376,9331,3390],{"class":3389},[3376,9333,3649],{"class":3393},[3376,9335,3398],{"class":3397},[3376,9337,9338],{"class":3378,"line":3386},[3376,9339,3405],{"emptyLinePlaceholder":3404},[3376,9341,9342],{"class":3378,"line":3401},[3376,9343,9344],{"class":3382},"\u002F* Теми *\u002F\n",[3376,9346,9347,9349,9352],{"class":3378,"line":3408},[3376,9348,3390],{"class":3389},[3376,9350,9351],{"class":3393}," \".\u002Ftheme\u002Fprimitives.css\"",[3376,9353,3398],{"class":3397},[3376,9355,9356,9358,9361],{"class":3378,"line":3417},[3376,9357,3390],{"class":3389},[3376,9359,9360],{"class":3393}," \".\u002Ftheme\u002Fsemantic.css\"",[3376,9362,3398],{"class":3397},[3376,9364,9365,9367,9370],{"class":3378,"line":3436},[3376,9366,3390],{"class":3389},[3376,9368,9369],{"class":3393}," \".\u002Ftheme\u002Ftypography.css\"",[3376,9371,3398],{"class":3397},[3376,9373,9374,9376,9379],{"class":3378,"line":3454},[3376,9375,3390],{"class":3389},[3376,9377,9378],{"class":3393}," \".\u002Ftheme\u002Fanimations.css\"",[3376,9380,3398],{"class":3397},[3376,9382,9383],{"class":3378,"line":3460},[3376,9384,3405],{"emptyLinePlaceholder":3404},[3376,9386,9387],{"class":3378,"line":3465},[3376,9388,9389],{"class":3382},"\u002F* База *\u002F\n",[3376,9391,9392,9394,9397],{"class":3378,"line":3701},[3376,9393,3390],{"class":3389},[3376,9395,9396],{"class":3393}," \".\u002Fbase\u002Freset.css\"",[3376,9398,3398],{"class":3397},[3376,9400,9401,9403,9406],{"class":3378,"line":3707},[3376,9402,3390],{"class":3389},[3376,9404,9405],{"class":3393}," \".\u002Fbase\u002Fglobal.css\"",[3376,9407,3398],{"class":3397},[3376,9409,9410],{"class":3378,"line":3716},[3376,9411,3405],{"emptyLinePlaceholder":3404},[3376,9413,9414],{"class":3378,"line":3724},[3376,9415,9416],{"class":3382},"\u002F* Компоненти *\u002F\n",[3376,9418,9419,9421,9424],{"class":3378,"line":3746},[3376,9420,3390],{"class":3389},[3376,9422,9423],{"class":3393}," \".\u002Fcomponents\u002Fbuttons.css\"",[3376,9425,3398],{"class":3397},[3376,9427,9428],{"class":3378,"line":3771},[3376,9429,9430],{"class":3382},"\u002F* ... *\u002F\n",[3376,9432,9433],{"class":3378,"line":3777},[3376,9434,3405],{"emptyLinePlaceholder":3404},[3376,9436,9437],{"class":3378,"line":4205},[3376,9438,9439],{"class":3382},"\u002F* Утиліти *\u002F\n",[3376,9441,9442,9444,9447],{"class":3378,"line":4215},[3376,9443,3390],{"class":3389},[3376,9445,9446],{"class":3393}," \".\u002Futilities\u002Flayout.css\"",[3376,9448,3398],{"class":3397},[3376,9450,9451],{"class":3378,"line":4230},[3376,9452,9430],{"class":3382},[3376,9454,9455],{"class":3378,"line":4238},[3376,9456,3405],{"emptyLinePlaceholder":3404},[3376,9458,9459],{"class":3378,"line":4244},[3376,9460,9461],{"class":3382},"\u002F* Плагіни *\u002F\n",[3376,9463,9464,9466],{"class":3378,"line":4253},[3376,9465,6086],{"class":3389},[3376,9467,6089],{"class":3397},[3376,9469,9470],{"class":3378,"line":4263},[3376,9471,3405],{"emptyLinePlaceholder":3404},[3376,9473,9474],{"class":3378,"line":4268},[3376,9475,9476],{"class":3382},"\u002F* Варіанти *\u002F\n",[3376,9478,9479,9481],{"class":3378,"line":4277},[3376,9480,3468],{"class":3389},[3376,9482,3471],{"class":3397},[3353,9484,9485],{},"Наповніть кожен файл реальним контентом (не заглушками). Загальний обсяг CSS — не менше 10 файлів із реальними стилями.",[3353,9487,9488],{},"::",[3483,9490],{},[3348,9492,9494],{"id":9493},"підсумок","Підсумок",[9496,9497,9498],"mermaid",{},[3367,9499,9502],{"className":9500,"code":9501,"language":9496,"meta":3372,"style":3372},"language-mermaid shiki shiki-themes light-plus dark-plus dark-plus","graph TD\n    A[\"Вибір методу підключення\"] --> B{Який проєкт?}\n    B --> C[\"Статичний HTML\"]\n    B --> D[\"Vite \u002F React \u002F Vue\"]\n    B --> E[\"Next.js\"]\n    B --> F[\"Nuxt 3\"]\n    B --> G[\"Прототип\"]\n\n    C --> C1[\"Tailwind CLI\\n@tailwindcss\u002Fcli\"]\n    D --> D1[\"Vite plugin\\n@tailwindcss\u002Fvite\"]\n    E --> E1[\"PostCSS plugin\\n@tailwindcss\u002Fpostcss\"]\n    F --> F1[\"Vite plugin\\n@tailwindcss\u002Fvite\"]\n    G --> G1[\"CDN\\ncdn.tailwindcss.com\"]\n\n    C1 & D1 & E1 & F1 --> H[\"CSS Entry Point\\nsrc\u002Finput.css або globals.css\"]\n    H --> I[\"@import 'tailwindcss'\"]\n    I --> J[\"@theme {...}\"]\n    I --> K[\"@custom-variant dark\"]\n    I --> L[\"@plugin '@tailwindcss\u002Ftypography'\"]\n    I --> M[\"@utility card {...}\"]\n",[3357,9503,9504,9509,9514,9519,9524,9529,9534,9539,9543,9548,9553,9558,9563,9568,9572,9577,9582,9587,9592,9597],{"__ignoreMap":3372},[3376,9505,9506],{"class":3378,"line":3379},[3376,9507,9508],{},"graph TD\n",[3376,9510,9511],{"class":3378,"line":3386},[3376,9512,9513],{},"    A[\"Вибір методу підключення\"] --> B{Який проєкт?}\n",[3376,9515,9516],{"class":3378,"line":3401},[3376,9517,9518],{},"    B --> C[\"Статичний HTML\"]\n",[3376,9520,9521],{"class":3378,"line":3408},[3376,9522,9523],{},"    B --> D[\"Vite \u002F React \u002F Vue\"]\n",[3376,9525,9526],{"class":3378,"line":3417},[3376,9527,9528],{},"    B --> E[\"Next.js\"]\n",[3376,9530,9531],{"class":3378,"line":3436},[3376,9532,9533],{},"    B --> F[\"Nuxt 3\"]\n",[3376,9535,9536],{"class":3378,"line":3454},[3376,9537,9538],{},"    B --> G[\"Прототип\"]\n",[3376,9540,9541],{"class":3378,"line":3460},[3376,9542,3405],{"emptyLinePlaceholder":3404},[3376,9544,9545],{"class":3378,"line":3465},[3376,9546,9547],{},"    C --> C1[\"Tailwind CLI\\n@tailwindcss\u002Fcli\"]\n",[3376,9549,9550],{"class":3378,"line":3701},[3376,9551,9552],{},"    D --> D1[\"Vite plugin\\n@tailwindcss\u002Fvite\"]\n",[3376,9554,9555],{"class":3378,"line":3707},[3376,9556,9557],{},"    E --> E1[\"PostCSS plugin\\n@tailwindcss\u002Fpostcss\"]\n",[3376,9559,9560],{"class":3378,"line":3716},[3376,9561,9562],{},"    F --> F1[\"Vite plugin\\n@tailwindcss\u002Fvite\"]\n",[3376,9564,9565],{"class":3378,"line":3724},[3376,9566,9567],{},"    G --> G1[\"CDN\\ncdn.tailwindcss.com\"]\n",[3376,9569,9570],{"class":3378,"line":3746},[3376,9571,3405],{"emptyLinePlaceholder":3404},[3376,9573,9574],{"class":3378,"line":3771},[3376,9575,9576],{},"    C1 & D1 & E1 & F1 --> H[\"CSS Entry Point\\nsrc\u002Finput.css або globals.css\"]\n",[3376,9578,9579],{"class":3378,"line":3777},[3376,9580,9581],{},"    H --> I[\"@import 'tailwindcss'\"]\n",[3376,9583,9584],{"class":3378,"line":4205},[3376,9585,9586],{},"    I --> J[\"@theme {...}\"]\n",[3376,9588,9589],{"class":3378,"line":4215},[3376,9590,9591],{},"    I --> K[\"@custom-variant dark\"]\n",[3376,9593,9594],{"class":3378,"line":4230},[3376,9595,9596],{},"    I --> L[\"@plugin '@tailwindcss\u002Ftypography'\"]\n",[3376,9598,9599],{"class":3378,"line":4238},[3376,9600,9601],{},"    I --> M[\"@utility card {...}\"]\n",[3353,9603,9604],{},"Ключові принципи налаштування Tailwind v4:",[9606,9607,9608,9625,9630,9637],"card-group",{},[9609,9610,9613,9615,9616,3446,9618,3446,9620,3446,9622,9624],"card",{"icon":9611,"title":9612},"i-heroicons-document-text","CSS — єдине джерело правди",[3357,9614,3359],{}," — минуле. Вся конфігурація: ",[3357,9617,3411],{},[3357,9619,6086],{},[3357,9621,3468],{},[3357,9623,6667],{}," — живе прямо у CSS-файлі.",[9609,9626,9629],{"icon":9627,"title":9628},"i-heroicons-trash","Purge не потрібен","v4 генерує тільки ті класи, що знайдені у файлах. Немає «включити всі класи і потім видалити зайві» — тільки те, що використовується.",[9609,9631,9634,9636],{"icon":9632,"title":9633},"i-heroicons-bolt","Vite — найшвидший шлях",[3357,9635,8726],{}," — найпродуктивніша інтеграція. HMR (hot module replacement) спрацьовує миттєво, навіть для великих проєктів.",[9609,9638,8662,9641,8665,9644,9646],{"icon":9639,"title":9640},"i-heroicons-sparkles","IntelliSense обов'язковий",[3357,9642,9643],{},"bradlc.vscode-tailwindcss",[3357,9645,8429],{},". Без автодоповнення та автосортування продуктивність різко падає.",[3483,9648],{},[3353,9650,9651],{},[9652,9653,9654,9655],"em",{},"Попередня стаття: ",[9656,9657,3327],"a",{"href":9658},"\u002F21.tailwind\u002F11.tailwind-animations-transforms",[7108,9660,9661],{},"html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .s8xlr, html code.shiki .s8xlr{--shiki-light:#AF00DB;--shiki-default:#C586C0;--shiki-dark:#C586C0}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sqdDX, html code.shiki .sqdDX{--shiki-light:#800000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sKtos, html code.shiki .sKtos{--shiki-light:#800000;--shiki-default:#569CD6;--shiki-dark:#569CD6}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sa4r_, html code.shiki .sa4r_{--shiki-light:#E50000;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .sLwNe, html code.shiki .sLwNe{--shiki-light:#0451A5;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .s0P7L, html code.shiki .s0P7L{--shiki-light:#800000;--shiki-default:#808080;--shiki-dark:#808080}html pre.shiki code .su9tN, html code.shiki .su9tN{--shiki-light:#0000FF;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .sN1BT, html code.shiki .sN1BT{--shiki-light:#267F99;--shiki-default:#4EC9B0;--shiki-dark:#4EC9B0}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .s-QsJ, html code.shiki .s-QsJ{--shiki-light:#0070C1;--shiki-default:#4FC1FF;--shiki-dark:#4FC1FF}html pre.shiki code .sD7JJ, html code.shiki .sD7JJ{--shiki-light:#000000FF;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sDUd3, html code.shiki .sDUd3{--shiki-light:#0451A5;--shiki-default:#CE9178;--shiki-dark:#CE9178}",{"title":3372,"searchDepth":3386,"depth":3386,"links":9663},[9664,9665,9671,9678,9688,9696,9697],{"id":3350,"depth":3386,"text":3351},{"id":3487,"depth":3386,"text":3488,"children":9666},[9667,9668,9669,9670],{"id":3492,"depth":3401,"text":3493},{"id":3557,"depth":3401,"text":3558},{"id":3964,"depth":3401,"text":3965},{"id":4296,"depth":3401,"text":4297},{"id":4412,"depth":3386,"text":4413,"children":9672},[9673,9674,9675,9676,9677],{"id":4416,"depth":3401,"text":4417},{"id":4646,"depth":3401,"text":4647},{"id":5162,"depth":3401,"text":5163},{"id":5511,"depth":3401,"text":5512},{"id":5716,"depth":3401,"text":5717},{"id":5842,"depth":3386,"text":9679,"children":9680},"Частина ІІІ. CSS-файл замість tailwind.config.js",[9681,9682,9684,9686],{"id":5848,"depth":3401,"text":5849},{"id":6094,"depth":3401,"text":9683},"3.2. @theme: повна анатомія",{"id":6515,"depth":3401,"text":9685},"3.3. @plugin: підключення офіційних плагінів",{"id":6663,"depth":3401,"text":9687},"3.4. @utility: власні утиліти",{"id":7861,"depth":3386,"text":7862,"children":9689},[9690,9691,9693,9694],{"id":7865,"depth":3401,"text":7866},{"id":7988,"depth":3401,"text":9692},"4.2. Оптимізація через @source",{"id":8186,"depth":3401,"text":8187},{"id":8425,"depth":3401,"text":9695},"4.4. prettier-plugin-tailwindcss: автосортування класів",{"id":8632,"depth":3386,"text":8633},{"id":9493,"depth":3386,"text":9494},"Вичерпний посібник із налаштування Tailwind CSS v4: Tailwind CLI, інтеграція з Vite, Next.js, Nuxt. PostCSS-конфігурація. CSS-entry point замість tailwind.config.js. Оптимізація збірки, purge та production-build. IntelliSense та інструменти розробника.","md",null,{},{"title":3331,"description":9698},"6jxZhI11ajkJP2rn9YoQ2kIrEuQxMrL0Bm_3uzdJ6fM",[9705,9707],{"title":3327,"path":3328,"stem":3329,"description":9706,"children":-1},"Вичерпний посібник з анімацій у Tailwind CSS v4: transition, animation, вбудовані keyframes, кастомні @keyframes. Повна система трансформацій: scale, rotate, translate, skew. Нові 3D-трансформації v4: perspective, rotate-x\u002Fy\u002Fz, backface-visible. Мікроанімації для UI.",{"title":3335,"path":3336,"stem":3337,"description":9708,"children":-1},"Тестування AsciiDiagram та BoxDiagram компонентів",1782371241050]