[{"data":1,"prerenderedAt":13855},["ShallowReactive",2],{"navigation_docs":3,"-tailwind-tailwind-arbitrary-container-queries":3338,"-tailwind-tailwind-arbitrary-container-queries-surround":13850},[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":3323,"body":3340,"description":13844,"extension":13845,"links":13846,"meta":13847,"navigation":3484,"path":3324,"seo":13848,"stem":3325,"__hash__":13849},"docs\u002F21.tailwind\u002F10.tailwind-arbitrary-container-queries.md",{"type":3341,"value":3342,"toc":13807},"minimark",[3343,3347,3352,3356,3368,3371,3400,3403,3407,3410,3416,3421,3424,3434,3437,3616,3619,3631,3633,3637,3640,3946,3948,3952,3955,4176,4245,4247,4263,4266,4451,4467,4470,4712,4714,4718,4729,4934,5653,5664,5666,5670,5673,5782,5785,5832,5843,5846,5964,5970,5972,5976,5979,6160,6162,6166,6169,6569,6584,6586,6593,6600,6613,6829,6831,6835,6845,7027,7220,7222,7226,7229,7387,7761,7763,7767,7771,7782,7785,7819,7826,7838,7926,7929,7931,7935,7942,7947,7952,8018,8021,8082,8099,8103,8113,8240,8242,8246,8252,8458,8468,8470,8480,8490,8502,8541,8552,8649,8662,8722,8727,8766,8768,8774,8777,10407,10409,10413,10416,10484,10587,10589,10593,10596,11082,13337,13478,13685,13688,13690,13694,13697,13706,13744,13751,13779,13786,13788,13804],[3344,3345,3323],"h1",{"id":3346},"довільні-значення-та-контейнерні-запити-у-tailwind-v4",[3348,3349,3351],"h2",{"id":3350},"вступ-коли-стандартних-класів-недостатньо","Вступ: коли стандартних класів недостатньо",[3353,3354,3355],"p",{},"Tailwind CSS постачається з ретельно підібраною дизайн-системою: фіксованими відступами, кольорами, розмірами шрифтів. У переважній більшості випадків ця система повністю задовольняє потреби проєкту. Але реальний веб складніший за будь-яку систему.",[3353,3357,3358,3359,3363,3364,3367],{},"Дизайнер передав макет із ",[3360,3361,3362],"code",{},"padding: 18px"," — значення, якого немає у Tailwind за замовчуванням. Замовник вимагає точний корпоративний колір ",[3360,3365,3366],{},"#C84B31",". Компонент картки має адаптуватися не до ширини екрана, а до ширини свого контейнера.",[3353,3369,3370],{},"Для всіх цих ситуацій Tailwind v4 надає два потужні механізми:",[3372,3373,3374,3390],"ol",{},[3375,3376,3377,3381,3382,3385,3386,3389],"li",{},[3378,3379,3380],"strong",{},"Довільні значення"," (Arbitrary Values) — синтаксис ",[3360,3383,3384],{},"[]"," та ",[3360,3387,3388],{},"()"," для точних CSS-значень прямо у класі.",[3375,3391,3392,3395,3396,3399],{},[3378,3393,3394],{},"Контейнерні запити"," (",[3360,3397,3398],{},"@container",") — вбудована підтримка (раніше потребувала плагіну), що дозволяє компонентам адаптуватися до розміру батьківського контейнера, а не вікна браузера.",[3353,3401,3402],{},"Обидва механізми є фундаментальними для production-розробки. Без них ви або «ламаєте» дизайн-систему заради зручності, або пишете тонни окремого CSS там, де могли б залишитися у HTML.",[3404,3405,3406],"note",{},"Матеріал цієї статті ґрунтується на знанні базових utility-класів (стаття 03), системи теми (стаття 05) та варіантів (стаття 06). Якщо ви ще не знайомі з ними — рекомендується спочатку прочитати їх.",[3408,3409],"hr",{},[3348,3411,3413,3414],{"id":3412},"частина-і-довільні-значення-синтаксис-квадратних-дужок","Частина І. Довільні значення: синтаксис квадратних дужок ",[3360,3415,3384],{},[3417,3418,3420],"h3",{"id":3419},"_11-основний-синтаксис","1.1. Основний синтаксис",[3353,3422,3423],{},"Будь-яка Tailwind-утиліта підтримує довільне значення у квадратних дужках замість стандартного:",[3425,3426,3431],"pre",{"className":3427,"code":3429,"language":3430},[3428],"language-text","{властивість}-[{довільне значення}]\n","text",[3360,3432,3429],{"__ignoreMap":3433},"",[3353,3435,3436],{},"Приклади:",[3425,3438,3442],{"className":3439,"code":3440,"language":3441,"meta":3433,"style":3433},"language-html shiki shiki-themes light-plus dark-plus dark-plus","\u003C!-- Замість стандартного p-4 (16px) — точно 18px -->\n\u003Cdiv class=\"p-[18px]\">\n\n\u003C!-- Корпоративний колір, якого немає у палітрі -->\n\u003Cdiv class=\"bg-[#C84B31]\">\n\n\u003C!-- Нестандартний розмір шрифту -->\n\u003Cp class=\"text-[13px]\">\n\n\u003C!-- Ширина у відсотках, яку не генерує Tailwind за замовчуванням -->\n\u003Cdiv class=\"w-[37.5%]\">\n\n\u003C!-- Позиція у top: рівно 3.75rem -->\n\u003Cdiv class=\"top-[3.75rem]\">\n\n\u003C!-- z-index будь-якого значення -->\n\u003Cdiv class=\"z-[999]\">\n","html",[3360,3443,3444,3453,3479,3486,3492,3508,3513,3519,3535,3540,3546,3562,3567,3573,3589,3594,3600],{"__ignoreMap":3433},[3445,3446,3449],"span",{"class":3447,"line":3448},"line",1,[3445,3450,3452],{"class":3451},"spJ8K","\u003C!-- Замість стандартного p-4 (16px) — точно 18px -->\n",[3445,3454,3456,3460,3464,3468,3472,3476],{"class":3447,"line":3455},2,[3445,3457,3459],{"class":3458},"s0P7L","\u003C",[3445,3461,3463],{"class":3462},"sKtos","div",[3445,3465,3467],{"class":3466},"sa4r_"," class",[3445,3469,3471],{"class":3470},"sHH4Y","=",[3445,3473,3475],{"class":3474},"su9tN","\"p-[18px]\"",[3445,3477,3478],{"class":3458},">\n",[3445,3480,3482],{"class":3447,"line":3481},3,[3445,3483,3485],{"emptyLinePlaceholder":3484},true,"\n",[3445,3487,3489],{"class":3447,"line":3488},4,[3445,3490,3491],{"class":3451},"\u003C!-- Корпоративний колір, якого немає у палітрі -->\n",[3445,3493,3495,3497,3499,3501,3503,3506],{"class":3447,"line":3494},5,[3445,3496,3459],{"class":3458},[3445,3498,3463],{"class":3462},[3445,3500,3467],{"class":3466},[3445,3502,3471],{"class":3470},[3445,3504,3505],{"class":3474},"\"bg-[#C84B31]\"",[3445,3507,3478],{"class":3458},[3445,3509,3511],{"class":3447,"line":3510},6,[3445,3512,3485],{"emptyLinePlaceholder":3484},[3445,3514,3516],{"class":3447,"line":3515},7,[3445,3517,3518],{"class":3451},"\u003C!-- Нестандартний розмір шрифту -->\n",[3445,3520,3522,3524,3526,3528,3530,3533],{"class":3447,"line":3521},8,[3445,3523,3459],{"class":3458},[3445,3525,3353],{"class":3462},[3445,3527,3467],{"class":3466},[3445,3529,3471],{"class":3470},[3445,3531,3532],{"class":3474},"\"text-[13px]\"",[3445,3534,3478],{"class":3458},[3445,3536,3538],{"class":3447,"line":3537},9,[3445,3539,3485],{"emptyLinePlaceholder":3484},[3445,3541,3543],{"class":3447,"line":3542},10,[3445,3544,3545],{"class":3451},"\u003C!-- Ширина у відсотках, яку не генерує Tailwind за замовчуванням -->\n",[3445,3547,3549,3551,3553,3555,3557,3560],{"class":3447,"line":3548},11,[3445,3550,3459],{"class":3458},[3445,3552,3463],{"class":3462},[3445,3554,3467],{"class":3466},[3445,3556,3471],{"class":3470},[3445,3558,3559],{"class":3474},"\"w-[37.5%]\"",[3445,3561,3478],{"class":3458},[3445,3563,3565],{"class":3447,"line":3564},12,[3445,3566,3485],{"emptyLinePlaceholder":3484},[3445,3568,3570],{"class":3447,"line":3569},13,[3445,3571,3572],{"class":3451},"\u003C!-- Позиція у top: рівно 3.75rem -->\n",[3445,3574,3576,3578,3580,3582,3584,3587],{"class":3447,"line":3575},14,[3445,3577,3459],{"class":3458},[3445,3579,3463],{"class":3462},[3445,3581,3467],{"class":3466},[3445,3583,3471],{"class":3470},[3445,3585,3586],{"class":3474},"\"top-[3.75rem]\"",[3445,3588,3478],{"class":3458},[3445,3590,3592],{"class":3447,"line":3591},15,[3445,3593,3485],{"emptyLinePlaceholder":3484},[3445,3595,3597],{"class":3447,"line":3596},16,[3445,3598,3599],{"class":3451},"\u003C!-- z-index будь-якого значення -->\n",[3445,3601,3603,3605,3607,3609,3611,3614],{"class":3447,"line":3602},17,[3445,3604,3459],{"class":3458},[3445,3606,3463],{"class":3462},[3445,3608,3467],{"class":3466},[3445,3610,3471],{"class":3470},[3445,3612,3613],{"class":3474},"\"z-[999]\"",[3445,3615,3478],{"class":3458},[3353,3617,3618],{},"Tailwind бере значення у дужках «як є» і підставляє у відповідну CSS-властивість. Ніякої магії — просто escape-люк з дизайн-системи.",[3620,3621,3622,3623,3626,3627,3630],"tip",{},"Довільні значення — це не «обхід» системи. Це інструмент для ",[3378,3624,3625],{},"точних поодиноких значень",", що не вписуються у шкалу. Якщо ви використовуєте одне й те саме довільне значення у 5+ місцях — це сигнал: варто додати його до ",[3360,3628,3629],{},"@theme",".",[3408,3632],{},[3417,3634,3636],{"id":3635},"_12-повна-таблиця-підтримуваних-типів-значень","1.2. Повна таблиця підтримуваних типів значень",[3353,3638,3639],{},"Практично кожна Tailwind-утиліта підтримує довільні значення:",[3641,3642,3643,3659],"table",{},[3644,3645,3646],"thead",{},[3647,3648,3649,3653,3656],"tr",{},[3650,3651,3652],"th",{},"Утиліта",[3650,3654,3655],{},"Приклад",[3650,3657,3658],{},"CSS",[3660,3661,3662,3685,3706,3727,3748,3766,3787,3802,3820,3838,3856,3874,3892,3910,3928],"tbody",{},[3647,3663,3664,3670,3682],{},[3665,3666,3667],"td",{},[3378,3668,3669],{},"Spacing",[3665,3671,3672,3675,3676,3675,3679],{},[3360,3673,3674],{},"p-[18px]",", ",[3360,3677,3678],{},"m-[1.75rem]",[3360,3680,3681],{},"gap-[11px]",[3665,3683,3684],{},"padding, margin, gap",[3647,3686,3687,3692,3703],{},[3665,3688,3689],{},[3378,3690,3691],{},"Sizing",[3665,3693,3694,3675,3697,3675,3700],{},[3360,3695,3696],{},"w-[200px]",[3360,3698,3699],{},"h-[calc(100vh-4rem)]",[3360,3701,3702],{},"min-w-[320px]",[3665,3704,3705],{},"width, height, min-width",[3647,3707,3708,3713,3724],{},[3665,3709,3710],{},[3378,3711,3712],{},"Colors",[3665,3714,3715,3675,3718,3675,3721],{},[3360,3716,3717],{},"bg-[#C84B31]",[3360,3719,3720],{},"text-[rgb(120,50,200)]",[3360,3722,3723],{},"border-[oklch(0.6 0.2 30)]",[3665,3725,3726],{},"background-color, color, border-color",[3647,3728,3729,3734,3745],{},[3665,3730,3731],{},[3378,3732,3733],{},"Typography",[3665,3735,3736,3675,3739,3675,3742],{},[3360,3737,3738],{},"text-[13px]",[3360,3740,3741],{},"text-[1.375rem]",[3360,3743,3744],{},"leading-[1.4]",[3665,3746,3747],{},"font-size, line-height",[3647,3749,3750,3755,3763],{},[3665,3751,3752],{},[3378,3753,3754],{},"Opacity",[3665,3756,3757,3675,3760],{},[3360,3758,3759],{},"opacity-[0.35]",[3360,3761,3762],{},"bg-blue-500\u002F[0.15]",[3665,3764,3765],{},"opacity, color alpha",[3647,3767,3768,3773,3784],{},[3665,3769,3770],{},[3378,3771,3772],{},"Border",[3665,3774,3775,3675,3778,3675,3781],{},[3360,3776,3777],{},"rounded-[6px]",[3360,3779,3780],{},"border-[3px]",[3360,3782,3783],{},"border-[#F00]",[3665,3785,3786],{},"border-radius, width, color",[3647,3788,3789,3794,3799],{},[3665,3790,3791],{},[3378,3792,3793],{},"Shadow",[3665,3795,3796],{},[3360,3797,3798],{},"shadow-[0_4px_30px_rgba(0,0,0,0.1)]",[3665,3800,3801],{},"box-shadow",[3647,3803,3804,3809,3817],{},[3665,3805,3806],{},[3378,3807,3808],{},"Position",[3665,3810,3811,3675,3814],{},[3360,3812,3813],{},"top-[3.75rem]",[3360,3815,3816],{},"left-[calc(50%-1rem)]",[3665,3818,3819],{},"top, left",[3647,3821,3822,3827,3835],{},[3665,3823,3824],{},[3378,3825,3826],{},"Z-index",[3665,3828,3829,3675,3832],{},[3360,3830,3831],{},"z-[100]",[3360,3833,3834],{},"z-[9999]",[3665,3836,3837],{},"z-index",[3647,3839,3840,3845,3853],{},[3665,3841,3842],{},[3378,3843,3844],{},"Grid",[3665,3846,3847,3675,3850],{},[3360,3848,3849],{},"grid-cols-[200px_1fr_auto]",[3360,3851,3852],{},"col-span-[7]",[3665,3854,3855],{},"grid-template-columns",[3647,3857,3858,3863,3871],{},[3665,3859,3860],{},[3378,3861,3862],{},"Transition",[3665,3864,3865,3675,3868],{},[3360,3866,3867],{},"duration-[350ms]",[3360,3869,3870],{},"delay-[50ms]",[3665,3872,3873],{},"transition-duration, delay",[3647,3875,3876,3881,3889],{},[3665,3877,3878],{},[3378,3879,3880],{},"Transform",[3665,3882,3883,3675,3886],{},[3360,3884,3885],{},"translate-x-[calc(-50%-1rem)]",[3360,3887,3888],{},"rotate-[33deg]",[3665,3890,3891],{},"transform",[3647,3893,3894,3899,3907],{},[3665,3895,3896],{},[3378,3897,3898],{},"Flex",[3665,3900,3901,3675,3904],{},[3360,3902,3903],{},"basis-[200px]",[3360,3905,3906],{},"grow-[2]",[3665,3908,3909],{},"flex-basis, flex-grow",[3647,3911,3912,3917,3925],{},[3665,3913,3914],{},[3378,3915,3916],{},"Filters",[3665,3918,3919,3675,3922],{},[3360,3920,3921],{},"blur-[2px]",[3360,3923,3924],{},"brightness-[0.85]",[3665,3926,3927],{},"filter",[3647,3929,3930,3935,3943],{},[3665,3931,3932],{},[3378,3933,3934],{},"Inset",[3665,3936,3937,3675,3940],{},[3360,3938,3939],{},"inset-[10%]",[3360,3941,3942],{},"inset-x-[2rem]",[3665,3944,3945],{},"inset",[3408,3947],{},[3417,3949,3951],{"id":3950},"_13-кольори-всі-формати","1.3. Кольори: всі формати",[3353,3953,3954],{},"У довільних значеннях підтримуються будь-які формати CSS-кольорів:",[3425,3956,3958],{"className":3439,"code":3957,"language":3441,"meta":3433,"style":3433},"\u003C!-- HEX -->\n\u003Cdiv class=\"bg-[#C84B31]\">\n\u003Cdiv class=\"bg-[#C84B3180]\"> \u003C!-- з прозорістю через HEX -->\n\n\u003C!-- RGB та RGBA -->\n\u003Cdiv class=\"bg-[rgb(200,75,49)]\">\n\u003Cdiv class=\"bg-[rgba(200,75,49,0.5)]\">\n\n\u003C!-- HSL -->\n\u003Cdiv class=\"bg-[hsl(12,61%,49%)]\">\n\u003Cdiv class=\"bg-[hsl(12_61%_49%)]\"> \u003C!-- сучасний синтаксис без ком -->\n\n\u003C!-- OKLCH — рекомендований у v4 -->\n\u003Cdiv class=\"bg-[oklch(0.55_0.22_25)]\">\n\n\u003C!-- Іменовані кольори (рідко, але допустимо) -->\n\u003Cdiv class=\"bg-[cornflowerblue]\">\n\n\u003C!-- Посилання на CSS Custom Property -->\n\u003Cdiv class=\"bg-[var(--brand-color)]\">\n\u003C!-- або короткий синтаксис v4: -->\n\u003Cdiv class=\"bg-(--brand-color)\">\n",[3360,3959,3960,3965,3979,3998,4002,4007,4022,4037,4041,4046,4061,4079,4083,4088,4103,4107,4112,4127,4132,4138,4154,4160],{"__ignoreMap":3433},[3445,3961,3962],{"class":3447,"line":3448},[3445,3963,3964],{"class":3451},"\u003C!-- HEX -->\n",[3445,3966,3967,3969,3971,3973,3975,3977],{"class":3447,"line":3455},[3445,3968,3459],{"class":3458},[3445,3970,3463],{"class":3462},[3445,3972,3467],{"class":3466},[3445,3974,3471],{"class":3470},[3445,3976,3505],{"class":3474},[3445,3978,3478],{"class":3458},[3445,3980,3981,3983,3985,3987,3989,3992,3995],{"class":3447,"line":3481},[3445,3982,3459],{"class":3458},[3445,3984,3463],{"class":3462},[3445,3986,3467],{"class":3466},[3445,3988,3471],{"class":3470},[3445,3990,3991],{"class":3474},"\"bg-[#C84B3180]\"",[3445,3993,3994],{"class":3458},">",[3445,3996,3997],{"class":3451}," \u003C!-- з прозорістю через HEX -->\n",[3445,3999,4000],{"class":3447,"line":3488},[3445,4001,3485],{"emptyLinePlaceholder":3484},[3445,4003,4004],{"class":3447,"line":3494},[3445,4005,4006],{"class":3451},"\u003C!-- RGB та RGBA -->\n",[3445,4008,4009,4011,4013,4015,4017,4020],{"class":3447,"line":3510},[3445,4010,3459],{"class":3458},[3445,4012,3463],{"class":3462},[3445,4014,3467],{"class":3466},[3445,4016,3471],{"class":3470},[3445,4018,4019],{"class":3474},"\"bg-[rgb(200,75,49)]\"",[3445,4021,3478],{"class":3458},[3445,4023,4024,4026,4028,4030,4032,4035],{"class":3447,"line":3515},[3445,4025,3459],{"class":3458},[3445,4027,3463],{"class":3462},[3445,4029,3467],{"class":3466},[3445,4031,3471],{"class":3470},[3445,4033,4034],{"class":3474},"\"bg-[rgba(200,75,49,0.5)]\"",[3445,4036,3478],{"class":3458},[3445,4038,4039],{"class":3447,"line":3521},[3445,4040,3485],{"emptyLinePlaceholder":3484},[3445,4042,4043],{"class":3447,"line":3537},[3445,4044,4045],{"class":3451},"\u003C!-- HSL -->\n",[3445,4047,4048,4050,4052,4054,4056,4059],{"class":3447,"line":3542},[3445,4049,3459],{"class":3458},[3445,4051,3463],{"class":3462},[3445,4053,3467],{"class":3466},[3445,4055,3471],{"class":3470},[3445,4057,4058],{"class":3474},"\"bg-[hsl(12,61%,49%)]\"",[3445,4060,3478],{"class":3458},[3445,4062,4063,4065,4067,4069,4071,4074,4076],{"class":3447,"line":3548},[3445,4064,3459],{"class":3458},[3445,4066,3463],{"class":3462},[3445,4068,3467],{"class":3466},[3445,4070,3471],{"class":3470},[3445,4072,4073],{"class":3474},"\"bg-[hsl(12_61%_49%)]\"",[3445,4075,3994],{"class":3458},[3445,4077,4078],{"class":3451}," \u003C!-- сучасний синтаксис без ком -->\n",[3445,4080,4081],{"class":3447,"line":3564},[3445,4082,3485],{"emptyLinePlaceholder":3484},[3445,4084,4085],{"class":3447,"line":3569},[3445,4086,4087],{"class":3451},"\u003C!-- OKLCH — рекомендований у v4 -->\n",[3445,4089,4090,4092,4094,4096,4098,4101],{"class":3447,"line":3575},[3445,4091,3459],{"class":3458},[3445,4093,3463],{"class":3462},[3445,4095,3467],{"class":3466},[3445,4097,3471],{"class":3470},[3445,4099,4100],{"class":3474},"\"bg-[oklch(0.55_0.22_25)]\"",[3445,4102,3478],{"class":3458},[3445,4104,4105],{"class":3447,"line":3591},[3445,4106,3485],{"emptyLinePlaceholder":3484},[3445,4108,4109],{"class":3447,"line":3596},[3445,4110,4111],{"class":3451},"\u003C!-- Іменовані кольори (рідко, але допустимо) -->\n",[3445,4113,4114,4116,4118,4120,4122,4125],{"class":3447,"line":3602},[3445,4115,3459],{"class":3458},[3445,4117,3463],{"class":3462},[3445,4119,3467],{"class":3466},[3445,4121,3471],{"class":3470},[3445,4123,4124],{"class":3474},"\"bg-[cornflowerblue]\"",[3445,4126,3478],{"class":3458},[3445,4128,4130],{"class":3447,"line":4129},18,[3445,4131,3485],{"emptyLinePlaceholder":3484},[3445,4133,4135],{"class":3447,"line":4134},19,[3445,4136,4137],{"class":3451},"\u003C!-- Посилання на CSS Custom Property -->\n",[3445,4139,4141,4143,4145,4147,4149,4152],{"class":3447,"line":4140},20,[3445,4142,3459],{"class":3458},[3445,4144,3463],{"class":3462},[3445,4146,3467],{"class":3466},[3445,4148,3471],{"class":3470},[3445,4150,4151],{"class":3474},"\"bg-[var(--brand-color)]\"",[3445,4153,3478],{"class":3458},[3445,4155,4157],{"class":3447,"line":4156},21,[3445,4158,4159],{"class":3451},"\u003C!-- або короткий синтаксис v4: -->\n",[3445,4161,4163,4165,4167,4169,4171,4174],{"class":3447,"line":4162},22,[3445,4164,3459],{"class":3458},[3445,4166,3463],{"class":3462},[3445,4168,3467],{"class":3466},[3445,4170,3471],{"class":3470},[3445,4172,4173],{"class":3474},"\"bg-(--brand-color)\"",[3445,4175,3478],{"class":3458},[4177,4178,4179,4190,4239],"warning",{},[3353,4180,4181,4182,4185,4186,4189],{},"Пробіли у довільних значеннях ",[3378,4183,4184],{},"заборонені"," — браузер не зможе розпізнати клас. Замість пробілів використовуйте підкреслення ",[3360,4187,4188],{},"_",":",[3425,4191,4193],{"className":3439,"code":4192,"language":3441,"meta":3433,"style":3433},"\u003C!-- ❌ Не працює: пробіл у значенні -->\n\u003Cdiv class=\"shadow-[0 4px 6px rgba(0,0,0,0.1)]\">\n\n\u003C!-- ✅ Правильно: підкреслення замість пробілів -->\n\u003Cdiv class=\"shadow-[0_4px_6px_rgba(0,0,0,0.1)]\">\n",[3360,4194,4195,4200,4215,4219,4224],{"__ignoreMap":3433},[3445,4196,4197],{"class":3447,"line":3448},[3445,4198,4199],{"class":3451},"\u003C!-- ❌ Не працює: пробіл у значенні -->\n",[3445,4201,4202,4204,4206,4208,4210,4213],{"class":3447,"line":3455},[3445,4203,3459],{"class":3458},[3445,4205,3463],{"class":3462},[3445,4207,3467],{"class":3466},[3445,4209,3471],{"class":3470},[3445,4211,4212],{"class":3474},"\"shadow-[0 4px 6px rgba(0,0,0,0.1)]\"",[3445,4214,3478],{"class":3458},[3445,4216,4217],{"class":3447,"line":3481},[3445,4218,3485],{"emptyLinePlaceholder":3484},[3445,4220,4221],{"class":3447,"line":3488},[3445,4222,4223],{"class":3451},"\u003C!-- ✅ Правильно: підкреслення замість пробілів -->\n",[3445,4225,4226,4228,4230,4232,4234,4237],{"class":3447,"line":3494},[3445,4227,3459],{"class":3458},[3445,4229,3463],{"class":3462},[3445,4231,3467],{"class":3466},[3445,4233,3471],{"class":3470},[3445,4235,4236],{"class":3474},"\"shadow-[0_4px_6px_rgba(0,0,0,0.1)]\"",[3445,4238,3478],{"class":3458},[3353,4240,4241,4242,4244],{},"Tailwind автоматично перетворює ",[3360,4243,4188],{}," на пробіл при генерації CSS.",[3408,4246],{},[3417,4248,4250,4251,3675,4254,3675,4257,3675,4260],{"id":4249},"_14-синтаксис-calc-min-max-clamp","1.4. Синтаксис ",[3360,4252,4253],{},"calc()",[3360,4255,4256],{},"min()",[3360,4258,4259],{},"max()",[3360,4261,4262],{},"clamp()",[3353,4264,4265],{},"CSS-функції прекрасно поєднуються з довільними значеннями:",[3425,4267,4269],{"className":3439,"code":4268,"language":3441,"meta":3433,"style":3433},"\u003C!-- calc(): розрахункові значення -->\n\u003Cdiv class=\"w-[calc(100%-2rem)]\">\n    \u003C!-- width: calc(100% - 2rem) -->\n\n\u003Cdiv class=\"h-[calc(100vh-4rem)]\">\n    \u003C!-- height: calc(100vh - 4rem) — часто для sticky layouts -->\n\n\u003Cdiv class=\"translate-x-[calc(-50%+1rem)]\">\n    \u003C!-- Центрування з компенсацією -->\n\n\u003C!-- min() \u002F max(): обмеження -->\n\u003Cdiv class=\"w-[min(100%,80rem)]\">\n    \u003C!-- width: min(100%, 80rem) — fluid + обмеження максимуму -->\n\n\u003Cdiv class=\"p-[max(1rem,3vw)]\">\n    \u003C!-- padding: max(1rem, 3vw) — мінімальний відступ із адаптивним ростом -->\n\n\u003C!-- clamp(): плавний діапазон -->\n\u003Cdiv class=\"text-[clamp(1rem,2.5vw,1.5rem)]\">\n    \u003C!-- font-size: clamp(1rem, 2.5vw, 1.5rem) — fluid typography -->\n\n\u003Cdiv class=\"w-[clamp(280px,50%,640px)]\">\n    \u003C!-- Fluid width: від 280px до 640px -->\n",[3360,4270,4271,4276,4291,4296,4300,4315,4320,4324,4339,4344,4348,4353,4368,4373,4377,4392,4397,4401,4406,4421,4426,4430,4445],{"__ignoreMap":3433},[3445,4272,4273],{"class":3447,"line":3448},[3445,4274,4275],{"class":3451},"\u003C!-- calc(): розрахункові значення -->\n",[3445,4277,4278,4280,4282,4284,4286,4289],{"class":3447,"line":3455},[3445,4279,3459],{"class":3458},[3445,4281,3463],{"class":3462},[3445,4283,3467],{"class":3466},[3445,4285,3471],{"class":3470},[3445,4287,4288],{"class":3474},"\"w-[calc(100%-2rem)]\"",[3445,4290,3478],{"class":3458},[3445,4292,4293],{"class":3447,"line":3481},[3445,4294,4295],{"class":3451},"    \u003C!-- width: calc(100% - 2rem) -->\n",[3445,4297,4298],{"class":3447,"line":3488},[3445,4299,3485],{"emptyLinePlaceholder":3484},[3445,4301,4302,4304,4306,4308,4310,4313],{"class":3447,"line":3494},[3445,4303,3459],{"class":3458},[3445,4305,3463],{"class":3462},[3445,4307,3467],{"class":3466},[3445,4309,3471],{"class":3470},[3445,4311,4312],{"class":3474},"\"h-[calc(100vh-4rem)]\"",[3445,4314,3478],{"class":3458},[3445,4316,4317],{"class":3447,"line":3510},[3445,4318,4319],{"class":3451},"    \u003C!-- height: calc(100vh - 4rem) — часто для sticky layouts -->\n",[3445,4321,4322],{"class":3447,"line":3515},[3445,4323,3485],{"emptyLinePlaceholder":3484},[3445,4325,4326,4328,4330,4332,4334,4337],{"class":3447,"line":3521},[3445,4327,3459],{"class":3458},[3445,4329,3463],{"class":3462},[3445,4331,3467],{"class":3466},[3445,4333,3471],{"class":3470},[3445,4335,4336],{"class":3474},"\"translate-x-[calc(-50%+1rem)]\"",[3445,4338,3478],{"class":3458},[3445,4340,4341],{"class":3447,"line":3537},[3445,4342,4343],{"class":3451},"    \u003C!-- Центрування з компенсацією -->\n",[3445,4345,4346],{"class":3447,"line":3542},[3445,4347,3485],{"emptyLinePlaceholder":3484},[3445,4349,4350],{"class":3447,"line":3548},[3445,4351,4352],{"class":3451},"\u003C!-- min() \u002F max(): обмеження -->\n",[3445,4354,4355,4357,4359,4361,4363,4366],{"class":3447,"line":3564},[3445,4356,3459],{"class":3458},[3445,4358,3463],{"class":3462},[3445,4360,3467],{"class":3466},[3445,4362,3471],{"class":3470},[3445,4364,4365],{"class":3474},"\"w-[min(100%,80rem)]\"",[3445,4367,3478],{"class":3458},[3445,4369,4370],{"class":3447,"line":3569},[3445,4371,4372],{"class":3451},"    \u003C!-- width: min(100%, 80rem) — fluid + обмеження максимуму -->\n",[3445,4374,4375],{"class":3447,"line":3575},[3445,4376,3485],{"emptyLinePlaceholder":3484},[3445,4378,4379,4381,4383,4385,4387,4390],{"class":3447,"line":3591},[3445,4380,3459],{"class":3458},[3445,4382,3463],{"class":3462},[3445,4384,3467],{"class":3466},[3445,4386,3471],{"class":3470},[3445,4388,4389],{"class":3474},"\"p-[max(1rem,3vw)]\"",[3445,4391,3478],{"class":3458},[3445,4393,4394],{"class":3447,"line":3596},[3445,4395,4396],{"class":3451},"    \u003C!-- padding: max(1rem, 3vw) — мінімальний відступ із адаптивним ростом -->\n",[3445,4398,4399],{"class":3447,"line":3602},[3445,4400,3485],{"emptyLinePlaceholder":3484},[3445,4402,4403],{"class":3447,"line":4129},[3445,4404,4405],{"class":3451},"\u003C!-- clamp(): плавний діапазон -->\n",[3445,4407,4408,4410,4412,4414,4416,4419],{"class":3447,"line":4134},[3445,4409,3459],{"class":3458},[3445,4411,3463],{"class":3462},[3445,4413,3467],{"class":3466},[3445,4415,3471],{"class":3470},[3445,4417,4418],{"class":3474},"\"text-[clamp(1rem,2.5vw,1.5rem)]\"",[3445,4420,3478],{"class":3458},[3445,4422,4423],{"class":3447,"line":4140},[3445,4424,4425],{"class":3451},"    \u003C!-- font-size: clamp(1rem, 2.5vw, 1.5rem) — fluid typography -->\n",[3445,4427,4428],{"class":3447,"line":4156},[3445,4429,3485],{"emptyLinePlaceholder":3484},[3445,4431,4432,4434,4436,4438,4440,4443],{"class":3447,"line":4162},[3445,4433,3459],{"class":3458},[3445,4435,3463],{"class":3462},[3445,4437,3467],{"class":3466},[3445,4439,3471],{"class":3470},[3445,4441,4442],{"class":3474},"\"w-[clamp(280px,50%,640px)]\"",[3445,4444,3478],{"class":3458},[3445,4446,4448],{"class":3447,"line":4447},23,[3445,4449,4450],{"class":3451},"    \u003C!-- Fluid width: від 280px до 640px -->\n",[3620,4452,4453,4455,4456,4459,4460,4463,4464,3630],{},[3360,4454,4262],{}," у поєднанні з ",[3360,4457,4458],{},"text-[...]"," дає ",[3378,4461,4462],{},"fluid typography"," — розмір тексту плавно масштабується між мінімальним та максимальним значеннями залежно від ширини вікна. Це елегантна альтернатива набору responsive-класів ",[3360,4465,4466],{},"text-sm md:text-base lg:text-lg",[3353,4468,4469],{},"Живий приклад fluid typography:",[4471,4472,4474],"html-preview",{":tailwind":4473},"true",[3425,4475,4477],{"className":3439,"code":4476,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"p-8 bg-white space-y-4\" style=\"font-family: system-ui, sans-serif;\">\n    \u003Cp class=\"text-xs font-bold uppercase tracking-widest text-slate-400 mb-2\">\n        Fluid Typography через clamp()\n    \u003C\u002Fp>\n\n    \u003C!-- Плавна адаптація від 14px до 22px залежно від ширини вікна -->\n    \u003Cp class=\"text-[clamp(14px,2.5vw,22px)] text-slate-800 leading-relaxed\">\n        Цей текст плавно масштабується: від 14px на вузьких екранах до 22px на широких.\n        Немає «стрибків» між breakpoints — розмір змінюється неперервно.\n    \u003C\u002Fp>\n\n    \u003C!-- Hero заголовок: від 2rem до 4.5rem -->\n    \u003Ch2 class=\"text-[clamp(2rem,5vw,4.5rem)] font-black tracking-tight text-slate-900 leading-none\">\n        Fluid Hero\n    \u003C\u002Fh2>\n\n    \u003C!-- Для порівняння — дискретні breakpoints (старий підхід) -->\n    \u003Cdiv class=\"border-t border-slate-100 pt-4\">\n        \u003Cp class=\"text-xs font-bold uppercase tracking-widest text-slate-400 mb-2\">\n            Для порівняння: дискретний підхід (text-sm md:text-base lg:text-xl)\n        \u003C\u002Fp>\n        \u003Cp class=\"text-sm md:text-base lg:text-xl text-slate-600\">\n            Цей текст «стрибає» між розмірами на breakpoints.\n        \u003C\u002Fp>\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,4478,4479,4502,4518,4523,4532,4536,4541,4556,4561,4566,4574,4578,4583,4598,4603,4611,4615,4620,4635,4650,4655,4664,4679,4684,4693,4702],{"__ignoreMap":3433},[3445,4480,4481,4483,4485,4487,4489,4492,4495,4497,4500],{"class":3447,"line":3448},[3445,4482,3459],{"class":3458},[3445,4484,3463],{"class":3462},[3445,4486,3467],{"class":3466},[3445,4488,3471],{"class":3470},[3445,4490,4491],{"class":3474},"\"p-8 bg-white space-y-4\"",[3445,4493,4494],{"class":3466}," style",[3445,4496,3471],{"class":3470},[3445,4498,4499],{"class":3474},"\"font-family: system-ui, sans-serif;\"",[3445,4501,3478],{"class":3458},[3445,4503,4504,4507,4509,4511,4513,4516],{"class":3447,"line":3455},[3445,4505,4506],{"class":3458},"    \u003C",[3445,4508,3353],{"class":3462},[3445,4510,3467],{"class":3466},[3445,4512,3471],{"class":3470},[3445,4514,4515],{"class":3474},"\"text-xs font-bold uppercase tracking-widest text-slate-400 mb-2\"",[3445,4517,3478],{"class":3458},[3445,4519,4520],{"class":3447,"line":3481},[3445,4521,4522],{"class":3470},"        Fluid Typography через clamp()\n",[3445,4524,4525,4528,4530],{"class":3447,"line":3488},[3445,4526,4527],{"class":3458},"    \u003C\u002F",[3445,4529,3353],{"class":3462},[3445,4531,3478],{"class":3458},[3445,4533,4534],{"class":3447,"line":3494},[3445,4535,3485],{"emptyLinePlaceholder":3484},[3445,4537,4538],{"class":3447,"line":3510},[3445,4539,4540],{"class":3451},"    \u003C!-- Плавна адаптація від 14px до 22px залежно від ширини вікна -->\n",[3445,4542,4543,4545,4547,4549,4551,4554],{"class":3447,"line":3515},[3445,4544,4506],{"class":3458},[3445,4546,3353],{"class":3462},[3445,4548,3467],{"class":3466},[3445,4550,3471],{"class":3470},[3445,4552,4553],{"class":3474},"\"text-[clamp(14px,2.5vw,22px)] text-slate-800 leading-relaxed\"",[3445,4555,3478],{"class":3458},[3445,4557,4558],{"class":3447,"line":3521},[3445,4559,4560],{"class":3470},"        Цей текст плавно масштабується: від 14px на вузьких екранах до 22px на широких.\n",[3445,4562,4563],{"class":3447,"line":3537},[3445,4564,4565],{"class":3470},"        Немає «стрибків» між breakpoints — розмір змінюється неперервно.\n",[3445,4567,4568,4570,4572],{"class":3447,"line":3542},[3445,4569,4527],{"class":3458},[3445,4571,3353],{"class":3462},[3445,4573,3478],{"class":3458},[3445,4575,4576],{"class":3447,"line":3548},[3445,4577,3485],{"emptyLinePlaceholder":3484},[3445,4579,4580],{"class":3447,"line":3564},[3445,4581,4582],{"class":3451},"    \u003C!-- Hero заголовок: від 2rem до 4.5rem -->\n",[3445,4584,4585,4587,4589,4591,4593,4596],{"class":3447,"line":3569},[3445,4586,4506],{"class":3458},[3445,4588,3348],{"class":3462},[3445,4590,3467],{"class":3466},[3445,4592,3471],{"class":3470},[3445,4594,4595],{"class":3474},"\"text-[clamp(2rem,5vw,4.5rem)] font-black tracking-tight text-slate-900 leading-none\"",[3445,4597,3478],{"class":3458},[3445,4599,4600],{"class":3447,"line":3575},[3445,4601,4602],{"class":3470},"        Fluid Hero\n",[3445,4604,4605,4607,4609],{"class":3447,"line":3591},[3445,4606,4527],{"class":3458},[3445,4608,3348],{"class":3462},[3445,4610,3478],{"class":3458},[3445,4612,4613],{"class":3447,"line":3596},[3445,4614,3485],{"emptyLinePlaceholder":3484},[3445,4616,4617],{"class":3447,"line":3602},[3445,4618,4619],{"class":3451},"    \u003C!-- Для порівняння — дискретні breakpoints (старий підхід) -->\n",[3445,4621,4622,4624,4626,4628,4630,4633],{"class":3447,"line":4129},[3445,4623,4506],{"class":3458},[3445,4625,3463],{"class":3462},[3445,4627,3467],{"class":3466},[3445,4629,3471],{"class":3470},[3445,4631,4632],{"class":3474},"\"border-t border-slate-100 pt-4\"",[3445,4634,3478],{"class":3458},[3445,4636,4637,4640,4642,4644,4646,4648],{"class":3447,"line":4134},[3445,4638,4639],{"class":3458},"        \u003C",[3445,4641,3353],{"class":3462},[3445,4643,3467],{"class":3466},[3445,4645,3471],{"class":3470},[3445,4647,4515],{"class":3474},[3445,4649,3478],{"class":3458},[3445,4651,4652],{"class":3447,"line":4140},[3445,4653,4654],{"class":3470},"            Для порівняння: дискретний підхід (text-sm md:text-base lg:text-xl)\n",[3445,4656,4657,4660,4662],{"class":3447,"line":4156},[3445,4658,4659],{"class":3458},"        \u003C\u002F",[3445,4661,3353],{"class":3462},[3445,4663,3478],{"class":3458},[3445,4665,4666,4668,4670,4672,4674,4677],{"class":3447,"line":4162},[3445,4667,4639],{"class":3458},[3445,4669,3353],{"class":3462},[3445,4671,3467],{"class":3466},[3445,4673,3471],{"class":3470},[3445,4675,4676],{"class":3474},"\"text-sm md:text-base lg:text-xl text-slate-600\"",[3445,4678,3478],{"class":3458},[3445,4680,4681],{"class":3447,"line":4447},[3445,4682,4683],{"class":3470},"            Цей текст «стрибає» між розмірами на breakpoints.\n",[3445,4685,4687,4689,4691],{"class":3447,"line":4686},24,[3445,4688,4659],{"class":3458},[3445,4690,3353],{"class":3462},[3445,4692,3478],{"class":3458},[3445,4694,4696,4698,4700],{"class":3447,"line":4695},25,[3445,4697,4527],{"class":3458},[3445,4699,3463],{"class":3462},[3445,4701,3478],{"class":3458},[3445,4703,4705,4708,4710],{"class":3447,"line":4704},26,[3445,4706,4707],{"class":3458},"\u003C\u002F",[3445,4709,3463],{"class":3462},[3445,4711,3478],{"class":3458},[3408,4713],{},[3417,4715,4717],{"id":4716},"_15-довільні-css-властивості","1.5. Довільні CSS-властивості",[3353,4719,4720,4721,4724,4725,4728],{},"Окрім довільних ",[3378,4722,4723],{},"значень"," для стандартних утиліт, Tailwind v4 підтримує повністю довільні ",[3378,4726,4727],{},"CSS-властивості"," — через синтаксис у квадратних дужках з повною назвою властивості:",[3425,4730,4732],{"className":3439,"code":4731,"language":3441,"meta":3433,"style":3433},"\u003C!-- Властивість, якої немає у Tailwind як утиліти -->\n\u003Cdiv class=\"[mask-image:linear-gradient(to_bottom,black,transparent)]\">\n\n\u003C!-- Кастомний scroll-behavior для конкретного елемента -->\n\u003Cdiv class=\"[scroll-snap-type:x_mandatory]\">\n\n\u003C!-- CSS Grid areas — складна сітка -->\n\u003Cdiv class=\"[grid-template-areas:'header_header'_'sidebar_main'_'footer_footer']\">\n\n\u003C!-- Accent color для form-елементів -->\n\u003Cinput type=\"checkbox\" class=\"[accent-color:oklch(0.585_0.233_277)]\">\n\n\u003C!-- content властивість для псевдоелементів -->\n\u003Cdiv class=\"before:content-['→'] before:mr-2\">\n\n\u003C!-- Writing mode для вертикального тексту -->\n\u003Cspan class=\"[writing-mode:vertical-lr] [text-orientation:mixed]\">\n    Вертикальний текст\n\u003C\u002Fspan>\n\n\u003C!-- Field sizing — нова CSS властивість (2024) -->\n\u003Ctextarea class=\"[field-sizing:content]\">\n    \u003C!-- Textarea автоматично росте з контентом -->\n\u003C\u002Ftextarea>\n",[3360,4733,4734,4739,4754,4758,4763,4778,4782,4787,4802,4806,4811,4835,4839,4844,4859,4863,4868,4883,4888,4896,4900,4905,4921,4926],{"__ignoreMap":3433},[3445,4735,4736],{"class":3447,"line":3448},[3445,4737,4738],{"class":3451},"\u003C!-- Властивість, якої немає у Tailwind як утиліти -->\n",[3445,4740,4741,4743,4745,4747,4749,4752],{"class":3447,"line":3455},[3445,4742,3459],{"class":3458},[3445,4744,3463],{"class":3462},[3445,4746,3467],{"class":3466},[3445,4748,3471],{"class":3470},[3445,4750,4751],{"class":3474},"\"[mask-image:linear-gradient(to_bottom,black,transparent)]\"",[3445,4753,3478],{"class":3458},[3445,4755,4756],{"class":3447,"line":3481},[3445,4757,3485],{"emptyLinePlaceholder":3484},[3445,4759,4760],{"class":3447,"line":3488},[3445,4761,4762],{"class":3451},"\u003C!-- Кастомний scroll-behavior для конкретного елемента -->\n",[3445,4764,4765,4767,4769,4771,4773,4776],{"class":3447,"line":3494},[3445,4766,3459],{"class":3458},[3445,4768,3463],{"class":3462},[3445,4770,3467],{"class":3466},[3445,4772,3471],{"class":3470},[3445,4774,4775],{"class":3474},"\"[scroll-snap-type:x_mandatory]\"",[3445,4777,3478],{"class":3458},[3445,4779,4780],{"class":3447,"line":3510},[3445,4781,3485],{"emptyLinePlaceholder":3484},[3445,4783,4784],{"class":3447,"line":3515},[3445,4785,4786],{"class":3451},"\u003C!-- CSS Grid areas — складна сітка -->\n",[3445,4788,4789,4791,4793,4795,4797,4800],{"class":3447,"line":3521},[3445,4790,3459],{"class":3458},[3445,4792,3463],{"class":3462},[3445,4794,3467],{"class":3466},[3445,4796,3471],{"class":3470},[3445,4798,4799],{"class":3474},"\"[grid-template-areas:'header_header'_'sidebar_main'_'footer_footer']\"",[3445,4801,3478],{"class":3458},[3445,4803,4804],{"class":3447,"line":3537},[3445,4805,3485],{"emptyLinePlaceholder":3484},[3445,4807,4808],{"class":3447,"line":3542},[3445,4809,4810],{"class":3451},"\u003C!-- Accent color для form-елементів -->\n",[3445,4812,4813,4815,4818,4821,4823,4826,4828,4830,4833],{"class":3447,"line":3548},[3445,4814,3459],{"class":3458},[3445,4816,4817],{"class":3462},"input",[3445,4819,4820],{"class":3466}," type",[3445,4822,3471],{"class":3470},[3445,4824,4825],{"class":3474},"\"checkbox\"",[3445,4827,3467],{"class":3466},[3445,4829,3471],{"class":3470},[3445,4831,4832],{"class":3474},"\"[accent-color:oklch(0.585_0.233_277)]\"",[3445,4834,3478],{"class":3458},[3445,4836,4837],{"class":3447,"line":3564},[3445,4838,3485],{"emptyLinePlaceholder":3484},[3445,4840,4841],{"class":3447,"line":3569},[3445,4842,4843],{"class":3451},"\u003C!-- content властивість для псевдоелементів -->\n",[3445,4845,4846,4848,4850,4852,4854,4857],{"class":3447,"line":3575},[3445,4847,3459],{"class":3458},[3445,4849,3463],{"class":3462},[3445,4851,3467],{"class":3466},[3445,4853,3471],{"class":3470},[3445,4855,4856],{"class":3474},"\"before:content-['→'] before:mr-2\"",[3445,4858,3478],{"class":3458},[3445,4860,4861],{"class":3447,"line":3591},[3445,4862,3485],{"emptyLinePlaceholder":3484},[3445,4864,4865],{"class":3447,"line":3596},[3445,4866,4867],{"class":3451},"\u003C!-- Writing mode для вертикального тексту -->\n",[3445,4869,4870,4872,4874,4876,4878,4881],{"class":3447,"line":3602},[3445,4871,3459],{"class":3458},[3445,4873,3445],{"class":3462},[3445,4875,3467],{"class":3466},[3445,4877,3471],{"class":3470},[3445,4879,4880],{"class":3474},"\"[writing-mode:vertical-lr] [text-orientation:mixed]\"",[3445,4882,3478],{"class":3458},[3445,4884,4885],{"class":3447,"line":4129},[3445,4886,4887],{"class":3470},"    Вертикальний текст\n",[3445,4889,4890,4892,4894],{"class":3447,"line":4134},[3445,4891,4707],{"class":3458},[3445,4893,3445],{"class":3462},[3445,4895,3478],{"class":3458},[3445,4897,4898],{"class":3447,"line":4140},[3445,4899,3485],{"emptyLinePlaceholder":3484},[3445,4901,4902],{"class":3447,"line":4156},[3445,4903,4904],{"class":3451},"\u003C!-- Field sizing — нова CSS властивість (2024) -->\n",[3445,4906,4907,4909,4912,4914,4916,4919],{"class":3447,"line":4162},[3445,4908,3459],{"class":3458},[3445,4910,4911],{"class":3462},"textarea",[3445,4913,3467],{"class":3466},[3445,4915,3471],{"class":3470},[3445,4917,4918],{"class":3474},"\"[field-sizing:content]\"",[3445,4920,3478],{"class":3458},[3445,4922,4923],{"class":3447,"line":4447},[3445,4924,4925],{"class":3451},"    \u003C!-- Textarea автоматично росте з контентом -->\n",[3445,4927,4928,4930,4932],{"class":3447,"line":4686},[3445,4929,4707],{"class":3458},[3445,4931,4911],{"class":3462},[3445,4933,3478],{"class":3458},[4471,4935,4936],{":tailwind":4473},[3425,4937,4939],{"className":3439,"code":4938,"language":3441,"meta":3433,"style":3433},"\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\u003C\u002Fhead>\n\u003Cbody class=\"p-6 bg-slate-50\" style=\"font-family: 'Inter', system-ui, sans-serif;\">\n    \u003Cdiv class=\"max-w-md mx-auto bg-white rounded-2xl border border-slate-200 p-6 shadow-sm space-y-6\">\n        \u003Cp class=\"text-xs font-bold text-slate-400 uppercase tracking-widest\">Arbitrary CSS Properties Sandbox\u003C\u002Fp>\n        \n        \u003C!-- Field Sizing Content -->\n        \u003Cdiv class=\"space-y-2\">\n            \u003Clabel class=\"block text-xs font-semibold text-slate-600\">Auto-growing Input [field-sizing:content]\u003C\u002Flabel>\n            \u003Cp class=\"text-[11px] text-slate-400\">Почніть вводити текст, і це поле автоматично розширюватиметься по вертикалі без скролбару:\u003C\u002Fp>\n            \u003Ctextarea class=\"[field-sizing:content] w-full min-h-[40px] px-3 py-2 border border-slate-300 focus:border-indigo-500 rounded-lg text-sm outline-none transition-colors resize-none\" placeholder=\"Введіть кілька абзаців тут...\">\u003C\u002Ftextarea>\n        \u003C\u002Fdiv>\n\n        \u003C!-- Writing Mode Vertical -->\n        \u003Cdiv class=\"space-y-3 pt-4 border-t border-slate-100\">\n            \u003Cdiv class=\"flex items-center justify-between\">\n                \u003Clabel class=\"block text-xs font-semibold text-slate-600\">Writing Mode [writing-mode:...]\u003C\u002Flabel>\n                \u003Cbutton onclick=\"toggleDirection()\" class=\"px-3 py-1 bg-slate-100 hover:bg-slate-200 text-slate-700 text-xs font-semibold rounded-lg transition-all\">\n                    Змінити режим\n                \u003C\u002Fbutton>\n            \u003C\u002Fdiv>\n            \n            \u003Cdiv class=\"h-40 flex items-center justify-center bg-slate-50 rounded-xl border border-slate-100 overflow-hidden\">\n                \u003Cspan id=\"writingText\" class=\"text-indigo-600 font-extrabold text-lg transition-all [writing-mode:vertical-lr] [text-orientation:mixed]\">\n                    Вертикальний текст\n                \u003C\u002Fspan>\n            \u003C\u002Fdiv>\n        \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n\n    \u003Cscript>\n        function toggleDirection() {\n            const txt = document.getElementById('writingText');\n            if (txt.classList.contains('[writing-mode:vertical-lr]')) {\n                txt.classList.remove('[writing-mode:vertical-lr]', '[text-orientation:mixed]');\n                txt.textContent = 'Горизонтальний текст';\n            } else {\n                txt.classList.add('[writing-mode:vertical-lr]', '[text-orientation:mixed]');\n                txt.textContent = 'Вертикальний текст';\n            }\n        }\n    \u003C\u002Fscript>\n\u003C\u002Fbody>\n\u003C\u002Fhtml>\n",[3360,4940,4941,4954,4970,4979,4996,5019,5044,5052,5075,5090,5114,5119,5124,5139,5165,5189,5216,5224,5228,5233,5248,5263,5287,5318,5323,5332,5341,5347,5363,5387,5393,5402,5411,5420,5429,5434,5443,5456,5488,5518,5544,5562,5574,5598,5614,5620,5626,5635,5644],{"__ignoreMap":3433},[3445,4942,4943,4946,4949,4952],{"class":3447,"line":3448},[3445,4944,4945],{"class":3458},"\u003C!",[3445,4947,4948],{"class":3462},"DOCTYPE",[3445,4950,4951],{"class":3466}," html",[3445,4953,3478],{"class":3458},[3445,4955,4956,4958,4960,4963,4965,4968],{"class":3447,"line":3455},[3445,4957,3459],{"class":3458},[3445,4959,3441],{"class":3462},[3445,4961,4962],{"class":3466}," lang",[3445,4964,3471],{"class":3470},[3445,4966,4967],{"class":3474},"\"uk\"",[3445,4969,3478],{"class":3458},[3445,4971,4972,4974,4977],{"class":3447,"line":3481},[3445,4973,3459],{"class":3458},[3445,4975,4976],{"class":3462},"head",[3445,4978,3478],{"class":3458},[3445,4980,4981,4983,4986,4989,4991,4994],{"class":3447,"line":3488},[3445,4982,3459],{"class":3458},[3445,4984,4985],{"class":3462},"meta",[3445,4987,4988],{"class":3466}," charset",[3445,4990,3471],{"class":3470},[3445,4992,4993],{"class":3474},"\"UTF-8\"",[3445,4995,3478],{"class":3458},[3445,4997,4998,5000,5003,5006,5009,5012,5015,5017],{"class":3447,"line":3494},[3445,4999,3459],{"class":3458},[3445,5001,5002],{"class":3462},"script",[3445,5004,5005],{"class":3466}," src",[3445,5007,3471],{"class":5008},"sD7JJ",[3445,5010,5011],{"class":3474},"\"https:\u002F\u002Fcdn.tailwindcss.com\"",[3445,5013,5014],{"class":3458},">\u003C\u002F",[3445,5016,5002],{"class":3462},[3445,5018,3478],{"class":3458},[3445,5020,5021,5023,5026,5029,5031,5034,5037,5039,5042],{"class":3447,"line":3510},[3445,5022,3459],{"class":3458},[3445,5024,5025],{"class":3462},"link",[3445,5027,5028],{"class":3466}," href",[3445,5030,3471],{"class":3470},[3445,5032,5033],{"class":3474},"\"https:\u002F\u002Ffonts.googleapis.com\u002Fcss2?family=Inter:wght@400;500;600;700&display=swap\"",[3445,5035,5036],{"class":3466}," rel",[3445,5038,3471],{"class":3470},[3445,5040,5041],{"class":3474},"\"stylesheet\"",[3445,5043,3478],{"class":3458},[3445,5045,5046,5048,5050],{"class":3447,"line":3515},[3445,5047,4707],{"class":3458},[3445,5049,4976],{"class":3462},[3445,5051,3478],{"class":3458},[3445,5053,5054,5056,5059,5061,5063,5066,5068,5070,5073],{"class":3447,"line":3521},[3445,5055,3459],{"class":3458},[3445,5057,5058],{"class":3462},"body",[3445,5060,3467],{"class":3466},[3445,5062,3471],{"class":3470},[3445,5064,5065],{"class":3474},"\"p-6 bg-slate-50\"",[3445,5067,4494],{"class":3466},[3445,5069,3471],{"class":3470},[3445,5071,5072],{"class":3474},"\"font-family: 'Inter', system-ui, sans-serif;\"",[3445,5074,3478],{"class":3458},[3445,5076,5077,5079,5081,5083,5085,5088],{"class":3447,"line":3537},[3445,5078,4506],{"class":3458},[3445,5080,3463],{"class":3462},[3445,5082,3467],{"class":3466},[3445,5084,3471],{"class":3470},[3445,5086,5087],{"class":3474},"\"max-w-md mx-auto bg-white rounded-2xl border border-slate-200 p-6 shadow-sm space-y-6\"",[3445,5089,3478],{"class":3458},[3445,5091,5092,5094,5096,5098,5100,5103,5105,5108,5110,5112],{"class":3447,"line":3542},[3445,5093,4639],{"class":3458},[3445,5095,3353],{"class":3462},[3445,5097,3467],{"class":3466},[3445,5099,3471],{"class":3470},[3445,5101,5102],{"class":3474},"\"text-xs font-bold text-slate-400 uppercase tracking-widest\"",[3445,5104,3994],{"class":3458},[3445,5106,5107],{"class":3470},"Arbitrary CSS Properties Sandbox",[3445,5109,4707],{"class":3458},[3445,5111,3353],{"class":3462},[3445,5113,3478],{"class":3458},[3445,5115,5116],{"class":3447,"line":3548},[3445,5117,5118],{"class":3470},"        \n",[3445,5120,5121],{"class":3447,"line":3564},[3445,5122,5123],{"class":3451},"        \u003C!-- Field Sizing Content -->\n",[3445,5125,5126,5128,5130,5132,5134,5137],{"class":3447,"line":3569},[3445,5127,4639],{"class":3458},[3445,5129,3463],{"class":3462},[3445,5131,3467],{"class":3466},[3445,5133,3471],{"class":3470},[3445,5135,5136],{"class":3474},"\"space-y-2\"",[3445,5138,3478],{"class":3458},[3445,5140,5141,5144,5147,5149,5151,5154,5156,5159,5161,5163],{"class":3447,"line":3575},[3445,5142,5143],{"class":3458},"            \u003C",[3445,5145,5146],{"class":3462},"label",[3445,5148,3467],{"class":3466},[3445,5150,3471],{"class":3470},[3445,5152,5153],{"class":3474},"\"block text-xs font-semibold text-slate-600\"",[3445,5155,3994],{"class":3458},[3445,5157,5158],{"class":3470},"Auto-growing Input [field-sizing:content]",[3445,5160,4707],{"class":3458},[3445,5162,5146],{"class":3462},[3445,5164,3478],{"class":3458},[3445,5166,5167,5169,5171,5173,5175,5178,5180,5183,5185,5187],{"class":3447,"line":3591},[3445,5168,5143],{"class":3458},[3445,5170,3353],{"class":3462},[3445,5172,3467],{"class":3466},[3445,5174,3471],{"class":3470},[3445,5176,5177],{"class":3474},"\"text-[11px] text-slate-400\"",[3445,5179,3994],{"class":3458},[3445,5181,5182],{"class":3470},"Почніть вводити текст, і це поле автоматично розширюватиметься по вертикалі без скролбару:",[3445,5184,4707],{"class":3458},[3445,5186,3353],{"class":3462},[3445,5188,3478],{"class":3458},[3445,5190,5191,5193,5195,5197,5199,5202,5205,5207,5210,5212,5214],{"class":3447,"line":3596},[3445,5192,5143],{"class":3458},[3445,5194,4911],{"class":3462},[3445,5196,3467],{"class":3466},[3445,5198,3471],{"class":3470},[3445,5200,5201],{"class":3474},"\"[field-sizing:content] w-full min-h-[40px] px-3 py-2 border border-slate-300 focus:border-indigo-500 rounded-lg text-sm outline-none transition-colors resize-none\"",[3445,5203,5204],{"class":3466}," placeholder",[3445,5206,3471],{"class":3470},[3445,5208,5209],{"class":3474},"\"Введіть кілька абзаців тут...\"",[3445,5211,5014],{"class":3458},[3445,5213,4911],{"class":3462},[3445,5215,3478],{"class":3458},[3445,5217,5218,5220,5222],{"class":3447,"line":3602},[3445,5219,4659],{"class":3458},[3445,5221,3463],{"class":3462},[3445,5223,3478],{"class":3458},[3445,5225,5226],{"class":3447,"line":4129},[3445,5227,3485],{"emptyLinePlaceholder":3484},[3445,5229,5230],{"class":3447,"line":4134},[3445,5231,5232],{"class":3451},"        \u003C!-- Writing Mode Vertical -->\n",[3445,5234,5235,5237,5239,5241,5243,5246],{"class":3447,"line":4140},[3445,5236,4639],{"class":3458},[3445,5238,3463],{"class":3462},[3445,5240,3467],{"class":3466},[3445,5242,3471],{"class":3470},[3445,5244,5245],{"class":3474},"\"space-y-3 pt-4 border-t border-slate-100\"",[3445,5247,3478],{"class":3458},[3445,5249,5250,5252,5254,5256,5258,5261],{"class":3447,"line":4156},[3445,5251,5143],{"class":3458},[3445,5253,3463],{"class":3462},[3445,5255,3467],{"class":3466},[3445,5257,3471],{"class":3470},[3445,5259,5260],{"class":3474},"\"flex items-center justify-between\"",[3445,5262,3478],{"class":3458},[3445,5264,5265,5268,5270,5272,5274,5276,5278,5281,5283,5285],{"class":3447,"line":4162},[3445,5266,5267],{"class":3458},"                \u003C",[3445,5269,5146],{"class":3462},[3445,5271,3467],{"class":3466},[3445,5273,3471],{"class":3470},[3445,5275,5153],{"class":3474},[3445,5277,3994],{"class":3458},[3445,5279,5280],{"class":3470},"Writing Mode [writing-mode:...]",[3445,5282,4707],{"class":3458},[3445,5284,5146],{"class":3462},[3445,5286,3478],{"class":3458},[3445,5288,5289,5291,5294,5297,5299,5302,5306,5309,5311,5313,5316],{"class":3447,"line":4447},[3445,5290,5267],{"class":3458},[3445,5292,5293],{"class":3462},"button",[3445,5295,5296],{"class":3466}," onclick",[3445,5298,3471],{"class":3470},[3445,5300,5301],{"class":3474},"\"",[3445,5303,5305],{"class":5304},"s8Opu","toggleDirection",[3445,5307,5308],{"class":3474},"()\"",[3445,5310,3467],{"class":3466},[3445,5312,3471],{"class":3470},[3445,5314,5315],{"class":3474},"\"px-3 py-1 bg-slate-100 hover:bg-slate-200 text-slate-700 text-xs font-semibold rounded-lg transition-all\"",[3445,5317,3478],{"class":3458},[3445,5319,5320],{"class":3447,"line":4686},[3445,5321,5322],{"class":3470},"                    Змінити режим\n",[3445,5324,5325,5328,5330],{"class":3447,"line":4695},[3445,5326,5327],{"class":3458},"                \u003C\u002F",[3445,5329,5293],{"class":3462},[3445,5331,3478],{"class":3458},[3445,5333,5334,5337,5339],{"class":3447,"line":4704},[3445,5335,5336],{"class":3458},"            \u003C\u002F",[3445,5338,3463],{"class":3462},[3445,5340,3478],{"class":3458},[3445,5342,5344],{"class":3447,"line":5343},27,[3445,5345,5346],{"class":3470},"            \n",[3445,5348,5350,5352,5354,5356,5358,5361],{"class":3447,"line":5349},28,[3445,5351,5143],{"class":3458},[3445,5353,3463],{"class":3462},[3445,5355,3467],{"class":3466},[3445,5357,3471],{"class":3470},[3445,5359,5360],{"class":3474},"\"h-40 flex items-center justify-center bg-slate-50 rounded-xl border border-slate-100 overflow-hidden\"",[3445,5362,3478],{"class":3458},[3445,5364,5366,5368,5370,5373,5375,5378,5380,5382,5385],{"class":3447,"line":5365},29,[3445,5367,5267],{"class":3458},[3445,5369,3445],{"class":3462},[3445,5371,5372],{"class":3466}," id",[3445,5374,3471],{"class":3470},[3445,5376,5377],{"class":3474},"\"writingText\"",[3445,5379,3467],{"class":3466},[3445,5381,3471],{"class":3470},[3445,5383,5384],{"class":3474},"\"text-indigo-600 font-extrabold text-lg transition-all [writing-mode:vertical-lr] [text-orientation:mixed]\"",[3445,5386,3478],{"class":3458},[3445,5388,5390],{"class":3447,"line":5389},30,[3445,5391,5392],{"class":3470},"                    Вертикальний текст\n",[3445,5394,5396,5398,5400],{"class":3447,"line":5395},31,[3445,5397,5327],{"class":3458},[3445,5399,3445],{"class":3462},[3445,5401,3478],{"class":3458},[3445,5403,5405,5407,5409],{"class":3447,"line":5404},32,[3445,5406,5336],{"class":3458},[3445,5408,3463],{"class":3462},[3445,5410,3478],{"class":3458},[3445,5412,5414,5416,5418],{"class":3447,"line":5413},33,[3445,5415,4659],{"class":3458},[3445,5417,3463],{"class":3462},[3445,5419,3478],{"class":3458},[3445,5421,5423,5425,5427],{"class":3447,"line":5422},34,[3445,5424,4527],{"class":3458},[3445,5426,3463],{"class":3462},[3445,5428,3478],{"class":3458},[3445,5430,5432],{"class":3447,"line":5431},35,[3445,5433,3485],{"emptyLinePlaceholder":3484},[3445,5435,5437,5439,5441],{"class":3447,"line":5436},36,[3445,5438,4506],{"class":3458},[3445,5440,5002],{"class":3462},[3445,5442,3478],{"class":3458},[3445,5444,5446,5450,5453],{"class":3447,"line":5445},37,[3445,5447,5449],{"class":5448},"su1O8","        function",[3445,5451,5452],{"class":5304}," toggleDirection",[3445,5454,5455],{"class":5008},"() {\n",[3445,5457,5459,5462,5466,5469,5473,5475,5478,5481,5485],{"class":3447,"line":5458},38,[3445,5460,5461],{"class":5448},"            const",[3445,5463,5465],{"class":5464},"s-QsJ"," txt",[3445,5467,5468],{"class":3470}," =",[3445,5470,5472],{"class":5471},"siwwj"," document",[3445,5474,3630],{"class":5008},[3445,5476,5477],{"class":5304},"getElementById",[3445,5479,5480],{"class":5008},"(",[3445,5482,5484],{"class":5483},"sbdoH","'writingText'",[3445,5486,5487],{"class":5008},");\n",[3445,5489,5491,5495,5497,5500,5502,5505,5507,5510,5512,5515],{"class":3447,"line":5490},39,[3445,5492,5494],{"class":5493},"s8xlr","            if",[3445,5496,3395],{"class":5008},[3445,5498,5499],{"class":5471},"txt",[3445,5501,3630],{"class":5008},[3445,5503,5504],{"class":5471},"classList",[3445,5506,3630],{"class":5008},[3445,5508,5509],{"class":5304},"contains",[3445,5511,5480],{"class":5008},[3445,5513,5514],{"class":5483},"'[writing-mode:vertical-lr]'",[3445,5516,5517],{"class":5008},")) {\n",[3445,5519,5521,5524,5526,5528,5530,5533,5535,5537,5539,5542],{"class":3447,"line":5520},40,[3445,5522,5523],{"class":5471},"                txt",[3445,5525,3630],{"class":5008},[3445,5527,5504],{"class":5471},[3445,5529,3630],{"class":5008},[3445,5531,5532],{"class":5304},"remove",[3445,5534,5480],{"class":5008},[3445,5536,5514],{"class":5483},[3445,5538,3675],{"class":5008},[3445,5540,5541],{"class":5483},"'[text-orientation:mixed]'",[3445,5543,5487],{"class":5008},[3445,5545,5547,5549,5551,5554,5556,5559],{"class":3447,"line":5546},41,[3445,5548,5523],{"class":5471},[3445,5550,3630],{"class":5008},[3445,5552,5553],{"class":5471},"textContent",[3445,5555,5468],{"class":3470},[3445,5557,5558],{"class":5483}," 'Горизонтальний текст'",[3445,5560,5561],{"class":5008},";\n",[3445,5563,5565,5568,5571],{"class":3447,"line":5564},42,[3445,5566,5567],{"class":5008},"            } ",[3445,5569,5570],{"class":5493},"else",[3445,5572,5573],{"class":5008}," {\n",[3445,5575,5577,5579,5581,5583,5585,5588,5590,5592,5594,5596],{"class":3447,"line":5576},43,[3445,5578,5523],{"class":5471},[3445,5580,3630],{"class":5008},[3445,5582,5504],{"class":5471},[3445,5584,3630],{"class":5008},[3445,5586,5587],{"class":5304},"add",[3445,5589,5480],{"class":5008},[3445,5591,5514],{"class":5483},[3445,5593,3675],{"class":5008},[3445,5595,5541],{"class":5483},[3445,5597,5487],{"class":5008},[3445,5599,5601,5603,5605,5607,5609,5612],{"class":3447,"line":5600},44,[3445,5602,5523],{"class":5471},[3445,5604,3630],{"class":5008},[3445,5606,5553],{"class":5471},[3445,5608,5468],{"class":3470},[3445,5610,5611],{"class":5483}," 'Вертикальний текст'",[3445,5613,5561],{"class":5008},[3445,5615,5617],{"class":3447,"line":5616},45,[3445,5618,5619],{"class":5008},"            }\n",[3445,5621,5623],{"class":3447,"line":5622},46,[3445,5624,5625],{"class":5008},"        }\n",[3445,5627,5629,5631,5633],{"class":3447,"line":5628},47,[3445,5630,4527],{"class":3458},[3445,5632,5002],{"class":3462},[3445,5634,3478],{"class":3458},[3445,5636,5638,5640,5642],{"class":3447,"line":5637},48,[3445,5639,4707],{"class":3458},[3445,5641,5058],{"class":3462},[3445,5643,3478],{"class":3458},[3445,5645,5647,5649,5651],{"class":3447,"line":5646},49,[3445,5648,4707],{"class":3458},[3445,5650,3441],{"class":3462},[3445,5652,3478],{"class":3458},[3404,5654,5655,5656,5659,5660,5663],{},"Синтаксис ",[3360,5657,5658],{},"[property:value]"," дає доступ до ",[3378,5661,5662],{},"будь-якої CSS-властивості"," — навіть найновіших, що ще не мають утиліт у Tailwind. Це робить вас незалежними від версій Tailwind при роботі з новими CSS-можливостями.",[3408,5665],{},[3417,5667,5669],{"id":5668},"_16-новий-синтаксис-v4-круглі-дужки-для-css-змінних","1.6. Новий синтаксис v4: круглі дужки для CSS-змінних",[3353,5671,5672],{},"У Tailwind v4 введено скорочений синтаксис для значень, що є CSS Custom Properties:",[3425,5674,5676],{"className":3439,"code":5675,"language":3441,"meta":3433,"style":3433},"\u003C!-- Старий синтаксис (все ще працює) -->\n\u003Cdiv class=\"bg-[var(--color-brand)]\">\n\u003Cdiv class=\"text-[var(--font-size-hero)]\">\n\u003Cdiv class=\"p-[var(--spacing-section)]\">\n\n\u003C!-- Новий синтаксис v4 — коротший та читабельніший -->\n\u003Cdiv class=\"bg-(--color-brand)\">\n\u003Cdiv class=\"text-(--font-size-hero)\">\n\u003Cdiv class=\"p-(--spacing-section)\">\n",[3360,5677,5678,5683,5698,5713,5728,5732,5737,5752,5767],{"__ignoreMap":3433},[3445,5679,5680],{"class":3447,"line":3448},[3445,5681,5682],{"class":3451},"\u003C!-- Старий синтаксис (все ще працює) -->\n",[3445,5684,5685,5687,5689,5691,5693,5696],{"class":3447,"line":3455},[3445,5686,3459],{"class":3458},[3445,5688,3463],{"class":3462},[3445,5690,3467],{"class":3466},[3445,5692,3471],{"class":3470},[3445,5694,5695],{"class":3474},"\"bg-[var(--color-brand)]\"",[3445,5697,3478],{"class":3458},[3445,5699,5700,5702,5704,5706,5708,5711],{"class":3447,"line":3481},[3445,5701,3459],{"class":3458},[3445,5703,3463],{"class":3462},[3445,5705,3467],{"class":3466},[3445,5707,3471],{"class":3470},[3445,5709,5710],{"class":3474},"\"text-[var(--font-size-hero)]\"",[3445,5712,3478],{"class":3458},[3445,5714,5715,5717,5719,5721,5723,5726],{"class":3447,"line":3488},[3445,5716,3459],{"class":3458},[3445,5718,3463],{"class":3462},[3445,5720,3467],{"class":3466},[3445,5722,3471],{"class":3470},[3445,5724,5725],{"class":3474},"\"p-[var(--spacing-section)]\"",[3445,5727,3478],{"class":3458},[3445,5729,5730],{"class":3447,"line":3494},[3445,5731,3485],{"emptyLinePlaceholder":3484},[3445,5733,5734],{"class":3447,"line":3510},[3445,5735,5736],{"class":3451},"\u003C!-- Новий синтаксис v4 — коротший та читабельніший -->\n",[3445,5738,5739,5741,5743,5745,5747,5750],{"class":3447,"line":3515},[3445,5740,3459],{"class":3458},[3445,5742,3463],{"class":3462},[3445,5744,3467],{"class":3466},[3445,5746,3471],{"class":3470},[3445,5748,5749],{"class":3474},"\"bg-(--color-brand)\"",[3445,5751,3478],{"class":3458},[3445,5753,5754,5756,5758,5760,5762,5765],{"class":3447,"line":3521},[3445,5755,3459],{"class":3458},[3445,5757,3463],{"class":3462},[3445,5759,3467],{"class":3466},[3445,5761,3471],{"class":3470},[3445,5763,5764],{"class":3474},"\"text-(--font-size-hero)\"",[3445,5766,3478],{"class":3458},[3445,5768,5769,5771,5773,5775,5777,5780],{"class":3447,"line":3537},[3445,5770,3459],{"class":3458},[3445,5772,3463],{"class":3462},[3445,5774,3467],{"class":3466},[3445,5776,3471],{"class":3470},[3445,5778,5779],{"class":3474},"\"p-(--spacing-section)\"",[3445,5781,3478],{"class":3458},[3353,5783,5784],{},"Обидва записи генерують однаковий CSS:",[3425,5786,5790],{"className":5787,"code":5788,"language":5789,"meta":3433,"style":3433},"language-css shiki shiki-themes light-plus dark-plus dark-plus",".bg-\\(--color-brand\\) {\n    background-color: var(--color-brand);\n}\n","css",[3360,5791,5792,5810,5827],{"__ignoreMap":3433},[3445,5793,5794,5798,5802,5805,5808],{"class":3447,"line":3448},[3445,5795,5797],{"class":5796},"sqdDX",".bg-",[3445,5799,5801],{"class":5800},"sjcCO","\\(",[3445,5803,5804],{"class":5796},"--color-brand",[3445,5806,5807],{"class":5800},"\\)",[3445,5809,5573],{"class":3470},[3445,5811,5812,5815,5818,5821,5823,5825],{"class":3447,"line":3455},[3445,5813,5814],{"class":3466},"    background-color",[3445,5816,5817],{"class":3470},": ",[3445,5819,5820],{"class":5304},"var",[3445,5822,5480],{"class":3470},[3445,5824,5804],{"class":3466},[3445,5826,5487],{"class":3470},[3445,5828,5829],{"class":3447,"line":3481},[3445,5830,5831],{"class":3470},"}\n",[3353,5833,5834,5835,5838,5839,5842],{},"Новий синтаксис ",[3360,5836,5837],{},"(--var)"," є ",[3378,5840,5841],{},"рекомендованим"," у v4 — він коротший і розрізняє CSS-змінні від довільних literal-значень у квадратних дужках.",[3353,5844,5845],{},"Де це особливо корисно:",[3425,5847,5849],{"className":3439,"code":5848,"language":3441,"meta":3433,"style":3433},"\u003C!-- Система дизайн-токенів: скрізь де використовуються семантичні токени -->\n\u003Cdiv class=\"bg-(--color-bg-surface)\n            text-(--color-text-primary)\n            border border-(--color-border-default)\n            p-(--spacing-card)\">\n\n\u003C!-- Компоненти з кастомними CSS-змінними -->\n\u003Cdiv class=\"grid\"\n     style=\"--cols: 3\"\n     class=\"grid-cols-(--cols)\">\n\n\u003C!-- Анімації з CSS-змінними -->\n\u003Cdiv class=\"transition-[color,background-color]\n            duration-(--duration-fast)\n            ease-(--ease-spring)\">\n",[3360,5850,5851,5856,5869,5874,5879,5886,5890,5895,5908,5918,5930,5934,5939,5952,5957],{"__ignoreMap":3433},[3445,5852,5853],{"class":3447,"line":3448},[3445,5854,5855],{"class":3451},"\u003C!-- Система дизайн-токенів: скрізь де використовуються семантичні токени -->\n",[3445,5857,5858,5860,5862,5864,5866],{"class":3447,"line":3455},[3445,5859,3459],{"class":3458},[3445,5861,3463],{"class":3462},[3445,5863,3467],{"class":3466},[3445,5865,3471],{"class":3470},[3445,5867,5868],{"class":3474},"\"bg-(--color-bg-surface)\n",[3445,5870,5871],{"class":3447,"line":3481},[3445,5872,5873],{"class":3474},"            text-(--color-text-primary)\n",[3445,5875,5876],{"class":3447,"line":3488},[3445,5877,5878],{"class":3474},"            border border-(--color-border-default)\n",[3445,5880,5881,5884],{"class":3447,"line":3494},[3445,5882,5883],{"class":3474},"            p-(--spacing-card)\"",[3445,5885,3478],{"class":3458},[3445,5887,5888],{"class":3447,"line":3510},[3445,5889,3485],{"emptyLinePlaceholder":3484},[3445,5891,5892],{"class":3447,"line":3515},[3445,5893,5894],{"class":3451},"\u003C!-- Компоненти з кастомними CSS-змінними -->\n",[3445,5896,5897,5899,5901,5903,5905],{"class":3447,"line":3521},[3445,5898,3459],{"class":3458},[3445,5900,3463],{"class":3462},[3445,5902,3467],{"class":3466},[3445,5904,3471],{"class":3470},[3445,5906,5907],{"class":3474},"\"grid\"\n",[3445,5909,5910,5913,5915],{"class":3447,"line":3537},[3445,5911,5912],{"class":3466},"     style",[3445,5914,3471],{"class":3470},[3445,5916,5917],{"class":3474},"\"--cols: 3\"\n",[3445,5919,5920,5923,5925,5928],{"class":3447,"line":3542},[3445,5921,5922],{"class":3466},"     class",[3445,5924,3471],{"class":3470},[3445,5926,5927],{"class":3474},"\"grid-cols-(--cols)\"",[3445,5929,3478],{"class":3458},[3445,5931,5932],{"class":3447,"line":3548},[3445,5933,3485],{"emptyLinePlaceholder":3484},[3445,5935,5936],{"class":3447,"line":3564},[3445,5937,5938],{"class":3451},"\u003C!-- Анімації з CSS-змінними -->\n",[3445,5940,5941,5943,5945,5947,5949],{"class":3447,"line":3569},[3445,5942,3459],{"class":3458},[3445,5944,3463],{"class":3462},[3445,5946,3467],{"class":3466},[3445,5948,3471],{"class":3470},[3445,5950,5951],{"class":3474},"\"transition-[color,background-color]\n",[3445,5953,5954],{"class":3447,"line":3575},[3445,5955,5956],{"class":3474},"            duration-(--duration-fast)\n",[3445,5958,5959,5962],{"class":3447,"line":3591},[3445,5960,5961],{"class":3474},"            ease-(--ease-spring)\"",[3445,5963,3478],{"class":3458},[3620,5965,5966,5967,5969],{},"Для систем дизайн-токенів (розглянутих у статті 09) синтаксис ",[3360,5968,5837],{}," є особливо цінним: він робить HTML-код лаконічним і одразу показує, що значення береться з системи токенів, а не є «магічним числом».",[3408,5971],{},[3417,5973,5975],{"id":5974},"_17-поєднання-довільних-значень-із-варіантами","1.7. Поєднання довільних значень із варіантами",[3353,5977,5978],{},"Довільні значення повністю сумісні з усіма варіантами Tailwind:",[3425,5980,5982],{"className":3439,"code":5981,"language":3441,"meta":3433,"style":3433},"\u003C!-- hover: + довільний колір -->\n\u003Cbutton class=\"bg-[#C84B31] hover:bg-[#A53926]\">\n\n\u003C!-- dark: + довільне значення -->\n\u003Cdiv class=\"bg-[#fafaf9] dark:bg-[#1a1a2e]\">\n\n\u003C!-- responsive: + довільний розмір -->\n\u003Cdiv class=\"w-[280px] md:w-[400px] lg:w-[clamp(400px,50%,600px)]\">\n\n\u003C!-- group-hover: + довільне перетворення -->\n\u003Cdiv class=\"group\">\n    \u003Cdiv class=\"translate-y-[2px] group-hover:translate-y-[-4px] transition-transform duration-200\">\n        Підіймається при hover на батьку\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n\n\u003C!-- focus: + довільна рамка -->\n\u003Cinput class=\"focus:ring-[3px] focus:ring-[#C84B31]\u002F30 focus:border-[#C84B31]\">\n\n\u003C!-- Мобільний стрибок + fluid на десктопі -->\n\u003Ch1 class=\"text-[2rem] md:text-[clamp(2.5rem,5vw,5rem)]\">\n",[3360,5983,5984,5989,6004,6008,6013,6028,6032,6037,6052,6056,6061,6076,6091,6096,6104,6112,6116,6121,6136,6140,6145],{"__ignoreMap":3433},[3445,5985,5986],{"class":3447,"line":3448},[3445,5987,5988],{"class":3451},"\u003C!-- hover: + довільний колір -->\n",[3445,5990,5991,5993,5995,5997,5999,6002],{"class":3447,"line":3455},[3445,5992,3459],{"class":3458},[3445,5994,5293],{"class":3462},[3445,5996,3467],{"class":3466},[3445,5998,3471],{"class":3470},[3445,6000,6001],{"class":3474},"\"bg-[#C84B31] hover:bg-[#A53926]\"",[3445,6003,3478],{"class":3458},[3445,6005,6006],{"class":3447,"line":3481},[3445,6007,3485],{"emptyLinePlaceholder":3484},[3445,6009,6010],{"class":3447,"line":3488},[3445,6011,6012],{"class":3451},"\u003C!-- dark: + довільне значення -->\n",[3445,6014,6015,6017,6019,6021,6023,6026],{"class":3447,"line":3494},[3445,6016,3459],{"class":3458},[3445,6018,3463],{"class":3462},[3445,6020,3467],{"class":3466},[3445,6022,3471],{"class":3470},[3445,6024,6025],{"class":3474},"\"bg-[#fafaf9] dark:bg-[#1a1a2e]\"",[3445,6027,3478],{"class":3458},[3445,6029,6030],{"class":3447,"line":3510},[3445,6031,3485],{"emptyLinePlaceholder":3484},[3445,6033,6034],{"class":3447,"line":3515},[3445,6035,6036],{"class":3451},"\u003C!-- responsive: + довільний розмір -->\n",[3445,6038,6039,6041,6043,6045,6047,6050],{"class":3447,"line":3521},[3445,6040,3459],{"class":3458},[3445,6042,3463],{"class":3462},[3445,6044,3467],{"class":3466},[3445,6046,3471],{"class":3470},[3445,6048,6049],{"class":3474},"\"w-[280px] md:w-[400px] lg:w-[clamp(400px,50%,600px)]\"",[3445,6051,3478],{"class":3458},[3445,6053,6054],{"class":3447,"line":3537},[3445,6055,3485],{"emptyLinePlaceholder":3484},[3445,6057,6058],{"class":3447,"line":3542},[3445,6059,6060],{"class":3451},"\u003C!-- group-hover: + довільне перетворення -->\n",[3445,6062,6063,6065,6067,6069,6071,6074],{"class":3447,"line":3548},[3445,6064,3459],{"class":3458},[3445,6066,3463],{"class":3462},[3445,6068,3467],{"class":3466},[3445,6070,3471],{"class":3470},[3445,6072,6073],{"class":3474},"\"group\"",[3445,6075,3478],{"class":3458},[3445,6077,6078,6080,6082,6084,6086,6089],{"class":3447,"line":3564},[3445,6079,4506],{"class":3458},[3445,6081,3463],{"class":3462},[3445,6083,3467],{"class":3466},[3445,6085,3471],{"class":3470},[3445,6087,6088],{"class":3474},"\"translate-y-[2px] group-hover:translate-y-[-4px] transition-transform duration-200\"",[3445,6090,3478],{"class":3458},[3445,6092,6093],{"class":3447,"line":3569},[3445,6094,6095],{"class":3470},"        Підіймається при hover на батьку\n",[3445,6097,6098,6100,6102],{"class":3447,"line":3575},[3445,6099,4527],{"class":3458},[3445,6101,3463],{"class":3462},[3445,6103,3478],{"class":3458},[3445,6105,6106,6108,6110],{"class":3447,"line":3591},[3445,6107,4707],{"class":3458},[3445,6109,3463],{"class":3462},[3445,6111,3478],{"class":3458},[3445,6113,6114],{"class":3447,"line":3596},[3445,6115,3485],{"emptyLinePlaceholder":3484},[3445,6117,6118],{"class":3447,"line":3602},[3445,6119,6120],{"class":3451},"\u003C!-- focus: + довільна рамка -->\n",[3445,6122,6123,6125,6127,6129,6131,6134],{"class":3447,"line":4129},[3445,6124,3459],{"class":3458},[3445,6126,4817],{"class":3462},[3445,6128,3467],{"class":3466},[3445,6130,3471],{"class":3470},[3445,6132,6133],{"class":3474},"\"focus:ring-[3px] focus:ring-[#C84B31]\u002F30 focus:border-[#C84B31]\"",[3445,6135,3478],{"class":3458},[3445,6137,6138],{"class":3447,"line":4134},[3445,6139,3485],{"emptyLinePlaceholder":3484},[3445,6141,6142],{"class":3447,"line":4140},[3445,6143,6144],{"class":3451},"\u003C!-- Мобільний стрибок + fluid на десктопі -->\n",[3445,6146,6147,6149,6151,6153,6155,6158],{"class":3447,"line":4156},[3445,6148,3459],{"class":3458},[3445,6150,3344],{"class":3462},[3445,6152,3467],{"class":3466},[3445,6154,3471],{"class":3470},[3445,6156,6157],{"class":3474},"\"text-[2rem] md:text-[clamp(2.5rem,5vw,5rem)]\"",[3445,6159,3478],{"class":3458},[3408,6161],{},[3417,6163,6165],{"id":6164},"_18-практичний-приклад-компонент-з-довільними-значеннями","1.8. Практичний приклад: компонент з довільними значеннями",[3353,6167,6168],{},"Розглянемо реальний сценарій: картка продукту з точним дизайном від дизайнера, де частина значень виходить за межі стандартної шкали.",[4471,6170,6171],{":tailwind":4473},[3425,6172,6174],{"className":3439,"code":6173,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"p-8 bg-slate-50 flex justify-center items-center min-h-48\"\n     style=\"font-family: system-ui, sans-serif;\">\n\n    \u003C!-- Product Card з довільними значеннями -->\n    \u003Cdiv class=\"bg-white rounded-[20px] overflow-hidden shadow-[0_8px_40px_rgba(0,0,0,0.08)]\n                w-[300px] hover:shadow-[0_16px_60px_rgba(0,0,0,0.14)]\n                hover:-translate-y-[3px] transition-all duration-300\">\n\n        \u003C!-- Зображення-плейсхолдер -->\n        \u003Cdiv class=\"h-[180px] bg-gradient-to-br from-[#C84B31] to-[#8B2FC9]\n                    relative flex items-end p-4\">\n            \u003C!-- Badge зі специфічним відступом -->\n            \u003Cspan class=\"absolute top-[14px] right-[14px]\n                         bg-white\u002F90 text-[#C84B31] text-[11px] font-bold\n                         px-[10px] py-[5px] rounded-[999px]\n                         [backdrop-filter:blur(8px)]\">\n                -35%\n            \u003C\u002Fspan>\n            \u003C!-- Назва на картці -->\n            \u003Ch2 class=\"text-white font-black text-[22px] leading-[1.2] text-shadow-sm\">\n                Premium Kit\n            \u003C\u002Fh2>\n        \u003C\u002Fdiv>\n\n        \u003C!-- Вміст -->\n        \u003Cdiv class=\"p-[22px]\">\n            \u003Cp class=\"text-[13px] text-slate-500 leading-[1.6] mb-[14px]\">\n                Дизайн-система з точними значеннями поза стандартною шкалою Tailwind.\n            \u003C\u002Fp>\n\n            \u003C!-- Ціна -->\n            \u003Cdiv class=\"flex items-baseline gap-[6px] mb-[18px]\">\n                \u003Cspan class=\"text-[28px] font-black text-slate-900\">$49\u003C\u002Fspan>\n                \u003Cspan class=\"text-[16px] text-slate-400 line-through\">$75\u003C\u002Fspan>\n            \u003C\u002Fdiv>\n\n            \u003C!-- Кнопка -->\n            \u003Cbutton class=\"w-full py-[13px] rounded-[12px]\n                           bg-[#C84B31] hover:bg-[#A53926] active:scale-[0.98]\n                           text-white text-[15px] font-bold\n                           transition-all duration-150\n                           shadow-[0_4px_14px_rgba(200,75,49,0.4)]\n                           hover:shadow-[0_6px_20px_rgba(200,75,49,0.5)]\">\n                Придбати зараз\n            \u003C\u002Fbutton>\n        \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,6175,6176,6189,6199,6203,6208,6221,6226,6233,6237,6242,6255,6262,6267,6280,6285,6290,6297,6302,6310,6315,6330,6335,6343,6351,6355,6360,6375,6390,6395,6403,6407,6412,6427,6451,6475,6483,6487,6492,6505,6510,6515,6520,6525,6532,6537,6545,6553,6561],{"__ignoreMap":3433},[3445,6177,6178,6180,6182,6184,6186],{"class":3447,"line":3448},[3445,6179,3459],{"class":3458},[3445,6181,3463],{"class":3462},[3445,6183,3467],{"class":3466},[3445,6185,3471],{"class":3470},[3445,6187,6188],{"class":3474},"\"p-8 bg-slate-50 flex justify-center items-center min-h-48\"\n",[3445,6190,6191,6193,6195,6197],{"class":3447,"line":3455},[3445,6192,5912],{"class":3466},[3445,6194,3471],{"class":3470},[3445,6196,4499],{"class":3474},[3445,6198,3478],{"class":3458},[3445,6200,6201],{"class":3447,"line":3481},[3445,6202,3485],{"emptyLinePlaceholder":3484},[3445,6204,6205],{"class":3447,"line":3488},[3445,6206,6207],{"class":3451},"    \u003C!-- Product Card з довільними значеннями -->\n",[3445,6209,6210,6212,6214,6216,6218],{"class":3447,"line":3494},[3445,6211,4506],{"class":3458},[3445,6213,3463],{"class":3462},[3445,6215,3467],{"class":3466},[3445,6217,3471],{"class":3470},[3445,6219,6220],{"class":3474},"\"bg-white rounded-[20px] overflow-hidden shadow-[0_8px_40px_rgba(0,0,0,0.08)]\n",[3445,6222,6223],{"class":3447,"line":3510},[3445,6224,6225],{"class":3474},"                w-[300px] hover:shadow-[0_16px_60px_rgba(0,0,0,0.14)]\n",[3445,6227,6228,6231],{"class":3447,"line":3515},[3445,6229,6230],{"class":3474},"                hover:-translate-y-[3px] transition-all duration-300\"",[3445,6232,3478],{"class":3458},[3445,6234,6235],{"class":3447,"line":3521},[3445,6236,3485],{"emptyLinePlaceholder":3484},[3445,6238,6239],{"class":3447,"line":3537},[3445,6240,6241],{"class":3451},"        \u003C!-- Зображення-плейсхолдер -->\n",[3445,6243,6244,6246,6248,6250,6252],{"class":3447,"line":3542},[3445,6245,4639],{"class":3458},[3445,6247,3463],{"class":3462},[3445,6249,3467],{"class":3466},[3445,6251,3471],{"class":3470},[3445,6253,6254],{"class":3474},"\"h-[180px] bg-gradient-to-br from-[#C84B31] to-[#8B2FC9]\n",[3445,6256,6257,6260],{"class":3447,"line":3548},[3445,6258,6259],{"class":3474},"                    relative flex items-end p-4\"",[3445,6261,3478],{"class":3458},[3445,6263,6264],{"class":3447,"line":3564},[3445,6265,6266],{"class":3451},"            \u003C!-- Badge зі специфічним відступом -->\n",[3445,6268,6269,6271,6273,6275,6277],{"class":3447,"line":3569},[3445,6270,5143],{"class":3458},[3445,6272,3445],{"class":3462},[3445,6274,3467],{"class":3466},[3445,6276,3471],{"class":3470},[3445,6278,6279],{"class":3474},"\"absolute top-[14px] right-[14px]\n",[3445,6281,6282],{"class":3447,"line":3575},[3445,6283,6284],{"class":3474},"                         bg-white\u002F90 text-[#C84B31] text-[11px] font-bold\n",[3445,6286,6287],{"class":3447,"line":3591},[3445,6288,6289],{"class":3474},"                         px-[10px] py-[5px] rounded-[999px]\n",[3445,6291,6292,6295],{"class":3447,"line":3596},[3445,6293,6294],{"class":3474},"                         [backdrop-filter:blur(8px)]\"",[3445,6296,3478],{"class":3458},[3445,6298,6299],{"class":3447,"line":3602},[3445,6300,6301],{"class":3470},"                -35%\n",[3445,6303,6304,6306,6308],{"class":3447,"line":4129},[3445,6305,5336],{"class":3458},[3445,6307,3445],{"class":3462},[3445,6309,3478],{"class":3458},[3445,6311,6312],{"class":3447,"line":4134},[3445,6313,6314],{"class":3451},"            \u003C!-- Назва на картці -->\n",[3445,6316,6317,6319,6321,6323,6325,6328],{"class":3447,"line":4140},[3445,6318,5143],{"class":3458},[3445,6320,3348],{"class":3462},[3445,6322,3467],{"class":3466},[3445,6324,3471],{"class":3470},[3445,6326,6327],{"class":3474},"\"text-white font-black text-[22px] leading-[1.2] text-shadow-sm\"",[3445,6329,3478],{"class":3458},[3445,6331,6332],{"class":3447,"line":4156},[3445,6333,6334],{"class":3470},"                Premium Kit\n",[3445,6336,6337,6339,6341],{"class":3447,"line":4162},[3445,6338,5336],{"class":3458},[3445,6340,3348],{"class":3462},[3445,6342,3478],{"class":3458},[3445,6344,6345,6347,6349],{"class":3447,"line":4447},[3445,6346,4659],{"class":3458},[3445,6348,3463],{"class":3462},[3445,6350,3478],{"class":3458},[3445,6352,6353],{"class":3447,"line":4686},[3445,6354,3485],{"emptyLinePlaceholder":3484},[3445,6356,6357],{"class":3447,"line":4695},[3445,6358,6359],{"class":3451},"        \u003C!-- Вміст -->\n",[3445,6361,6362,6364,6366,6368,6370,6373],{"class":3447,"line":4704},[3445,6363,4639],{"class":3458},[3445,6365,3463],{"class":3462},[3445,6367,3467],{"class":3466},[3445,6369,3471],{"class":3470},[3445,6371,6372],{"class":3474},"\"p-[22px]\"",[3445,6374,3478],{"class":3458},[3445,6376,6377,6379,6381,6383,6385,6388],{"class":3447,"line":5343},[3445,6378,5143],{"class":3458},[3445,6380,3353],{"class":3462},[3445,6382,3467],{"class":3466},[3445,6384,3471],{"class":3470},[3445,6386,6387],{"class":3474},"\"text-[13px] text-slate-500 leading-[1.6] mb-[14px]\"",[3445,6389,3478],{"class":3458},[3445,6391,6392],{"class":3447,"line":5349},[3445,6393,6394],{"class":3470},"                Дизайн-система з точними значеннями поза стандартною шкалою Tailwind.\n",[3445,6396,6397,6399,6401],{"class":3447,"line":5365},[3445,6398,5336],{"class":3458},[3445,6400,3353],{"class":3462},[3445,6402,3478],{"class":3458},[3445,6404,6405],{"class":3447,"line":5389},[3445,6406,3485],{"emptyLinePlaceholder":3484},[3445,6408,6409],{"class":3447,"line":5395},[3445,6410,6411],{"class":3451},"            \u003C!-- Ціна -->\n",[3445,6413,6414,6416,6418,6420,6422,6425],{"class":3447,"line":5404},[3445,6415,5143],{"class":3458},[3445,6417,3463],{"class":3462},[3445,6419,3467],{"class":3466},[3445,6421,3471],{"class":3470},[3445,6423,6424],{"class":3474},"\"flex items-baseline gap-[6px] mb-[18px]\"",[3445,6426,3478],{"class":3458},[3445,6428,6429,6431,6433,6435,6437,6440,6442,6445,6447,6449],{"class":3447,"line":5413},[3445,6430,5267],{"class":3458},[3445,6432,3445],{"class":3462},[3445,6434,3467],{"class":3466},[3445,6436,3471],{"class":3470},[3445,6438,6439],{"class":3474},"\"text-[28px] font-black text-slate-900\"",[3445,6441,3994],{"class":3458},[3445,6443,6444],{"class":3470},"$49",[3445,6446,4707],{"class":3458},[3445,6448,3445],{"class":3462},[3445,6450,3478],{"class":3458},[3445,6452,6453,6455,6457,6459,6461,6464,6466,6469,6471,6473],{"class":3447,"line":5422},[3445,6454,5267],{"class":3458},[3445,6456,3445],{"class":3462},[3445,6458,3467],{"class":3466},[3445,6460,3471],{"class":3470},[3445,6462,6463],{"class":3474},"\"text-[16px] text-slate-400 line-through\"",[3445,6465,3994],{"class":3458},[3445,6467,6468],{"class":3470},"$75",[3445,6470,4707],{"class":3458},[3445,6472,3445],{"class":3462},[3445,6474,3478],{"class":3458},[3445,6476,6477,6479,6481],{"class":3447,"line":5431},[3445,6478,5336],{"class":3458},[3445,6480,3463],{"class":3462},[3445,6482,3478],{"class":3458},[3445,6484,6485],{"class":3447,"line":5436},[3445,6486,3485],{"emptyLinePlaceholder":3484},[3445,6488,6489],{"class":3447,"line":5445},[3445,6490,6491],{"class":3451},"            \u003C!-- Кнопка -->\n",[3445,6493,6494,6496,6498,6500,6502],{"class":3447,"line":5458},[3445,6495,5143],{"class":3458},[3445,6497,5293],{"class":3462},[3445,6499,3467],{"class":3466},[3445,6501,3471],{"class":3470},[3445,6503,6504],{"class":3474},"\"w-full py-[13px] rounded-[12px]\n",[3445,6506,6507],{"class":3447,"line":5490},[3445,6508,6509],{"class":3474},"                           bg-[#C84B31] hover:bg-[#A53926] active:scale-[0.98]\n",[3445,6511,6512],{"class":3447,"line":5520},[3445,6513,6514],{"class":3474},"                           text-white text-[15px] font-bold\n",[3445,6516,6517],{"class":3447,"line":5546},[3445,6518,6519],{"class":3474},"                           transition-all duration-150\n",[3445,6521,6522],{"class":3447,"line":5564},[3445,6523,6524],{"class":3474},"                           shadow-[0_4px_14px_rgba(200,75,49,0.4)]\n",[3445,6526,6527,6530],{"class":3447,"line":5576},[3445,6528,6529],{"class":3474},"                           hover:shadow-[0_6px_20px_rgba(200,75,49,0.5)]\"",[3445,6531,3478],{"class":3458},[3445,6533,6534],{"class":3447,"line":5600},[3445,6535,6536],{"class":3470},"                Придбати зараз\n",[3445,6538,6539,6541,6543],{"class":3447,"line":5616},[3445,6540,5336],{"class":3458},[3445,6542,5293],{"class":3462},[3445,6544,3478],{"class":3458},[3445,6546,6547,6549,6551],{"class":3447,"line":5622},[3445,6548,4659],{"class":3458},[3445,6550,3463],{"class":3462},[3445,6552,3478],{"class":3458},[3445,6554,6555,6557,6559],{"class":3447,"line":5628},[3445,6556,4527],{"class":3458},[3445,6558,3463],{"class":3462},[3445,6560,3478],{"class":3458},[3445,6562,6563,6565,6567],{"class":3447,"line":5637},[3445,6564,4707],{"class":3458},[3445,6566,3463],{"class":3462},[3445,6568,3478],{"class":3458},[3353,6570,6571,6572,6575,6576,6579,6580,6583],{},"Зверніть, як довільні значення використовуються точково — там, де дизайн вимагає нестандартних пікселів (",[3360,6573,6574],{},"20px"," для border-radius, ",[3360,6577,6578],{},"180px"," для висоти обкладинки, ",[3360,6581,6582],{},"22px"," для padding), але загальна структура залишається через стандартні утиліти.",[3408,6585],{},[3348,6587,6589,6590],{"id":6588},"частина-іі-довільні-властивості-групи-та-apply","Частина ІІ. Довільні властивості: групи та ",[3360,6591,6592],{},"@apply",[3417,6594,6596,6597],{"id":6595},"_21-псевдоелементи-та-content","2.1. Псевдоелементи та ",[3360,6598,6599],{},"content",[3353,6601,6602,6603,3385,6606,6609,6610,6612],{},"Особливо корисними є довільні значення для псевдоелементів ",[3360,6604,6605],{},"before:",[3360,6607,6608],{},"after:",", де властивість ",[3360,6611,6599],{}," завжди потребує точного значення:",[3425,6614,6616],{"className":3439,"code":6615,"language":3441,"meta":3433,"style":3433},"\u003C!-- Лапки для цитати -->\n\u003Cblockquote class=\"relative pl-6\n                   before:content-['\\201C'] before:absolute before:left-0\n                   before:text-[3rem] before:text-indigo-200 before:leading-none\n                   before:font-serif before:-top-[0.5rem]\">\n    Довільні значення — це escape-люк, а не основний шлях.\n\u003C\u002Fblockquote>\n\n\u003C!-- Стрілка після посилання -->\n\u003Ca href=\"#\" class=\"after:content-['_→'] after:ml-[2px]\n                   after:transition-[transform,margin] after:inline-block\n                   hover:after:ml-[6px]\">\n    Читати далі\n\u003C\u002Fa>\n\n\u003C!-- Нумерований список через CSS-лічильник -->\n\u003Col class=\"[counter-reset:list-counter]\">\n    \u003Cli class=\"[counter-increment:list-counter]\n               before:content-[counter(list-counter)'.']\n               before:font-bold before:mr-[8px] before:text-indigo-600\">\n        Перший елемент\n    \u003C\u002Fli>\n\u003C\u002Fol>\n\n\u003C!-- Обов'язкова зірочка для form label -->\n\u003Clabel class=\"after:content-['*'] after:text-red-500 after:ml-[2px]\">\n    Email\n\u003C\u002Flabel>\n",[3360,6617,6618,6623,6637,6642,6647,6654,6659,6667,6671,6676,6697,6702,6709,6714,6722,6726,6731,6746,6759,6764,6771,6776,6784,6792,6796,6801,6816,6821],{"__ignoreMap":3433},[3445,6619,6620],{"class":3447,"line":3448},[3445,6621,6622],{"class":3451},"\u003C!-- Лапки для цитати -->\n",[3445,6624,6625,6627,6630,6632,6634],{"class":3447,"line":3455},[3445,6626,3459],{"class":3458},[3445,6628,6629],{"class":3462},"blockquote",[3445,6631,3467],{"class":3466},[3445,6633,3471],{"class":3470},[3445,6635,6636],{"class":3474},"\"relative pl-6\n",[3445,6638,6639],{"class":3447,"line":3481},[3445,6640,6641],{"class":3474},"                   before:content-['\\201C'] before:absolute before:left-0\n",[3445,6643,6644],{"class":3447,"line":3488},[3445,6645,6646],{"class":3474},"                   before:text-[3rem] before:text-indigo-200 before:leading-none\n",[3445,6648,6649,6652],{"class":3447,"line":3494},[3445,6650,6651],{"class":3474},"                   before:font-serif before:-top-[0.5rem]\"",[3445,6653,3478],{"class":3458},[3445,6655,6656],{"class":3447,"line":3510},[3445,6657,6658],{"class":3470},"    Довільні значення — це escape-люк, а не основний шлях.\n",[3445,6660,6661,6663,6665],{"class":3447,"line":3515},[3445,6662,4707],{"class":3458},[3445,6664,6629],{"class":3462},[3445,6666,3478],{"class":3458},[3445,6668,6669],{"class":3447,"line":3521},[3445,6670,3485],{"emptyLinePlaceholder":3484},[3445,6672,6673],{"class":3447,"line":3537},[3445,6674,6675],{"class":3451},"\u003C!-- Стрілка після посилання -->\n",[3445,6677,6678,6680,6683,6685,6687,6690,6692,6694],{"class":3447,"line":3542},[3445,6679,3459],{"class":3458},[3445,6681,6682],{"class":3462},"a",[3445,6684,5028],{"class":3466},[3445,6686,3471],{"class":3470},[3445,6688,6689],{"class":3474},"\"#\"",[3445,6691,3467],{"class":3466},[3445,6693,3471],{"class":3470},[3445,6695,6696],{"class":3474},"\"after:content-['_→'] after:ml-[2px]\n",[3445,6698,6699],{"class":3447,"line":3548},[3445,6700,6701],{"class":3474},"                   after:transition-[transform,margin] after:inline-block\n",[3445,6703,6704,6707],{"class":3447,"line":3564},[3445,6705,6706],{"class":3474},"                   hover:after:ml-[6px]\"",[3445,6708,3478],{"class":3458},[3445,6710,6711],{"class":3447,"line":3569},[3445,6712,6713],{"class":3470},"    Читати далі\n",[3445,6715,6716,6718,6720],{"class":3447,"line":3575},[3445,6717,4707],{"class":3458},[3445,6719,6682],{"class":3462},[3445,6721,3478],{"class":3458},[3445,6723,6724],{"class":3447,"line":3591},[3445,6725,3485],{"emptyLinePlaceholder":3484},[3445,6727,6728],{"class":3447,"line":3596},[3445,6729,6730],{"class":3451},"\u003C!-- Нумерований список через CSS-лічильник -->\n",[3445,6732,6733,6735,6737,6739,6741,6744],{"class":3447,"line":3602},[3445,6734,3459],{"class":3458},[3445,6736,3372],{"class":3462},[3445,6738,3467],{"class":3466},[3445,6740,3471],{"class":3470},[3445,6742,6743],{"class":3474},"\"[counter-reset:list-counter]\"",[3445,6745,3478],{"class":3458},[3445,6747,6748,6750,6752,6754,6756],{"class":3447,"line":4129},[3445,6749,4506],{"class":3458},[3445,6751,3375],{"class":3462},[3445,6753,3467],{"class":3466},[3445,6755,3471],{"class":3470},[3445,6757,6758],{"class":3474},"\"[counter-increment:list-counter]\n",[3445,6760,6761],{"class":3447,"line":4134},[3445,6762,6763],{"class":3474},"               before:content-[counter(list-counter)'.']\n",[3445,6765,6766,6769],{"class":3447,"line":4140},[3445,6767,6768],{"class":3474},"               before:font-bold before:mr-[8px] before:text-indigo-600\"",[3445,6770,3478],{"class":3458},[3445,6772,6773],{"class":3447,"line":4156},[3445,6774,6775],{"class":3470},"        Перший елемент\n",[3445,6777,6778,6780,6782],{"class":3447,"line":4162},[3445,6779,4527],{"class":3458},[3445,6781,3375],{"class":3462},[3445,6783,3478],{"class":3458},[3445,6785,6786,6788,6790],{"class":3447,"line":4447},[3445,6787,4707],{"class":3458},[3445,6789,3372],{"class":3462},[3445,6791,3478],{"class":3458},[3445,6793,6794],{"class":3447,"line":4686},[3445,6795,3485],{"emptyLinePlaceholder":3484},[3445,6797,6798],{"class":3447,"line":4695},[3445,6799,6800],{"class":3451},"\u003C!-- Обов'язкова зірочка для form label -->\n",[3445,6802,6803,6805,6807,6809,6811,6814],{"class":3447,"line":4704},[3445,6804,3459],{"class":3458},[3445,6806,5146],{"class":3462},[3445,6808,3467],{"class":3466},[3445,6810,3471],{"class":3470},[3445,6812,6813],{"class":3474},"\"after:content-['*'] after:text-red-500 after:ml-[2px]\"",[3445,6815,3478],{"class":3458},[3445,6817,6818],{"class":3447,"line":5343},[3445,6819,6820],{"class":3470},"    Email\n",[3445,6822,6823,6825,6827],{"class":3447,"line":5349},[3445,6824,4707],{"class":3458},[3445,6826,5146],{"class":3462},[3445,6828,3478],{"class":3458},[3408,6830],{},[3417,6832,6834],{"id":6833},"_22-css-grid-з-довільними-шаблонами","2.2. CSS Grid з довільними шаблонами",[3353,6836,6837,6838,3675,6841,6844],{},"Grid-система Tailwind підтримує лише прості варіанти (",[3360,6839,6840],{},"grid-cols-2",[3360,6842,6843],{},"grid-cols-3"," тощо). Для складних сіток — довільний шаблон:",[3425,6846,6848],{"className":3439,"code":6847,"language":3441,"meta":3433,"style":3433},"\u003C!-- Holy Grail Layout: header, sidebar, main, aside, footer -->\n\u003Cdiv class=\"grid min-h-screen\n            [grid-template-areas:'header_header_header'_'nav_main_aside'_'footer_footer_footer']\n            [grid-template-rows:auto_1fr_auto]\n            [grid-template-columns:240px_1fr_200px]\n            gap-4\">\n\n    \u003Cheader class=\"[grid-area:header] bg-white border-b p-4\">Шапка\u003C\u002Fheader>\n    \u003Cnav class=\"[grid-area:nav] bg-slate-50 p-4\">Навігація\u003C\u002Fnav>\n    \u003Cmain class=\"[grid-area:main] p-6\">Основний контент\u003C\u002Fmain>\n    \u003Caside class=\"[grid-area:aside] bg-slate-50 p-4\">Sidebar\u003C\u002Faside>\n    \u003Cfooter class=\"[grid-area:footer] bg-slate-800 text-white p-4\">Футер\u003C\u002Ffooter>\n\u003C\u002Fdiv>\n",[3360,6849,6850,6855,6868,6873,6878,6883,6890,6894,6919,6944,6969,6994,7019],{"__ignoreMap":3433},[3445,6851,6852],{"class":3447,"line":3448},[3445,6853,6854],{"class":3451},"\u003C!-- Holy Grail Layout: header, sidebar, main, aside, footer -->\n",[3445,6856,6857,6859,6861,6863,6865],{"class":3447,"line":3455},[3445,6858,3459],{"class":3458},[3445,6860,3463],{"class":3462},[3445,6862,3467],{"class":3466},[3445,6864,3471],{"class":3470},[3445,6866,6867],{"class":3474},"\"grid min-h-screen\n",[3445,6869,6870],{"class":3447,"line":3481},[3445,6871,6872],{"class":3474},"            [grid-template-areas:'header_header_header'_'nav_main_aside'_'footer_footer_footer']\n",[3445,6874,6875],{"class":3447,"line":3488},[3445,6876,6877],{"class":3474},"            [grid-template-rows:auto_1fr_auto]\n",[3445,6879,6880],{"class":3447,"line":3494},[3445,6881,6882],{"class":3474},"            [grid-template-columns:240px_1fr_200px]\n",[3445,6884,6885,6888],{"class":3447,"line":3510},[3445,6886,6887],{"class":3474},"            gap-4\"",[3445,6889,3478],{"class":3458},[3445,6891,6892],{"class":3447,"line":3515},[3445,6893,3485],{"emptyLinePlaceholder":3484},[3445,6895,6896,6898,6901,6903,6905,6908,6910,6913,6915,6917],{"class":3447,"line":3521},[3445,6897,4506],{"class":3458},[3445,6899,6900],{"class":3462},"header",[3445,6902,3467],{"class":3466},[3445,6904,3471],{"class":3470},[3445,6906,6907],{"class":3474},"\"[grid-area:header] bg-white border-b p-4\"",[3445,6909,3994],{"class":3458},[3445,6911,6912],{"class":3470},"Шапка",[3445,6914,4707],{"class":3458},[3445,6916,6900],{"class":3462},[3445,6918,3478],{"class":3458},[3445,6920,6921,6923,6926,6928,6930,6933,6935,6938,6940,6942],{"class":3447,"line":3537},[3445,6922,4506],{"class":3458},[3445,6924,6925],{"class":3462},"nav",[3445,6927,3467],{"class":3466},[3445,6929,3471],{"class":3470},[3445,6931,6932],{"class":3474},"\"[grid-area:nav] bg-slate-50 p-4\"",[3445,6934,3994],{"class":3458},[3445,6936,6937],{"class":3470},"Навігація",[3445,6939,4707],{"class":3458},[3445,6941,6925],{"class":3462},[3445,6943,3478],{"class":3458},[3445,6945,6946,6948,6951,6953,6955,6958,6960,6963,6965,6967],{"class":3447,"line":3542},[3445,6947,4506],{"class":3458},[3445,6949,6950],{"class":3462},"main",[3445,6952,3467],{"class":3466},[3445,6954,3471],{"class":3470},[3445,6956,6957],{"class":3474},"\"[grid-area:main] p-6\"",[3445,6959,3994],{"class":3458},[3445,6961,6962],{"class":3470},"Основний контент",[3445,6964,4707],{"class":3458},[3445,6966,6950],{"class":3462},[3445,6968,3478],{"class":3458},[3445,6970,6971,6973,6976,6978,6980,6983,6985,6988,6990,6992],{"class":3447,"line":3548},[3445,6972,4506],{"class":3458},[3445,6974,6975],{"class":3462},"aside",[3445,6977,3467],{"class":3466},[3445,6979,3471],{"class":3470},[3445,6981,6982],{"class":3474},"\"[grid-area:aside] bg-slate-50 p-4\"",[3445,6984,3994],{"class":3458},[3445,6986,6987],{"class":3470},"Sidebar",[3445,6989,4707],{"class":3458},[3445,6991,6975],{"class":3462},[3445,6993,3478],{"class":3458},[3445,6995,6996,6998,7001,7003,7005,7008,7010,7013,7015,7017],{"class":3447,"line":3564},[3445,6997,4506],{"class":3458},[3445,6999,7000],{"class":3462},"footer",[3445,7002,3467],{"class":3466},[3445,7004,3471],{"class":3470},[3445,7006,7007],{"class":3474},"\"[grid-area:footer] bg-slate-800 text-white p-4\"",[3445,7009,3994],{"class":3458},[3445,7011,7012],{"class":3470},"Футер",[3445,7014,4707],{"class":3458},[3445,7016,7000],{"class":3462},[3445,7018,3478],{"class":3458},[3445,7020,7021,7023,7025],{"class":3447,"line":3569},[3445,7022,4707],{"class":3458},[3445,7024,3463],{"class":3462},[3445,7026,3478],{"class":3458},[3425,7028,7030],{"className":3439,"code":7029,"language":3441,"meta":3433,"style":3433},"\u003C!-- Масонрі-подібна сітка через auto-fill\u002Fauto-fit -->\n\u003Cdiv class=\"grid\n            [grid-template-columns:repeat(auto-fill,minmax(280px,1fr))]\n            gap-4\">\n    \u003C!-- Картки автоматично заповнюють рядки -->\n\u003C\u002Fdiv>\n\n\u003C!-- Складна несиметрична сітка -->\n\u003Cdiv class=\"grid\n            [grid-template-columns:2fr_1fr_1fr]\n            [grid-template-rows:200px_300px]\n            gap-2\">\n    \u003C!-- Featured item займає весь перший стовпець -->\n    \u003Cdiv class=\"row-span-2 bg-indigo-500\">\u003C\u002Fdiv>\n    \u003Cdiv class=\"bg-blue-400\">\u003C\u002Fdiv>\n    \u003Cdiv class=\"bg-sky-400\">\u003C\u002Fdiv>\n    \u003Cdiv class=\"bg-violet-400\">\u003C\u002Fdiv>\n    \u003Cdiv class=\"bg-purple-400\">\u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,7031,7032,7037,7050,7055,7061,7066,7074,7078,7083,7095,7100,7105,7112,7117,7136,7155,7174,7193,7212],{"__ignoreMap":3433},[3445,7033,7034],{"class":3447,"line":3448},[3445,7035,7036],{"class":3451},"\u003C!-- Масонрі-подібна сітка через auto-fill\u002Fauto-fit -->\n",[3445,7038,7039,7041,7043,7045,7047],{"class":3447,"line":3455},[3445,7040,3459],{"class":3458},[3445,7042,3463],{"class":3462},[3445,7044,3467],{"class":3466},[3445,7046,3471],{"class":3470},[3445,7048,7049],{"class":3474},"\"grid\n",[3445,7051,7052],{"class":3447,"line":3481},[3445,7053,7054],{"class":3474},"            [grid-template-columns:repeat(auto-fill,minmax(280px,1fr))]\n",[3445,7056,7057,7059],{"class":3447,"line":3488},[3445,7058,6887],{"class":3474},[3445,7060,3478],{"class":3458},[3445,7062,7063],{"class":3447,"line":3494},[3445,7064,7065],{"class":3451},"    \u003C!-- Картки автоматично заповнюють рядки -->\n",[3445,7067,7068,7070,7072],{"class":3447,"line":3510},[3445,7069,4707],{"class":3458},[3445,7071,3463],{"class":3462},[3445,7073,3478],{"class":3458},[3445,7075,7076],{"class":3447,"line":3515},[3445,7077,3485],{"emptyLinePlaceholder":3484},[3445,7079,7080],{"class":3447,"line":3521},[3445,7081,7082],{"class":3451},"\u003C!-- Складна несиметрична сітка -->\n",[3445,7084,7085,7087,7089,7091,7093],{"class":3447,"line":3537},[3445,7086,3459],{"class":3458},[3445,7088,3463],{"class":3462},[3445,7090,3467],{"class":3466},[3445,7092,3471],{"class":3470},[3445,7094,7049],{"class":3474},[3445,7096,7097],{"class":3447,"line":3542},[3445,7098,7099],{"class":3474},"            [grid-template-columns:2fr_1fr_1fr]\n",[3445,7101,7102],{"class":3447,"line":3548},[3445,7103,7104],{"class":3474},"            [grid-template-rows:200px_300px]\n",[3445,7106,7107,7110],{"class":3447,"line":3564},[3445,7108,7109],{"class":3474},"            gap-2\"",[3445,7111,3478],{"class":3458},[3445,7113,7114],{"class":3447,"line":3569},[3445,7115,7116],{"class":3451},"    \u003C!-- Featured item займає весь перший стовпець -->\n",[3445,7118,7119,7121,7123,7125,7127,7130,7132,7134],{"class":3447,"line":3575},[3445,7120,4506],{"class":3458},[3445,7122,3463],{"class":3462},[3445,7124,3467],{"class":3466},[3445,7126,3471],{"class":3470},[3445,7128,7129],{"class":3474},"\"row-span-2 bg-indigo-500\"",[3445,7131,5014],{"class":3458},[3445,7133,3463],{"class":3462},[3445,7135,3478],{"class":3458},[3445,7137,7138,7140,7142,7144,7146,7149,7151,7153],{"class":3447,"line":3591},[3445,7139,4506],{"class":3458},[3445,7141,3463],{"class":3462},[3445,7143,3467],{"class":3466},[3445,7145,3471],{"class":3470},[3445,7147,7148],{"class":3474},"\"bg-blue-400\"",[3445,7150,5014],{"class":3458},[3445,7152,3463],{"class":3462},[3445,7154,3478],{"class":3458},[3445,7156,7157,7159,7161,7163,7165,7168,7170,7172],{"class":3447,"line":3596},[3445,7158,4506],{"class":3458},[3445,7160,3463],{"class":3462},[3445,7162,3467],{"class":3466},[3445,7164,3471],{"class":3470},[3445,7166,7167],{"class":3474},"\"bg-sky-400\"",[3445,7169,5014],{"class":3458},[3445,7171,3463],{"class":3462},[3445,7173,3478],{"class":3458},[3445,7175,7176,7178,7180,7182,7184,7187,7189,7191],{"class":3447,"line":3602},[3445,7177,4506],{"class":3458},[3445,7179,3463],{"class":3462},[3445,7181,3467],{"class":3466},[3445,7183,3471],{"class":3470},[3445,7185,7186],{"class":3474},"\"bg-violet-400\"",[3445,7188,5014],{"class":3458},[3445,7190,3463],{"class":3462},[3445,7192,3478],{"class":3458},[3445,7194,7195,7197,7199,7201,7203,7206,7208,7210],{"class":3447,"line":4129},[3445,7196,4506],{"class":3458},[3445,7198,3463],{"class":3462},[3445,7200,3467],{"class":3466},[3445,7202,3471],{"class":3470},[3445,7204,7205],{"class":3474},"\"bg-purple-400\"",[3445,7207,5014],{"class":3458},[3445,7209,3463],{"class":3462},[3445,7211,3478],{"class":3458},[3445,7213,7214,7216,7218],{"class":3447,"line":4134},[3445,7215,4707],{"class":3458},[3445,7217,3463],{"class":3462},[3445,7219,3478],{"class":3458},[3408,7221],{},[3417,7223,7225],{"id":7224},"_23-фільтри-маски-та-ефекти","2.3. Фільтри, маски та ефекти",[3353,7227,7228],{},"Довільні значення розкривають CSS-фільтри та маскування:",[3425,7230,7232],{"className":3439,"code":7231,"language":3441,"meta":3433,"style":3433},"\u003C!-- Blur-фільтри з точними значеннями -->\n\u003Cimg class=\"blur-[2px] hover:blur-none transition-all duration-300\">\n\n\u003C!-- Мультифільтр -->\n\u003Cdiv class=\"[filter:brightness(0.9)_contrast(1.1)_saturate(1.2)]\">\n\n\u003C!-- Маска градієнтом (fade-out ефект) -->\n\u003Cdiv class=\"[mask-image:linear-gradient(to_bottom,black_60%,transparent)]\">\n\n\u003C!-- Clip-path для нестандартних форм -->\n\u003Cdiv class=\"[clip-path:polygon(0_0,100%_0,85%_100%,0_100%)]\n            bg-indigo-600 text-white p-8\">\n    Паралелограм\n\u003C\u002Fdiv>\n\n\u003C!-- Backdrop blur для glassmorphism -->\n\u003Cdiv class=\"[backdrop-filter:blur(12px)_saturate(180%)]\n            bg-white\u002F20 border border-white\u002F30 rounded-xl\">\n    Скло\n\u003C\u002Fdiv>\n",[3360,7233,7234,7239,7255,7259,7264,7279,7283,7288,7303,7307,7312,7325,7332,7337,7345,7349,7354,7367,7374,7379],{"__ignoreMap":3433},[3445,7235,7236],{"class":3447,"line":3448},[3445,7237,7238],{"class":3451},"\u003C!-- Blur-фільтри з точними значеннями -->\n",[3445,7240,7241,7243,7246,7248,7250,7253],{"class":3447,"line":3455},[3445,7242,3459],{"class":3458},[3445,7244,7245],{"class":3462},"img",[3445,7247,3467],{"class":3466},[3445,7249,3471],{"class":3470},[3445,7251,7252],{"class":3474},"\"blur-[2px] hover:blur-none transition-all duration-300\"",[3445,7254,3478],{"class":3458},[3445,7256,7257],{"class":3447,"line":3481},[3445,7258,3485],{"emptyLinePlaceholder":3484},[3445,7260,7261],{"class":3447,"line":3488},[3445,7262,7263],{"class":3451},"\u003C!-- Мультифільтр -->\n",[3445,7265,7266,7268,7270,7272,7274,7277],{"class":3447,"line":3494},[3445,7267,3459],{"class":3458},[3445,7269,3463],{"class":3462},[3445,7271,3467],{"class":3466},[3445,7273,3471],{"class":3470},[3445,7275,7276],{"class":3474},"\"[filter:brightness(0.9)_contrast(1.1)_saturate(1.2)]\"",[3445,7278,3478],{"class":3458},[3445,7280,7281],{"class":3447,"line":3510},[3445,7282,3485],{"emptyLinePlaceholder":3484},[3445,7284,7285],{"class":3447,"line":3515},[3445,7286,7287],{"class":3451},"\u003C!-- Маска градієнтом (fade-out ефект) -->\n",[3445,7289,7290,7292,7294,7296,7298,7301],{"class":3447,"line":3521},[3445,7291,3459],{"class":3458},[3445,7293,3463],{"class":3462},[3445,7295,3467],{"class":3466},[3445,7297,3471],{"class":3470},[3445,7299,7300],{"class":3474},"\"[mask-image:linear-gradient(to_bottom,black_60%,transparent)]\"",[3445,7302,3478],{"class":3458},[3445,7304,7305],{"class":3447,"line":3537},[3445,7306,3485],{"emptyLinePlaceholder":3484},[3445,7308,7309],{"class":3447,"line":3542},[3445,7310,7311],{"class":3451},"\u003C!-- Clip-path для нестандартних форм -->\n",[3445,7313,7314,7316,7318,7320,7322],{"class":3447,"line":3548},[3445,7315,3459],{"class":3458},[3445,7317,3463],{"class":3462},[3445,7319,3467],{"class":3466},[3445,7321,3471],{"class":3470},[3445,7323,7324],{"class":3474},"\"[clip-path:polygon(0_0,100%_0,85%_100%,0_100%)]\n",[3445,7326,7327,7330],{"class":3447,"line":3564},[3445,7328,7329],{"class":3474},"            bg-indigo-600 text-white p-8\"",[3445,7331,3478],{"class":3458},[3445,7333,7334],{"class":3447,"line":3569},[3445,7335,7336],{"class":3470},"    Паралелограм\n",[3445,7338,7339,7341,7343],{"class":3447,"line":3575},[3445,7340,4707],{"class":3458},[3445,7342,3463],{"class":3462},[3445,7344,3478],{"class":3458},[3445,7346,7347],{"class":3447,"line":3591},[3445,7348,3485],{"emptyLinePlaceholder":3484},[3445,7350,7351],{"class":3447,"line":3596},[3445,7352,7353],{"class":3451},"\u003C!-- Backdrop blur для glassmorphism -->\n",[3445,7355,7356,7358,7360,7362,7364],{"class":3447,"line":3602},[3445,7357,3459],{"class":3458},[3445,7359,3463],{"class":3462},[3445,7361,3467],{"class":3466},[3445,7363,3471],{"class":3470},[3445,7365,7366],{"class":3474},"\"[backdrop-filter:blur(12px)_saturate(180%)]\n",[3445,7368,7369,7372],{"class":3447,"line":4129},[3445,7370,7371],{"class":3474},"            bg-white\u002F20 border border-white\u002F30 rounded-xl\"",[3445,7373,3478],{"class":3458},[3445,7375,7376],{"class":3447,"line":4134},[3445,7377,7378],{"class":3470},"    Скло\n",[3445,7380,7381,7383,7385],{"class":3447,"line":4140},[3445,7382,4707],{"class":3458},[3445,7384,3463],{"class":3462},[3445,7386,3478],{"class":3458},[4471,7388,7389],{":tailwind":4473},[3425,7390,7392],{"className":3439,"code":7391,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"p-8 bg-gradient-to-br from-slate-800 to-indigo-900 flex flex-wrap gap-4 justify-center items-center\"\n     style=\"font-family: system-ui, sans-serif; min-height: 200px;\">\n\n    \u003C!-- Glassmorphism через довільні властивості -->\n    \u003Cdiv class=\"[backdrop-filter:blur(16px)_saturate(180%)]\n                bg-white\u002F10 border border-white\u002F20\n                rounded-2xl p-6 text-white text-center w-36\">\n        \u003Cdiv class=\"text-3xl mb-2\">🔮\u003C\u002Fdiv>\n        \u003Cp class=\"text-sm font-semibold\">backdrop-filter\u003C\u002Fp>\n        \u003Cp class=\"text-xs text-white\u002F60 mt-1\">blur + saturate\u003C\u002Fp>\n    \u003C\u002Fdiv>\n\n    \u003C!-- Clip-path: нестандартна форма -->\n    \u003Cdiv class=\"[clip-path:polygon(10%_0%,90%_0%,100%_100%,0%_100%)]\n                bg-gradient-to-b from-indigo-400 to-indigo-600\n                text-white text-center p-6 w-36 h-28 flex flex-col justify-center\">\n        \u003Cp class=\"text-sm font-semibold\">clip-path\u003C\u002Fp>\n        \u003Cp class=\"text-xs text-indigo-100 mt-1\">polygon()\u003C\u002Fp>\n    \u003C\u002Fdiv>\n\n    \u003C!-- Маска: fade-out знизу -->\n    \u003Cdiv class=\"[mask-image:linear-gradient(to_bottom,black_40%,transparent)]\n                bg-white\u002F15 rounded-2xl p-6 text-white w-36 h-28\">\n        \u003Cp class=\"text-sm font-semibold\">mask-image\u003C\u002Fp>\n        \u003Cp class=\"text-xs text-white\u002F70 mt-1\">Текст зникає\u003C\u002Fp>\n        \u003Cp class=\"text-xs text-white\u002F50 mt-1\">поступово\u003C\u002Fp>\n        \u003Cp class=\"text-xs text-white\u002F20 mt-1\">донизу\u003C\u002Fp>\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,7393,7394,7407,7418,7422,7427,7440,7445,7452,7476,7500,7524,7532,7536,7541,7554,7559,7566,7589,7613,7621,7625,7630,7643,7650,7673,7697,7721,7745,7753],{"__ignoreMap":3433},[3445,7395,7396,7398,7400,7402,7404],{"class":3447,"line":3448},[3445,7397,3459],{"class":3458},[3445,7399,3463],{"class":3462},[3445,7401,3467],{"class":3466},[3445,7403,3471],{"class":3470},[3445,7405,7406],{"class":3474},"\"p-8 bg-gradient-to-br from-slate-800 to-indigo-900 flex flex-wrap gap-4 justify-center items-center\"\n",[3445,7408,7409,7411,7413,7416],{"class":3447,"line":3455},[3445,7410,5912],{"class":3466},[3445,7412,3471],{"class":3470},[3445,7414,7415],{"class":3474},"\"font-family: system-ui, sans-serif; min-height: 200px;\"",[3445,7417,3478],{"class":3458},[3445,7419,7420],{"class":3447,"line":3481},[3445,7421,3485],{"emptyLinePlaceholder":3484},[3445,7423,7424],{"class":3447,"line":3488},[3445,7425,7426],{"class":3451},"    \u003C!-- Glassmorphism через довільні властивості -->\n",[3445,7428,7429,7431,7433,7435,7437],{"class":3447,"line":3494},[3445,7430,4506],{"class":3458},[3445,7432,3463],{"class":3462},[3445,7434,3467],{"class":3466},[3445,7436,3471],{"class":3470},[3445,7438,7439],{"class":3474},"\"[backdrop-filter:blur(16px)_saturate(180%)]\n",[3445,7441,7442],{"class":3447,"line":3510},[3445,7443,7444],{"class":3474},"                bg-white\u002F10 border border-white\u002F20\n",[3445,7446,7447,7450],{"class":3447,"line":3515},[3445,7448,7449],{"class":3474},"                rounded-2xl p-6 text-white text-center w-36\"",[3445,7451,3478],{"class":3458},[3445,7453,7454,7456,7458,7460,7462,7465,7467,7470,7472,7474],{"class":3447,"line":3521},[3445,7455,4639],{"class":3458},[3445,7457,3463],{"class":3462},[3445,7459,3467],{"class":3466},[3445,7461,3471],{"class":3470},[3445,7463,7464],{"class":3474},"\"text-3xl mb-2\"",[3445,7466,3994],{"class":3458},[3445,7468,7469],{"class":3470},"🔮",[3445,7471,4707],{"class":3458},[3445,7473,3463],{"class":3462},[3445,7475,3478],{"class":3458},[3445,7477,7478,7480,7482,7484,7486,7489,7491,7494,7496,7498],{"class":3447,"line":3537},[3445,7479,4639],{"class":3458},[3445,7481,3353],{"class":3462},[3445,7483,3467],{"class":3466},[3445,7485,3471],{"class":3470},[3445,7487,7488],{"class":3474},"\"text-sm font-semibold\"",[3445,7490,3994],{"class":3458},[3445,7492,7493],{"class":3470},"backdrop-filter",[3445,7495,4707],{"class":3458},[3445,7497,3353],{"class":3462},[3445,7499,3478],{"class":3458},[3445,7501,7502,7504,7506,7508,7510,7513,7515,7518,7520,7522],{"class":3447,"line":3542},[3445,7503,4639],{"class":3458},[3445,7505,3353],{"class":3462},[3445,7507,3467],{"class":3466},[3445,7509,3471],{"class":3470},[3445,7511,7512],{"class":3474},"\"text-xs text-white\u002F60 mt-1\"",[3445,7514,3994],{"class":3458},[3445,7516,7517],{"class":3470},"blur + saturate",[3445,7519,4707],{"class":3458},[3445,7521,3353],{"class":3462},[3445,7523,3478],{"class":3458},[3445,7525,7526,7528,7530],{"class":3447,"line":3548},[3445,7527,4527],{"class":3458},[3445,7529,3463],{"class":3462},[3445,7531,3478],{"class":3458},[3445,7533,7534],{"class":3447,"line":3564},[3445,7535,3485],{"emptyLinePlaceholder":3484},[3445,7537,7538],{"class":3447,"line":3569},[3445,7539,7540],{"class":3451},"    \u003C!-- Clip-path: нестандартна форма -->\n",[3445,7542,7543,7545,7547,7549,7551],{"class":3447,"line":3575},[3445,7544,4506],{"class":3458},[3445,7546,3463],{"class":3462},[3445,7548,3467],{"class":3466},[3445,7550,3471],{"class":3470},[3445,7552,7553],{"class":3474},"\"[clip-path:polygon(10%_0%,90%_0%,100%_100%,0%_100%)]\n",[3445,7555,7556],{"class":3447,"line":3591},[3445,7557,7558],{"class":3474},"                bg-gradient-to-b from-indigo-400 to-indigo-600\n",[3445,7560,7561,7564],{"class":3447,"line":3596},[3445,7562,7563],{"class":3474},"                text-white text-center p-6 w-36 h-28 flex flex-col justify-center\"",[3445,7565,3478],{"class":3458},[3445,7567,7568,7570,7572,7574,7576,7578,7580,7583,7585,7587],{"class":3447,"line":3602},[3445,7569,4639],{"class":3458},[3445,7571,3353],{"class":3462},[3445,7573,3467],{"class":3466},[3445,7575,3471],{"class":3470},[3445,7577,7488],{"class":3474},[3445,7579,3994],{"class":3458},[3445,7581,7582],{"class":3470},"clip-path",[3445,7584,4707],{"class":3458},[3445,7586,3353],{"class":3462},[3445,7588,3478],{"class":3458},[3445,7590,7591,7593,7595,7597,7599,7602,7604,7607,7609,7611],{"class":3447,"line":4129},[3445,7592,4639],{"class":3458},[3445,7594,3353],{"class":3462},[3445,7596,3467],{"class":3466},[3445,7598,3471],{"class":3470},[3445,7600,7601],{"class":3474},"\"text-xs text-indigo-100 mt-1\"",[3445,7603,3994],{"class":3458},[3445,7605,7606],{"class":3470},"polygon()",[3445,7608,4707],{"class":3458},[3445,7610,3353],{"class":3462},[3445,7612,3478],{"class":3458},[3445,7614,7615,7617,7619],{"class":3447,"line":4134},[3445,7616,4527],{"class":3458},[3445,7618,3463],{"class":3462},[3445,7620,3478],{"class":3458},[3445,7622,7623],{"class":3447,"line":4140},[3445,7624,3485],{"emptyLinePlaceholder":3484},[3445,7626,7627],{"class":3447,"line":4156},[3445,7628,7629],{"class":3451},"    \u003C!-- Маска: fade-out знизу -->\n",[3445,7631,7632,7634,7636,7638,7640],{"class":3447,"line":4162},[3445,7633,4506],{"class":3458},[3445,7635,3463],{"class":3462},[3445,7637,3467],{"class":3466},[3445,7639,3471],{"class":3470},[3445,7641,7642],{"class":3474},"\"[mask-image:linear-gradient(to_bottom,black_40%,transparent)]\n",[3445,7644,7645,7648],{"class":3447,"line":4447},[3445,7646,7647],{"class":3474},"                bg-white\u002F15 rounded-2xl p-6 text-white w-36 h-28\"",[3445,7649,3478],{"class":3458},[3445,7651,7652,7654,7656,7658,7660,7662,7664,7667,7669,7671],{"class":3447,"line":4686},[3445,7653,4639],{"class":3458},[3445,7655,3353],{"class":3462},[3445,7657,3467],{"class":3466},[3445,7659,3471],{"class":3470},[3445,7661,7488],{"class":3474},[3445,7663,3994],{"class":3458},[3445,7665,7666],{"class":3470},"mask-image",[3445,7668,4707],{"class":3458},[3445,7670,3353],{"class":3462},[3445,7672,3478],{"class":3458},[3445,7674,7675,7677,7679,7681,7683,7686,7688,7691,7693,7695],{"class":3447,"line":4695},[3445,7676,4639],{"class":3458},[3445,7678,3353],{"class":3462},[3445,7680,3467],{"class":3466},[3445,7682,3471],{"class":3470},[3445,7684,7685],{"class":3474},"\"text-xs text-white\u002F70 mt-1\"",[3445,7687,3994],{"class":3458},[3445,7689,7690],{"class":3470},"Текст зникає",[3445,7692,4707],{"class":3458},[3445,7694,3353],{"class":3462},[3445,7696,3478],{"class":3458},[3445,7698,7699,7701,7703,7705,7707,7710,7712,7715,7717,7719],{"class":3447,"line":4704},[3445,7700,4639],{"class":3458},[3445,7702,3353],{"class":3462},[3445,7704,3467],{"class":3466},[3445,7706,3471],{"class":3470},[3445,7708,7709],{"class":3474},"\"text-xs text-white\u002F50 mt-1\"",[3445,7711,3994],{"class":3458},[3445,7713,7714],{"class":3470},"поступово",[3445,7716,4707],{"class":3458},[3445,7718,3353],{"class":3462},[3445,7720,3478],{"class":3458},[3445,7722,7723,7725,7727,7729,7731,7734,7736,7739,7741,7743],{"class":3447,"line":5343},[3445,7724,4639],{"class":3458},[3445,7726,3353],{"class":3462},[3445,7728,3467],{"class":3466},[3445,7730,3471],{"class":3470},[3445,7732,7733],{"class":3474},"\"text-xs text-white\u002F20 mt-1\"",[3445,7735,3994],{"class":3458},[3445,7737,7738],{"class":3470},"донизу",[3445,7740,4707],{"class":3458},[3445,7742,3353],{"class":3462},[3445,7744,3478],{"class":3458},[3445,7746,7747,7749,7751],{"class":3447,"line":5349},[3445,7748,4527],{"class":3458},[3445,7750,3463],{"class":3462},[3445,7752,3478],{"class":3458},[3445,7754,7755,7757,7759],{"class":3447,"line":5365},[3445,7756,4707],{"class":3458},[3445,7758,3463],{"class":3462},[3445,7760,3478],{"class":3458},[3408,7762],{},[3348,7764,7766],{"id":7765},"частина-ііі-контейнерні-запити-революція-у-компонентному-дизайні","Частина ІІІ. Контейнерні запити: революція у компонентному дизайні",[3417,7768,7770],{"id":7769},"_31-проблема-медіазапитів-і-чому-контейнерні-запити-її-вирішують","3.1. Проблема медіазапитів і чому контейнерні запити її вирішують",[3353,7772,7773,7774,7777,7778,7781],{},"Класичні медіазапити CSS — ",[3360,7775,7776],{},"@media (min-width: 768px)"," — прив'язані до розміру ",[3378,7779,7780],{},"вікна браузера"," (viewport). Для більшості застосунків це зручно: ширина вікна корелює із розміром елементів.",[3353,7783,7784],{},"Але така прив'язка має фундаментальний недолік: компонент не може адаптуватися сам по собі. Уявіть картку статті, яка відображається у трьох різних місцях на одній сторінці:",[7786,7787,7788],"mermaid",{},[3425,7789,7792],{"className":7790,"code":7791,"language":7786,"meta":3433,"style":3433},"language-mermaid shiki shiki-themes light-plus dark-plus dark-plus","graph LR\n    A[\"Viewport 1440px\u003Cbr\u002F>@media lg активний\"] --> B[\"Головна сторінка\"]\n    B --> C[\"Hero — повна ширина\u003Cbr\u002F>Картка: 800px wide\u003Cbr\u002F>✅ Компактний layout\"]\n    B --> D[\"Sidebar — 300px\u003Cbr\u002F>Картка: 280px wide\u003Cbr\u002F>❌ Переповнення!\"]\n    B --> E[\"Grid 3 cols\u003Cbr\u002F>Картка: 420px wide\u003Cbr\u002F>⚠️ Ні те, ні се\"]\n",[3360,7793,7794,7799,7804,7809,7814],{"__ignoreMap":3433},[3445,7795,7796],{"class":3447,"line":3448},[3445,7797,7798],{},"graph LR\n",[3445,7800,7801],{"class":3447,"line":3455},[3445,7802,7803],{},"    A[\"Viewport 1440px\u003Cbr\u002F>@media lg активний\"] --> B[\"Головна сторінка\"]\n",[3445,7805,7806],{"class":3447,"line":3481},[3445,7807,7808],{},"    B --> C[\"Hero — повна ширина\u003Cbr\u002F>Картка: 800px wide\u003Cbr\u002F>✅ Компактний layout\"]\n",[3445,7810,7811],{"class":3447,"line":3488},[3445,7812,7813],{},"    B --> D[\"Sidebar — 300px\u003Cbr\u002F>Картка: 280px wide\u003Cbr\u002F>❌ Переповнення!\"]\n",[3445,7815,7816],{"class":3447,"line":3494},[3445,7817,7818],{},"    B --> E[\"Grid 3 cols\u003Cbr\u002F>Картка: 420px wide\u003Cbr\u002F>⚠️ Ні те, ні се\"]\n",[3353,7820,7821,7822,7825],{},"Всі три картки на ",[3378,7823,7824],{},"одному viewport"," отримують одні й ті самі медіазапити — хоча їх реальна ширина абсолютно різна. Це проблема.",[3353,7827,7828,7830,7831,7834,7835,4189],{},[3378,7829,3394],{}," вирішують її: замість ",[3360,7832,7833],{},"@media (width >= 768px)"," компонент «дивиться» на ширину свого ",[3378,7836,7837],{},"безпосереднього контейнера",[3425,7839,7841],{"className":5787,"code":7840,"language":5789,"meta":3433,"style":3433},"\u002F* Медіазапит — дивиться на viewport *\u002F\n@media (width >= 640px) {\n    .card { flex-direction: row; }\n}\n\n\u002F* Контейнерний запит — дивиться на контейнер *\u002F\n@container (width >= 400px) {\n    .card { flex-direction: row; }\n}\n",[3360,7842,7843,7848,7868,7888,7892,7896,7901,7908,7922],{"__ignoreMap":3433},[3445,7844,7845],{"class":3447,"line":3448},[3445,7846,7847],{"class":3451},"\u002F* Медіазапит — дивиться на viewport *\u002F\n",[3445,7849,7850,7853,7855,7858,7861,7865],{"class":3447,"line":3455},[3445,7851,7852],{"class":5493},"@media",[3445,7854,3395],{"class":3470},[3445,7856,7857],{"class":3466},"width",[3445,7859,7860],{"class":3470}," >= ",[3445,7862,7864],{"class":7863},"sJj4R","640px",[3445,7866,7867],{"class":3470},") {\n",[3445,7869,7870,7873,7876,7879,7881,7885],{"class":3447,"line":3481},[3445,7871,7872],{"class":5796},"    .card",[3445,7874,7875],{"class":3470}," { ",[3445,7877,7878],{"class":3466},"flex-direction",[3445,7880,5817],{"class":3470},[3445,7882,7884],{"class":7883},"sDUd3","row",[3445,7886,7887],{"class":3470},"; }\n",[3445,7889,7890],{"class":3447,"line":3488},[3445,7891,5831],{"class":3470},[3445,7893,7894],{"class":3447,"line":3494},[3445,7895,3485],{"emptyLinePlaceholder":3484},[3445,7897,7898],{"class":3447,"line":3510},[3445,7899,7900],{"class":3451},"\u002F* Контейнерний запит — дивиться на контейнер *\u002F\n",[3445,7902,7903,7905],{"class":3447,"line":3515},[3445,7904,3398],{"class":5493},[3445,7906,7907],{"class":3470}," (width >= 400px) {\n",[3445,7909,7910,7912,7914,7916,7918,7920],{"class":3447,"line":3521},[3445,7911,7872],{"class":5796},[3445,7913,7875],{"class":3470},[3445,7915,7878],{"class":3466},[3445,7917,5817],{"class":3470},[3445,7919,7884],{"class":7883},[3445,7921,7887],{"class":3470},[3445,7923,7924],{"class":3447,"line":3537},[3445,7925,5831],{"class":3470},[3353,7927,7928],{},"Картка у sidebar (280px) залишиться вертикальною. Картка у hero (800px) стане горизонтальною. Обидві — на одному viewport, обидві — правильно адаптовані.",[3408,7930],{},[3417,7932,7934],{"id":7933},"_32-синтаксис-контейнерних-запитів-у-tailwind-v4","3.2. Синтаксис контейнерних запитів у Tailwind v4",[3353,7936,7937,7938,7941],{},"У Tailwind v4 контейнерні запити вбудовані ",[3378,7939,7940],{},"з коробки"," — без плагінів, без додаткових залежностей. Це одна із ключових новинок четвертої версії.",[7943,7944,7946],"h4",{"id":7945},"крок-1-оголошення-контейнера","Крок 1: оголошення контейнера",[3353,7948,7949,7950,4189],{},"Елемент, що стежить за своїм розміром, має бути оголошений контейнером через клас ",[3360,7951,3398],{},[3425,7953,7955],{"className":3439,"code":7954,"language":3441,"meta":3433,"style":3433},"\u003C!-- Проста картка-контейнер -->\n\u003Cdiv class=\"@container\">\n    \u003C!-- Вміст адаптується до ширини цього div -->\n    \u003Cdiv class=\"flex flex-col @md:flex-row\">\n        ...\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,7956,7957,7962,7977,7982,7997,8002,8010],{"__ignoreMap":3433},[3445,7958,7959],{"class":3447,"line":3448},[3445,7960,7961],{"class":3451},"\u003C!-- Проста картка-контейнер -->\n",[3445,7963,7964,7966,7968,7970,7972,7975],{"class":3447,"line":3455},[3445,7965,3459],{"class":3458},[3445,7967,3463],{"class":3462},[3445,7969,3467],{"class":3466},[3445,7971,3471],{"class":3470},[3445,7973,7974],{"class":3474},"\"@container\"",[3445,7976,3478],{"class":3458},[3445,7978,7979],{"class":3447,"line":3481},[3445,7980,7981],{"class":3451},"    \u003C!-- Вміст адаптується до ширини цього div -->\n",[3445,7983,7984,7986,7988,7990,7992,7995],{"class":3447,"line":3488},[3445,7985,4506],{"class":3458},[3445,7987,3463],{"class":3462},[3445,7989,3467],{"class":3466},[3445,7991,3471],{"class":3470},[3445,7993,7994],{"class":3474},"\"flex flex-col @md:flex-row\"",[3445,7996,3478],{"class":3458},[3445,7998,7999],{"class":3447,"line":3494},[3445,8000,8001],{"class":3470},"        ...\n",[3445,8003,8004,8006,8008],{"class":3447,"line":3510},[3445,8005,4527],{"class":3458},[3445,8007,3463],{"class":3462},[3445,8009,3478],{"class":3458},[3445,8011,8012,8014,8016],{"class":3447,"line":3515},[3445,8013,4707],{"class":3458},[3445,8015,3463],{"class":3462},[3445,8017,3478],{"class":3458},[3353,8019,8020],{},"CSS, що генерується:",[3425,8022,8024],{"className":5787,"code":8023,"language":5789,"meta":3433,"style":3433},".@container {\n    container-type: inline-size;\n}\n\n@container (width >= 28rem) {\n    .@md\\:flex-row { flex-direction: row; }\n}\n",[3360,8025,8026,8034,8042,8046,8050,8057,8078],{"__ignoreMap":3433},[3445,8027,8028,8032],{"class":3447,"line":3448},[3445,8029,8031],{"class":8030},"se1LK",".@container",[3445,8033,5573],{"class":3470},[3445,8035,8036,8039],{"class":3447,"line":3455},[3445,8037,8038],{"class":3466},"    container-type",[3445,8040,8041],{"class":3470},": inline-size;\n",[3445,8043,8044],{"class":3447,"line":3481},[3445,8045,5831],{"class":3470},[3445,8047,8048],{"class":3447,"line":3488},[3445,8049,3485],{"emptyLinePlaceholder":3484},[3445,8051,8052,8054],{"class":3447,"line":3494},[3445,8053,3398],{"class":5493},[3445,8055,8056],{"class":3470}," (width >= 28rem) {\n",[3445,8058,8059,8062,8065,8068,8070,8072,8074,8076],{"class":3447,"line":3510},[3445,8060,8061],{"class":8030},"    .@md",[3445,8063,8064],{"class":5800},"\\:",[3445,8066,8067],{"class":8030},"flex-row",[3445,8069,7875],{"class":3470},[3445,8071,7878],{"class":3466},[3445,8073,5817],{"class":3470},[3445,8075,7884],{"class":7883},[3445,8077,7887],{"class":3470},[3445,8079,8080],{"class":3447,"line":3515},[3445,8081,5831],{"class":3470},[3404,8083,8084,8085,8087,8088,8091,8092,8095,8096,3630],{},"Клас ",[3360,8086,3398],{}," встановлює ",[3360,8089,8090],{},"container-type: inline-size"," — це означає, що браузер відстежує лише ",[3378,8093,8094],{},"горизонтальний розмір"," контейнера (ширину). Якщо потрібно відстежувати висоту — додайте ",[3360,8097,8098],{},"[container-type:size]",[7943,8100,8102],{"id":8101},"крок-2-іменовані-контейнери","Крок 2: іменовані контейнери",[3353,8104,8105,8106,8109,8110,4189],{},"Якщо контейнери вкладені, виникає неоднозначність — дочірній елемент «бачить» лише ",[3378,8107,8108],{},"найближчий"," контейнер-батько. Для явного зв'язку використовуються ",[3378,8111,8112],{},"іменовані контейнери",[3425,8114,8116],{"className":3439,"code":8115,"language":3441,"meta":3433,"style":3433},"\u003C!-- Іменований контейнер через @container\u002F{name} -->\n\u003Cmain class=\"@container\u002Fmain\">\n    \u003Carticle class=\"@container\u002Fcard\">\n        \u003C!-- Цей варіант реагує на розмір article -->\n        \u003Ch2 class=\"text-base @lg\u002Fcard:text-xl @2xl\u002Fcard:text-3xl\">\n            Заголовок\n        \u003C\u002Fh2>\n\n        \u003C!-- А цей — на розмір main -->\n        \u003Cdiv class=\"hidden @xl\u002Fmain:block\">\n            Видимий тільки коли main ≥ 56rem\n        \u003C\u002Fdiv>\n    \u003C\u002Farticle>\n\u003C\u002Fmain>\n",[3360,8117,8118,8123,8138,8154,8159,8174,8179,8187,8191,8196,8211,8216,8224,8232],{"__ignoreMap":3433},[3445,8119,8120],{"class":3447,"line":3448},[3445,8121,8122],{"class":3451},"\u003C!-- Іменований контейнер через @container\u002F{name} -->\n",[3445,8124,8125,8127,8129,8131,8133,8136],{"class":3447,"line":3455},[3445,8126,3459],{"class":3458},[3445,8128,6950],{"class":3462},[3445,8130,3467],{"class":3466},[3445,8132,3471],{"class":3470},[3445,8134,8135],{"class":3474},"\"@container\u002Fmain\"",[3445,8137,3478],{"class":3458},[3445,8139,8140,8142,8145,8147,8149,8152],{"class":3447,"line":3481},[3445,8141,4506],{"class":3458},[3445,8143,8144],{"class":3462},"article",[3445,8146,3467],{"class":3466},[3445,8148,3471],{"class":3470},[3445,8150,8151],{"class":3474},"\"@container\u002Fcard\"",[3445,8153,3478],{"class":3458},[3445,8155,8156],{"class":3447,"line":3488},[3445,8157,8158],{"class":3451},"        \u003C!-- Цей варіант реагує на розмір article -->\n",[3445,8160,8161,8163,8165,8167,8169,8172],{"class":3447,"line":3494},[3445,8162,4639],{"class":3458},[3445,8164,3348],{"class":3462},[3445,8166,3467],{"class":3466},[3445,8168,3471],{"class":3470},[3445,8170,8171],{"class":3474},"\"text-base @lg\u002Fcard:text-xl @2xl\u002Fcard:text-3xl\"",[3445,8173,3478],{"class":3458},[3445,8175,8176],{"class":3447,"line":3510},[3445,8177,8178],{"class":3470},"            Заголовок\n",[3445,8180,8181,8183,8185],{"class":3447,"line":3515},[3445,8182,4659],{"class":3458},[3445,8184,3348],{"class":3462},[3445,8186,3478],{"class":3458},[3445,8188,8189],{"class":3447,"line":3521},[3445,8190,3485],{"emptyLinePlaceholder":3484},[3445,8192,8193],{"class":3447,"line":3537},[3445,8194,8195],{"class":3451},"        \u003C!-- А цей — на розмір main -->\n",[3445,8197,8198,8200,8202,8204,8206,8209],{"class":3447,"line":3542},[3445,8199,4639],{"class":3458},[3445,8201,3463],{"class":3462},[3445,8203,3467],{"class":3466},[3445,8205,3471],{"class":3470},[3445,8207,8208],{"class":3474},"\"hidden @xl\u002Fmain:block\"",[3445,8210,3478],{"class":3458},[3445,8212,8213],{"class":3447,"line":3548},[3445,8214,8215],{"class":3470},"            Видимий тільки коли main ≥ 56rem\n",[3445,8217,8218,8220,8222],{"class":3447,"line":3564},[3445,8219,4659],{"class":3458},[3445,8221,3463],{"class":3462},[3445,8223,3478],{"class":3458},[3445,8225,8226,8228,8230],{"class":3447,"line":3569},[3445,8227,4527],{"class":3458},[3445,8229,8144],{"class":3462},[3445,8231,3478],{"class":3458},[3445,8233,8234,8236,8238],{"class":3447,"line":3575},[3445,8235,4707],{"class":3458},[3445,8237,6950],{"class":3462},[3445,8239,3478],{"class":3458},[3408,8241],{},[3417,8243,8245],{"id":8244},"_33-breakpoints-контейнерних-запитів","3.3. Breakpoints контейнерних запитів",[3353,8247,8248,8249,4189],{},"Tailwind v4 надає ту саму шкалу breakpoints, що й для медіазапитів, але з префіксом ",[3360,8250,8251],{},"@",[3641,8253,8254,8269],{},[3644,8255,8256],{},[3647,8257,8258,8261,8264],{},[3650,8259,8260],{},"Варіант",[3650,8262,8263],{},"Ширина контейнера",[3650,8265,8266,8267],{},"Аналог ",[3360,8268,7852],{},[3660,8270,8271,8288,8305,8322,8339,8356,8373,8390,8407,8424,8441],{},[3647,8272,8273,8278,8283],{},[3665,8274,8275],{},[3360,8276,8277],{},"@xs:",[3665,8279,8280],{},[3360,8281,8282],{},"≥ 320px",[3665,8284,8285],{},[3360,8286,8287],{},"min-width: 320px",[3647,8289,8290,8295,8300],{},[3665,8291,8292],{},[3360,8293,8294],{},"@sm:",[3665,8296,8297],{},[3360,8298,8299],{},"≥ 384px",[3665,8301,8302],{},[3360,8303,8304],{},"min-width: 384px",[3647,8306,8307,8312,8317],{},[3665,8308,8309],{},[3360,8310,8311],{},"@md:",[3665,8313,8314],{},[3360,8315,8316],{},"≥ 448px",[3665,8318,8319],{},[3360,8320,8321],{},"min-width: 448px",[3647,8323,8324,8329,8334],{},[3665,8325,8326],{},[3360,8327,8328],{},"@lg:",[3665,8330,8331],{},[3360,8332,8333],{},"≥ 512px",[3665,8335,8336],{},[3360,8337,8338],{},"min-width: 512px",[3647,8340,8341,8346,8351],{},[3665,8342,8343],{},[3360,8344,8345],{},"@xl:",[3665,8347,8348],{},[3360,8349,8350],{},"≥ 576px",[3665,8352,8353],{},[3360,8354,8355],{},"min-width: 576px",[3647,8357,8358,8363,8368],{},[3665,8359,8360],{},[3360,8361,8362],{},"@2xl:",[3665,8364,8365],{},[3360,8366,8367],{},"≥ 672px",[3665,8369,8370],{},[3360,8371,8372],{},"min-width: 672px",[3647,8374,8375,8380,8385],{},[3665,8376,8377],{},[3360,8378,8379],{},"@3xl:",[3665,8381,8382],{},[3360,8383,8384],{},"≥ 768px",[3665,8386,8387],{},[3360,8388,8389],{},"min-width: 768px",[3647,8391,8392,8397,8402],{},[3665,8393,8394],{},[3360,8395,8396],{},"@4xl:",[3665,8398,8399],{},[3360,8400,8401],{},"≥ 896px",[3665,8403,8404],{},[3360,8405,8406],{},"min-width: 896px",[3647,8408,8409,8414,8419],{},[3665,8410,8411],{},[3360,8412,8413],{},"@5xl:",[3665,8415,8416],{},[3360,8417,8418],{},"≥ 1024px",[3665,8420,8421],{},[3360,8422,8423],{},"min-width: 1024px",[3647,8425,8426,8431,8436],{},[3665,8427,8428],{},[3360,8429,8430],{},"@6xl:",[3665,8432,8433],{},[3360,8434,8435],{},"≥ 1152px",[3665,8437,8438],{},[3360,8439,8440],{},"min-width: 1152px",[3647,8442,8443,8448,8453],{},[3665,8444,8445],{},[3360,8446,8447],{},"@7xl:",[3665,8449,8450],{},[3360,8451,8452],{},"≥ 1280px",[3665,8454,8455],{},[3360,8456,8457],{},"min-width: 1280px",[3353,8459,8460,8461,3675,8464,8467],{},"Ці breakpoints відрізняються від медіазапитних (",[3360,8462,8463],{},"sm: 640px",[3360,8465,8466],{},"md: 768px"," тощо) — вони починаються з менших значень, оскільки компоненти рідко займають весь viewport.",[3408,8469],{},[3417,8471,8473,8474,3385,8477],{"id":8472},"_34-варіанти-min-та-max","3.4. Варіанти ",[3360,8475,8476],{},"@min-*",[3360,8478,8479],{},"@max-*",[3353,8481,8482,8483,3385,8486,8489],{},"Так само, як медіазапити мають ",[3360,8484,8485],{},"min-width",[3360,8487,8488],{},"max-width",", контейнерні запити підтримують обидві форми.",[3353,8491,8492,8497,8498,8501],{},[3378,8493,8494],{},[3360,8495,8496],{},"@min-{bp}:"," — стиль застосовується коли контейнер ",[3378,8499,8500],{},"ширший або рівний"," значенню (mobile-first):",[3425,8503,8505],{"className":3439,"code":8504,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"@container\">\n    \u003C!-- Типовий mobile-first підхід -->\n    \u003Cdiv class=\"flex-col @min-md:flex-row @min-xl:grid @min-xl:grid-cols-3\">\n",[3360,8506,8507,8521,8526],{"__ignoreMap":3433},[3445,8508,8509,8511,8513,8515,8517,8519],{"class":3447,"line":3448},[3445,8510,3459],{"class":3458},[3445,8512,3463],{"class":3462},[3445,8514,3467],{"class":3466},[3445,8516,3471],{"class":3470},[3445,8518,7974],{"class":3474},[3445,8520,3478],{"class":3458},[3445,8522,8523],{"class":3447,"line":3455},[3445,8524,8525],{"class":3451},"    \u003C!-- Типовий mobile-first підхід -->\n",[3445,8527,8528,8530,8532,8534,8536,8539],{"class":3447,"line":3481},[3445,8529,4506],{"class":3458},[3445,8531,3463],{"class":3462},[3445,8533,3467],{"class":3466},[3445,8535,3471],{"class":3470},[3445,8537,8538],{"class":3474},"\"flex-col @min-md:flex-row @min-xl:grid @min-xl:grid-cols-3\"",[3445,8540,3478],{"class":3458},[3353,8542,8543,8497,8548,8551],{},[3378,8544,8545],{},[3360,8546,8547],{},"@max-{bp}:",[3378,8549,8550],{},"вужчий"," значення (desktop-first):",[3425,8553,8555],{"className":3439,"code":8554,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"@container\">\n    \u003C!-- Сховати текст у вузькому контейнері -->\n    \u003Cbutton class=\"flex gap-2 items-center\">\n        \u003Csvg>...\u003C\u002Fsvg>\n        \u003Cspan class=\"@max-sm:hidden\">Зберегти зміни\u003C\u002Fspan>\n    \u003C\u002Fbutton>\n\u003C\u002Fdiv>\n",[3360,8556,8557,8571,8576,8591,8609,8633,8641],{"__ignoreMap":3433},[3445,8558,8559,8561,8563,8565,8567,8569],{"class":3447,"line":3448},[3445,8560,3459],{"class":3458},[3445,8562,3463],{"class":3462},[3445,8564,3467],{"class":3466},[3445,8566,3471],{"class":3470},[3445,8568,7974],{"class":3474},[3445,8570,3478],{"class":3458},[3445,8572,8573],{"class":3447,"line":3455},[3445,8574,8575],{"class":3451},"    \u003C!-- Сховати текст у вузькому контейнері -->\n",[3445,8577,8578,8580,8582,8584,8586,8589],{"class":3447,"line":3481},[3445,8579,4506],{"class":3458},[3445,8581,5293],{"class":3462},[3445,8583,3467],{"class":3466},[3445,8585,3471],{"class":3470},[3445,8587,8588],{"class":3474},"\"flex gap-2 items-center\"",[3445,8590,3478],{"class":3458},[3445,8592,8593,8595,8598,8600,8603,8605,8607],{"class":3447,"line":3488},[3445,8594,4639],{"class":3458},[3445,8596,8597],{"class":3462},"svg",[3445,8599,3994],{"class":3458},[3445,8601,8602],{"class":3470},"...",[3445,8604,4707],{"class":3458},[3445,8606,8597],{"class":3462},[3445,8608,3478],{"class":3458},[3445,8610,8611,8613,8615,8617,8619,8622,8624,8627,8629,8631],{"class":3447,"line":3494},[3445,8612,4639],{"class":3458},[3445,8614,3445],{"class":3462},[3445,8616,3467],{"class":3466},[3445,8618,3471],{"class":3470},[3445,8620,8621],{"class":3474},"\"@max-sm:hidden\"",[3445,8623,3994],{"class":3458},[3445,8625,8626],{"class":3470},"Зберегти зміни",[3445,8628,4707],{"class":3458},[3445,8630,3445],{"class":3462},[3445,8632,3478],{"class":3458},[3445,8634,8635,8637,8639],{"class":3447,"line":3510},[3445,8636,4527],{"class":3458},[3445,8638,5293],{"class":3462},[3445,8640,3478],{"class":3458},[3445,8642,8643,8645,8647],{"class":3447,"line":3515},[3445,8644,4707],{"class":3458},[3445,8646,3463],{"class":3462},[3445,8648,3478],{"class":3458},[3353,8650,8651,8661],{},[3378,8652,8653,8654,8657,8658],{},"Комбінування ",[3360,8655,8656],{},"@min"," + ",[3360,8659,8660],{},"@max"," — для стилів у конкретному діапазоні:",[3425,8663,8665],{"className":3439,"code":8664,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"@container\">\n    \u003C!-- Показувати тільки у проміжному розмірі -->\n    \u003Cdiv class=\"hidden @min-sm:@max-lg:block\">\n        Видимий тільки коли контейнер від 384px до 512px\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,8666,8667,8681,8686,8701,8706,8714],{"__ignoreMap":3433},[3445,8668,8669,8671,8673,8675,8677,8679],{"class":3447,"line":3448},[3445,8670,3459],{"class":3458},[3445,8672,3463],{"class":3462},[3445,8674,3467],{"class":3466},[3445,8676,3471],{"class":3470},[3445,8678,7974],{"class":3474},[3445,8680,3478],{"class":3458},[3445,8682,8683],{"class":3447,"line":3455},[3445,8684,8685],{"class":3451},"    \u003C!-- Показувати тільки у проміжному розмірі -->\n",[3445,8687,8688,8690,8692,8694,8696,8699],{"class":3447,"line":3481},[3445,8689,4506],{"class":3458},[3445,8691,3463],{"class":3462},[3445,8693,3467],{"class":3466},[3445,8695,3471],{"class":3470},[3445,8697,8698],{"class":3474},"\"hidden @min-sm:@max-lg:block\"",[3445,8700,3478],{"class":3458},[3445,8702,8703],{"class":3447,"line":3488},[3445,8704,8705],{"class":3470},"        Видимий тільки коли контейнер від 384px до 512px\n",[3445,8707,8708,8710,8712],{"class":3447,"line":3494},[3445,8709,4527],{"class":3458},[3445,8711,3463],{"class":3462},[3445,8713,3478],{"class":3458},[3445,8715,8716,8718,8720],{"class":3447,"line":3510},[3445,8717,4707],{"class":3458},[3445,8719,3463],{"class":3462},[3445,8721,3478],{"class":3458},[3353,8723,8724],{},[3378,8725,8726],{},"Довільні значення у контейнерних запитах:",[3425,8728,8730],{"className":3439,"code":8729,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"@container\">\n    \u003C!-- Контейнерний запит із точним значенням -->\n    \u003Cdiv class=\"flex-col @min-[350px]:flex-row @min-[600px]:grid-cols-2\">\n",[3360,8731,8732,8746,8751],{"__ignoreMap":3433},[3445,8733,8734,8736,8738,8740,8742,8744],{"class":3447,"line":3448},[3445,8735,3459],{"class":3458},[3445,8737,3463],{"class":3462},[3445,8739,3467],{"class":3466},[3445,8741,3471],{"class":3470},[3445,8743,7974],{"class":3474},[3445,8745,3478],{"class":3458},[3445,8747,8748],{"class":3447,"line":3455},[3445,8749,8750],{"class":3451},"    \u003C!-- Контейнерний запит із точним значенням -->\n",[3445,8752,8753,8755,8757,8759,8761,8764],{"class":3447,"line":3481},[3445,8754,4506],{"class":3458},[3445,8756,3463],{"class":3462},[3445,8758,3467],{"class":3466},[3445,8760,3471],{"class":3470},[3445,8762,8763],{"class":3474},"\"flex-col @min-[350px]:flex-row @min-[600px]:grid-cols-2\"",[3445,8765,3478],{"class":3458},[3408,8767],{},[3417,8769,8771,8772],{"id":8770},"_35-живий-приклад-адаптивна-картка-через-container","3.5. Живий приклад: адаптивна картка через ",[3360,8773,3398],{},[3353,8775,8776],{},"Найкраще розуміння контейнерних запитів дає практичний приклад — одна картка, що змінює layout залежно від ширини свого контейнера. Спробуйте змінити ширину контейнера у DevTools, щоб побачити, як компонент адаптується:",[4471,8778,8779],{":tailwind":4473},[3425,8780,8782],{"className":3439,"code":8781,"language":3441,"meta":3433,"style":3433},"\u003C!DOCTYPE html>\n\u003Chtml lang=\"uk\">\n\u003Chead>\n    \u003Cmeta charset=\"UTF-8\">\n    \u003Cscript src=\"https:\u002F\u002Fcdn.tailwindcss.com\u002F4.0\">\u003C\u002Fscript>\n\u003C\u002Fhead>\n\u003Cbody class=\"bg-slate-100 p-6\" style=\"font-family: system-ui, sans-serif;\">\n\n\u003Cp class=\"text-xs font-bold uppercase tracking-widest text-slate-400 mb-4 text-center\">\n    Перетягніть повзунок, щоб змінити ширину контейнера\n\u003C\u002Fp>\n\n\u003C!-- Повзунок для зміни ширини контейнера -->\n\u003Cdiv class=\"flex items-center gap-3 mb-6 max-w-2xl mx-auto\">\n    \u003Cspan class=\"text-xs text-slate-500 w-8\">180\u003C\u002Fspan>\n    \u003Cinput type=\"range\" min=\"180\" max=\"700\" value=\"340\" id=\"width-slider\"\n           class=\"flex-1\" oninput=\"updateWidth(this.value)\">\n    \u003Cspan class=\"text-xs text-slate-500 w-8\">700\u003C\u002Fspan>\n    \u003Cspan id=\"width-label\" class=\"text-xs font-mono bg-slate-200 px-2 py-0.5 rounded text-slate-700 min-w-[52px] text-center\">\n        340px\n    \u003C\u002Fspan>\n\u003C\u002Fdiv>\n\n\u003C!-- Контейнер із регульованою шириною -->\n\u003Cdiv id=\"container-wrapper\" class=\"mx-auto transition-all duration-200\" style=\"width: 340px;\">\n    \u003C!-- @container: компонент адаптується до ширини wrapper -->\n    \u003Cdiv class=\"@container\">\n        \u003C!--\n            \u003C 280px  → тільки аватар і ім'я (вертикально, компактно)\n            280-400px → вертикальний layout, всі елементи\n            400px+   → горизонтальний layout (flex-row)\n            560px+   → з'являється статистика\n        -->\n        \u003Cdiv class=\"bg-white rounded-2xl overflow-hidden border border-slate-200 shadow-sm\">\n\n            \u003C!-- Горизонтальний layout на великих контейнерах -->\n            \u003Cdiv class=\"flex flex-col @[400px]:flex-row\">\n\n                \u003C!-- Аватар \u002F обкладинка -->\n                \u003Cdiv class=\"bg-gradient-to-br from-indigo-500 to-violet-600\n                            flex items-center justify-center\n                            h-32 @[400px]:h-auto @[400px]:w-32 @[400px]:shrink-0 flex-shrink-0\">\n                    \u003Cdiv class=\"size-16 rounded-2xl bg-white\u002F20 border-2 border-white\u002F40\n                                flex items-center justify-center text-white font-black text-xl\">\n                        IK\n                    \u003C\u002Fdiv>\n                \u003C\u002Fdiv>\n\n                \u003C!-- Основний контент -->\n                \u003Cdiv class=\"p-4 @[280px]:p-5 flex-1 min-w-0\">\n                    \u003C!-- Ім'я та роль -->\n                    \u003Cdiv class=\"flex items-start justify-between gap-2 mb-3\">\n                        \u003Cdiv class=\"min-w-0\">\n                            \u003Ch3 class=\"font-bold text-slate-900 text-sm @[280px]:text-base truncate\">\n                                Іван Кравченко\n                            \u003C\u002Fh3>\n                            \u003Cp class=\"text-xs @[280px]:text-sm text-slate-500\">\n                                Frontend Developer\n                            \u003C\u002Fp>\n                        \u003C\u002Fdiv>\n                        \u003C!-- Badge — прихований на дуже малих контейнерах -->\n                        \u003Cspan class=\"hidden @[280px]:inline-flex shrink-0\n                                     px-2 py-0.5 bg-indigo-100 text-indigo-700\n                                     text-xs font-semibold rounded-full\">\n                            Pro\n                        \u003C\u002Fspan>\n                    \u003C\u002Fdiv>\n\n                    \u003C!-- Опис — прихований на малих контейнерах -->\n                    \u003Cp class=\"hidden @[320px]:block text-xs text-slate-600 leading-relaxed mb-3 line-clamp-2\">\n                        Розробляю інтерфейси на React та Tailwind. Захоплений сучасним CSS та архітектурою дизайн-систем.\n                    \u003C\u002Fp>\n\n                    \u003C!-- Статистика — лише на широких контейнерах -->\n                    \u003Cdiv class=\"hidden @[560px]:grid grid-cols-3 gap-3 mb-3 py-3 border-t border-slate-100\">\n                        \u003Cdiv class=\"text-center\">\n                            \u003Cp class=\"text-base font-black text-slate-900\">48\u003C\u002Fp>\n                            \u003Cp class=\"text-xs text-slate-400\">Проєкти\u003C\u002Fp>\n                        \u003C\u002Fdiv>\n                        \u003Cdiv class=\"text-center\">\n                            \u003Cp class=\"text-base font-black text-slate-900\">2.4k\u003C\u002Fp>\n                            \u003Cp class=\"text-xs text-slate-400\">Підписники\u003C\u002Fp>\n                        \u003C\u002Fdiv>\n                        \u003Cdiv class=\"text-center\">\n                            \u003Cp class=\"text-base font-black text-slate-900\">97%\u003C\u002Fp>\n                            \u003Cp class=\"text-xs text-slate-400\">Рейтинг\u003C\u002Fp>\n                        \u003C\u002Fdiv>\n                    \u003C\u002Fdiv>\n\n                    \u003C!-- Кнопки -->\n                    \u003Cdiv class=\"flex gap-2\">\n                        \u003Cbutton class=\"flex-1 @[400px]:flex-none\n                                       py-1.5 px-3 @[280px]:px-4\n                                       bg-indigo-600 hover:bg-indigo-700\n                                       text-white text-xs @[280px]:text-sm font-semibold\n                                       rounded-lg transition-colors\">\n                            Профіль\n                        \u003C\u002Fbutton>\n                        \u003C!-- Друга кнопка — лише якщо є місце -->\n                        \u003Cbutton class=\"hidden @[320px]:flex\n                                       items-center gap-1.5\n                                       py-1.5 px-3 @[280px]:px-4\n                                       border border-slate-200 hover:bg-slate-50\n                                       text-slate-700 text-xs @[280px]:text-sm font-semibold\n                                       rounded-lg transition-colors\">\n                            \u003Cspan>Написати\u003C\u002Fspan>\n                        \u003C\u002Fbutton>\n                    \u003C\u002Fdiv>\n                \u003C\u002Fdiv>\n            \u003C\u002Fdiv>\n        \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n\n\u003C!-- Індикатор поточного breakpoint -->\n\u003Cdiv class=\"text-center mt-4\">\n    \u003Cp class=\"text-xs text-slate-500\" id=\"breakpoint-label\">...\u003C\u002Fp>\n\u003C\u002Fdiv>\n\n\u003Cscript>\n    function updateWidth(val) {\n        document.getElementById('container-wrapper').style.width = val + 'px'\n        document.getElementById('width-label').textContent = val + 'px'\n\n        const v = parseInt(val)\n        let bp = ''\n        if (v \u003C 280) bp = '\u003C 280px — мінімальний'\n        else if (v \u003C 320) bp = '≥ 280px — badge, опис'\n        else if (v \u003C 400) bp = '≥ 320px — друга кнопка + опис'\n        else if (v \u003C 560) bp = '≥ 400px — горизонтальний layout'\n        else bp = '≥ 560px — статистика'\n\n        document.getElementById('breakpoint-label').textContent = 'Активний breakpoint: ' + bp\n    }\n    updateWidth(340)\n\u003C\u002Fscript>\n\u003C\u002Fbody>\n\u003C\u002Fhtml>\n",[3360,8783,8784,8794,8808,8816,8830,8849,8857,8878,8882,8897,8902,8910,8914,8919,8934,8958,9002,9037,9060,9082,9087,9095,9103,9107,9112,9141,9146,9160,9165,9170,9175,9180,9185,9190,9205,9209,9214,9229,9233,9238,9251,9256,9263,9277,9284,9289,9298,9306,9310,9315,9331,9337,9353,9370,9387,9393,9403,9419,9425,9434,9444,9450,9464,9470,9478,9484,9493,9502,9507,9513,9529,9535,9544,9549,9555,9571,9587,9612,9637,9646,9661,9685,9709,9718,9733,9757,9781,9790,9799,9804,9810,9826,9840,9846,9852,9858,9866,9872,9881,9887,9901,9907,9912,9918,9924,9931,9949,9958,9967,9976,9985,9994,10003,10012,10017,10023,10039,10070,10079,10084,10093,10109,10145,10171,10176,10197,10211,10239,10266,10291,10316,10328,10333,10361,10367,10380,10389,10398],{"__ignoreMap":3433},[3445,8785,8786,8788,8790,8792],{"class":3447,"line":3448},[3445,8787,4945],{"class":3458},[3445,8789,4948],{"class":3462},[3445,8791,4951],{"class":3466},[3445,8793,3478],{"class":3458},[3445,8795,8796,8798,8800,8802,8804,8806],{"class":3447,"line":3455},[3445,8797,3459],{"class":3458},[3445,8799,3441],{"class":3462},[3445,8801,4962],{"class":3466},[3445,8803,3471],{"class":3470},[3445,8805,4967],{"class":3474},[3445,8807,3478],{"class":3458},[3445,8809,8810,8812,8814],{"class":3447,"line":3481},[3445,8811,3459],{"class":3458},[3445,8813,4976],{"class":3462},[3445,8815,3478],{"class":3458},[3445,8817,8818,8820,8822,8824,8826,8828],{"class":3447,"line":3488},[3445,8819,4506],{"class":3458},[3445,8821,4985],{"class":3462},[3445,8823,4988],{"class":3466},[3445,8825,3471],{"class":3470},[3445,8827,4993],{"class":3474},[3445,8829,3478],{"class":3458},[3445,8831,8832,8834,8836,8838,8840,8843,8845,8847],{"class":3447,"line":3494},[3445,8833,4506],{"class":3458},[3445,8835,5002],{"class":3462},[3445,8837,5005],{"class":3466},[3445,8839,3471],{"class":5008},[3445,8841,8842],{"class":3474},"\"https:\u002F\u002Fcdn.tailwindcss.com\u002F4.0\"",[3445,8844,5014],{"class":3458},[3445,8846,5002],{"class":3462},[3445,8848,3478],{"class":3458},[3445,8850,8851,8853,8855],{"class":3447,"line":3510},[3445,8852,4707],{"class":3458},[3445,8854,4976],{"class":3462},[3445,8856,3478],{"class":3458},[3445,8858,8859,8861,8863,8865,8867,8870,8872,8874,8876],{"class":3447,"line":3515},[3445,8860,3459],{"class":3458},[3445,8862,5058],{"class":3462},[3445,8864,3467],{"class":3466},[3445,8866,3471],{"class":3470},[3445,8868,8869],{"class":3474},"\"bg-slate-100 p-6\"",[3445,8871,4494],{"class":3466},[3445,8873,3471],{"class":3470},[3445,8875,4499],{"class":3474},[3445,8877,3478],{"class":3458},[3445,8879,8880],{"class":3447,"line":3521},[3445,8881,3485],{"emptyLinePlaceholder":3484},[3445,8883,8884,8886,8888,8890,8892,8895],{"class":3447,"line":3537},[3445,8885,3459],{"class":3458},[3445,8887,3353],{"class":3462},[3445,8889,3467],{"class":3466},[3445,8891,3471],{"class":3470},[3445,8893,8894],{"class":3474},"\"text-xs font-bold uppercase tracking-widest text-slate-400 mb-4 text-center\"",[3445,8896,3478],{"class":3458},[3445,8898,8899],{"class":3447,"line":3542},[3445,8900,8901],{"class":3470},"    Перетягніть повзунок, щоб змінити ширину контейнера\n",[3445,8903,8904,8906,8908],{"class":3447,"line":3548},[3445,8905,4707],{"class":3458},[3445,8907,3353],{"class":3462},[3445,8909,3478],{"class":3458},[3445,8911,8912],{"class":3447,"line":3564},[3445,8913,3485],{"emptyLinePlaceholder":3484},[3445,8915,8916],{"class":3447,"line":3569},[3445,8917,8918],{"class":3451},"\u003C!-- Повзунок для зміни ширини контейнера -->\n",[3445,8920,8921,8923,8925,8927,8929,8932],{"class":3447,"line":3575},[3445,8922,3459],{"class":3458},[3445,8924,3463],{"class":3462},[3445,8926,3467],{"class":3466},[3445,8928,3471],{"class":3470},[3445,8930,8931],{"class":3474},"\"flex items-center gap-3 mb-6 max-w-2xl mx-auto\"",[3445,8933,3478],{"class":3458},[3445,8935,8936,8938,8940,8942,8944,8947,8949,8952,8954,8956],{"class":3447,"line":3591},[3445,8937,4506],{"class":3458},[3445,8939,3445],{"class":3462},[3445,8941,3467],{"class":3466},[3445,8943,3471],{"class":3470},[3445,8945,8946],{"class":3474},"\"text-xs text-slate-500 w-8\"",[3445,8948,3994],{"class":3458},[3445,8950,8951],{"class":3470},"180",[3445,8953,4707],{"class":3458},[3445,8955,3445],{"class":3462},[3445,8957,3478],{"class":3458},[3445,8959,8960,8962,8964,8966,8968,8971,8974,8976,8979,8982,8984,8987,8990,8992,8995,8997,8999],{"class":3447,"line":3596},[3445,8961,4506],{"class":3458},[3445,8963,4817],{"class":3462},[3445,8965,4820],{"class":3466},[3445,8967,3471],{"class":3470},[3445,8969,8970],{"class":3474},"\"range\"",[3445,8972,8973],{"class":3466}," min",[3445,8975,3471],{"class":3470},[3445,8977,8978],{"class":3474},"\"180\"",[3445,8980,8981],{"class":3466}," max",[3445,8983,3471],{"class":3470},[3445,8985,8986],{"class":3474},"\"700\"",[3445,8988,8989],{"class":3466}," value",[3445,8991,3471],{"class":3470},[3445,8993,8994],{"class":3474},"\"340\"",[3445,8996,5372],{"class":3466},[3445,8998,3471],{"class":3470},[3445,9000,9001],{"class":3474},"\"width-slider\"\n",[3445,9003,9004,9007,9009,9012,9015,9017,9019,9022,9024,9027,9029,9032,9035],{"class":3447,"line":3602},[3445,9005,9006],{"class":3466},"           class",[3445,9008,3471],{"class":3470},[3445,9010,9011],{"class":3474},"\"flex-1\"",[3445,9013,9014],{"class":3466}," oninput",[3445,9016,3471],{"class":3470},[3445,9018,5301],{"class":3474},[3445,9020,9021],{"class":5304},"updateWidth",[3445,9023,5480],{"class":3474},[3445,9025,9026],{"class":5448},"this",[3445,9028,3630],{"class":3474},[3445,9030,9031],{"class":5471},"value",[3445,9033,9034],{"class":3474},")\"",[3445,9036,3478],{"class":3458},[3445,9038,9039,9041,9043,9045,9047,9049,9051,9054,9056,9058],{"class":3447,"line":4129},[3445,9040,4506],{"class":3458},[3445,9042,3445],{"class":3462},[3445,9044,3467],{"class":3466},[3445,9046,3471],{"class":3470},[3445,9048,8946],{"class":3474},[3445,9050,3994],{"class":3458},[3445,9052,9053],{"class":3470},"700",[3445,9055,4707],{"class":3458},[3445,9057,3445],{"class":3462},[3445,9059,3478],{"class":3458},[3445,9061,9062,9064,9066,9068,9070,9073,9075,9077,9080],{"class":3447,"line":4134},[3445,9063,4506],{"class":3458},[3445,9065,3445],{"class":3462},[3445,9067,5372],{"class":3466},[3445,9069,3471],{"class":3470},[3445,9071,9072],{"class":3474},"\"width-label\"",[3445,9074,3467],{"class":3466},[3445,9076,3471],{"class":3470},[3445,9078,9079],{"class":3474},"\"text-xs font-mono bg-slate-200 px-2 py-0.5 rounded text-slate-700 min-w-[52px] text-center\"",[3445,9081,3478],{"class":3458},[3445,9083,9084],{"class":3447,"line":4140},[3445,9085,9086],{"class":3470},"        340px\n",[3445,9088,9089,9091,9093],{"class":3447,"line":4156},[3445,9090,4527],{"class":3458},[3445,9092,3445],{"class":3462},[3445,9094,3478],{"class":3458},[3445,9096,9097,9099,9101],{"class":3447,"line":4162},[3445,9098,4707],{"class":3458},[3445,9100,3463],{"class":3462},[3445,9102,3478],{"class":3458},[3445,9104,9105],{"class":3447,"line":4447},[3445,9106,3485],{"emptyLinePlaceholder":3484},[3445,9108,9109],{"class":3447,"line":4686},[3445,9110,9111],{"class":3451},"\u003C!-- Контейнер із регульованою шириною -->\n",[3445,9113,9114,9116,9118,9120,9122,9125,9127,9129,9132,9134,9136,9139],{"class":3447,"line":4695},[3445,9115,3459],{"class":3458},[3445,9117,3463],{"class":3462},[3445,9119,5372],{"class":3466},[3445,9121,3471],{"class":3470},[3445,9123,9124],{"class":3474},"\"container-wrapper\"",[3445,9126,3467],{"class":3466},[3445,9128,3471],{"class":3470},[3445,9130,9131],{"class":3474},"\"mx-auto transition-all duration-200\"",[3445,9133,4494],{"class":3466},[3445,9135,3471],{"class":3470},[3445,9137,9138],{"class":3474},"\"width: 340px;\"",[3445,9140,3478],{"class":3458},[3445,9142,9143],{"class":3447,"line":4704},[3445,9144,9145],{"class":3451},"    \u003C!-- @container: компонент адаптується до ширини wrapper -->\n",[3445,9147,9148,9150,9152,9154,9156,9158],{"class":3447,"line":5343},[3445,9149,4506],{"class":3458},[3445,9151,3463],{"class":3462},[3445,9153,3467],{"class":3466},[3445,9155,3471],{"class":3470},[3445,9157,7974],{"class":3474},[3445,9159,3478],{"class":3458},[3445,9161,9162],{"class":3447,"line":5349},[3445,9163,9164],{"class":3451},"        \u003C!--\n",[3445,9166,9167],{"class":3447,"line":5365},[3445,9168,9169],{"class":3451},"            \u003C 280px  → тільки аватар і ім'я (вертикально, компактно)\n",[3445,9171,9172],{"class":3447,"line":5389},[3445,9173,9174],{"class":3451},"            280-400px → вертикальний layout, всі елементи\n",[3445,9176,9177],{"class":3447,"line":5395},[3445,9178,9179],{"class":3451},"            400px+   → горизонтальний layout (flex-row)\n",[3445,9181,9182],{"class":3447,"line":5404},[3445,9183,9184],{"class":3451},"            560px+   → з'являється статистика\n",[3445,9186,9187],{"class":3447,"line":5413},[3445,9188,9189],{"class":3451},"        -->\n",[3445,9191,9192,9194,9196,9198,9200,9203],{"class":3447,"line":5422},[3445,9193,4639],{"class":3458},[3445,9195,3463],{"class":3462},[3445,9197,3467],{"class":3466},[3445,9199,3471],{"class":3470},[3445,9201,9202],{"class":3474},"\"bg-white rounded-2xl overflow-hidden border border-slate-200 shadow-sm\"",[3445,9204,3478],{"class":3458},[3445,9206,9207],{"class":3447,"line":5431},[3445,9208,3485],{"emptyLinePlaceholder":3484},[3445,9210,9211],{"class":3447,"line":5436},[3445,9212,9213],{"class":3451},"            \u003C!-- Горизонтальний layout на великих контейнерах -->\n",[3445,9215,9216,9218,9220,9222,9224,9227],{"class":3447,"line":5445},[3445,9217,5143],{"class":3458},[3445,9219,3463],{"class":3462},[3445,9221,3467],{"class":3466},[3445,9223,3471],{"class":3470},[3445,9225,9226],{"class":3474},"\"flex flex-col @[400px]:flex-row\"",[3445,9228,3478],{"class":3458},[3445,9230,9231],{"class":3447,"line":5458},[3445,9232,3485],{"emptyLinePlaceholder":3484},[3445,9234,9235],{"class":3447,"line":5490},[3445,9236,9237],{"class":3451},"                \u003C!-- Аватар \u002F обкладинка -->\n",[3445,9239,9240,9242,9244,9246,9248],{"class":3447,"line":5520},[3445,9241,5267],{"class":3458},[3445,9243,3463],{"class":3462},[3445,9245,3467],{"class":3466},[3445,9247,3471],{"class":3470},[3445,9249,9250],{"class":3474},"\"bg-gradient-to-br from-indigo-500 to-violet-600\n",[3445,9252,9253],{"class":3447,"line":5546},[3445,9254,9255],{"class":3474},"                            flex items-center justify-center\n",[3445,9257,9258,9261],{"class":3447,"line":5564},[3445,9259,9260],{"class":3474},"                            h-32 @[400px]:h-auto @[400px]:w-32 @[400px]:shrink-0 flex-shrink-0\"",[3445,9262,3478],{"class":3458},[3445,9264,9265,9268,9270,9272,9274],{"class":3447,"line":5576},[3445,9266,9267],{"class":3458},"                    \u003C",[3445,9269,3463],{"class":3462},[3445,9271,3467],{"class":3466},[3445,9273,3471],{"class":3470},[3445,9275,9276],{"class":3474},"\"size-16 rounded-2xl bg-white\u002F20 border-2 border-white\u002F40\n",[3445,9278,9279,9282],{"class":3447,"line":5600},[3445,9280,9281],{"class":3474},"                                flex items-center justify-center text-white font-black text-xl\"",[3445,9283,3478],{"class":3458},[3445,9285,9286],{"class":3447,"line":5616},[3445,9287,9288],{"class":3470},"                        IK\n",[3445,9290,9291,9294,9296],{"class":3447,"line":5622},[3445,9292,9293],{"class":3458},"                    \u003C\u002F",[3445,9295,3463],{"class":3462},[3445,9297,3478],{"class":3458},[3445,9299,9300,9302,9304],{"class":3447,"line":5628},[3445,9301,5327],{"class":3458},[3445,9303,3463],{"class":3462},[3445,9305,3478],{"class":3458},[3445,9307,9308],{"class":3447,"line":5637},[3445,9309,3485],{"emptyLinePlaceholder":3484},[3445,9311,9312],{"class":3447,"line":5646},[3445,9313,9314],{"class":3451},"                \u003C!-- Основний контент -->\n",[3445,9316,9318,9320,9322,9324,9326,9329],{"class":3447,"line":9317},50,[3445,9319,5267],{"class":3458},[3445,9321,3463],{"class":3462},[3445,9323,3467],{"class":3466},[3445,9325,3471],{"class":3470},[3445,9327,9328],{"class":3474},"\"p-4 @[280px]:p-5 flex-1 min-w-0\"",[3445,9330,3478],{"class":3458},[3445,9332,9334],{"class":3447,"line":9333},51,[3445,9335,9336],{"class":3451},"                    \u003C!-- Ім'я та роль -->\n",[3445,9338,9340,9342,9344,9346,9348,9351],{"class":3447,"line":9339},52,[3445,9341,9267],{"class":3458},[3445,9343,3463],{"class":3462},[3445,9345,3467],{"class":3466},[3445,9347,3471],{"class":3470},[3445,9349,9350],{"class":3474},"\"flex items-start justify-between gap-2 mb-3\"",[3445,9352,3478],{"class":3458},[3445,9354,9356,9359,9361,9363,9365,9368],{"class":3447,"line":9355},53,[3445,9357,9358],{"class":3458},"                        \u003C",[3445,9360,3463],{"class":3462},[3445,9362,3467],{"class":3466},[3445,9364,3471],{"class":3470},[3445,9366,9367],{"class":3474},"\"min-w-0\"",[3445,9369,3478],{"class":3458},[3445,9371,9373,9376,9378,9380,9382,9385],{"class":3447,"line":9372},54,[3445,9374,9375],{"class":3458},"                            \u003C",[3445,9377,3417],{"class":3462},[3445,9379,3467],{"class":3466},[3445,9381,3471],{"class":3470},[3445,9383,9384],{"class":3474},"\"font-bold text-slate-900 text-sm @[280px]:text-base truncate\"",[3445,9386,3478],{"class":3458},[3445,9388,9390],{"class":3447,"line":9389},55,[3445,9391,9392],{"class":3470},"                                Іван Кравченко\n",[3445,9394,9396,9399,9401],{"class":3447,"line":9395},56,[3445,9397,9398],{"class":3458},"                            \u003C\u002F",[3445,9400,3417],{"class":3462},[3445,9402,3478],{"class":3458},[3445,9404,9406,9408,9410,9412,9414,9417],{"class":3447,"line":9405},57,[3445,9407,9375],{"class":3458},[3445,9409,3353],{"class":3462},[3445,9411,3467],{"class":3466},[3445,9413,3471],{"class":3470},[3445,9415,9416],{"class":3474},"\"text-xs @[280px]:text-sm text-slate-500\"",[3445,9418,3478],{"class":3458},[3445,9420,9422],{"class":3447,"line":9421},58,[3445,9423,9424],{"class":3470},"                                Frontend Developer\n",[3445,9426,9428,9430,9432],{"class":3447,"line":9427},59,[3445,9429,9398],{"class":3458},[3445,9431,3353],{"class":3462},[3445,9433,3478],{"class":3458},[3445,9435,9437,9440,9442],{"class":3447,"line":9436},60,[3445,9438,9439],{"class":3458},"                        \u003C\u002F",[3445,9441,3463],{"class":3462},[3445,9443,3478],{"class":3458},[3445,9445,9447],{"class":3447,"line":9446},61,[3445,9448,9449],{"class":3451},"                        \u003C!-- Badge — прихований на дуже малих контейнерах -->\n",[3445,9451,9453,9455,9457,9459,9461],{"class":3447,"line":9452},62,[3445,9454,9358],{"class":3458},[3445,9456,3445],{"class":3462},[3445,9458,3467],{"class":3466},[3445,9460,3471],{"class":3470},[3445,9462,9463],{"class":3474},"\"hidden @[280px]:inline-flex shrink-0\n",[3445,9465,9467],{"class":3447,"line":9466},63,[3445,9468,9469],{"class":3474},"                                     px-2 py-0.5 bg-indigo-100 text-indigo-700\n",[3445,9471,9473,9476],{"class":3447,"line":9472},64,[3445,9474,9475],{"class":3474},"                                     text-xs font-semibold rounded-full\"",[3445,9477,3478],{"class":3458},[3445,9479,9481],{"class":3447,"line":9480},65,[3445,9482,9483],{"class":3470},"                            Pro\n",[3445,9485,9487,9489,9491],{"class":3447,"line":9486},66,[3445,9488,9439],{"class":3458},[3445,9490,3445],{"class":3462},[3445,9492,3478],{"class":3458},[3445,9494,9496,9498,9500],{"class":3447,"line":9495},67,[3445,9497,9293],{"class":3458},[3445,9499,3463],{"class":3462},[3445,9501,3478],{"class":3458},[3445,9503,9505],{"class":3447,"line":9504},68,[3445,9506,3485],{"emptyLinePlaceholder":3484},[3445,9508,9510],{"class":3447,"line":9509},69,[3445,9511,9512],{"class":3451},"                    \u003C!-- Опис — прихований на малих контейнерах -->\n",[3445,9514,9516,9518,9520,9522,9524,9527],{"class":3447,"line":9515},70,[3445,9517,9267],{"class":3458},[3445,9519,3353],{"class":3462},[3445,9521,3467],{"class":3466},[3445,9523,3471],{"class":3470},[3445,9525,9526],{"class":3474},"\"hidden @[320px]:block text-xs text-slate-600 leading-relaxed mb-3 line-clamp-2\"",[3445,9528,3478],{"class":3458},[3445,9530,9532],{"class":3447,"line":9531},71,[3445,9533,9534],{"class":3470},"                        Розробляю інтерфейси на React та Tailwind. Захоплений сучасним CSS та архітектурою дизайн-систем.\n",[3445,9536,9538,9540,9542],{"class":3447,"line":9537},72,[3445,9539,9293],{"class":3458},[3445,9541,3353],{"class":3462},[3445,9543,3478],{"class":3458},[3445,9545,9547],{"class":3447,"line":9546},73,[3445,9548,3485],{"emptyLinePlaceholder":3484},[3445,9550,9552],{"class":3447,"line":9551},74,[3445,9553,9554],{"class":3451},"                    \u003C!-- Статистика — лише на широких контейнерах -->\n",[3445,9556,9558,9560,9562,9564,9566,9569],{"class":3447,"line":9557},75,[3445,9559,9267],{"class":3458},[3445,9561,3463],{"class":3462},[3445,9563,3467],{"class":3466},[3445,9565,3471],{"class":3470},[3445,9567,9568],{"class":3474},"\"hidden @[560px]:grid grid-cols-3 gap-3 mb-3 py-3 border-t border-slate-100\"",[3445,9570,3478],{"class":3458},[3445,9572,9574,9576,9578,9580,9582,9585],{"class":3447,"line":9573},76,[3445,9575,9358],{"class":3458},[3445,9577,3463],{"class":3462},[3445,9579,3467],{"class":3466},[3445,9581,3471],{"class":3470},[3445,9583,9584],{"class":3474},"\"text-center\"",[3445,9586,3478],{"class":3458},[3445,9588,9590,9592,9594,9596,9598,9601,9603,9606,9608,9610],{"class":3447,"line":9589},77,[3445,9591,9375],{"class":3458},[3445,9593,3353],{"class":3462},[3445,9595,3467],{"class":3466},[3445,9597,3471],{"class":3470},[3445,9599,9600],{"class":3474},"\"text-base font-black text-slate-900\"",[3445,9602,3994],{"class":3458},[3445,9604,9605],{"class":3470},"48",[3445,9607,4707],{"class":3458},[3445,9609,3353],{"class":3462},[3445,9611,3478],{"class":3458},[3445,9613,9615,9617,9619,9621,9623,9626,9628,9631,9633,9635],{"class":3447,"line":9614},78,[3445,9616,9375],{"class":3458},[3445,9618,3353],{"class":3462},[3445,9620,3467],{"class":3466},[3445,9622,3471],{"class":3470},[3445,9624,9625],{"class":3474},"\"text-xs text-slate-400\"",[3445,9627,3994],{"class":3458},[3445,9629,9630],{"class":3470},"Проєкти",[3445,9632,4707],{"class":3458},[3445,9634,3353],{"class":3462},[3445,9636,3478],{"class":3458},[3445,9638,9640,9642,9644],{"class":3447,"line":9639},79,[3445,9641,9439],{"class":3458},[3445,9643,3463],{"class":3462},[3445,9645,3478],{"class":3458},[3445,9647,9649,9651,9653,9655,9657,9659],{"class":3447,"line":9648},80,[3445,9650,9358],{"class":3458},[3445,9652,3463],{"class":3462},[3445,9654,3467],{"class":3466},[3445,9656,3471],{"class":3470},[3445,9658,9584],{"class":3474},[3445,9660,3478],{"class":3458},[3445,9662,9664,9666,9668,9670,9672,9674,9676,9679,9681,9683],{"class":3447,"line":9663},81,[3445,9665,9375],{"class":3458},[3445,9667,3353],{"class":3462},[3445,9669,3467],{"class":3466},[3445,9671,3471],{"class":3470},[3445,9673,9600],{"class":3474},[3445,9675,3994],{"class":3458},[3445,9677,9678],{"class":3470},"2.4k",[3445,9680,4707],{"class":3458},[3445,9682,3353],{"class":3462},[3445,9684,3478],{"class":3458},[3445,9686,9688,9690,9692,9694,9696,9698,9700,9703,9705,9707],{"class":3447,"line":9687},82,[3445,9689,9375],{"class":3458},[3445,9691,3353],{"class":3462},[3445,9693,3467],{"class":3466},[3445,9695,3471],{"class":3470},[3445,9697,9625],{"class":3474},[3445,9699,3994],{"class":3458},[3445,9701,9702],{"class":3470},"Підписники",[3445,9704,4707],{"class":3458},[3445,9706,3353],{"class":3462},[3445,9708,3478],{"class":3458},[3445,9710,9712,9714,9716],{"class":3447,"line":9711},83,[3445,9713,9439],{"class":3458},[3445,9715,3463],{"class":3462},[3445,9717,3478],{"class":3458},[3445,9719,9721,9723,9725,9727,9729,9731],{"class":3447,"line":9720},84,[3445,9722,9358],{"class":3458},[3445,9724,3463],{"class":3462},[3445,9726,3467],{"class":3466},[3445,9728,3471],{"class":3470},[3445,9730,9584],{"class":3474},[3445,9732,3478],{"class":3458},[3445,9734,9736,9738,9740,9742,9744,9746,9748,9751,9753,9755],{"class":3447,"line":9735},85,[3445,9737,9375],{"class":3458},[3445,9739,3353],{"class":3462},[3445,9741,3467],{"class":3466},[3445,9743,3471],{"class":3470},[3445,9745,9600],{"class":3474},[3445,9747,3994],{"class":3458},[3445,9749,9750],{"class":3470},"97%",[3445,9752,4707],{"class":3458},[3445,9754,3353],{"class":3462},[3445,9756,3478],{"class":3458},[3445,9758,9760,9762,9764,9766,9768,9770,9772,9775,9777,9779],{"class":3447,"line":9759},86,[3445,9761,9375],{"class":3458},[3445,9763,3353],{"class":3462},[3445,9765,3467],{"class":3466},[3445,9767,3471],{"class":3470},[3445,9769,9625],{"class":3474},[3445,9771,3994],{"class":3458},[3445,9773,9774],{"class":3470},"Рейтинг",[3445,9776,4707],{"class":3458},[3445,9778,3353],{"class":3462},[3445,9780,3478],{"class":3458},[3445,9782,9784,9786,9788],{"class":3447,"line":9783},87,[3445,9785,9439],{"class":3458},[3445,9787,3463],{"class":3462},[3445,9789,3478],{"class":3458},[3445,9791,9793,9795,9797],{"class":3447,"line":9792},88,[3445,9794,9293],{"class":3458},[3445,9796,3463],{"class":3462},[3445,9798,3478],{"class":3458},[3445,9800,9802],{"class":3447,"line":9801},89,[3445,9803,3485],{"emptyLinePlaceholder":3484},[3445,9805,9807],{"class":3447,"line":9806},90,[3445,9808,9809],{"class":3451},"                    \u003C!-- Кнопки -->\n",[3445,9811,9813,9815,9817,9819,9821,9824],{"class":3447,"line":9812},91,[3445,9814,9267],{"class":3458},[3445,9816,3463],{"class":3462},[3445,9818,3467],{"class":3466},[3445,9820,3471],{"class":3470},[3445,9822,9823],{"class":3474},"\"flex gap-2\"",[3445,9825,3478],{"class":3458},[3445,9827,9829,9831,9833,9835,9837],{"class":3447,"line":9828},92,[3445,9830,9358],{"class":3458},[3445,9832,5293],{"class":3462},[3445,9834,3467],{"class":3466},[3445,9836,3471],{"class":3470},[3445,9838,9839],{"class":3474},"\"flex-1 @[400px]:flex-none\n",[3445,9841,9843],{"class":3447,"line":9842},93,[3445,9844,9845],{"class":3474},"                                       py-1.5 px-3 @[280px]:px-4\n",[3445,9847,9849],{"class":3447,"line":9848},94,[3445,9850,9851],{"class":3474},"                                       bg-indigo-600 hover:bg-indigo-700\n",[3445,9853,9855],{"class":3447,"line":9854},95,[3445,9856,9857],{"class":3474},"                                       text-white text-xs @[280px]:text-sm font-semibold\n",[3445,9859,9861,9864],{"class":3447,"line":9860},96,[3445,9862,9863],{"class":3474},"                                       rounded-lg transition-colors\"",[3445,9865,3478],{"class":3458},[3445,9867,9869],{"class":3447,"line":9868},97,[3445,9870,9871],{"class":3470},"                            Профіль\n",[3445,9873,9875,9877,9879],{"class":3447,"line":9874},98,[3445,9876,9439],{"class":3458},[3445,9878,5293],{"class":3462},[3445,9880,3478],{"class":3458},[3445,9882,9884],{"class":3447,"line":9883},99,[3445,9885,9886],{"class":3451},"                        \u003C!-- Друга кнопка — лише якщо є місце -->\n",[3445,9888,9890,9892,9894,9896,9898],{"class":3447,"line":9889},100,[3445,9891,9358],{"class":3458},[3445,9893,5293],{"class":3462},[3445,9895,3467],{"class":3466},[3445,9897,3471],{"class":3470},[3445,9899,9900],{"class":3474},"\"hidden @[320px]:flex\n",[3445,9902,9904],{"class":3447,"line":9903},101,[3445,9905,9906],{"class":3474},"                                       items-center gap-1.5\n",[3445,9908,9910],{"class":3447,"line":9909},102,[3445,9911,9845],{"class":3474},[3445,9913,9915],{"class":3447,"line":9914},103,[3445,9916,9917],{"class":3474},"                                       border border-slate-200 hover:bg-slate-50\n",[3445,9919,9921],{"class":3447,"line":9920},104,[3445,9922,9923],{"class":3474},"                                       text-slate-700 text-xs @[280px]:text-sm font-semibold\n",[3445,9925,9927,9929],{"class":3447,"line":9926},105,[3445,9928,9863],{"class":3474},[3445,9930,3478],{"class":3458},[3445,9932,9934,9936,9938,9940,9943,9945,9947],{"class":3447,"line":9933},106,[3445,9935,9375],{"class":3458},[3445,9937,3445],{"class":3462},[3445,9939,3994],{"class":3458},[3445,9941,9942],{"class":3470},"Написати",[3445,9944,4707],{"class":3458},[3445,9946,3445],{"class":3462},[3445,9948,3478],{"class":3458},[3445,9950,9952,9954,9956],{"class":3447,"line":9951},107,[3445,9953,9439],{"class":3458},[3445,9955,5293],{"class":3462},[3445,9957,3478],{"class":3458},[3445,9959,9961,9963,9965],{"class":3447,"line":9960},108,[3445,9962,9293],{"class":3458},[3445,9964,3463],{"class":3462},[3445,9966,3478],{"class":3458},[3445,9968,9970,9972,9974],{"class":3447,"line":9969},109,[3445,9971,5327],{"class":3458},[3445,9973,3463],{"class":3462},[3445,9975,3478],{"class":3458},[3445,9977,9979,9981,9983],{"class":3447,"line":9978},110,[3445,9980,5336],{"class":3458},[3445,9982,3463],{"class":3462},[3445,9984,3478],{"class":3458},[3445,9986,9988,9990,9992],{"class":3447,"line":9987},111,[3445,9989,4659],{"class":3458},[3445,9991,3463],{"class":3462},[3445,9993,3478],{"class":3458},[3445,9995,9997,9999,10001],{"class":3447,"line":9996},112,[3445,9998,4527],{"class":3458},[3445,10000,3463],{"class":3462},[3445,10002,3478],{"class":3458},[3445,10004,10006,10008,10010],{"class":3447,"line":10005},113,[3445,10007,4707],{"class":3458},[3445,10009,3463],{"class":3462},[3445,10011,3478],{"class":3458},[3445,10013,10015],{"class":3447,"line":10014},114,[3445,10016,3485],{"emptyLinePlaceholder":3484},[3445,10018,10020],{"class":3447,"line":10019},115,[3445,10021,10022],{"class":3451},"\u003C!-- Індикатор поточного breakpoint -->\n",[3445,10024,10026,10028,10030,10032,10034,10037],{"class":3447,"line":10025},116,[3445,10027,3459],{"class":3458},[3445,10029,3463],{"class":3462},[3445,10031,3467],{"class":3466},[3445,10033,3471],{"class":3470},[3445,10035,10036],{"class":3474},"\"text-center mt-4\"",[3445,10038,3478],{"class":3458},[3445,10040,10042,10044,10046,10048,10050,10053,10055,10057,10060,10062,10064,10066,10068],{"class":3447,"line":10041},117,[3445,10043,4506],{"class":3458},[3445,10045,3353],{"class":3462},[3445,10047,3467],{"class":3466},[3445,10049,3471],{"class":3470},[3445,10051,10052],{"class":3474},"\"text-xs text-slate-500\"",[3445,10054,5372],{"class":3466},[3445,10056,3471],{"class":3470},[3445,10058,10059],{"class":3474},"\"breakpoint-label\"",[3445,10061,3994],{"class":3458},[3445,10063,8602],{"class":3470},[3445,10065,4707],{"class":3458},[3445,10067,3353],{"class":3462},[3445,10069,3478],{"class":3458},[3445,10071,10073,10075,10077],{"class":3447,"line":10072},118,[3445,10074,4707],{"class":3458},[3445,10076,3463],{"class":3462},[3445,10078,3478],{"class":3458},[3445,10080,10082],{"class":3447,"line":10081},119,[3445,10083,3485],{"emptyLinePlaceholder":3484},[3445,10085,10087,10089,10091],{"class":3447,"line":10086},120,[3445,10088,3459],{"class":3458},[3445,10090,5002],{"class":3462},[3445,10092,3478],{"class":3458},[3445,10094,10096,10099,10102,10104,10107],{"class":3447,"line":10095},121,[3445,10097,10098],{"class":5448},"    function",[3445,10100,10101],{"class":5304}," updateWidth",[3445,10103,5480],{"class":5008},[3445,10105,10106],{"class":5471},"val",[3445,10108,7867],{"class":5008},[3445,10110,10112,10115,10117,10119,10121,10124,10127,10130,10132,10134,10136,10139,10142],{"class":3447,"line":10111},122,[3445,10113,10114],{"class":5471},"        document",[3445,10116,3630],{"class":5008},[3445,10118,5477],{"class":5304},[3445,10120,5480],{"class":5008},[3445,10122,10123],{"class":5483},"'container-wrapper'",[3445,10125,10126],{"class":5008},").",[3445,10128,10129],{"class":5471},"style",[3445,10131,3630],{"class":5008},[3445,10133,7857],{"class":5471},[3445,10135,5468],{"class":3470},[3445,10137,10138],{"class":5471}," val",[3445,10140,10141],{"class":3470}," +",[3445,10143,10144],{"class":5483}," 'px'\n",[3445,10146,10148,10150,10152,10154,10156,10159,10161,10163,10165,10167,10169],{"class":3447,"line":10147},123,[3445,10149,10114],{"class":5471},[3445,10151,3630],{"class":5008},[3445,10153,5477],{"class":5304},[3445,10155,5480],{"class":5008},[3445,10157,10158],{"class":5483},"'width-label'",[3445,10160,10126],{"class":5008},[3445,10162,5553],{"class":5471},[3445,10164,5468],{"class":3470},[3445,10166,10138],{"class":5471},[3445,10168,10141],{"class":3470},[3445,10170,10144],{"class":5483},[3445,10172,10174],{"class":3447,"line":10173},124,[3445,10175,3485],{"emptyLinePlaceholder":3484},[3445,10177,10179,10182,10185,10187,10190,10192,10194],{"class":3447,"line":10178},125,[3445,10180,10181],{"class":5448},"        const",[3445,10183,10184],{"class":5464}," v",[3445,10186,5468],{"class":3470},[3445,10188,10189],{"class":5304}," parseInt",[3445,10191,5480],{"class":5008},[3445,10193,10106],{"class":5471},[3445,10195,10196],{"class":5008},")\n",[3445,10198,10200,10203,10206,10208],{"class":3447,"line":10199},126,[3445,10201,10202],{"class":5448},"        let",[3445,10204,10205],{"class":5471}," bp",[3445,10207,5468],{"class":3470},[3445,10209,10210],{"class":5483}," ''\n",[3445,10212,10214,10217,10219,10222,10225,10228,10231,10234,10236],{"class":3447,"line":10213},127,[3445,10215,10216],{"class":5493},"        if",[3445,10218,3395],{"class":5008},[3445,10220,10221],{"class":5471},"v",[3445,10223,10224],{"class":3470}," \u003C",[3445,10226,10227],{"class":7863}," 280",[3445,10229,10230],{"class":5008},") ",[3445,10232,10233],{"class":5471},"bp",[3445,10235,5468],{"class":3470},[3445,10237,10238],{"class":5483}," '\u003C 280px — мінімальний'\n",[3445,10240,10242,10245,10248,10250,10252,10254,10257,10259,10261,10263],{"class":3447,"line":10241},128,[3445,10243,10244],{"class":5493},"        else",[3445,10246,10247],{"class":5493}," if",[3445,10249,3395],{"class":5008},[3445,10251,10221],{"class":5471},[3445,10253,10224],{"class":3470},[3445,10255,10256],{"class":7863}," 320",[3445,10258,10230],{"class":5008},[3445,10260,10233],{"class":5471},[3445,10262,5468],{"class":3470},[3445,10264,10265],{"class":5483}," '≥ 280px — badge, опис'\n",[3445,10267,10269,10271,10273,10275,10277,10279,10282,10284,10286,10288],{"class":3447,"line":10268},129,[3445,10270,10244],{"class":5493},[3445,10272,10247],{"class":5493},[3445,10274,3395],{"class":5008},[3445,10276,10221],{"class":5471},[3445,10278,10224],{"class":3470},[3445,10280,10281],{"class":7863}," 400",[3445,10283,10230],{"class":5008},[3445,10285,10233],{"class":5471},[3445,10287,5468],{"class":3470},[3445,10289,10290],{"class":5483}," '≥ 320px — друга кнопка + опис'\n",[3445,10292,10294,10296,10298,10300,10302,10304,10307,10309,10311,10313],{"class":3447,"line":10293},130,[3445,10295,10244],{"class":5493},[3445,10297,10247],{"class":5493},[3445,10299,3395],{"class":5008},[3445,10301,10221],{"class":5471},[3445,10303,10224],{"class":3470},[3445,10305,10306],{"class":7863}," 560",[3445,10308,10230],{"class":5008},[3445,10310,10233],{"class":5471},[3445,10312,5468],{"class":3470},[3445,10314,10315],{"class":5483}," '≥ 400px — горизонтальний layout'\n",[3445,10317,10319,10321,10323,10325],{"class":3447,"line":10318},131,[3445,10320,10244],{"class":5493},[3445,10322,10205],{"class":5471},[3445,10324,5468],{"class":3470},[3445,10326,10327],{"class":5483}," '≥ 560px — статистика'\n",[3445,10329,10331],{"class":3447,"line":10330},132,[3445,10332,3485],{"emptyLinePlaceholder":3484},[3445,10334,10336,10338,10340,10342,10344,10347,10349,10351,10353,10356,10358],{"class":3447,"line":10335},133,[3445,10337,10114],{"class":5471},[3445,10339,3630],{"class":5008},[3445,10341,5477],{"class":5304},[3445,10343,5480],{"class":5008},[3445,10345,10346],{"class":5483},"'breakpoint-label'",[3445,10348,10126],{"class":5008},[3445,10350,5553],{"class":5471},[3445,10352,5468],{"class":3470},[3445,10354,10355],{"class":5483}," 'Активний breakpoint: '",[3445,10357,10141],{"class":3470},[3445,10359,10360],{"class":5471}," bp\n",[3445,10362,10364],{"class":3447,"line":10363},134,[3445,10365,10366],{"class":5008},"    }\n",[3445,10368,10370,10373,10375,10378],{"class":3447,"line":10369},135,[3445,10371,10372],{"class":5304},"    updateWidth",[3445,10374,5480],{"class":5008},[3445,10376,10377],{"class":7863},"340",[3445,10379,10196],{"class":5008},[3445,10381,10383,10385,10387],{"class":3447,"line":10382},136,[3445,10384,4707],{"class":3458},[3445,10386,5002],{"class":3462},[3445,10388,3478],{"class":3458},[3445,10390,10392,10394,10396],{"class":3447,"line":10391},137,[3445,10393,4707],{"class":3458},[3445,10395,5058],{"class":3462},[3445,10397,3478],{"class":3458},[3445,10399,10401,10403,10405],{"class":3447,"line":10400},138,[3445,10402,4707],{"class":3458},[3445,10404,3441],{"class":3462},[3445,10406,3478],{"class":3458},[3408,10408],{},[3417,10410,10412],{"id":10411},"_36-порівняння-медіазапити-проти-контейнерних-запитів","3.6. Порівняння: медіазапити проти контейнерних запитів",[3353,10414,10415],{},"Обидва підходи виправдані — але для різних задач:",[10417,10418,10419,10454],"card-group",{},[10420,10421,10424,10429,10444],"card",{"icon":10422,"title":10423},"i-heroicons-device-phone-mobile","Медіазапити @media",[3353,10425,10426],{},[3378,10427,10428],{},"Коли використовувати:",[10430,10431,10432,10435,10438,10441],"ul",{},[3375,10433,10434],{},"Layout сторінки (sidebar, navbar, grid-система)",[3375,10436,10437],{},"Компоненти, розмір яких завжди корелює з viewport (hero section, full-width banner)",[3375,10439,10440],{},"Типографічна шкала для всього документу",[3375,10442,10443],{},"Навігація, що трансформується (бургер-меню)",[3353,10445,10446,10449,10450,10453],{},[3378,10447,10448],{},"Приклад:"," ",[3360,10451,10452],{},"md:hidden"," — сховати sidebar на мобільному",[10420,10455,10458,10462,10476],{"icon":10456,"title":10457},"i-heroicons-squares-2x2","Контейнерні запити @container",[3353,10459,10460],{},[3378,10461,10428],{},[10430,10463,10464,10467,10470,10473],{},[3375,10465,10466],{},"Переносимі компоненти (Card, ProductItem, TeamMember)",[3375,10468,10469],{},"Компоненти, що використовуються у різних контекстах (sidebar, grid, full-width)",[3375,10471,10472],{},"Компонентні бібліотеки (UI-kit)",[3375,10474,10475],{},"Адаптивні списки, що можуть мати 1-4 колонки залежно від контейнера",[3353,10477,10478,10449,10480,10483],{},[3378,10479,10448],{},[3360,10481,10482],{},"@md:flex-row"," — картка горизонтальна коли ширина ≥ 448px",[3425,10485,10487],{"className":3439,"code":10486,"language":3441,"meta":3433,"style":3433},"\u003C!-- Комбінація обох: viewport layout + компонентна адаптивність -->\n\u003Cdiv class=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4\">\n    \u003C!--\n        На рівні сторінки: медіазапит визначає кількість колонок.\n        На рівні компонента: @container визначає внутрішній layout.\n    -->\n    \u003Cdiv class=\"@container\">\n        \u003Carticle class=\"flex flex-col @[360px]:flex-row gap-4 bg-white rounded-xl p-4\">\n            \u003C!-- Картка адаптується до своєї реальної ширини в колонці -->\n        \u003C\u002Farticle>\n    \u003C\u002Fdiv>\n\u003C\u002Fdiv>\n",[3360,10488,10489,10494,10509,10514,10519,10524,10529,10543,10558,10563,10571,10579],{"__ignoreMap":3433},[3445,10490,10491],{"class":3447,"line":3448},[3445,10492,10493],{"class":3451},"\u003C!-- Комбінація обох: viewport layout + компонентна адаптивність -->\n",[3445,10495,10496,10498,10500,10502,10504,10507],{"class":3447,"line":3455},[3445,10497,3459],{"class":3458},[3445,10499,3463],{"class":3462},[3445,10501,3467],{"class":3466},[3445,10503,3471],{"class":3470},[3445,10505,10506],{"class":3474},"\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4\"",[3445,10508,3478],{"class":3458},[3445,10510,10511],{"class":3447,"line":3481},[3445,10512,10513],{"class":3451},"    \u003C!--\n",[3445,10515,10516],{"class":3447,"line":3488},[3445,10517,10518],{"class":3451},"        На рівні сторінки: медіазапит визначає кількість колонок.\n",[3445,10520,10521],{"class":3447,"line":3494},[3445,10522,10523],{"class":3451},"        На рівні компонента: @container визначає внутрішній layout.\n",[3445,10525,10526],{"class":3447,"line":3510},[3445,10527,10528],{"class":3451},"    -->\n",[3445,10530,10531,10533,10535,10537,10539,10541],{"class":3447,"line":3515},[3445,10532,4506],{"class":3458},[3445,10534,3463],{"class":3462},[3445,10536,3467],{"class":3466},[3445,10538,3471],{"class":3470},[3445,10540,7974],{"class":3474},[3445,10542,3478],{"class":3458},[3445,10544,10545,10547,10549,10551,10553,10556],{"class":3447,"line":3521},[3445,10546,4639],{"class":3458},[3445,10548,8144],{"class":3462},[3445,10550,3467],{"class":3466},[3445,10552,3471],{"class":3470},[3445,10554,10555],{"class":3474},"\"flex flex-col @[360px]:flex-row gap-4 bg-white rounded-xl p-4\"",[3445,10557,3478],{"class":3458},[3445,10559,10560],{"class":3447,"line":3537},[3445,10561,10562],{"class":3451},"            \u003C!-- Картка адаптується до своєї реальної ширини в колонці -->\n",[3445,10564,10565,10567,10569],{"class":3447,"line":3542},[3445,10566,4659],{"class":3458},[3445,10568,8144],{"class":3462},[3445,10570,3478],{"class":3458},[3445,10572,10573,10575,10577],{"class":3447,"line":3548},[3445,10574,4527],{"class":3458},[3445,10576,3463],{"class":3462},[3445,10578,3478],{"class":3458},[3445,10580,10581,10583,10585],{"class":3447,"line":3564},[3445,10582,4707],{"class":3458},[3445,10584,3463],{"class":3462},[3445,10586,3478],{"class":3458},[3408,10588],{},[3417,10590,10592],{"id":10591},"_37-контейнерні-запити-з-іменуванням-складні-вкладення","3.7. Контейнерні запити з іменуванням: складні вкладення",[3353,10594,10595],{},"Розглянемо складний приклад: Dashboard із вкладеними контейнерами, де різні рівні ієрархії адаптуються незалежно:",[3425,10597,10599],{"className":3439,"code":10598,"language":3441,"meta":3433,"style":3433},"\u003C!-- Зовнішній контейнер: весь dashboard -->\n\u003Cdiv class=\"@container\u002Fdashboard grid grid-cols-1 @3xl\u002Fdashboard:grid-cols-[260px_1fr] gap-6\">\n\n    \u003C!-- Sidebar: залежить від розміру dashboard -->\n    \u003Caside class=\"hidden @3xl\u002Fdashboard:block bg-white rounded-xl border border-slate-200 p-4\">\n        \u003Cnav>Навігація\u003C\u002Fnav>\n    \u003C\u002Faside>\n\n    \u003C!-- Основний контент: власний контейнер -->\n    \u003Cmain class=\"@container\u002Fmain space-y-6\">\n\n        \u003C!-- Stats grid: адаптується до main -->\n        \u003Cdiv class=\"grid grid-cols-2 @2xl\u002Fmain:grid-cols-4 gap-4\">\n            \u003Cdiv class=\"@container\u002Fstat bg-white rounded-xl p-4 border border-slate-200\">\n                \u003C!-- Stat card: адаптується до stat контейнера -->\n                \u003Cdiv class=\"flex flex-col @[180px]\u002Fstat:flex-row @[180px]\u002Fstat:items-center gap-2\">\n                    \u003Cspan class=\"text-2xl\">📈\u003C\u002Fspan>\n                    \u003Cdiv>\n                        \u003Cp class=\"text-2xl font-black\">2,847\u003C\u002Fp>\n                        \u003Cp class=\"text-xs text-slate-500\">Відвідувачі\u003C\u002Fp>\n                    \u003C\u002Fdiv>\n                \u003C\u002Fdiv>\n            \u003C\u002Fdiv>\n            \u003C!-- Більше stat-карток... -->\n        \u003C\u002Fdiv>\n\n        \u003C!-- Таблиця: показує різну кількість колонок -->\n        \u003Cdiv class=\"@container\u002Ftable bg-white rounded-xl border border-slate-200\">\n            \u003Ctable class=\"w-full\">\n                \u003Cthead>\n                    \u003Ctr class=\"border-b border-slate-100\">\n                        \u003Cth class=\"text-left p-4 text-sm font-semibold text-slate-700\">Ім'я\u003C\u002Fth>\n                        \u003C!-- Ці колонки приховані у вузькому контейнері -->\n                        \u003Cth class=\"hidden @[500px]\u002Ftable:table-cell text-left p-4 text-sm font-semibold text-slate-700\">Email\u003C\u002Fth>\n                        \u003Cth class=\"hidden @[700px]\u002Ftable:table-cell text-left p-4 text-sm font-semibold text-slate-700\">Дата\u003C\u002Fth>\n                        \u003Cth class=\"text-left p-4 text-sm font-semibold text-slate-700\">Статус\u003C\u002Fth>\n                    \u003C\u002Ftr>\n                \u003C\u002Fthead>\n            \u003C\u002Ftable>\n        \u003C\u002Fdiv>\n\n    \u003C\u002Fmain>\n\u003C\u002Fdiv>\n",[3360,10600,10601,10606,10621,10625,10630,10645,10661,10669,10673,10678,10693,10697,10702,10717,10732,10737,10752,10776,10784,10808,10831,10839,10847,10855,10860,10868,10872,10877,10892,10907,10915,10930,10954,10959,10983,11007,11030,11038,11046,11054,11062,11066,11074],{"__ignoreMap":3433},[3445,10602,10603],{"class":3447,"line":3448},[3445,10604,10605],{"class":3451},"\u003C!-- Зовнішній контейнер: весь dashboard -->\n",[3445,10607,10608,10610,10612,10614,10616,10619],{"class":3447,"line":3455},[3445,10609,3459],{"class":3458},[3445,10611,3463],{"class":3462},[3445,10613,3467],{"class":3466},[3445,10615,3471],{"class":3470},[3445,10617,10618],{"class":3474},"\"@container\u002Fdashboard grid grid-cols-1 @3xl\u002Fdashboard:grid-cols-[260px_1fr] gap-6\"",[3445,10620,3478],{"class":3458},[3445,10622,10623],{"class":3447,"line":3481},[3445,10624,3485],{"emptyLinePlaceholder":3484},[3445,10626,10627],{"class":3447,"line":3488},[3445,10628,10629],{"class":3451},"    \u003C!-- Sidebar: залежить від розміру dashboard -->\n",[3445,10631,10632,10634,10636,10638,10640,10643],{"class":3447,"line":3494},[3445,10633,4506],{"class":3458},[3445,10635,6975],{"class":3462},[3445,10637,3467],{"class":3466},[3445,10639,3471],{"class":3470},[3445,10641,10642],{"class":3474},"\"hidden @3xl\u002Fdashboard:block bg-white rounded-xl border border-slate-200 p-4\"",[3445,10644,3478],{"class":3458},[3445,10646,10647,10649,10651,10653,10655,10657,10659],{"class":3447,"line":3510},[3445,10648,4639],{"class":3458},[3445,10650,6925],{"class":3462},[3445,10652,3994],{"class":3458},[3445,10654,6937],{"class":3470},[3445,10656,4707],{"class":3458},[3445,10658,6925],{"class":3462},[3445,10660,3478],{"class":3458},[3445,10662,10663,10665,10667],{"class":3447,"line":3515},[3445,10664,4527],{"class":3458},[3445,10666,6975],{"class":3462},[3445,10668,3478],{"class":3458},[3445,10670,10671],{"class":3447,"line":3521},[3445,10672,3485],{"emptyLinePlaceholder":3484},[3445,10674,10675],{"class":3447,"line":3537},[3445,10676,10677],{"class":3451},"    \u003C!-- Основний контент: власний контейнер -->\n",[3445,10679,10680,10682,10684,10686,10688,10691],{"class":3447,"line":3542},[3445,10681,4506],{"class":3458},[3445,10683,6950],{"class":3462},[3445,10685,3467],{"class":3466},[3445,10687,3471],{"class":3470},[3445,10689,10690],{"class":3474},"\"@container\u002Fmain space-y-6\"",[3445,10692,3478],{"class":3458},[3445,10694,10695],{"class":3447,"line":3548},[3445,10696,3485],{"emptyLinePlaceholder":3484},[3445,10698,10699],{"class":3447,"line":3564},[3445,10700,10701],{"class":3451},"        \u003C!-- Stats grid: адаптується до main -->\n",[3445,10703,10704,10706,10708,10710,10712,10715],{"class":3447,"line":3569},[3445,10705,4639],{"class":3458},[3445,10707,3463],{"class":3462},[3445,10709,3467],{"class":3466},[3445,10711,3471],{"class":3470},[3445,10713,10714],{"class":3474},"\"grid grid-cols-2 @2xl\u002Fmain:grid-cols-4 gap-4\"",[3445,10716,3478],{"class":3458},[3445,10718,10719,10721,10723,10725,10727,10730],{"class":3447,"line":3575},[3445,10720,5143],{"class":3458},[3445,10722,3463],{"class":3462},[3445,10724,3467],{"class":3466},[3445,10726,3471],{"class":3470},[3445,10728,10729],{"class":3474},"\"@container\u002Fstat bg-white rounded-xl p-4 border border-slate-200\"",[3445,10731,3478],{"class":3458},[3445,10733,10734],{"class":3447,"line":3591},[3445,10735,10736],{"class":3451},"                \u003C!-- Stat card: адаптується до stat контейнера -->\n",[3445,10738,10739,10741,10743,10745,10747,10750],{"class":3447,"line":3596},[3445,10740,5267],{"class":3458},[3445,10742,3463],{"class":3462},[3445,10744,3467],{"class":3466},[3445,10746,3471],{"class":3470},[3445,10748,10749],{"class":3474},"\"flex flex-col @[180px]\u002Fstat:flex-row @[180px]\u002Fstat:items-center gap-2\"",[3445,10751,3478],{"class":3458},[3445,10753,10754,10756,10758,10760,10762,10765,10767,10770,10772,10774],{"class":3447,"line":3602},[3445,10755,9267],{"class":3458},[3445,10757,3445],{"class":3462},[3445,10759,3467],{"class":3466},[3445,10761,3471],{"class":3470},[3445,10763,10764],{"class":3474},"\"text-2xl\"",[3445,10766,3994],{"class":3458},[3445,10768,10769],{"class":3470},"📈",[3445,10771,4707],{"class":3458},[3445,10773,3445],{"class":3462},[3445,10775,3478],{"class":3458},[3445,10777,10778,10780,10782],{"class":3447,"line":4129},[3445,10779,9267],{"class":3458},[3445,10781,3463],{"class":3462},[3445,10783,3478],{"class":3458},[3445,10785,10786,10788,10790,10792,10794,10797,10799,10802,10804,10806],{"class":3447,"line":4134},[3445,10787,9358],{"class":3458},[3445,10789,3353],{"class":3462},[3445,10791,3467],{"class":3466},[3445,10793,3471],{"class":3470},[3445,10795,10796],{"class":3474},"\"text-2xl font-black\"",[3445,10798,3994],{"class":3458},[3445,10800,10801],{"class":3470},"2,847",[3445,10803,4707],{"class":3458},[3445,10805,3353],{"class":3462},[3445,10807,3478],{"class":3458},[3445,10809,10810,10812,10814,10816,10818,10820,10822,10825,10827,10829],{"class":3447,"line":4140},[3445,10811,9358],{"class":3458},[3445,10813,3353],{"class":3462},[3445,10815,3467],{"class":3466},[3445,10817,3471],{"class":3470},[3445,10819,10052],{"class":3474},[3445,10821,3994],{"class":3458},[3445,10823,10824],{"class":3470},"Відвідувачі",[3445,10826,4707],{"class":3458},[3445,10828,3353],{"class":3462},[3445,10830,3478],{"class":3458},[3445,10832,10833,10835,10837],{"class":3447,"line":4156},[3445,10834,9293],{"class":3458},[3445,10836,3463],{"class":3462},[3445,10838,3478],{"class":3458},[3445,10840,10841,10843,10845],{"class":3447,"line":4162},[3445,10842,5327],{"class":3458},[3445,10844,3463],{"class":3462},[3445,10846,3478],{"class":3458},[3445,10848,10849,10851,10853],{"class":3447,"line":4447},[3445,10850,5336],{"class":3458},[3445,10852,3463],{"class":3462},[3445,10854,3478],{"class":3458},[3445,10856,10857],{"class":3447,"line":4686},[3445,10858,10859],{"class":3451},"            \u003C!-- Більше stat-карток... -->\n",[3445,10861,10862,10864,10866],{"class":3447,"line":4695},[3445,10863,4659],{"class":3458},[3445,10865,3463],{"class":3462},[3445,10867,3478],{"class":3458},[3445,10869,10870],{"class":3447,"line":4704},[3445,10871,3485],{"emptyLinePlaceholder":3484},[3445,10873,10874],{"class":3447,"line":5343},[3445,10875,10876],{"class":3451},"        \u003C!-- Таблиця: показує різну кількість колонок -->\n",[3445,10878,10879,10881,10883,10885,10887,10890],{"class":3447,"line":5349},[3445,10880,4639],{"class":3458},[3445,10882,3463],{"class":3462},[3445,10884,3467],{"class":3466},[3445,10886,3471],{"class":3470},[3445,10888,10889],{"class":3474},"\"@container\u002Ftable bg-white rounded-xl border border-slate-200\"",[3445,10891,3478],{"class":3458},[3445,10893,10894,10896,10898,10900,10902,10905],{"class":3447,"line":5365},[3445,10895,5143],{"class":3458},[3445,10897,3641],{"class":3462},[3445,10899,3467],{"class":3466},[3445,10901,3471],{"class":3470},[3445,10903,10904],{"class":3474},"\"w-full\"",[3445,10906,3478],{"class":3458},[3445,10908,10909,10911,10913],{"class":3447,"line":5389},[3445,10910,5267],{"class":3458},[3445,10912,3644],{"class":3462},[3445,10914,3478],{"class":3458},[3445,10916,10917,10919,10921,10923,10925,10928],{"class":3447,"line":5395},[3445,10918,9267],{"class":3458},[3445,10920,3647],{"class":3462},[3445,10922,3467],{"class":3466},[3445,10924,3471],{"class":3470},[3445,10926,10927],{"class":3474},"\"border-b border-slate-100\"",[3445,10929,3478],{"class":3458},[3445,10931,10932,10934,10936,10938,10940,10943,10945,10948,10950,10952],{"class":3447,"line":5404},[3445,10933,9358],{"class":3458},[3445,10935,3650],{"class":3462},[3445,10937,3467],{"class":3466},[3445,10939,3471],{"class":3470},[3445,10941,10942],{"class":3474},"\"text-left p-4 text-sm font-semibold text-slate-700\"",[3445,10944,3994],{"class":3458},[3445,10946,10947],{"class":3470},"Ім'я",[3445,10949,4707],{"class":3458},[3445,10951,3650],{"class":3462},[3445,10953,3478],{"class":3458},[3445,10955,10956],{"class":3447,"line":5413},[3445,10957,10958],{"class":3451},"                        \u003C!-- Ці колонки приховані у вузькому контейнері -->\n",[3445,10960,10961,10963,10965,10967,10969,10972,10974,10977,10979,10981],{"class":3447,"line":5422},[3445,10962,9358],{"class":3458},[3445,10964,3650],{"class":3462},[3445,10966,3467],{"class":3466},[3445,10968,3471],{"class":3470},[3445,10970,10971],{"class":3474},"\"hidden @[500px]\u002Ftable:table-cell text-left p-4 text-sm font-semibold text-slate-700\"",[3445,10973,3994],{"class":3458},[3445,10975,10976],{"class":3470},"Email",[3445,10978,4707],{"class":3458},[3445,10980,3650],{"class":3462},[3445,10982,3478],{"class":3458},[3445,10984,10985,10987,10989,10991,10993,10996,10998,11001,11003,11005],{"class":3447,"line":5431},[3445,10986,9358],{"class":3458},[3445,10988,3650],{"class":3462},[3445,10990,3467],{"class":3466},[3445,10992,3471],{"class":3470},[3445,10994,10995],{"class":3474},"\"hidden @[700px]\u002Ftable:table-cell text-left p-4 text-sm font-semibold text-slate-700\"",[3445,10997,3994],{"class":3458},[3445,10999,11000],{"class":3470},"Дата",[3445,11002,4707],{"class":3458},[3445,11004,3650],{"class":3462},[3445,11006,3478],{"class":3458},[3445,11008,11009,11011,11013,11015,11017,11019,11021,11024,11026,11028],{"class":3447,"line":5436},[3445,11010,9358],{"class":3458},[3445,11012,3650],{"class":3462},[3445,11014,3467],{"class":3466},[3445,11016,3471],{"class":3470},[3445,11018,10942],{"class":3474},[3445,11020,3994],{"class":3458},[3445,11022,11023],{"class":3470},"Статус",[3445,11025,4707],{"class":3458},[3445,11027,3650],{"class":3462},[3445,11029,3478],{"class":3458},[3445,11031,11032,11034,11036],{"class":3447,"line":5445},[3445,11033,9293],{"class":3458},[3445,11035,3647],{"class":3462},[3445,11037,3478],{"class":3458},[3445,11039,11040,11042,11044],{"class":3447,"line":5458},[3445,11041,5327],{"class":3458},[3445,11043,3644],{"class":3462},[3445,11045,3478],{"class":3458},[3445,11047,11048,11050,11052],{"class":3447,"line":5490},[3445,11049,5336],{"class":3458},[3445,11051,3641],{"class":3462},[3445,11053,3478],{"class":3458},[3445,11055,11056,11058,11060],{"class":3447,"line":5520},[3445,11057,4659],{"class":3458},[3445,11059,3463],{"class":3462},[3445,11061,3478],{"class":3458},[3445,11063,11064],{"class":3447,"line":5546},[3445,11065,3485],{"emptyLinePlaceholder":3484},[3445,11067,11068,11070,11072],{"class":3447,"line":5564},[3445,11069,4527],{"class":3458},[3445,11071,6950],{"class":3462},[3445,11073,3478],{"class":3458},[3445,11075,11076,11078,11080],{"class":3447,"line":5576},[3445,11077,4707],{"class":3458},[3445,11079,3463],{"class":3462},[3445,11081,3478],{"class":3458},[4471,11083,11084,12965,12967,12973,12978,13065,13068,13102,13111,13113,13117],{":tailwind":4473},[3425,11085,11087],{"className":3439,"code":11086,"language":3441,"meta":3433,"style":3433},"\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\u003C\u002Fhead>\n\u003Cbody class=\"p-6 bg-slate-100\" style=\"font-family: 'Inter', system-ui, sans-serif;\">\n    \u003Cdiv class=\"max-w-3xl mx-auto space-y-6\">\n        \u003Cp class=\"text-xs font-bold text-slate-400 uppercase tracking-widest text-center\">Dashboard Nested Containers Simulator\u003C\u002Fp>\n        \n        \u003C!-- Width Slider Control -->\n        \u003Cdiv class=\"flex items-center gap-3 bg-white p-4 rounded-2xl border border-slate-200 shadow-sm max-w-xl mx-auto\">\n            \u003Cspan class=\"text-xs text-slate-500 font-medium\">300px\u003C\u002Fspan>\n            \u003Cinput type=\"range\" min=\"300\" max=\"750\" value=\"600\" id=\"dash-slider\" class=\"flex-1\" oninput=\"resizeDashboard(this.value)\">\n            \u003Cspan class=\"text-xs text-slate-500 font-medium\">750px\u003C\u002Fspan>\n            \u003Cspan id=\"dash-width-label\" class=\"text-xs font-mono bg-slate-200 px-2 py-0.5 rounded text-slate-700 min-w-[52px] text-center\">600px\u003C\u002Fspan>\n        \u003C\u002Fdiv>\n\n        \u003C!-- Dashboard Wrapper -->\n        \u003Cdiv id=\"dashboard-container\" class=\"mx-auto bg-slate-50 rounded-2xl border border-slate-200 p-4 shadow-sm min-h-[350px] transition-all duration-150 overflow-hidden\" style=\"width: 600px;\">\n            \u003C!-- Outer Container -->\n            \u003Cdiv class=\"@container\u002Fdashboard grid grid-cols-1 @[550px]\u002Fdashboard:grid-cols-[160px_1fr] gap-4\">\n                \n                \u003C!-- Sidebar (Collapses under 550px) -->\n                \u003Caside class=\"hidden @[550px]\u002Fdashboard:block bg-white rounded-xl border border-slate-200 p-3 space-y-2\">\n                    \u003Cp class=\"text-[10px] font-bold text-slate-400 uppercase tracking-wider\">Навігація\u003C\u002Fp>\n                    \u003Cdiv class=\"space-y-1\">\n                        \u003Cdiv class=\"px-2 py-1.5 bg-indigo-50 text-indigo-600 rounded-lg text-xs font-bold\">🏠 Панель\u003C\u002Fdiv>\n                        \u003Cdiv class=\"px-2 py-1.5 text-slate-600 hover:bg-slate-50 rounded-lg text-xs font-medium\">📈 Статистика\u003C\u002Fdiv>\n                        \u003Cdiv class=\"px-2 py-1.5 text-slate-600 hover:bg-slate-50 rounded-lg text-xs font-medium\">⚙️ Налаштування\u003C\u002Fdiv>\n                    \u003C\u002Fdiv>\n                \u003C\u002Faside>\n\n                \u003C!-- Main Content Area -->\n                \u003Cmain class=\"@container\u002Fmain space-y-4\">\n                    \n                    \u003C!-- Header Info -->\n                    \u003Cdiv class=\"flex justify-between items-center bg-white p-3 rounded-xl border border-slate-200\">\n                        \u003Ch4 class=\"text-xs font-bold text-slate-900\">Головна робоча зона\u003C\u002Fh4>\n                        \u003Cspan class=\"text-[10px] bg-slate-100 text-slate-500 px-2 py-0.5 rounded font-mono\">@[container\u002Fmain]\u003C\u002Fspan>\n                    \u003C\u002Fdiv>\n\n                    \u003C!-- Stats Grid (Adapts to Main container width) -->\n                    \u003Cdiv class=\"grid grid-cols-2 @[400px]\u002Fmain:grid-cols-4 gap-3\">\n                        \u003Cdiv class=\"@container\u002Fstat bg-white rounded-xl p-3 border border-slate-200\">\n                            \u003Cdiv class=\"flex flex-col @[140px]\u002Fstat:flex-row @[140px]\u002Fstat:items-center gap-1.5\">\n                                \u003Cspan class=\"text-xl\">📈\u003C\u002Fspan>\n                                \u003Cdiv>\n                                    \u003Cp class=\"text-sm font-bold text-slate-900\">2,847\u003C\u002Fp>\n                                    \u003Cp class=\"text-[9px] text-slate-400\">Візити\u003C\u002Fp>\n                                \u003C\u002Fdiv>\n                            \u003C\u002Fdiv>\n                        \u003C\u002Fdiv>\n                        \u003Cdiv class=\"@container\u002Fstat bg-white rounded-xl p-3 border border-slate-200\">\n                            \u003Cdiv class=\"flex flex-col @[140px]\u002Fstat:flex-row @[140px]\u002Fstat:items-center gap-1.5\">\n                                \u003Cspan class=\"text-xl\">💰\u003C\u002Fspan>\n                                \u003Cdiv>\n                                    \u003Cp class=\"text-sm font-bold text-slate-900\">$12.4k\u003C\u002Fp>\n                                    \u003Cp class=\"text-[9px] text-slate-400\">Дохід\u003C\u002Fp>\n                                \u003C\u002Fdiv>\n                            \u003C\u002Fdiv>\n                        \u003C\u002Fdiv>\n                        \u003Cdiv class=\"@container\u002Fstat bg-white rounded-xl p-3 border border-slate-200\">\n                            \u003Cdiv class=\"flex flex-col @[140px]\u002Fstat:flex-row @[140px]\u002Fstat:items-center gap-1.5\">\n                                \u003Cspan class=\"text-xl\">👥\u003C\u002Fspan>\n                                \u003Cdiv>\n                                    \u003Cp class=\"text-sm font-bold text-slate-900\">432\u003C\u002Fp>\n                                    \u003Cp class=\"text-[9px] text-slate-400\">Клієнти\u003C\u002Fp>\n                                \u003C\u002Fdiv>\n                            \u003C\u002Fdiv>\n                        \u003C\u002Fdiv>\n                        \u003Cdiv class=\"@container\u002Fstat bg-white rounded-xl p-3 border border-slate-200\">\n                            \u003Cdiv class=\"flex flex-col @[140px]\u002Fstat:flex-row @[140px]\u002Fstat:items-center gap-1.5\">\n                                \u003Cspan class=\"text-xl\">🔮\u003C\u002Fspan>\n                                \u003Cdiv>\n                                    \u003Cp class=\"text-sm font-bold text-slate-900\">98%\u003C\u002Fp>\n                                    \u003Cp class=\"text-[9px] text-slate-400\">Успіх\u003C\u002Fp>\n                                \u003C\u002Fdiv>\n                            \u003C\u002Fdiv>\n                        \u003C\u002Fdiv>\n                    \u003C\u002Fdiv>\n\n                    \u003C!-- Table (Adapts columns dynamically) -->\n                    \u003Cdiv class=\"@container\u002Ftable bg-white rounded-xl border border-slate-200 overflow-hidden\">\n                        \u003Cdiv class=\"bg-slate-50\u002F50 px-3 py-2 border-b border-slate-100 flex justify-between items-center\">\n                            \u003Cspan class=\"text-[10px] font-bold text-slate-400 uppercase\">Останні транзакції\u003C\u002Fspan>\n                            \u003Cspan class=\"text-[9px] bg-slate-100 text-slate-500 px-2 py-0.5 rounded font-mono\">@[container\u002Ftable]\u003C\u002Fspan>\n                        \u003C\u002Fdiv>\n                        \u003Ctable class=\"w-full text-left text-xs\">\n                            \u003Cthead>\n                                \u003Ctr class=\"border-b border-slate-100 bg-slate-50\u002F20 text-slate-500\">\n                                    \u003Cth class=\"p-3 font-semibold\">Ім'я\u003C\u002Fth>\n                                    \u003Cth class=\"hidden @[380px]\u002Ftable:table-cell p-3 font-semibold\">Email\u003C\u002Fth>\n                                    \u003Cth class=\"hidden @[520px]\u002Ftable:table-cell p-3 font-semibold\">Дата\u003C\u002Fth>\n                                    \u003Cth class=\"p-3 font-semibold\">Статус\u003C\u002Fth>\n                                \u003C\u002Ftr>\n                            \u003C\u002Fthead>\n                            \u003Ctbody>\n                                \u003Ctr class=\"border-b border-slate-100 text-slate-700\">\n                                    \u003Ctd class=\"p-3 font-medium\">Іван К.\u003C\u002Ftd>\n                                    \u003Ctd class=\"hidden @[380px]\u002Ftable:table-cell p-3 text-slate-500\">ivan@example.com\u003C\u002Ftd>\n                                    \u003Ctd class=\"hidden @[520px]\u002Ftable:table-cell p-3 text-slate-500\">03.06.2026\u003C\u002Ftd>\n                                    \u003Ctd class=\"p-3\">\u003Cspan class=\"bg-emerald-100 text-emerald-800 text-[10px] font-bold px-2 py-0.5 rounded-full\">Успішно\u003C\u002Fspan>\u003C\u002Ftd>\n                                \u003C\u002Ftr>\n                                \u003Ctr class=\"text-slate-700\">\n                                    \u003Ctd class=\"p-3 font-medium\">Марія П.\u003C\u002Ftd>\n                                    \u003Ctd class=\"hidden @[380px]\u002Ftable:table-cell p-3 text-slate-500\">maria@example.com\u003C\u002Ftd>\n                                    \u003Ctd class=\"hidden @[520px]\u002Ftable:table-cell p-3 text-slate-500\">02.06.2026\u003C\u002Ftd>\n                                    \u003Ctd class=\"p-3\">\u003Cspan class=\"bg-amber-100 text-amber-800 text-[10px] font-bold px-2 py-0.5 rounded-full\">В черзі\u003C\u002Fspan>\u003C\u002Ftd>\n                                \u003C\u002Ftr>\n                            \u003C\u002Ftbody>\n                        \u003C\u002Ftable>\n                    \u003C\u002Fdiv>\n                \u003C\u002Fmain>\n            \u003C\u002Fdiv>\n        \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n\n    \u003Cscript>\n        function resizeDashboard(val) {\n            document.getElementById('dashboard-container').style.width = val + 'px';\n            document.getElementById('dash-width-label').textContent = val + 'px';\n        }\n    \u003C\u002Fscript>\n\u003C\u002Fbody>\n\u003C\u002Fhtml>\n",[3360,11088,11089,11099,11113,11121,11135,11153,11173,11181,11202,11217,11241,11245,11250,11265,11289,11356,11379,11409,11417,11421,11426,11455,11460,11475,11480,11485,11500,11523,11538,11562,11586,11609,11617,11625,11629,11634,11649,11654,11659,11674,11698,11722,11730,11734,11739,11754,11769,11784,11808,11816,11840,11864,11873,11881,11889,11903,11917,11940,11948,11971,11994,12002,12010,12018,12032,12046,12069,12077,12100,12123,12131,12139,12147,12161,12175,12197,12205,12228,12251,12259,12267,12275,12283,12287,12292,12307,12322,12346,12370,12378,12393,12401,12416,12439,12462,12485,12507,12515,12523,12531,12546,12570,12594,12618,12658,12666,12681,12704,12727,12750,12788,12796,12804,12812,12820,12828,12836,12844,12852,12856,12864,12877,12910,12937,12941,12949,12957],{"__ignoreMap":3433},[3445,11090,11091,11093,11095,11097],{"class":3447,"line":3448},[3445,11092,4945],{"class":3458},[3445,11094,4948],{"class":3462},[3445,11096,4951],{"class":3466},[3445,11098,3478],{"class":3458},[3445,11100,11101,11103,11105,11107,11109,11111],{"class":3447,"line":3455},[3445,11102,3459],{"class":3458},[3445,11104,3441],{"class":3462},[3445,11106,4962],{"class":3466},[3445,11108,3471],{"class":3470},[3445,11110,4967],{"class":3474},[3445,11112,3478],{"class":3458},[3445,11114,11115,11117,11119],{"class":3447,"line":3481},[3445,11116,3459],{"class":3458},[3445,11118,4976],{"class":3462},[3445,11120,3478],{"class":3458},[3445,11122,11123,11125,11127,11129,11131,11133],{"class":3447,"line":3488},[3445,11124,3459],{"class":3458},[3445,11126,4985],{"class":3462},[3445,11128,4988],{"class":3466},[3445,11130,3471],{"class":3470},[3445,11132,4993],{"class":3474},[3445,11134,3478],{"class":3458},[3445,11136,11137,11139,11141,11143,11145,11147,11149,11151],{"class":3447,"line":3494},[3445,11138,3459],{"class":3458},[3445,11140,5002],{"class":3462},[3445,11142,5005],{"class":3466},[3445,11144,3471],{"class":5008},[3445,11146,5011],{"class":3474},[3445,11148,5014],{"class":3458},[3445,11150,5002],{"class":3462},[3445,11152,3478],{"class":3458},[3445,11154,11155,11157,11159,11161,11163,11165,11167,11169,11171],{"class":3447,"line":3510},[3445,11156,3459],{"class":3458},[3445,11158,5025],{"class":3462},[3445,11160,5028],{"class":3466},[3445,11162,3471],{"class":3470},[3445,11164,5033],{"class":3474},[3445,11166,5036],{"class":3466},[3445,11168,3471],{"class":3470},[3445,11170,5041],{"class":3474},[3445,11172,3478],{"class":3458},[3445,11174,11175,11177,11179],{"class":3447,"line":3515},[3445,11176,4707],{"class":3458},[3445,11178,4976],{"class":3462},[3445,11180,3478],{"class":3458},[3445,11182,11183,11185,11187,11189,11191,11194,11196,11198,11200],{"class":3447,"line":3521},[3445,11184,3459],{"class":3458},[3445,11186,5058],{"class":3462},[3445,11188,3467],{"class":3466},[3445,11190,3471],{"class":3470},[3445,11192,11193],{"class":3474},"\"p-6 bg-slate-100\"",[3445,11195,4494],{"class":3466},[3445,11197,3471],{"class":3470},[3445,11199,5072],{"class":3474},[3445,11201,3478],{"class":3458},[3445,11203,11204,11206,11208,11210,11212,11215],{"class":3447,"line":3537},[3445,11205,4506],{"class":3458},[3445,11207,3463],{"class":3462},[3445,11209,3467],{"class":3466},[3445,11211,3471],{"class":3470},[3445,11213,11214],{"class":3474},"\"max-w-3xl mx-auto space-y-6\"",[3445,11216,3478],{"class":3458},[3445,11218,11219,11221,11223,11225,11227,11230,11232,11235,11237,11239],{"class":3447,"line":3542},[3445,11220,4639],{"class":3458},[3445,11222,3353],{"class":3462},[3445,11224,3467],{"class":3466},[3445,11226,3471],{"class":3470},[3445,11228,11229],{"class":3474},"\"text-xs font-bold text-slate-400 uppercase tracking-widest text-center\"",[3445,11231,3994],{"class":3458},[3445,11233,11234],{"class":3470},"Dashboard Nested Containers Simulator",[3445,11236,4707],{"class":3458},[3445,11238,3353],{"class":3462},[3445,11240,3478],{"class":3458},[3445,11242,11243],{"class":3447,"line":3548},[3445,11244,5118],{"class":3470},[3445,11246,11247],{"class":3447,"line":3564},[3445,11248,11249],{"class":3451},"        \u003C!-- Width Slider Control -->\n",[3445,11251,11252,11254,11256,11258,11260,11263],{"class":3447,"line":3569},[3445,11253,4639],{"class":3458},[3445,11255,3463],{"class":3462},[3445,11257,3467],{"class":3466},[3445,11259,3471],{"class":3470},[3445,11261,11262],{"class":3474},"\"flex items-center gap-3 bg-white p-4 rounded-2xl border border-slate-200 shadow-sm max-w-xl mx-auto\"",[3445,11264,3478],{"class":3458},[3445,11266,11267,11269,11271,11273,11275,11278,11280,11283,11285,11287],{"class":3447,"line":3575},[3445,11268,5143],{"class":3458},[3445,11270,3445],{"class":3462},[3445,11272,3467],{"class":3466},[3445,11274,3471],{"class":3470},[3445,11276,11277],{"class":3474},"\"text-xs text-slate-500 font-medium\"",[3445,11279,3994],{"class":3458},[3445,11281,11282],{"class":3470},"300px",[3445,11284,4707],{"class":3458},[3445,11286,3445],{"class":3462},[3445,11288,3478],{"class":3458},[3445,11290,11291,11293,11295,11297,11299,11301,11303,11305,11308,11310,11312,11315,11317,11319,11322,11324,11326,11329,11331,11333,11335,11337,11339,11341,11344,11346,11348,11350,11352,11354],{"class":3447,"line":3591},[3445,11292,5143],{"class":3458},[3445,11294,4817],{"class":3462},[3445,11296,4820],{"class":3466},[3445,11298,3471],{"class":3470},[3445,11300,8970],{"class":3474},[3445,11302,8973],{"class":3466},[3445,11304,3471],{"class":3470},[3445,11306,11307],{"class":3474},"\"300\"",[3445,11309,8981],{"class":3466},[3445,11311,3471],{"class":3470},[3445,11313,11314],{"class":3474},"\"750\"",[3445,11316,8989],{"class":3466},[3445,11318,3471],{"class":3470},[3445,11320,11321],{"class":3474},"\"600\"",[3445,11323,5372],{"class":3466},[3445,11325,3471],{"class":3470},[3445,11327,11328],{"class":3474},"\"dash-slider\"",[3445,11330,3467],{"class":3466},[3445,11332,3471],{"class":3470},[3445,11334,9011],{"class":3474},[3445,11336,9014],{"class":3466},[3445,11338,3471],{"class":3470},[3445,11340,5301],{"class":3474},[3445,11342,11343],{"class":5304},"resizeDashboard",[3445,11345,5480],{"class":3474},[3445,11347,9026],{"class":5448},[3445,11349,3630],{"class":3474},[3445,11351,9031],{"class":5471},[3445,11353,9034],{"class":3474},[3445,11355,3478],{"class":3458},[3445,11357,11358,11360,11362,11364,11366,11368,11370,11373,11375,11377],{"class":3447,"line":3596},[3445,11359,5143],{"class":3458},[3445,11361,3445],{"class":3462},[3445,11363,3467],{"class":3466},[3445,11365,3471],{"class":3470},[3445,11367,11277],{"class":3474},[3445,11369,3994],{"class":3458},[3445,11371,11372],{"class":3470},"750px",[3445,11374,4707],{"class":3458},[3445,11376,3445],{"class":3462},[3445,11378,3478],{"class":3458},[3445,11380,11381,11383,11385,11387,11389,11392,11394,11396,11398,11400,11403,11405,11407],{"class":3447,"line":3602},[3445,11382,5143],{"class":3458},[3445,11384,3445],{"class":3462},[3445,11386,5372],{"class":3466},[3445,11388,3471],{"class":3470},[3445,11390,11391],{"class":3474},"\"dash-width-label\"",[3445,11393,3467],{"class":3466},[3445,11395,3471],{"class":3470},[3445,11397,9079],{"class":3474},[3445,11399,3994],{"class":3458},[3445,11401,11402],{"class":3470},"600px",[3445,11404,4707],{"class":3458},[3445,11406,3445],{"class":3462},[3445,11408,3478],{"class":3458},[3445,11410,11411,11413,11415],{"class":3447,"line":4129},[3445,11412,4659],{"class":3458},[3445,11414,3463],{"class":3462},[3445,11416,3478],{"class":3458},[3445,11418,11419],{"class":3447,"line":4134},[3445,11420,3485],{"emptyLinePlaceholder":3484},[3445,11422,11423],{"class":3447,"line":4140},[3445,11424,11425],{"class":3451},"        \u003C!-- Dashboard Wrapper -->\n",[3445,11427,11428,11430,11432,11434,11436,11439,11441,11443,11446,11448,11450,11453],{"class":3447,"line":4156},[3445,11429,4639],{"class":3458},[3445,11431,3463],{"class":3462},[3445,11433,5372],{"class":3466},[3445,11435,3471],{"class":3470},[3445,11437,11438],{"class":3474},"\"dashboard-container\"",[3445,11440,3467],{"class":3466},[3445,11442,3471],{"class":3470},[3445,11444,11445],{"class":3474},"\"mx-auto bg-slate-50 rounded-2xl border border-slate-200 p-4 shadow-sm min-h-[350px] transition-all duration-150 overflow-hidden\"",[3445,11447,4494],{"class":3466},[3445,11449,3471],{"class":3470},[3445,11451,11452],{"class":3474},"\"width: 600px;\"",[3445,11454,3478],{"class":3458},[3445,11456,11457],{"class":3447,"line":4162},[3445,11458,11459],{"class":3451},"            \u003C!-- Outer Container -->\n",[3445,11461,11462,11464,11466,11468,11470,11473],{"class":3447,"line":4447},[3445,11463,5143],{"class":3458},[3445,11465,3463],{"class":3462},[3445,11467,3467],{"class":3466},[3445,11469,3471],{"class":3470},[3445,11471,11472],{"class":3474},"\"@container\u002Fdashboard grid grid-cols-1 @[550px]\u002Fdashboard:grid-cols-[160px_1fr] gap-4\"",[3445,11474,3478],{"class":3458},[3445,11476,11477],{"class":3447,"line":4686},[3445,11478,11479],{"class":3470},"                \n",[3445,11481,11482],{"class":3447,"line":4695},[3445,11483,11484],{"class":3451},"                \u003C!-- Sidebar (Collapses under 550px) -->\n",[3445,11486,11487,11489,11491,11493,11495,11498],{"class":3447,"line":4704},[3445,11488,5267],{"class":3458},[3445,11490,6975],{"class":3462},[3445,11492,3467],{"class":3466},[3445,11494,3471],{"class":3470},[3445,11496,11497],{"class":3474},"\"hidden @[550px]\u002Fdashboard:block bg-white rounded-xl border border-slate-200 p-3 space-y-2\"",[3445,11499,3478],{"class":3458},[3445,11501,11502,11504,11506,11508,11510,11513,11515,11517,11519,11521],{"class":3447,"line":5343},[3445,11503,9267],{"class":3458},[3445,11505,3353],{"class":3462},[3445,11507,3467],{"class":3466},[3445,11509,3471],{"class":3470},[3445,11511,11512],{"class":3474},"\"text-[10px] font-bold text-slate-400 uppercase tracking-wider\"",[3445,11514,3994],{"class":3458},[3445,11516,6937],{"class":3470},[3445,11518,4707],{"class":3458},[3445,11520,3353],{"class":3462},[3445,11522,3478],{"class":3458},[3445,11524,11525,11527,11529,11531,11533,11536],{"class":3447,"line":5349},[3445,11526,9267],{"class":3458},[3445,11528,3463],{"class":3462},[3445,11530,3467],{"class":3466},[3445,11532,3471],{"class":3470},[3445,11534,11535],{"class":3474},"\"space-y-1\"",[3445,11537,3478],{"class":3458},[3445,11539,11540,11542,11544,11546,11548,11551,11553,11556,11558,11560],{"class":3447,"line":5365},[3445,11541,9358],{"class":3458},[3445,11543,3463],{"class":3462},[3445,11545,3467],{"class":3466},[3445,11547,3471],{"class":3470},[3445,11549,11550],{"class":3474},"\"px-2 py-1.5 bg-indigo-50 text-indigo-600 rounded-lg text-xs font-bold\"",[3445,11552,3994],{"class":3458},[3445,11554,11555],{"class":3470},"🏠 Панель",[3445,11557,4707],{"class":3458},[3445,11559,3463],{"class":3462},[3445,11561,3478],{"class":3458},[3445,11563,11564,11566,11568,11570,11572,11575,11577,11580,11582,11584],{"class":3447,"line":5389},[3445,11565,9358],{"class":3458},[3445,11567,3463],{"class":3462},[3445,11569,3467],{"class":3466},[3445,11571,3471],{"class":3470},[3445,11573,11574],{"class":3474},"\"px-2 py-1.5 text-slate-600 hover:bg-slate-50 rounded-lg text-xs font-medium\"",[3445,11576,3994],{"class":3458},[3445,11578,11579],{"class":3470},"📈 Статистика",[3445,11581,4707],{"class":3458},[3445,11583,3463],{"class":3462},[3445,11585,3478],{"class":3458},[3445,11587,11588,11590,11592,11594,11596,11598,11600,11603,11605,11607],{"class":3447,"line":5395},[3445,11589,9358],{"class":3458},[3445,11591,3463],{"class":3462},[3445,11593,3467],{"class":3466},[3445,11595,3471],{"class":3470},[3445,11597,11574],{"class":3474},[3445,11599,3994],{"class":3458},[3445,11601,11602],{"class":3470},"⚙️ Налаштування",[3445,11604,4707],{"class":3458},[3445,11606,3463],{"class":3462},[3445,11608,3478],{"class":3458},[3445,11610,11611,11613,11615],{"class":3447,"line":5404},[3445,11612,9293],{"class":3458},[3445,11614,3463],{"class":3462},[3445,11616,3478],{"class":3458},[3445,11618,11619,11621,11623],{"class":3447,"line":5413},[3445,11620,5327],{"class":3458},[3445,11622,6975],{"class":3462},[3445,11624,3478],{"class":3458},[3445,11626,11627],{"class":3447,"line":5422},[3445,11628,3485],{"emptyLinePlaceholder":3484},[3445,11630,11631],{"class":3447,"line":5431},[3445,11632,11633],{"class":3451},"                \u003C!-- Main Content Area -->\n",[3445,11635,11636,11638,11640,11642,11644,11647],{"class":3447,"line":5436},[3445,11637,5267],{"class":3458},[3445,11639,6950],{"class":3462},[3445,11641,3467],{"class":3466},[3445,11643,3471],{"class":3470},[3445,11645,11646],{"class":3474},"\"@container\u002Fmain space-y-4\"",[3445,11648,3478],{"class":3458},[3445,11650,11651],{"class":3447,"line":5445},[3445,11652,11653],{"class":3470},"                    \n",[3445,11655,11656],{"class":3447,"line":5458},[3445,11657,11658],{"class":3451},"                    \u003C!-- Header Info -->\n",[3445,11660,11661,11663,11665,11667,11669,11672],{"class":3447,"line":5490},[3445,11662,9267],{"class":3458},[3445,11664,3463],{"class":3462},[3445,11666,3467],{"class":3466},[3445,11668,3471],{"class":3470},[3445,11670,11671],{"class":3474},"\"flex justify-between items-center bg-white p-3 rounded-xl border border-slate-200\"",[3445,11673,3478],{"class":3458},[3445,11675,11676,11678,11680,11682,11684,11687,11689,11692,11694,11696],{"class":3447,"line":5520},[3445,11677,9358],{"class":3458},[3445,11679,7943],{"class":3462},[3445,11681,3467],{"class":3466},[3445,11683,3471],{"class":3470},[3445,11685,11686],{"class":3474},"\"text-xs font-bold text-slate-900\"",[3445,11688,3994],{"class":3458},[3445,11690,11691],{"class":3470},"Головна робоча зона",[3445,11693,4707],{"class":3458},[3445,11695,7943],{"class":3462},[3445,11697,3478],{"class":3458},[3445,11699,11700,11702,11704,11706,11708,11711,11713,11716,11718,11720],{"class":3447,"line":5546},[3445,11701,9358],{"class":3458},[3445,11703,3445],{"class":3462},[3445,11705,3467],{"class":3466},[3445,11707,3471],{"class":3470},[3445,11709,11710],{"class":3474},"\"text-[10px] bg-slate-100 text-slate-500 px-2 py-0.5 rounded font-mono\"",[3445,11712,3994],{"class":3458},[3445,11714,11715],{"class":3470},"@[container\u002Fmain]",[3445,11717,4707],{"class":3458},[3445,11719,3445],{"class":3462},[3445,11721,3478],{"class":3458},[3445,11723,11724,11726,11728],{"class":3447,"line":5564},[3445,11725,9293],{"class":3458},[3445,11727,3463],{"class":3462},[3445,11729,3478],{"class":3458},[3445,11731,11732],{"class":3447,"line":5576},[3445,11733,3485],{"emptyLinePlaceholder":3484},[3445,11735,11736],{"class":3447,"line":5600},[3445,11737,11738],{"class":3451},"                    \u003C!-- Stats Grid (Adapts to Main container width) -->\n",[3445,11740,11741,11743,11745,11747,11749,11752],{"class":3447,"line":5616},[3445,11742,9267],{"class":3458},[3445,11744,3463],{"class":3462},[3445,11746,3467],{"class":3466},[3445,11748,3471],{"class":3470},[3445,11750,11751],{"class":3474},"\"grid grid-cols-2 @[400px]\u002Fmain:grid-cols-4 gap-3\"",[3445,11753,3478],{"class":3458},[3445,11755,11756,11758,11760,11762,11764,11767],{"class":3447,"line":5622},[3445,11757,9358],{"class":3458},[3445,11759,3463],{"class":3462},[3445,11761,3467],{"class":3466},[3445,11763,3471],{"class":3470},[3445,11765,11766],{"class":3474},"\"@container\u002Fstat bg-white rounded-xl p-3 border border-slate-200\"",[3445,11768,3478],{"class":3458},[3445,11770,11771,11773,11775,11777,11779,11782],{"class":3447,"line":5628},[3445,11772,9375],{"class":3458},[3445,11774,3463],{"class":3462},[3445,11776,3467],{"class":3466},[3445,11778,3471],{"class":3470},[3445,11780,11781],{"class":3474},"\"flex flex-col @[140px]\u002Fstat:flex-row @[140px]\u002Fstat:items-center gap-1.5\"",[3445,11783,3478],{"class":3458},[3445,11785,11786,11789,11791,11793,11795,11798,11800,11802,11804,11806],{"class":3447,"line":5637},[3445,11787,11788],{"class":3458},"                                \u003C",[3445,11790,3445],{"class":3462},[3445,11792,3467],{"class":3466},[3445,11794,3471],{"class":3470},[3445,11796,11797],{"class":3474},"\"text-xl\"",[3445,11799,3994],{"class":3458},[3445,11801,10769],{"class":3470},[3445,11803,4707],{"class":3458},[3445,11805,3445],{"class":3462},[3445,11807,3478],{"class":3458},[3445,11809,11810,11812,11814],{"class":3447,"line":5646},[3445,11811,11788],{"class":3458},[3445,11813,3463],{"class":3462},[3445,11815,3478],{"class":3458},[3445,11817,11818,11821,11823,11825,11827,11830,11832,11834,11836,11838],{"class":3447,"line":9317},[3445,11819,11820],{"class":3458},"                                    \u003C",[3445,11822,3353],{"class":3462},[3445,11824,3467],{"class":3466},[3445,11826,3471],{"class":3470},[3445,11828,11829],{"class":3474},"\"text-sm font-bold text-slate-900\"",[3445,11831,3994],{"class":3458},[3445,11833,10801],{"class":3470},[3445,11835,4707],{"class":3458},[3445,11837,3353],{"class":3462},[3445,11839,3478],{"class":3458},[3445,11841,11842,11844,11846,11848,11850,11853,11855,11858,11860,11862],{"class":3447,"line":9333},[3445,11843,11820],{"class":3458},[3445,11845,3353],{"class":3462},[3445,11847,3467],{"class":3466},[3445,11849,3471],{"class":3470},[3445,11851,11852],{"class":3474},"\"text-[9px] text-slate-400\"",[3445,11854,3994],{"class":3458},[3445,11856,11857],{"class":3470},"Візити",[3445,11859,4707],{"class":3458},[3445,11861,3353],{"class":3462},[3445,11863,3478],{"class":3458},[3445,11865,11866,11869,11871],{"class":3447,"line":9339},[3445,11867,11868],{"class":3458},"                                \u003C\u002F",[3445,11870,3463],{"class":3462},[3445,11872,3478],{"class":3458},[3445,11874,11875,11877,11879],{"class":3447,"line":9355},[3445,11876,9398],{"class":3458},[3445,11878,3463],{"class":3462},[3445,11880,3478],{"class":3458},[3445,11882,11883,11885,11887],{"class":3447,"line":9372},[3445,11884,9439],{"class":3458},[3445,11886,3463],{"class":3462},[3445,11888,3478],{"class":3458},[3445,11890,11891,11893,11895,11897,11899,11901],{"class":3447,"line":9389},[3445,11892,9358],{"class":3458},[3445,11894,3463],{"class":3462},[3445,11896,3467],{"class":3466},[3445,11898,3471],{"class":3470},[3445,11900,11766],{"class":3474},[3445,11902,3478],{"class":3458},[3445,11904,11905,11907,11909,11911,11913,11915],{"class":3447,"line":9395},[3445,11906,9375],{"class":3458},[3445,11908,3463],{"class":3462},[3445,11910,3467],{"class":3466},[3445,11912,3471],{"class":3470},[3445,11914,11781],{"class":3474},[3445,11916,3478],{"class":3458},[3445,11918,11919,11921,11923,11925,11927,11929,11931,11934,11936,11938],{"class":3447,"line":9405},[3445,11920,11788],{"class":3458},[3445,11922,3445],{"class":3462},[3445,11924,3467],{"class":3466},[3445,11926,3471],{"class":3470},[3445,11928,11797],{"class":3474},[3445,11930,3994],{"class":3458},[3445,11932,11933],{"class":3470},"💰",[3445,11935,4707],{"class":3458},[3445,11937,3445],{"class":3462},[3445,11939,3478],{"class":3458},[3445,11941,11942,11944,11946],{"class":3447,"line":9421},[3445,11943,11788],{"class":3458},[3445,11945,3463],{"class":3462},[3445,11947,3478],{"class":3458},[3445,11949,11950,11952,11954,11956,11958,11960,11962,11965,11967,11969],{"class":3447,"line":9427},[3445,11951,11820],{"class":3458},[3445,11953,3353],{"class":3462},[3445,11955,3467],{"class":3466},[3445,11957,3471],{"class":3470},[3445,11959,11829],{"class":3474},[3445,11961,3994],{"class":3458},[3445,11963,11964],{"class":3470},"$12.4k",[3445,11966,4707],{"class":3458},[3445,11968,3353],{"class":3462},[3445,11970,3478],{"class":3458},[3445,11972,11973,11975,11977,11979,11981,11983,11985,11988,11990,11992],{"class":3447,"line":9436},[3445,11974,11820],{"class":3458},[3445,11976,3353],{"class":3462},[3445,11978,3467],{"class":3466},[3445,11980,3471],{"class":3470},[3445,11982,11852],{"class":3474},[3445,11984,3994],{"class":3458},[3445,11986,11987],{"class":3470},"Дохід",[3445,11989,4707],{"class":3458},[3445,11991,3353],{"class":3462},[3445,11993,3478],{"class":3458},[3445,11995,11996,11998,12000],{"class":3447,"line":9446},[3445,11997,11868],{"class":3458},[3445,11999,3463],{"class":3462},[3445,12001,3478],{"class":3458},[3445,12003,12004,12006,12008],{"class":3447,"line":9452},[3445,12005,9398],{"class":3458},[3445,12007,3463],{"class":3462},[3445,12009,3478],{"class":3458},[3445,12011,12012,12014,12016],{"class":3447,"line":9466},[3445,12013,9439],{"class":3458},[3445,12015,3463],{"class":3462},[3445,12017,3478],{"class":3458},[3445,12019,12020,12022,12024,12026,12028,12030],{"class":3447,"line":9472},[3445,12021,9358],{"class":3458},[3445,12023,3463],{"class":3462},[3445,12025,3467],{"class":3466},[3445,12027,3471],{"class":3470},[3445,12029,11766],{"class":3474},[3445,12031,3478],{"class":3458},[3445,12033,12034,12036,12038,12040,12042,12044],{"class":3447,"line":9480},[3445,12035,9375],{"class":3458},[3445,12037,3463],{"class":3462},[3445,12039,3467],{"class":3466},[3445,12041,3471],{"class":3470},[3445,12043,11781],{"class":3474},[3445,12045,3478],{"class":3458},[3445,12047,12048,12050,12052,12054,12056,12058,12060,12063,12065,12067],{"class":3447,"line":9486},[3445,12049,11788],{"class":3458},[3445,12051,3445],{"class":3462},[3445,12053,3467],{"class":3466},[3445,12055,3471],{"class":3470},[3445,12057,11797],{"class":3474},[3445,12059,3994],{"class":3458},[3445,12061,12062],{"class":3470},"👥",[3445,12064,4707],{"class":3458},[3445,12066,3445],{"class":3462},[3445,12068,3478],{"class":3458},[3445,12070,12071,12073,12075],{"class":3447,"line":9495},[3445,12072,11788],{"class":3458},[3445,12074,3463],{"class":3462},[3445,12076,3478],{"class":3458},[3445,12078,12079,12081,12083,12085,12087,12089,12091,12094,12096,12098],{"class":3447,"line":9504},[3445,12080,11820],{"class":3458},[3445,12082,3353],{"class":3462},[3445,12084,3467],{"class":3466},[3445,12086,3471],{"class":3470},[3445,12088,11829],{"class":3474},[3445,12090,3994],{"class":3458},[3445,12092,12093],{"class":3470},"432",[3445,12095,4707],{"class":3458},[3445,12097,3353],{"class":3462},[3445,12099,3478],{"class":3458},[3445,12101,12102,12104,12106,12108,12110,12112,12114,12117,12119,12121],{"class":3447,"line":9509},[3445,12103,11820],{"class":3458},[3445,12105,3353],{"class":3462},[3445,12107,3467],{"class":3466},[3445,12109,3471],{"class":3470},[3445,12111,11852],{"class":3474},[3445,12113,3994],{"class":3458},[3445,12115,12116],{"class":3470},"Клієнти",[3445,12118,4707],{"class":3458},[3445,12120,3353],{"class":3462},[3445,12122,3478],{"class":3458},[3445,12124,12125,12127,12129],{"class":3447,"line":9515},[3445,12126,11868],{"class":3458},[3445,12128,3463],{"class":3462},[3445,12130,3478],{"class":3458},[3445,12132,12133,12135,12137],{"class":3447,"line":9531},[3445,12134,9398],{"class":3458},[3445,12136,3463],{"class":3462},[3445,12138,3478],{"class":3458},[3445,12140,12141,12143,12145],{"class":3447,"line":9537},[3445,12142,9439],{"class":3458},[3445,12144,3463],{"class":3462},[3445,12146,3478],{"class":3458},[3445,12148,12149,12151,12153,12155,12157,12159],{"class":3447,"line":9546},[3445,12150,9358],{"class":3458},[3445,12152,3463],{"class":3462},[3445,12154,3467],{"class":3466},[3445,12156,3471],{"class":3470},[3445,12158,11766],{"class":3474},[3445,12160,3478],{"class":3458},[3445,12162,12163,12165,12167,12169,12171,12173],{"class":3447,"line":9551},[3445,12164,9375],{"class":3458},[3445,12166,3463],{"class":3462},[3445,12168,3467],{"class":3466},[3445,12170,3471],{"class":3470},[3445,12172,11781],{"class":3474},[3445,12174,3478],{"class":3458},[3445,12176,12177,12179,12181,12183,12185,12187,12189,12191,12193,12195],{"class":3447,"line":9557},[3445,12178,11788],{"class":3458},[3445,12180,3445],{"class":3462},[3445,12182,3467],{"class":3466},[3445,12184,3471],{"class":3470},[3445,12186,11797],{"class":3474},[3445,12188,3994],{"class":3458},[3445,12190,7469],{"class":3470},[3445,12192,4707],{"class":3458},[3445,12194,3445],{"class":3462},[3445,12196,3478],{"class":3458},[3445,12198,12199,12201,12203],{"class":3447,"line":9573},[3445,12200,11788],{"class":3458},[3445,12202,3463],{"class":3462},[3445,12204,3478],{"class":3458},[3445,12206,12207,12209,12211,12213,12215,12217,12219,12222,12224,12226],{"class":3447,"line":9589},[3445,12208,11820],{"class":3458},[3445,12210,3353],{"class":3462},[3445,12212,3467],{"class":3466},[3445,12214,3471],{"class":3470},[3445,12216,11829],{"class":3474},[3445,12218,3994],{"class":3458},[3445,12220,12221],{"class":3470},"98%",[3445,12223,4707],{"class":3458},[3445,12225,3353],{"class":3462},[3445,12227,3478],{"class":3458},[3445,12229,12230,12232,12234,12236,12238,12240,12242,12245,12247,12249],{"class":3447,"line":9614},[3445,12231,11820],{"class":3458},[3445,12233,3353],{"class":3462},[3445,12235,3467],{"class":3466},[3445,12237,3471],{"class":3470},[3445,12239,11852],{"class":3474},[3445,12241,3994],{"class":3458},[3445,12243,12244],{"class":3470},"Успіх",[3445,12246,4707],{"class":3458},[3445,12248,3353],{"class":3462},[3445,12250,3478],{"class":3458},[3445,12252,12253,12255,12257],{"class":3447,"line":9639},[3445,12254,11868],{"class":3458},[3445,12256,3463],{"class":3462},[3445,12258,3478],{"class":3458},[3445,12260,12261,12263,12265],{"class":3447,"line":9648},[3445,12262,9398],{"class":3458},[3445,12264,3463],{"class":3462},[3445,12266,3478],{"class":3458},[3445,12268,12269,12271,12273],{"class":3447,"line":9663},[3445,12270,9439],{"class":3458},[3445,12272,3463],{"class":3462},[3445,12274,3478],{"class":3458},[3445,12276,12277,12279,12281],{"class":3447,"line":9687},[3445,12278,9293],{"class":3458},[3445,12280,3463],{"class":3462},[3445,12282,3478],{"class":3458},[3445,12284,12285],{"class":3447,"line":9711},[3445,12286,3485],{"emptyLinePlaceholder":3484},[3445,12288,12289],{"class":3447,"line":9720},[3445,12290,12291],{"class":3451},"                    \u003C!-- Table (Adapts columns dynamically) -->\n",[3445,12293,12294,12296,12298,12300,12302,12305],{"class":3447,"line":9735},[3445,12295,9267],{"class":3458},[3445,12297,3463],{"class":3462},[3445,12299,3467],{"class":3466},[3445,12301,3471],{"class":3470},[3445,12303,12304],{"class":3474},"\"@container\u002Ftable bg-white rounded-xl border border-slate-200 overflow-hidden\"",[3445,12306,3478],{"class":3458},[3445,12308,12309,12311,12313,12315,12317,12320],{"class":3447,"line":9759},[3445,12310,9358],{"class":3458},[3445,12312,3463],{"class":3462},[3445,12314,3467],{"class":3466},[3445,12316,3471],{"class":3470},[3445,12318,12319],{"class":3474},"\"bg-slate-50\u002F50 px-3 py-2 border-b border-slate-100 flex justify-between items-center\"",[3445,12321,3478],{"class":3458},[3445,12323,12324,12326,12328,12330,12332,12335,12337,12340,12342,12344],{"class":3447,"line":9783},[3445,12325,9375],{"class":3458},[3445,12327,3445],{"class":3462},[3445,12329,3467],{"class":3466},[3445,12331,3471],{"class":3470},[3445,12333,12334],{"class":3474},"\"text-[10px] font-bold text-slate-400 uppercase\"",[3445,12336,3994],{"class":3458},[3445,12338,12339],{"class":3470},"Останні транзакції",[3445,12341,4707],{"class":3458},[3445,12343,3445],{"class":3462},[3445,12345,3478],{"class":3458},[3445,12347,12348,12350,12352,12354,12356,12359,12361,12364,12366,12368],{"class":3447,"line":9792},[3445,12349,9375],{"class":3458},[3445,12351,3445],{"class":3462},[3445,12353,3467],{"class":3466},[3445,12355,3471],{"class":3470},[3445,12357,12358],{"class":3474},"\"text-[9px] bg-slate-100 text-slate-500 px-2 py-0.5 rounded font-mono\"",[3445,12360,3994],{"class":3458},[3445,12362,12363],{"class":3470},"@[container\u002Ftable]",[3445,12365,4707],{"class":3458},[3445,12367,3445],{"class":3462},[3445,12369,3478],{"class":3458},[3445,12371,12372,12374,12376],{"class":3447,"line":9801},[3445,12373,9439],{"class":3458},[3445,12375,3463],{"class":3462},[3445,12377,3478],{"class":3458},[3445,12379,12380,12382,12384,12386,12388,12391],{"class":3447,"line":9806},[3445,12381,9358],{"class":3458},[3445,12383,3641],{"class":3462},[3445,12385,3467],{"class":3466},[3445,12387,3471],{"class":3470},[3445,12389,12390],{"class":3474},"\"w-full text-left text-xs\"",[3445,12392,3478],{"class":3458},[3445,12394,12395,12397,12399],{"class":3447,"line":9812},[3445,12396,9375],{"class":3458},[3445,12398,3644],{"class":3462},[3445,12400,3478],{"class":3458},[3445,12402,12403,12405,12407,12409,12411,12414],{"class":3447,"line":9828},[3445,12404,11788],{"class":3458},[3445,12406,3647],{"class":3462},[3445,12408,3467],{"class":3466},[3445,12410,3471],{"class":3470},[3445,12412,12413],{"class":3474},"\"border-b border-slate-100 bg-slate-50\u002F20 text-slate-500\"",[3445,12415,3478],{"class":3458},[3445,12417,12418,12420,12422,12424,12426,12429,12431,12433,12435,12437],{"class":3447,"line":9842},[3445,12419,11820],{"class":3458},[3445,12421,3650],{"class":3462},[3445,12423,3467],{"class":3466},[3445,12425,3471],{"class":3470},[3445,12427,12428],{"class":3474},"\"p-3 font-semibold\"",[3445,12430,3994],{"class":3458},[3445,12432,10947],{"class":3470},[3445,12434,4707],{"class":3458},[3445,12436,3650],{"class":3462},[3445,12438,3478],{"class":3458},[3445,12440,12441,12443,12445,12447,12449,12452,12454,12456,12458,12460],{"class":3447,"line":9848},[3445,12442,11820],{"class":3458},[3445,12444,3650],{"class":3462},[3445,12446,3467],{"class":3466},[3445,12448,3471],{"class":3470},[3445,12450,12451],{"class":3474},"\"hidden @[380px]\u002Ftable:table-cell p-3 font-semibold\"",[3445,12453,3994],{"class":3458},[3445,12455,10976],{"class":3470},[3445,12457,4707],{"class":3458},[3445,12459,3650],{"class":3462},[3445,12461,3478],{"class":3458},[3445,12463,12464,12466,12468,12470,12472,12475,12477,12479,12481,12483],{"class":3447,"line":9854},[3445,12465,11820],{"class":3458},[3445,12467,3650],{"class":3462},[3445,12469,3467],{"class":3466},[3445,12471,3471],{"class":3470},[3445,12473,12474],{"class":3474},"\"hidden @[520px]\u002Ftable:table-cell p-3 font-semibold\"",[3445,12476,3994],{"class":3458},[3445,12478,11000],{"class":3470},[3445,12480,4707],{"class":3458},[3445,12482,3650],{"class":3462},[3445,12484,3478],{"class":3458},[3445,12486,12487,12489,12491,12493,12495,12497,12499,12501,12503,12505],{"class":3447,"line":9860},[3445,12488,11820],{"class":3458},[3445,12490,3650],{"class":3462},[3445,12492,3467],{"class":3466},[3445,12494,3471],{"class":3470},[3445,12496,12428],{"class":3474},[3445,12498,3994],{"class":3458},[3445,12500,11023],{"class":3470},[3445,12502,4707],{"class":3458},[3445,12504,3650],{"class":3462},[3445,12506,3478],{"class":3458},[3445,12508,12509,12511,12513],{"class":3447,"line":9868},[3445,12510,11868],{"class":3458},[3445,12512,3647],{"class":3462},[3445,12514,3478],{"class":3458},[3445,12516,12517,12519,12521],{"class":3447,"line":9874},[3445,12518,9398],{"class":3458},[3445,12520,3644],{"class":3462},[3445,12522,3478],{"class":3458},[3445,12524,12525,12527,12529],{"class":3447,"line":9883},[3445,12526,9375],{"class":3458},[3445,12528,3660],{"class":3462},[3445,12530,3478],{"class":3458},[3445,12532,12533,12535,12537,12539,12541,12544],{"class":3447,"line":9889},[3445,12534,11788],{"class":3458},[3445,12536,3647],{"class":3462},[3445,12538,3467],{"class":3466},[3445,12540,3471],{"class":3470},[3445,12542,12543],{"class":3474},"\"border-b border-slate-100 text-slate-700\"",[3445,12545,3478],{"class":3458},[3445,12547,12548,12550,12552,12554,12556,12559,12561,12564,12566,12568],{"class":3447,"line":9903},[3445,12549,11820],{"class":3458},[3445,12551,3665],{"class":3462},[3445,12553,3467],{"class":3466},[3445,12555,3471],{"class":3470},[3445,12557,12558],{"class":3474},"\"p-3 font-medium\"",[3445,12560,3994],{"class":3458},[3445,12562,12563],{"class":3470},"Іван К.",[3445,12565,4707],{"class":3458},[3445,12567,3665],{"class":3462},[3445,12569,3478],{"class":3458},[3445,12571,12572,12574,12576,12578,12580,12583,12585,12588,12590,12592],{"class":3447,"line":9909},[3445,12573,11820],{"class":3458},[3445,12575,3665],{"class":3462},[3445,12577,3467],{"class":3466},[3445,12579,3471],{"class":3470},[3445,12581,12582],{"class":3474},"\"hidden @[380px]\u002Ftable:table-cell p-3 text-slate-500\"",[3445,12584,3994],{"class":3458},[3445,12586,12587],{"class":3470},"ivan@example.com",[3445,12589,4707],{"class":3458},[3445,12591,3665],{"class":3462},[3445,12593,3478],{"class":3458},[3445,12595,12596,12598,12600,12602,12604,12607,12609,12612,12614,12616],{"class":3447,"line":9914},[3445,12597,11820],{"class":3458},[3445,12599,3665],{"class":3462},[3445,12601,3467],{"class":3466},[3445,12603,3471],{"class":3470},[3445,12605,12606],{"class":3474},"\"hidden @[520px]\u002Ftable:table-cell p-3 text-slate-500\"",[3445,12608,3994],{"class":3458},[3445,12610,12611],{"class":3470},"03.06.2026",[3445,12613,4707],{"class":3458},[3445,12615,3665],{"class":3462},[3445,12617,3478],{"class":3458},[3445,12619,12620,12622,12624,12626,12628,12631,12634,12636,12638,12640,12643,12645,12648,12650,12652,12654,12656],{"class":3447,"line":9920},[3445,12621,11820],{"class":3458},[3445,12623,3665],{"class":3462},[3445,12625,3467],{"class":3466},[3445,12627,3471],{"class":3470},[3445,12629,12630],{"class":3474},"\"p-3\"",[3445,12632,12633],{"class":3458},">\u003C",[3445,12635,3445],{"class":3462},[3445,12637,3467],{"class":3466},[3445,12639,3471],{"class":3470},[3445,12641,12642],{"class":3474},"\"bg-emerald-100 text-emerald-800 text-[10px] font-bold px-2 py-0.5 rounded-full\"",[3445,12644,3994],{"class":3458},[3445,12646,12647],{"class":3470},"Успішно",[3445,12649,4707],{"class":3458},[3445,12651,3445],{"class":3462},[3445,12653,5014],{"class":3458},[3445,12655,3665],{"class":3462},[3445,12657,3478],{"class":3458},[3445,12659,12660,12662,12664],{"class":3447,"line":9926},[3445,12661,11868],{"class":3458},[3445,12663,3647],{"class":3462},[3445,12665,3478],{"class":3458},[3445,12667,12668,12670,12672,12674,12676,12679],{"class":3447,"line":9933},[3445,12669,11788],{"class":3458},[3445,12671,3647],{"class":3462},[3445,12673,3467],{"class":3466},[3445,12675,3471],{"class":3470},[3445,12677,12678],{"class":3474},"\"text-slate-700\"",[3445,12680,3478],{"class":3458},[3445,12682,12683,12685,12687,12689,12691,12693,12695,12698,12700,12702],{"class":3447,"line":9951},[3445,12684,11820],{"class":3458},[3445,12686,3665],{"class":3462},[3445,12688,3467],{"class":3466},[3445,12690,3471],{"class":3470},[3445,12692,12558],{"class":3474},[3445,12694,3994],{"class":3458},[3445,12696,12697],{"class":3470},"Марія П.",[3445,12699,4707],{"class":3458},[3445,12701,3665],{"class":3462},[3445,12703,3478],{"class":3458},[3445,12705,12706,12708,12710,12712,12714,12716,12718,12721,12723,12725],{"class":3447,"line":9960},[3445,12707,11820],{"class":3458},[3445,12709,3665],{"class":3462},[3445,12711,3467],{"class":3466},[3445,12713,3471],{"class":3470},[3445,12715,12582],{"class":3474},[3445,12717,3994],{"class":3458},[3445,12719,12720],{"class":3470},"maria@example.com",[3445,12722,4707],{"class":3458},[3445,12724,3665],{"class":3462},[3445,12726,3478],{"class":3458},[3445,12728,12729,12731,12733,12735,12737,12739,12741,12744,12746,12748],{"class":3447,"line":9969},[3445,12730,11820],{"class":3458},[3445,12732,3665],{"class":3462},[3445,12734,3467],{"class":3466},[3445,12736,3471],{"class":3470},[3445,12738,12606],{"class":3474},[3445,12740,3994],{"class":3458},[3445,12742,12743],{"class":3470},"02.06.2026",[3445,12745,4707],{"class":3458},[3445,12747,3665],{"class":3462},[3445,12749,3478],{"class":3458},[3445,12751,12752,12754,12756,12758,12760,12762,12764,12766,12768,12770,12773,12775,12778,12780,12782,12784,12786],{"class":3447,"line":9978},[3445,12753,11820],{"class":3458},[3445,12755,3665],{"class":3462},[3445,12757,3467],{"class":3466},[3445,12759,3471],{"class":3470},[3445,12761,12630],{"class":3474},[3445,12763,12633],{"class":3458},[3445,12765,3445],{"class":3462},[3445,12767,3467],{"class":3466},[3445,12769,3471],{"class":3470},[3445,12771,12772],{"class":3474},"\"bg-amber-100 text-amber-800 text-[10px] font-bold px-2 py-0.5 rounded-full\"",[3445,12774,3994],{"class":3458},[3445,12776,12777],{"class":3470},"В черзі",[3445,12779,4707],{"class":3458},[3445,12781,3445],{"class":3462},[3445,12783,5014],{"class":3458},[3445,12785,3665],{"class":3462},[3445,12787,3478],{"class":3458},[3445,12789,12790,12792,12794],{"class":3447,"line":9987},[3445,12791,11868],{"class":3458},[3445,12793,3647],{"class":3462},[3445,12795,3478],{"class":3458},[3445,12797,12798,12800,12802],{"class":3447,"line":9996},[3445,12799,9398],{"class":3458},[3445,12801,3660],{"class":3462},[3445,12803,3478],{"class":3458},[3445,12805,12806,12808,12810],{"class":3447,"line":10005},[3445,12807,9439],{"class":3458},[3445,12809,3641],{"class":3462},[3445,12811,3478],{"class":3458},[3445,12813,12814,12816,12818],{"class":3447,"line":10014},[3445,12815,9293],{"class":3458},[3445,12817,3463],{"class":3462},[3445,12819,3478],{"class":3458},[3445,12821,12822,12824,12826],{"class":3447,"line":10019},[3445,12823,5327],{"class":3458},[3445,12825,6950],{"class":3462},[3445,12827,3478],{"class":3458},[3445,12829,12830,12832,12834],{"class":3447,"line":10025},[3445,12831,5336],{"class":3458},[3445,12833,3463],{"class":3462},[3445,12835,3478],{"class":3458},[3445,12837,12838,12840,12842],{"class":3447,"line":10041},[3445,12839,4659],{"class":3458},[3445,12841,3463],{"class":3462},[3445,12843,3478],{"class":3458},[3445,12845,12846,12848,12850],{"class":3447,"line":10072},[3445,12847,4527],{"class":3458},[3445,12849,3463],{"class":3462},[3445,12851,3478],{"class":3458},[3445,12853,12854],{"class":3447,"line":10081},[3445,12855,3485],{"emptyLinePlaceholder":3484},[3445,12857,12858,12860,12862],{"class":3447,"line":10086},[3445,12859,4506],{"class":3458},[3445,12861,5002],{"class":3462},[3445,12863,3478],{"class":3458},[3445,12865,12866,12868,12871,12873,12875],{"class":3447,"line":10095},[3445,12867,5449],{"class":5448},[3445,12869,12870],{"class":5304}," resizeDashboard",[3445,12872,5480],{"class":5008},[3445,12874,10106],{"class":5471},[3445,12876,7867],{"class":5008},[3445,12878,12879,12882,12884,12886,12888,12891,12893,12895,12897,12899,12901,12903,12905,12908],{"class":3447,"line":10111},[3445,12880,12881],{"class":5471},"            document",[3445,12883,3630],{"class":5008},[3445,12885,5477],{"class":5304},[3445,12887,5480],{"class":5008},[3445,12889,12890],{"class":5483},"'dashboard-container'",[3445,12892,10126],{"class":5008},[3445,12894,10129],{"class":5471},[3445,12896,3630],{"class":5008},[3445,12898,7857],{"class":5471},[3445,12900,5468],{"class":3470},[3445,12902,10138],{"class":5471},[3445,12904,10141],{"class":3470},[3445,12906,12907],{"class":5483}," 'px'",[3445,12909,5561],{"class":5008},[3445,12911,12912,12914,12916,12918,12920,12923,12925,12927,12929,12931,12933,12935],{"class":3447,"line":10147},[3445,12913,12881],{"class":5471},[3445,12915,3630],{"class":5008},[3445,12917,5477],{"class":5304},[3445,12919,5480],{"class":5008},[3445,12921,12922],{"class":5483},"'dash-width-label'",[3445,12924,10126],{"class":5008},[3445,12926,5553],{"class":5471},[3445,12928,5468],{"class":3470},[3445,12930,10138],{"class":5471},[3445,12932,10141],{"class":3470},[3445,12934,12907],{"class":5483},[3445,12936,5561],{"class":5008},[3445,12938,12939],{"class":3447,"line":10173},[3445,12940,5625],{"class":5008},[3445,12942,12943,12945,12947],{"class":3447,"line":10178},[3445,12944,4527],{"class":3458},[3445,12946,5002],{"class":3462},[3445,12948,3478],{"class":3458},[3445,12950,12951,12953,12955],{"class":3447,"line":10199},[3445,12952,4707],{"class":3458},[3445,12954,5058],{"class":3462},[3445,12956,3478],{"class":3458},[3445,12958,12959,12961,12963],{"class":3447,"line":10213},[3445,12960,4707],{"class":3458},[3445,12962,3441],{"class":3462},[3445,12964,3478],{"class":3458},[3408,12966],{},[3417,12968,12970,12971],{"id":12969},"_38-контейнерні-запити-стилізація-у-css-через-theme","3.8. Контейнерні запити: стилізація у CSS через ",[3360,12972,3629],{},[3353,12974,12975,12976,4189],{},"Якщо ви хочете власні breakpoints для контейнерних запитів — їх можна додати до ",[3360,12977,3629],{},[3425,12979,12982],{"className":5787,"code":12980,"filename":12981,"language":5789,"meta":3433,"style":3433},"@import 'tailwindcss';\n\n@theme {\n    \u002F* Кастомні breakpoints для @container *\u002F\n    --breakpoint-@card-sm:  200px;  \u002F* @card-sm: *\u002F\n    --breakpoint-@card-md:  320px;  \u002F* @card-md: *\u002F\n    --breakpoint-@card-lg:  480px;  \u002F* @card-lg: *\u002F\n    --breakpoint-@card-xl:  640px;  \u002F* @card-xl: *\u002F\n\n    --breakpoint-@sidebar:  280px;  \u002F* @sidebar: *\u002F\n    --breakpoint-@panel:    400px;  \u002F* @panel: *\u002F\n}\n","src\u002Fstyles\u002Fmain.css",[3360,12983,12984,12994,12998,13004,13009,13017,13025,13033,13041,13045,13053,13061],{"__ignoreMap":3433},[3445,12985,12986,12989,12992],{"class":3447,"line":3448},[3445,12987,12988],{"class":5493},"@import",[3445,12990,12991],{"class":5483}," 'tailwindcss'",[3445,12993,5561],{"class":3470},[3445,12995,12996],{"class":3447,"line":3455},[3445,12997,3485],{"emptyLinePlaceholder":3484},[3445,12999,13000,13002],{"class":3447,"line":3481},[3445,13001,3629],{"class":5493},[3445,13003,5573],{"class":3470},[3445,13005,13006],{"class":3447,"line":3488},[3445,13007,13008],{"class":3451},"    \u002F* Кастомні breakpoints для @container *\u002F\n",[3445,13010,13011,13014],{"class":3447,"line":3494},[3445,13012,13013],{"class":3470},"    --breakpoint-@card-sm:  200px;  ",[3445,13015,13016],{"class":3451},"\u002F* @card-sm: *\u002F\n",[3445,13018,13019,13022],{"class":3447,"line":3510},[3445,13020,13021],{"class":3470},"    --breakpoint-@card-md:  320px;  ",[3445,13023,13024],{"class":3451},"\u002F* @card-md: *\u002F\n",[3445,13026,13027,13030],{"class":3447,"line":3515},[3445,13028,13029],{"class":3470},"    --breakpoint-@card-lg:  480px;  ",[3445,13031,13032],{"class":3451},"\u002F* @card-lg: *\u002F\n",[3445,13034,13035,13038],{"class":3447,"line":3521},[3445,13036,13037],{"class":3470},"    --breakpoint-@card-xl:  640px;  ",[3445,13039,13040],{"class":3451},"\u002F* @card-xl: *\u002F\n",[3445,13042,13043],{"class":3447,"line":3537},[3445,13044,3485],{"emptyLinePlaceholder":3484},[3445,13046,13047,13050],{"class":3447,"line":3542},[3445,13048,13049],{"class":3470},"    --breakpoint-@sidebar:  280px;  ",[3445,13051,13052],{"class":3451},"\u002F* @sidebar: *\u002F\n",[3445,13054,13055,13058],{"class":3447,"line":3548},[3445,13056,13057],{"class":3470},"    --breakpoint-@panel:    400px;  ",[3445,13059,13060],{"class":3451},"\u002F* @panel: *\u002F\n",[3445,13062,13063],{"class":3447,"line":3564},[3445,13064,5831],{"class":3470},[3353,13066,13067],{},"Після цього ви можете використовувати ці семантичні назви:",[3425,13069,13071],{"className":3439,"code":13070,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"@container\">\n    \u003Cdiv class=\"flex-col @card-md:flex-row @card-xl:grid @card-xl:grid-cols-3\">\n",[3360,13072,13073,13087],{"__ignoreMap":3433},[3445,13074,13075,13077,13079,13081,13083,13085],{"class":3447,"line":3448},[3445,13076,3459],{"class":3458},[3445,13078,3463],{"class":3462},[3445,13080,3467],{"class":3466},[3445,13082,3471],{"class":3470},[3445,13084,7974],{"class":3474},[3445,13086,3478],{"class":3458},[3445,13088,13089,13091,13093,13095,13097,13100],{"class":3447,"line":3455},[3445,13090,4506],{"class":3458},[3445,13092,3463],{"class":3462},[3445,13094,3467],{"class":3466},[3445,13096,3471],{"class":3470},[3445,13098,13099],{"class":3474},"\"flex-col @card-md:flex-row @card-xl:grid @card-xl:grid-cols-3\"",[3445,13101,3478],{"class":3458},[3404,13103,13104,13105,13107,13108,13110],{},"Назви кастомних breakpoints мають починатися з ",[3360,13106,8251],{}," у значенні змінної ",[3360,13109,3629],{},". Це дозволяє Tailwind відрізняти container breakpoints від media breakpoints.",[3408,13112],{},[3348,13114,13116],{"id":13115},"частина-iv-завдання-для-самоперевірки","Частина IV. Завдання для самоперевірки",[13118,13119,13120],"accordion",{},[13121,13122,13124,13129,13132,13241,13243,13253,13256,13304,13307,13309,13314,13317],"accordion-item",{"label":13123},"Рівень 1: Базовий — розуміння синтаксису",[3353,13125,13126],{},[3378,13127,13128],{},"Завдання 1.1. Декодування довільних значень.",[3353,13130,13131],{},"Що генерує кожен із цих класів у CSS? Відповідайте без запуску коду:",[3425,13133,13135],{"className":3439,"code":13134,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"w-[37.5%]\">\n\u003Cdiv class=\"text-[clamp(1rem,2.5vw,2rem)]\">\n\u003Cdiv class=\"bg-[oklch(0.6_0.22_270)]\">\n\u003Cdiv class=\"shadow-[0_8px_32px_rgba(0,0,0,0.12)]\">\n\u003Cdiv class=\"[grid-template-columns:200px_1fr_auto]\">\n\u003Cdiv class=\"before:content-['©']\">\n\u003Cdiv class=\"translate-x-[calc(-50%+8px)]\">\n",[3360,13136,13137,13151,13166,13181,13196,13211,13226],{"__ignoreMap":3433},[3445,13138,13139,13141,13143,13145,13147,13149],{"class":3447,"line":3448},[3445,13140,3459],{"class":3458},[3445,13142,3463],{"class":3462},[3445,13144,3467],{"class":3466},[3445,13146,3471],{"class":3470},[3445,13148,3559],{"class":3474},[3445,13150,3478],{"class":3458},[3445,13152,13153,13155,13157,13159,13161,13164],{"class":3447,"line":3455},[3445,13154,3459],{"class":3458},[3445,13156,3463],{"class":3462},[3445,13158,3467],{"class":3466},[3445,13160,3471],{"class":3470},[3445,13162,13163],{"class":3474},"\"text-[clamp(1rem,2.5vw,2rem)]\"",[3445,13165,3478],{"class":3458},[3445,13167,13168,13170,13172,13174,13176,13179],{"class":3447,"line":3481},[3445,13169,3459],{"class":3458},[3445,13171,3463],{"class":3462},[3445,13173,3467],{"class":3466},[3445,13175,3471],{"class":3470},[3445,13177,13178],{"class":3474},"\"bg-[oklch(0.6_0.22_270)]\"",[3445,13180,3478],{"class":3458},[3445,13182,13183,13185,13187,13189,13191,13194],{"class":3447,"line":3488},[3445,13184,3459],{"class":3458},[3445,13186,3463],{"class":3462},[3445,13188,3467],{"class":3466},[3445,13190,3471],{"class":3470},[3445,13192,13193],{"class":3474},"\"shadow-[0_8px_32px_rgba(0,0,0,0.12)]\"",[3445,13195,3478],{"class":3458},[3445,13197,13198,13200,13202,13204,13206,13209],{"class":3447,"line":3494},[3445,13199,3459],{"class":3458},[3445,13201,3463],{"class":3462},[3445,13203,3467],{"class":3466},[3445,13205,3471],{"class":3470},[3445,13207,13208],{"class":3474},"\"[grid-template-columns:200px_1fr_auto]\"",[3445,13210,3478],{"class":3458},[3445,13212,13213,13215,13217,13219,13221,13224],{"class":3447,"line":3510},[3445,13214,3459],{"class":3458},[3445,13216,3463],{"class":3462},[3445,13218,3467],{"class":3466},[3445,13220,3471],{"class":3470},[3445,13222,13223],{"class":3474},"\"before:content-['©']\"",[3445,13225,3478],{"class":3458},[3445,13227,13228,13230,13232,13234,13236,13239],{"class":3447,"line":3515},[3445,13229,3459],{"class":3458},[3445,13231,3463],{"class":3462},[3445,13233,3467],{"class":3466},[3445,13235,3471],{"class":3470},[3445,13237,13238],{"class":3474},"\"translate-x-[calc(-50%+8px)]\"",[3445,13240,3478],{"class":3458},[3408,13242],{},[3353,13244,13245],{},[3378,13246,13247,13248,13250,13251,3630],{},"Завдання 1.2. Синтаксис v4: ",[3360,13249,3384],{}," проти ",[3360,13252,3388],{},[3353,13254,13255],{},"Поясніть різницю між:",[3425,13257,13259],{"className":3439,"code":13258,"language":3441,"meta":3433,"style":3433},"\u003Cdiv class=\"bg-[var(--color-brand)]\">\n\u003Cdiv class=\"bg-(--color-brand)\">\n\u003Cdiv class=\"bg-[#FF5733]\">\n",[3360,13260,13261,13275,13289],{"__ignoreMap":3433},[3445,13262,13263,13265,13267,13269,13271,13273],{"class":3447,"line":3448},[3445,13264,3459],{"class":3458},[3445,13266,3463],{"class":3462},[3445,13268,3467],{"class":3466},[3445,13270,3471],{"class":3470},[3445,13272,5695],{"class":3474},[3445,13274,3478],{"class":3458},[3445,13276,13277,13279,13281,13283,13285,13287],{"class":3447,"line":3455},[3445,13278,3459],{"class":3458},[3445,13280,3463],{"class":3462},[3445,13282,3467],{"class":3466},[3445,13284,3471],{"class":3470},[3445,13286,5749],{"class":3474},[3445,13288,3478],{"class":3458},[3445,13290,13291,13293,13295,13297,13299,13302],{"class":3447,"line":3481},[3445,13292,3459],{"class":3458},[3445,13294,3463],{"class":3462},[3445,13296,3467],{"class":3466},[3445,13298,3471],{"class":3470},[3445,13300,13301],{"class":3474},"\"bg-[#FF5733]\"",[3445,13303,3478],{"class":3458},[3353,13305,13306],{},"Яка з форм є новинкою Tailwind v4? Коли який синтаксис правильно використовувати?",[3408,13308],{},[3353,13310,13311],{},[3378,13312,13313],{},"Завдання 1.3. Контейнерні vs медіазапити.",[3353,13315,13316],{},"Для кожного сценарію вкажіть, який підхід правильний:",[3372,13318,13319,13322,13325,13328,13331,13334],{},[3375,13320,13321],{},"Navbar, що перетворюється з горизонтального на вертикальний при ширині \u003C 768px",[3375,13323,13324],{},"Картка товару, що може бути у sidebar (240px) або у grid (400px)",[3375,13326,13327],{},"Типографічна шкала для всього сайту",[3375,13329,13330],{},"Компонент коментаря в різних місцях (post-page, modal, sidebar)",[3375,13332,13333],{},"Hero section із full-width зображенням",[3375,13335,13336],{},"UI-kit кнопка з текстом, що зникає при малому контейнері",[13121,13338,13340,13345,13351,13357,13360,13362,13367,13384,13420,13434,13436,13441,13444,13450,13453],{"label":13339},"Рівень 2: Практика — компоненти",[3353,13341,13342],{},[3378,13343,13344],{},"Завдання 2.1. Адаптивна картка продукту.",[3353,13346,13347,13348,13350],{},"Реалізуйте картку товару, що через ",[3360,13349,3398],{}," змінює layout:",[3425,13352,13355],{"className":13353,"code":13354,"language":3430},[3428],"\u003C 200px  → тільки зображення + ціна\n200-320px → зображення + назва + ціна\n320-500px → вертикальний: зображення + всі деталі + кнопка\n500px+   → горизонтальний: зображення зліва, контент справа\n",[3360,13356,13354],{"__ignoreMap":3433},[3353,13358,13359],{},"Картку треба розмістити у трьох місцях на одній сторінці (sidebar 240px, grid 360px, featured 600px) — і вона має коректно виглядати у кожному.",[3408,13361],{},[3353,13363,13364],{},[3378,13365,13366],{},"Завдання 2.2. Fluid typography та spacing.",[3353,13368,13369,13370,3675,13373,3675,13376,13379,13380,3385,13382,4189],{},"Без використання responsive breakpoints (",[3360,13371,13372],{},"sm:",[3360,13374,13375],{},"md:",[3360,13377,13378],{},"lg:",") — тільки через ",[3360,13381,4262],{},[3360,13383,4253],{},[3372,13385,13386,13397,13407],{},[3375,13387,13388,13389,13392,13393,13396],{},"Hero заголовок: від ",[3360,13390,13391],{},"2rem"," (320px viewport) до ",[3360,13394,13395],{},"5rem"," (1440px viewport) — плавно",[3375,13398,13399,13400,13402,13403,13406],{},"Відступи між секціями: від ",[3360,13401,13391],{}," до ",[3360,13404,13405],{},"6rem"," — плавно",[3375,13408,13409,13410,13413,13414,13417,13418],{},"Максимальна ширина контейнера: від ",[3360,13411,13412],{},"100%"," (\u003C 640px) до ",[3360,13415,13416],{},"80rem"," — через ",[3360,13419,4256],{},[3353,13421,13422,13423,13426,13427,13430,13431,3630],{},"Перевірте: жодного ",[3360,13424,13425],{},"md:text-*"," або ",[3360,13428,13429],{},"lg:text-*"," — тільки ",[3360,13432,13433],{},"text-[clamp(...)]",[3408,13435],{},[3353,13437,13438],{},[3378,13439,13440],{},"Завдання 2.3. Holy Grail через довільні властивості.",[3353,13442,13443],{},"Реалізуйте повну сторінку у Holy Grail layout виключно через Tailwind та довільні значення:",[3425,13445,13448],{"className":13446,"code":13447,"language":3430},[3428],"┌──────────────────────────────┐\n│          Header              │\n├────────┬─────────────┬───────┤\n│  Nav   │    Main     │ Aside │\n│ 220px  │    1fr      │ 180px │\n├────────┴─────────────┴───────┤\n│          Footer              │\n└──────────────────────────────┘\n",[3360,13449,13447],{"__ignoreMap":3433},[3353,13451,13452],{},"Вимоги:",[10430,13454,13455,13464,13471],{},[3375,13456,13457,3385,13460,13463],{},[3360,13458,13459],{},"[grid-template-areas:...]",[3360,13461,13462],{},"[grid-area:...]"," для позиціонування",[3375,13465,13466,13467,13470],{},"Мінімальна висота ",[3360,13468,13469],{},"min-h-screen"," для Main",[3375,13472,13473,13474,13477],{},"На мобільному (",[3360,13475,13476],{},"\u003C md",") — Nav та Aside ховаються, Main займає всю ширину",[13121,13479,13481,13486,13489,13497,13517,13524,13544,13551,13559,13562,13564,13569,13576,13668],{"label":13480},"Рівень 3: Архітектура — компонентна бібліотека",[3353,13482,13483],{},[3378,13484,13485],{},"Завдання 3.1. UI-kit із @container.",[3353,13487,13488],{},"Побудуйте мінімальну компонентну бібліотеку, де всі компоненти адаптуються до свого контейнера:",[3353,13490,13491],{},[3378,13492,13493,13494,4189],{},"Компонент ",[3360,13495,13496],{},"\u003CCard>",[10430,13498,13499,13505,13511],{},[3375,13500,13501,13504],{},[3360,13502,13503],{},"\u003C 300px",": тільки заголовок + кнопка",[3375,13506,13507,13510],{},[3360,13508,13509],{},"300–480px",": заголовок + опис (line-clamp-2) + кнопка",[3375,13512,13513,13516],{},[3360,13514,13515],{},"480px+",": зображення (ліворуч) + весь контент (праворуч)",[3353,13518,13519],{},[3378,13520,13493,13521,4189],{},[3360,13522,13523],{},"\u003CDataTable>",[10430,13525,13526,13532,13538],{},[3375,13527,13528,13531],{},[3360,13529,13530],{},"\u003C 400px",": тільки 2 головні колонки, решта приховані",[3375,13533,13534,13537],{},[3360,13535,13536],{},"400–600px",": 3 колонки",[3375,13539,13540,13543],{},[3360,13541,13542],{},"600px+",": всі колонки + actions",[3353,13545,13546],{},[3378,13547,13493,13548,4189],{},[3360,13549,13550],{},"\u003CNavLink>",[10430,13552,13553,13556],{},[3375,13554,13555],{},"У вузькому контейнері (sidebar \u003C 220px): тільки іконка",[3375,13557,13558],{},"У ширшому: іконка + label",[3353,13560,13561],{},"Зберіть їх на одній сторінці та продемонструйте в різних layout-контекстах.",[3408,13563],{},[3353,13565,13566],{},[3378,13567,13568],{},"Завдання 3.2. Fluid Design System.",[3353,13570,13571,13572,13575],{},"Побудуйте дизайн-систему, де ",[3378,13573,13574],{},"весь spacing та typography"," є fluid:",[3425,13577,13579],{"className":5787,"code":13578,"language":5789,"meta":3433,"style":3433},"\u002F* @theme із fluid значеннями через CSS-змінні *\u002F\n@theme {\n    --spacing-section: clamp(2rem, 5vw, 6rem);\n    --spacing-card:    clamp(1rem, 2vw, 1.5rem);\n    --font-size-h1:    clamp(1.75rem, 5vw, 3.5rem);\n    --font-size-h2:    clamp(1.375rem, 3.5vw, 2.25rem);\n    --font-size-body:  clamp(0.9375rem, 1.5vw, 1.0625rem);\n}\n",[3360,13580,13581,13586,13592,13597,13607,13622,13644,13664],{"__ignoreMap":3433},[3445,13582,13583],{"class":3447,"line":3448},[3445,13584,13585],{"class":3451},"\u002F* @theme із fluid значеннями через CSS-змінні *\u002F\n",[3445,13587,13588,13590],{"class":3447,"line":3455},[3445,13589,3629],{"class":5493},[3445,13591,5573],{"class":3470},[3445,13593,13594],{"class":3447,"line":3481},[3445,13595,13596],{"class":3470},"    --spacing-section: clamp(2rem, 5vw, 6rem);\n",[3445,13598,13599,13602,13605],{"class":3447,"line":3488},[3445,13600,13601],{"class":3470},"    --spacing-card:    clamp(1rem, 2vw, 1",[3445,13603,13604],{"class":5796},".5rem",[3445,13606,5487],{"class":3470},[3445,13608,13609,13612,13615,13618,13620],{"class":3447,"line":3494},[3445,13610,13611],{"class":3470},"    --font-size-h1:    clamp(1",[3445,13613,13614],{"class":5796},".75rem",[3445,13616,13617],{"class":3470},", 5vw, 3",[3445,13619,13604],{"class":5796},[3445,13621,5487],{"class":3470},[3445,13623,13624,13627,13630,13633,13636,13639,13642],{"class":3447,"line":3510},[3445,13625,13626],{"class":3470},"    --font-size-h2:    clamp(1",[3445,13628,13629],{"class":5796},".375rem",[3445,13631,13632],{"class":3470},", 3",[3445,13634,13635],{"class":5796},".5vw",[3445,13637,13638],{"class":3470},", 2",[3445,13640,13641],{"class":5796},".25rem",[3445,13643,5487],{"class":3470},[3445,13645,13646,13649,13652,13655,13657,13659,13662],{"class":3447,"line":3515},[3445,13647,13648],{"class":3470},"    --font-size-body:  clamp(0",[3445,13650,13651],{"class":5796},".9375rem",[3445,13653,13654],{"class":3470},", 1",[3445,13656,13635],{"class":5796},[3445,13658,13654],{"class":3470},[3445,13660,13661],{"class":5796},".0625rem",[3445,13663,5487],{"class":3470},[3445,13665,13666],{"class":3447,"line":3521},[3445,13667,5831],{"class":3470},[3353,13669,13670,13671,3675,13674,13677,13678,3675,13680,3675,13682,13684],{},"Використайте ці токени через ",[3360,13672,13673],{},"p-(--spacing-card)",[3360,13675,13676],{},"text-(--font-size-h1)"," тощо на повноцінній landing page. Жодних ",[3360,13679,13372],{},[3360,13681,13375],{},[3360,13683,13378],{}," медіазапитів для відступів та шрифтів — тільки fluid значення.",[3353,13686,13687],{},"::",[3408,13689],{},[3348,13691,13693],{"id":13692},"підсумок","Підсумок",[3353,13695,13696],{},"У цій статті ми розглянули два потужні механізми Tailwind v4, що дозволяють вийти за межі стандартної дизайн-системи там, де це необхідно.",[3353,13698,13699],{},[3378,13700,13701,13702,3385,13704,4189],{},"Довільні значення ",[3360,13703,3384],{},[3360,13705,3388],{},[10430,13707,13708,13714,13722,13733,13738],{},[3375,13709,5655,13710,13713],{},[3360,13711,13712],{},"[value]"," — для literal CSS-значень: пікселів, кольорів, функцій",[3375,13715,5655,13716,13718,13719],{},[3360,13717,5837],{}," — новинка v4, скорочення для ",[3360,13720,13721],{},"[var(--var)]",[3375,13723,13724,3675,13726,3675,13728,3675,13730,13732],{},[3360,13725,4253],{},[3360,13727,4256],{},[3360,13729,4259],{},[3360,13731,4262],{}," — математика прямо у класі",[3375,13734,13735,13737],{},[3360,13736,5658],{}," — довільні CSS-властивості для всього, чого немає у Tailwind",[3375,13739,13740,13741,13743],{},"Підкреслення ",[3360,13742,4188],{}," замість пробілів у значеннях",[3353,13745,13746],{},[3378,13747,13748,13749,4189],{},"Контейнерні запити ",[3360,13750,3398],{},[10430,13752,13753,13758,13764,13769,13776],{},[3375,13754,13755,13757],{},[3360,13756,3398],{}," на батьку — оголошує контейнер",[3375,13759,13760,13763],{},[3360,13761,13762],{},"@{bp}:"," варіанти — стилі за мінімальною шириною контейнера",[3375,13765,13766,13768],{},[3360,13767,8547],{}," варіанти — стилі за максимальною шириною",[3375,13770,13771,13772,13775],{},"Іменовані контейнери ",[3360,13773,13774],{},"\u002Fname"," — для вкладених структур",[3375,13777,13778],{},"Вбудовано у Tailwind v4 без плагінів",[3620,13780,13781,13782,13785],{},"Головне правило: ",[3378,13783,13784],{},"стандартні утиліти — за замовчуванням, довільні значення — для точності, контейнерні запити — для переносимих компонентів",". Комбінуйте всі три підходи, і ваш код стане одночасно виразним та гнучким.",[3408,13787],{},[3353,13789,13790,13798],{},[13791,13792,13793,13794],"em",{},"Попередня стаття: ",[6682,13795,13797],{"href":13796},"\u002F21.tailwind\u002F09.tailwind-dark-mode-theming","Темна тема та система дизайн-токенів",[13791,13799,13800,13801],{},"Наступна стаття: ",[6682,13802,3327],{"href":13803},"\u002F21.tailwind\u002F11.tailwind-animations-transforms",[10129,13805,13806],{},"html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .s0P7L, html code.shiki .s0P7L{--shiki-light:#800000;--shiki-default:#808080;--shiki-dark:#808080}html pre.shiki code .sKtos, html code.shiki .sKtos{--shiki-light:#800000;--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 .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .su9tN, html code.shiki .su9tN{--shiki-light:#0000FF;--shiki-default:#CE9178;--shiki-dark:#CE9178}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 .sD7JJ, html code.shiki .sD7JJ{--shiki-light:#000000FF;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}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 .s-QsJ, html code.shiki .s-QsJ{--shiki-light:#0070C1;--shiki-default:#4FC1FF;--shiki-dark:#4FC1FF}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .s8xlr, html code.shiki .s8xlr{--shiki-light:#AF00DB;--shiki-default:#C586C0;--shiki-dark:#C586C0}html pre.shiki code .sqdDX, html code.shiki .sqdDX{--shiki-light:#800000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sjcCO, html code.shiki .sjcCO{--shiki-light:#EE0000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .sDUd3, html code.shiki .sDUd3{--shiki-light:#0451A5;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .se1LK, html code.shiki .se1LK{--shiki-light:#CD3131;--shiki-default:#F44747;--shiki-dark:#F44747}",{"title":3433,"searchDepth":3455,"depth":3455,"links":13808},[13809,13810,13822,13829,13842,13843],{"id":3350,"depth":3455,"text":3351},{"id":3412,"depth":3455,"text":13811,"children":13812},"Частина І. Довільні значення: синтаксис квадратних дужок []",[13813,13814,13815,13816,13818,13819,13820,13821],{"id":3419,"depth":3481,"text":3420},{"id":3635,"depth":3481,"text":3636},{"id":3950,"depth":3481,"text":3951},{"id":4249,"depth":3481,"text":13817},"1.4. Синтаксис calc(), min(), max(), clamp()",{"id":4716,"depth":3481,"text":4717},{"id":5668,"depth":3481,"text":5669},{"id":5974,"depth":3481,"text":5975},{"id":6164,"depth":3481,"text":6165},{"id":6588,"depth":3455,"text":13823,"children":13824},"Частина ІІ. Довільні властивості: групи та @apply",[13825,13827,13828],{"id":6595,"depth":3481,"text":13826},"2.1. Псевдоелементи та content",{"id":6833,"depth":3481,"text":6834},{"id":7224,"depth":3481,"text":7225},{"id":7765,"depth":3455,"text":7766,"children":13830},[13831,13832,13833,13834,13836,13838,13839,13840],{"id":7769,"depth":3481,"text":7770},{"id":7933,"depth":3481,"text":7934},{"id":8244,"depth":3481,"text":8245},{"id":8472,"depth":3481,"text":13835},"3.4. Варіанти @min-* та @max-*",{"id":8770,"depth":3481,"text":13837},"3.5. Живий приклад: адаптивна картка через @container",{"id":10411,"depth":3481,"text":10412},{"id":10591,"depth":3481,"text":10592},{"id":12969,"depth":3481,"text":13841},"3.8. Контейнерні запити: стилізація у CSS через @theme",{"id":13115,"depth":3455,"text":13116},{"id":13692,"depth":3455,"text":13693},"Вичерпний посібник з довільних значень у Tailwind v4: синтаксис квадратних дужок [], нові круглі дужки (--var), довільні властивості, calc() та CSS-функції. Контейнерні запити @container: вбудована підтримка v4, варіанти @min-*, @max-*, компонентно-орієнтована адаптивність.","md",null,{},{"title":3323,"description":13844},"sunhKrdIofakOnKrkWLpDnl9dwGoTtR45vIK3t9rlHU",[13851,13853],{"title":3319,"path":3320,"stem":3321,"description":13852,"children":-1},"Вичерпний посібник з реалізації темної теми у Tailwind CSS v4: від теорії CSS Custom Properties до production-ready системи токенів. Стратегії перемикання теми, semantic tokens, multi-theming, збереження вибору у localStorage та підтримка системних налаштувань.",{"title":3327,"path":3328,"stem":3329,"description":13854,"children":-1},"Вичерпний посібник з анімацій у Tailwind CSS v4: transition, animation, вбудовані keyframes, кастомні @keyframes. Повна система трансформацій: scale, rotate, translate, skew. Нові 3D-трансформації v4: perspective, rotate-x\u002Fy\u002Fz, backface-visible. Мікроанімації для UI.",1782371240168]