[{"data":1,"prerenderedAt":18595},["ShallowReactive",2],{"navigation_docs":3,"-html-css-10a-css-sizing":2784,"-html-css-10a-css-sizing-surround":18590},[4,1640,1721,2175,2203,2410,2476,2526,2583,2617,2743,2780],{"title":5,"icon":6,"path":7,"stem":8,"children":9},"C#","i-devicon-csharp","/csharp","01.csharp",[10,13,60,90,120,202,219,253,379,404,457,650,1346,1636],{"title":11,"path":7,"stem":12},"C# Roadmap","01.csharp/index",{"title":14,"icon":15,"path":16,"stem":17,"children":18,"page":59},"Fundamentals","i-lucide-book-open","/csharp/fundamentals","01.csharp/01.fundamentals",[19,23,27,31,35,39,43,47,51,55],{"title":20,"path":21,"stem":22},"Вступ до екосистеми .NET","/csharp/fundamentals/introduction-to-ecosystem","01.csharp/01.fundamentals/01.introduction-to-ecosystem",{"title":24,"path":25,"stem":26},"Структура програми на C#","/csharp/fundamentals/program-structure","01.csharp/01.fundamentals/02.program-structure",{"title":28,"path":29,"stem":30},"Змінні та Типи Даних","/csharp/fundamentals/variables-data-types","01.csharp/01.fundamentals/03.variables-data-types",{"title":32,"path":33,"stem":34},"Масиви","/csharp/fundamentals/arrays","01.csharp/01.fundamentals/04.arrays",{"title":36,"path":37,"stem":38},"Strings & Text Handling","/csharp/fundamentals/strings-text-handling","01.csharp/01.fundamentals/05.strings-text-handling",{"title":40,"path":41,"stem":42},"Дати і Час","/csharp/fundamentals/dates-time-handling","01.csharp/01.fundamentals/06.dates-time-handling",{"title":44,"path":45,"stem":46},"Потік Керування","/csharp/fundamentals/control-flow","01.csharp/01.fundamentals/07.control-flow",{"title":48,"path":49,"stem":50},"Методи","/csharp/fundamentals/methods","01.csharp/01.fundamentals/08.methods",{"title":52,"path":53,"stem":54},"Основи Відлагодження","/csharp/fundamentals/debugging-basics","01.csharp/01.fundamentals/09.debugging-basics",{"title":56,"path":57,"stem":58},"Інтерактивна Консоль (Classic)","/csharp/fundamentals/interactive-console","01.csharp/01.fundamentals/10.interactive-console",false,{"title":61,"icon":62,"path":63,"stem":64,"children":65,"page":59},"OOP","i-lucide-box","/csharp/oop","01.csharp/02.oop",[66,70,74,78,82,86],{"title":67,"path":68,"stem":69},"Package Management (Управління Пакетами)","/csharp/oop/package-management","01.csharp/02.oop/01.package-management",{"title":71,"path":72,"stem":73},"Класи та Об'єкти","/csharp/oop/classes-objects","01.csharp/02.oop/02.classes-objects",{"title":75,"path":76,"stem":77},"Властивості та Поля","/csharp/oop/properties-fields","01.csharp/02.oop/03.properties-fields",{"title":79,"path":80,"stem":81},"Стовпи ООП","/csharp/oop/oop-pillars","01.csharp/02.oop/04.oop-pillars",{"title":83,"path":84,"stem":85},"Advanced Types","/csharp/oop/advanced-types","01.csharp/02.oop/05.advanced-types",{"title":87,"path":88,"stem":89},"Namespaces (Простори Імен)","/csharp/oop/namespaces","01.csharp/02.oop/06.namespaces",{"title":91,"icon":92,"path":93,"stem":94,"children":95,"page":59},"Advanced Core","i-lucide-zap","/csharp/advanced-core","01.csharp/03.advanced-core",[96,100,104,108,112,116],{"title":97,"path":98,"stem":99},"Generics (Узагальнення)","/csharp/advanced-core/generics","01.csharp/03.advanced-core/01.generics",{"title":101,"path":102,"stem":103},"Делегати, Події та Лямбда-вирази","/csharp/advanced-core/delegates-events-lambdas","01.csharp/03.advanced-core/02.delegates-events-lambdas",{"title":105,"path":106,"stem":107},"Interfaces Deep Dive (Інтерфейси: Поглиблений Розгляд)","/csharp/advanced-core/interfaces-deep-dive","01.csharp/03.advanced-core/03.interfaces-deep-dive",{"title":109,"path":110,"stem":111},"Обробка Винятків","/csharp/advanced-core/exception-handling","01.csharp/03.advanced-core/04.exception-handling",{"title":113,"path":114,"stem":115},"Pattern Matching","/csharp/advanced-core/pattern-matching","01.csharp/03.advanced-core/05.pattern-matching",{"title":117,"path":118,"stem":119},"Додаткові Можливості C#","/csharp/advanced-core/additional-features","01.csharp/03.advanced-core/06.additional-features",{"title":121,"icon":122,"path":123,"stem":124,"children":125,"page":59},"Architecture Best Practices","i-lucide-building-2","/csharp/architecture-best-practices","01.csharp/04.architecture-best-practices",[126,130,149,153,157,161,165,169],{"title":127,"path":128,"stem":129},"Software Design Principles (Частина 1)","/csharp/architecture-best-practices/software-design-principles","01.csharp/04.architecture-best-practices/01.software-design-principles",{"title":131,"icon":132,"path":133,"stem":134,"children":135,"page":59},"Design Patterns","i-lucide-folder","/csharp/architecture-best-practices/design-patterns","01.csharp/04.architecture-best-practices/02.design-patterns",[136],{"title":137,"icon":132,"path":138,"stem":139,"children":140,"page":59},"Creational","/csharp/architecture-best-practices/design-patterns/creational","01.csharp/04.architecture-best-practices/02.design-patterns/creational",[141,145],{"title":142,"path":143,"stem":144},"Singleton (Одинак)","/csharp/architecture-best-practices/design-patterns/creational/singleton","01.csharp/04.architecture-best-practices/02.design-patterns/creational/01.singleton",{"title":146,"path":147,"stem":148},"Builder (Будівельник)","/csharp/architecture-best-practices/design-patterns/creational/builder","01.csharp/04.architecture-best-practices/02.design-patterns/creational/02.builder",{"title":150,"path":151,"stem":152},"Building Professional CLIs","/csharp/architecture-best-practices/building-professional-clis","01.csharp/04.architecture-best-practices/03.building-professional-clis",{"title":154,"path":155,"stem":156},"Validation & Flow Control","/csharp/architecture-best-practices/validation-flow-control","01.csharp/04.architecture-best-practices/04.validation-flow-control",{"title":158,"path":159,"stem":160},"The Modern .NET Host (Microsoft.Extensions)","/csharp/architecture-best-practices/modern-dotnet-host","01.csharp/04.architecture-best-practices/05.modern-dotnet-host",{"title":162,"path":163,"stem":164},"Data Mapper: Repository та DAO патерни (Частина 1)","/csharp/architecture-best-practices/data-mapper-part1","01.csharp/04.architecture-best-practices/06.data-mapper-part1",{"title":166,"path":167,"stem":168},"Data Mapper: Repository та DAO патерни (Частина 2)","/csharp/architecture-best-practices/data-mapper-part2","01.csharp/04.architecture-best-practices/07.data-mapper-part2",{"title":170,"icon":132,"path":171,"stem":172,"children":173,"page":59},"Di Ioc","/csharp/architecture-best-practices/di-ioc","01.csharp/04.architecture-best-practices/08.di-ioc",[174,178,182,186,190,194,198],{"title":175,"path":176,"stem":177},"Проблема залежностей та Інверсія Контролю","/csharp/architecture-best-practices/di-ioc/the-dependency-problem","01.csharp/04.architecture-best-practices/08.di-ioc/01.the-dependency-problem",{"title":179,"path":180,"stem":181},"Будуємо власний Service Container","/csharp/architecture-best-practices/di-ioc/build-your-own-container","01.csharp/04.architecture-best-practices/08.di-ioc/02.build-your-own-container",{"title":183,"path":184,"stem":185},"Service Locator: Паттерн та Анти-паттерн","/csharp/architecture-best-practices/di-ioc/service-locator-pattern","01.csharp/04.architecture-best-practices/08.di-ioc/03.service-locator-pattern",{"title":187,"path":188,"stem":189},"Паттерни Dependency Injection","/csharp/architecture-best-practices/di-ioc/dependency-injection-patterns","01.csharp/04.architecture-best-practices/08.di-ioc/04.dependency-injection-patterns",{"title":191,"path":192,"stem":193},"Microsoft DI: IServiceCollection та IServiceProvider","/csharp/architecture-best-practices/di-ioc/microsoft-di-deep-dive","01.csharp/04.architecture-best-practices/08.di-ioc/05.microsoft-di-deep-dive",{"title":195,"path":196,"stem":197},"Service Lifetimes та Scopes","/csharp/architecture-best-practices/di-ioc/service-lifetimes-and-scopes","01.csharp/04.architecture-best-practices/08.di-ioc/06.service-lifetimes-and-scopes",{"title":199,"path":200,"stem":201},"DI Анти-паттерни та Найкращі Практики","/csharp/architecture-best-practices/di-ioc/di-anti-patterns-and-best-practices","01.csharp/04.architecture-best-practices/08.di-ioc/07.di-anti-patterns-and-best-practices",{"title":203,"icon":132,"path":204,"stem":205,"children":206,"page":59},"Standard Library","/csharp/standard-library","01.csharp/05.standard-library",[207,211,215],{"title":208,"path":209,"stem":210},"Collections (Колекції)","/csharp/standard-library/collections","01.csharp/05.standard-library/01.collections",{"title":212,"path":213,"stem":214},"High Performance Types (Високопродуктивні Типи)","/csharp/standard-library/high-performance-types","01.csharp/05.standard-library/02.high-performance-types",{"title":216,"path":217,"stem":218},"LINQ (Language Integrated Query)","/csharp/standard-library/linq","01.csharp/05.standard-library/03.linq",{"title":220,"icon":221,"path":222,"stem":223,"children":224,"page":59},"System Internals Concurrency","i-lucide-server","/csharp/system-internals-concurrency","01.csharp/06.system-internals-concurrency",[225,229,233,237,241,245,249],{"title":226,"path":227,"stem":228},"Memory Management","/csharp/system-internals-concurrency/memory-management","01.csharp/06.system-internals-concurrency/01.memory-management",{"title":230,"path":231,"stem":232},"Reflection API: System.Type та Метадані","/csharp/system-internals-concurrency/reflection-fundamentals","01.csharp/06.system-internals-concurrency/02.reflection-fundamentals",{"title":234,"path":235,"stem":236},"Attributes та Dynamic Language Runtime","/csharp/system-internals-concurrency/attributes-dynamic","01.csharp/06.system-internals-concurrency/03.attributes-dynamic",{"title":238,"path":239,"stem":240},"Expression Trees: Швидка Альтернатива Рефлексії","/csharp/system-internals-concurrency/expression-trees-compiled","01.csharp/06.system-internals-concurrency/04.expression-trees-compiled",{"title":242,"path":243,"stem":244},"Source Generators: Compile-Time Code Generation","/csharp/system-internals-concurrency/source-generators","01.csharp/06.system-internals-concurrency/05.source-generators",{"title":246,"path":247,"stem":248},"Multithreading Fundamentals","/csharp/system-internals-concurrency/multithreading-fundamentals","01.csharp/06.system-internals-concurrency/06.multithreading-fundamentals",{"title":250,"path":251,"stem":252},"Synchronization Primitives","/csharp/system-internals-concurrency/synchronization-primitives","01.csharp/06.system-internals-concurrency/07.synchronization-primitives",{"title":254,"icon":255,"path":256,"stem":257,"children":258,"page":59},"System Programming Windows","i-lucide-cpu","/csharp/system-programming-windows","01.csharp/07.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},"Як Працює Операційна Система","/csharp/system-programming-windows/how-os-works","01.csharp/07.system-programming-windows/01.how-os-works",{"title":264,"path":265,"stem":266},"Процеси в .NET — API та Запуск","/csharp/system-programming-windows/processes-in-dotnet","01.csharp/07.system-programming-windows/02.processes-in-dotnet",{"title":268,"path":269,"stem":270},"Процеси в .NET — IPC та Міжпроцесна Комунікація","/csharp/system-programming-windows/02a.processes-ipc","01.csharp/07.system-programming-windows/02a.processes-ipc",{"title":272,"path":273,"stem":274},"Application Domains та Збірки — AppDomain і AssemblyLoadContext","/csharp/system-programming-windows/appdomains-assemblies","01.csharp/07.system-programming-windows/03.appdomains-assemblies",{"title":276,"path":277,"stem":278},"Application Domains та Збірки — Plug-in Система з Hot-Reload","/csharp/system-programming-windows/03a.appdomains-plugin-system","01.csharp/07.system-programming-windows/03a.appdomains-plugin-system",{"title":280,"path":281,"stem":282},"Потоки — Основи та API Thread","/csharp/system-programming-windows/thread-fundamentals","01.csharp/07.system-programming-windows/04.thread-fundamentals",{"title":284,"path":285,"stem":286},"Потоки — Lifecycle, Пріоритети та Безпечне Завершення","/csharp/system-programming-windows/04a.thread-lifecycle-priorities","01.csharp/07.system-programming-windows/04a.thread-lifecycle-priorities",{"title":288,"path":289,"stem":290},"Проблеми Спільного Стану — Race Condition та Data Race","/csharp/system-programming-windows/shared-state-problems","01.csharp/07.system-programming-windows/05.shared-state-problems",{"title":292,"path":293,"stem":294},"Проблеми Спільного Стану — Memory Model та volatile","/csharp/system-programming-windows/05a.shared-state-memory-model","01.csharp/07.system-programming-windows/05a.shared-state-memory-model",{"title":296,"path":297,"stem":298},"Синхронізація — Monitor, lock та еволюція примітивів","/csharp/system-programming-windows/synchronization-fundamentals","01.csharp/07.system-programming-windows/06.synchronization-fundamentals",{"title":300,"path":301,"stem":302},"Синхронізація — Наскрізний Приклад та Deadlock Detection","/csharp/system-programming-windows/06a.synchronization-walkthrough","01.csharp/07.system-programming-windows/06a.synchronization-walkthrough",{"title":304,"path":305,"stem":306},"Синхронізація — Mutex, Semaphore та Event-Based Primitives","/csharp/system-programming-windows/synchronization-advanced","01.csharp/07.system-programming-windows/07.synchronization-advanced",{"title":308,"path":309,"stem":310},"Синхронізація — Interlocked, Volatile та Lock-Free Структури","/csharp/system-programming-windows/07a.synchronization-advanced-walkthrough","01.csharp/07.system-programming-windows/07a.synchronization-advanced-walkthrough",{"title":312,"path":313,"stem":314},"Interlocked, CAS та Lock-Free Структури","/csharp/system-programming-windows/interlocked-cas-lockfree","01.csharp/07.system-programming-windows/08.interlocked-cas-lockfree",{"title":316,"path":317,"stem":318},"Volatile, Memory Model та Spinning","/csharp/system-programming-windows/08a.volatile-memory-model","01.csharp/07.system-programming-windows/08a.volatile-memory-model",{"title":320,"path":321,"stem":322},"ThreadPool — Пул Потоків для Ефективного Виконання","/csharp/system-programming-windows/thread-pool","01.csharp/07.system-programming-windows/09.thread-pool",{"title":324,"path":325,"stem":326},"ThreadPool — Просунуті Сценарії та Внутрішня Будова","/csharp/system-programming-windows/09a.thread-pool-advanced","01.csharp/07.system-programming-windows/09a.thread-pool-advanced",{"title":328,"path":329,"stem":330},"Concurrent та Immutable Collections","/csharp/system-programming-windows/concurrent-collections","01.csharp/07.system-programming-windows/10.concurrent-collections",{"title":332,"path":333,"stem":334},"TPL, Task та Композиція — Від Thread до Task","/csharp/system-programming-windows/tpl-parallel-plinq","01.csharp/07.system-programming-windows/11.tpl-parallel-plinq",{"title":336,"path":337,"stem":338},"Parallel Class та PLINQ — Data Parallelism","/csharp/system-programming-windows/11a.tpl-parallel-plinq-advanced","01.csharp/07.system-programming-windows/11a.tpl-parallel-plinq-advanced",{"title":340,"path":341,"stem":342},"Async/Await — Фундамент Асинхронного Програмування","/csharp/system-programming-windows/async-fundamentals","01.csharp/07.system-programming-windows/12.async-fundamentals",{"title":344,"path":345,"stem":346},"SynchronizationContext та ConfigureAwait — Контекст Виконання","/csharp/system-programming-windows/async-context-configureawait","01.csharp/07.system-programming-windows/13.async-context-configureawait",{"title":348,"path":349,"stem":350},"Async — Просунуті Паттерни","/csharp/system-programming-windows/async-advanced","01.csharp/07.system-programming-windows/14.async-advanced",{"title":352,"path":353,"stem":354},"System.Threading.Channels — Async Producer-Consumer","/csharp/system-programming-windows/channels","01.csharp/07.system-programming-windows/15.channels",{"title":356,"path":357,"stem":358},"Асинхронна Синхронізація","/csharp/system-programming-windows/async-synchronization","01.csharp/07.system-programming-windows/16.async-synchronization",{"title":360,"path":361,"stem":362},"Unsafe Code та Вказівники","/csharp/system-programming-windows/unsafe-code","01.csharp/07.system-programming-windows/17.unsafe-code",{"title":364,"path":365,"stem":366},"P/Invoke та Windows API — Міст між .NET та Native Code","/csharp/system-programming-windows/pinvoke-winapi","01.csharp/07.system-programming-windows/18.pinvoke-winapi",{"title":368,"path":369,"stem":370},"Реєстр Windows — Центральна База Конфігурації Системи","/csharp/system-programming-windows/windows-registry","01.csharp/07.system-programming-windows/19.windows-registry",{"title":372,"path":373,"stem":374},"Windows Hooks, Hotkeys та Services — Глибока Інтеграція з ОС","/csharp/system-programming-windows/windows-hooks-services","01.csharp/07.system-programming-windows/20.windows-hooks-services",{"title":376,"path":377,"stem":378},"Системне Програмування C# (Windows) — 07.system-programming-windows","/csharp/system-programming-windows/implementation_plan","01.csharp/07.system-programming-windows/implementation_plan",{"title":380,"icon":132,"path":381,"stem":382,"children":383,"page":59},"Io","/csharp/io","01.csharp/08.io",[384,388,392,396,400],{"title":385,"path":386,"stem":387},"8.1.1. Основи роботи з файловою системою","/csharp/io/file-system-basics","01.csharp/08.io/01.file-system-basics",{"title":389,"path":390,"stem":391},"8.1.2. Потоки (Streams) та Серіалізація Даних","/csharp/io/streams-serialization","01.csharp/08.io/02.streams-serialization",{"title":393,"path":394,"stem":395},"8.2.1. JSON Serialization з System.Text.Json","/csharp/io/json-serialization","01.csharp/08.io/03.json-serialization",{"title":397,"path":398,"stem":399},"8.2.2. XML Serialization та LINQ to XML","/csharp/io/xml-serialization","01.csharp/08.io/04.xml-serialization",{"title":401,"path":402,"stem":403},"8.2.3. Binary Serialization: MessagePack та Protocol Buffers","/csharp/io/binary-serialization","01.csharp/08.io/05.binary-serialization",{"title":405,"icon":132,"path":406,"stem":407,"children":408,"page":59},"Ado Net","/csharp/ado-net","01.csharp/09.ado-net",[409,413,417,421,425,429,433,437,441,445,449,453],{"title":410,"path":411,"stem":412},"9.1. Введення в ADO.NET","/csharp/ado-net/introduction-to-adonet","01.csharp/09.ado-net/01.introduction-to-adonet",{"title":414,"path":415,"stem":416},"9.2. Клас DbConnection — з'єднання з базою даних","/csharp/ado-net/connection","01.csharp/09.ado-net/02.connection",{"title":418,"path":419,"stem":420},"9.3. Клас DbCommand — виконання SQL-запитів","/csharp/ado-net/command-and-queries","01.csharp/09.ado-net/03.command-and-queries",{"title":422,"path":423,"stem":424},"9.4. Клас DbDataReader — ефективне читання даних","/csharp/ado-net/datareader","01.csharp/09.ado-net/04.datareader",{"title":426,"path":427,"stem":428},"9.5. Параметризовані запити та захист від SQL Injection","/csharp/ado-net/parameters-and-sql-injection","01.csharp/09.ado-net/05.parameters-and-sql-injection",{"title":430,"path":431,"stem":432},"9.6. Транзакції в ADO.NET","/csharp/ado-net/transactions","01.csharp/09.ado-net/06.transactions",{"title":434,"path":435,"stem":436},"9.7. DbProviderFactory — провайдер-незалежний код","/csharp/ado-net/provider-factory","01.csharp/09.ado-net/07.provider-factory",{"title":438,"path":439,"stem":440},"9.8. Асинхронний доступ до даних","/csharp/ado-net/async-data-access","01.csharp/09.ado-net/08.async-data-access",{"title":442,"path":443,"stem":444},"9.9. Від'єднаний режим: DataSet, DataTable, DataRow","/csharp/ado-net/disconnected-mode-dataset","01.csharp/09.ado-net/09.disconnected-mode-dataset",{"title":446,"path":447,"stem":448},"9.10. DataAdapter — міст між DataSet та базою даних","/csharp/ado-net/data-adapter","01.csharp/09.ado-net/10.data-adapter",{"title":450,"path":451,"stem":452},"9.11. Data Mapper та Repository: Архітектура доступу до даних","/csharp/ado-net/data-mapper-repository","01.csharp/09.ado-net/11.data-mapper-repository",{"title":454,"path":455,"stem":456},"9.12. Identity Map, Unit of Work та Specification Pattern","/csharp/ado-net/advanced-patterns","01.csharp/09.ado-net/12.advanced-patterns",{"title":458,"icon":255,"path":459,"stem":460,"children":461,"page":59},"Ef Core","/csharp/ef-core","01.csharp/10.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 до об'єктів","/csharp/ef-core/what-is-orm","01.csharp/10.ef-core/01.what-is-orm",{"title":467,"path":468,"stem":469},"Перший проєкт — від нуля до CRUD","/csharp/ef-core/first-project","01.csharp/10.ef-core/02.first-project",{"title":471,"path":472,"stem":473},"DbContext — Серце EF Core","/csharp/ef-core/dbcontext-deep-dive","01.csharp/10.ef-core/03.dbcontext-deep-dive",{"title":475,"path":476,"stem":477},"Провайдери баз даних — Архітектура та Вибір СУБД","/csharp/ef-core/database-providers","01.csharp/10.ef-core/04.database-providers",{"title":479,"path":480,"stem":481},"Конвенції EF Core — Магія без конфігурації","/csharp/ef-core/conventions","01.csharp/10.ef-core/05.conventions",{"title":483,"path":484,"stem":485},"Fluent API та Data Annotations — Явна конфігурація моделі","/csharp/ef-core/fluent-api-vs-annotations","01.csharp/10.ef-core/06.fluent-api-vs-annotations",{"title":487,"path":488,"stem":489},"Зв'язки — One-to-One та One-to-Many","/csharp/ef-core/relationships-basics","01.csharp/10.ef-core/07.relationships-basics",{"title":491,"path":492,"stem":493},"Зв'язки Advanced — Many-to-Many та Складні Сценарії","/csharp/ef-core/relationships-advanced","01.csharp/10.ef-core/08.relationships-advanced",{"title":495,"path":496,"stem":497},"Властивості — Типи, Конвертери, Компаратори (Частина 1)","/csharp/ef-core/property-configuration-part1","01.csharp/10.ef-core/09.property-configuration-part1",{"title":499,"path":500,"stem":501},"Властивості — Value Comparers, Generators, Shadow Properties (Частина 2)","/csharp/ef-core/property-configuration-part2","01.csharp/10.ef-core/09.property-configuration-part2",{"title":503,"path":504,"stem":505},"Складні типи — Owned Types та Complex Types (Частина 1)","/csharp/ef-core/complex-types-owned-part1","01.csharp/10.ef-core/10.complex-types-owned-part1",{"title":507,"path":508,"stem":509},"Складні типи — Complex Types, Keyless Entities, Порівняння (Частина 2)","/csharp/ef-core/complex-types-owned-part2","01.csharp/10.ef-core/10.complex-types-owned-part2",{"title":511,"path":512,"stem":513},"JSON Columns — Складні дані у JSON (Частина 1)","/csharp/ef-core/json-columns-part1","01.csharp/10.ef-core/11.json-columns-part1",{"title":515,"path":516,"stem":517},"JSON Columns — Value Comparers, Індекси, Провайдери (Частина 2)","/csharp/ef-core/json-columns-part2","01.csharp/10.ef-core/11.json-columns-part2",{"title":519,"path":520,"stem":521},"Успадкування — Абстрактні класи та TPH (Частина 1)","/csharp/ef-core/inheritance-part1","01.csharp/10.ef-core/12.inheritance-part1",{"title":523,"path":524,"stem":525},"Успадкування — TPT, TPC та Порівняння Стратегій (Частина 2)","/csharp/ef-core/inheritance-part2","01.csharp/10.ef-core/12.inheritance-part2",{"title":527,"path":528,"stem":529,"children":530},"Індекси, Обмеження та Схема (Частина 1)","/csharp/ef-core/indexes-constraints-part1","01.csharp/10.ef-core/13.indexes-constraints-part1",[531],{"title":527,"path":528,"stem":529},{"title":533,"path":534,"stem":535,"children":536},"Індекси, Обмеження та Схема (Частина 2)","/csharp/ef-core/indexes-constraints-part2","01.csharp/10.ef-core/13.indexes-constraints-part2",[537],{"title":533,"path":534,"stem":535},{"title":539,"path":540,"stem":541},"Seed Data — Початкові Дані (Частина 1)","/csharp/ef-core/seeding-part1","01.csharp/10.ef-core/14.seeding-part1",{"title":543,"path":544,"stem":545},"Seed Data — SQL-скрипти, Bogus та Стратегії (Частина 2)","/csharp/ef-core/seeding-part2","01.csharp/10.ef-core/14.seeding-part2",{"title":547,"path":548,"stem":549},"Global Query Filters — Глобальні Фільтри (Частина 1)","/csharp/ef-core/global-query-filters-part1","01.csharp/10.ef-core/15.global-query-filters-part1",{"title":551,"path":552,"stem":553},"Global Query Filters — Підводні камені та Інтеграція (Частина 2)","/csharp/ef-core/global-query-filters-part2","01.csharp/10.ef-core/15.global-query-filters-part2",{"title":555,"path":556,"stem":557},"LINQ-запити в EF Core (Частина 1)","/csharp/ef-core/linq-queries-part1","01.csharp/10.ef-core/16.linq-queries-part1",{"title":559,"path":560,"stem":561},"LINQ-запити в EF Core (Частина 2)","/csharp/ef-core/linq-queries-part2","01.csharp/10.ef-core/16.linq-queries-part2",{"title":563,"path":564,"stem":565},"Завантаження Пов'язаних Даних (Частина 1)","/csharp/ef-core/loading-related-data-part1","01.csharp/10.ef-core/17.loading-related-data-part1",{"title":567,"path":568,"stem":569},"Завантаження Пов'язаних Даних (Частина 2)","/csharp/ef-core/loading-related-data-part2","01.csharp/10.ef-core/17.loading-related-data-part2",{"title":571,"path":572,"stem":573},"Raw SQL, Views та Stored Procedures (Частина 1)","/csharp/ef-core/raw-sql-part1","01.csharp/10.ef-core/18.raw-sql-part1",{"title":575,"path":576,"stem":577},"Raw SQL — Stored Procedures, DbFunction та Bulk Operations (Частина 2)","/csharp/ef-core/raw-sql-part2","01.csharp/10.ef-core/18.raw-sql-part2",{"title":579,"path":580,"stem":581},"Продвинуті Запити — Compiled Queries, Bulk та Оптимізація (Частина 1)","/csharp/ef-core/advanced-queries-part1","01.csharp/10.ef-core/19.advanced-queries-part1",{"title":583,"path":584,"stem":585},"Продвинуті Запити — Query Tags, Bulk та Interceptors (Частина 2)","/csharp/ef-core/advanced-queries-part2","01.csharp/10.ef-core/19.advanced-queries-part2",{"title":587,"path":588,"stem":589},"Change Tracker — Відстеження Змін (Частина 1)","/csharp/ef-core/change-tracking-part1","01.csharp/10.ef-core/20.change-tracking-part1",{"title":591,"path":592,"stem":593},"Change Tracker — Графи Об'єктів та Disconnected (Частина 2)","/csharp/ef-core/change-tracking-part2","01.csharp/10.ef-core/20.change-tracking-part2",{"title":595,"path":596,"stem":597},"Збереження Даних та Транзакції (Частина 1)","/csharp/ef-core/saving-data-part1","01.csharp/10.ef-core/21.saving-data-part1",{"title":599,"path":600,"stem":601},"Збереження Даних — Concurrency та Outbox (Частина 2)","/csharp/ef-core/saving-data-part2","01.csharp/10.ef-core/21.saving-data-part2",{"title":603,"path":604,"stem":605},"Конкурентність та Блокування (Частина 1)","/csharp/ef-core/concurrency-part1","01.csharp/10.ef-core/22.concurrency-part1",{"title":607,"path":608,"stem":609},"Конкурентність — Дедлоки та Queue Processing (Частина 2)","/csharp/ef-core/concurrency-part2","01.csharp/10.ef-core/22.concurrency-part2",{"title":611,"path":612,"stem":613},"Міграції в EF Core — Основи (Частина 1)","/csharp/ef-core/migrations-basics-part1","01.csharp/10.ef-core/23.migrations-basics-part1",{"title":615,"path":616,"stem":617},"Міграції в EF Core — Основи (Частина 2)","/csharp/ef-core/migrations-basics-part2","01.csharp/10.ef-core/23.migrations-basics-part2",{"title":619,"path":620,"stem":621},"Міграції — Просунуті Сценарії (Частина 1)","/csharp/ef-core/migrations-advanced-part1","01.csharp/10.ef-core/24.migrations-advanced-part1",{"title":623,"path":624,"stem":625},"Міграції — Просунуті Сценарії (Частина 2)","/csharp/ef-core/migrations-advanced-part2","01.csharp/10.ef-core/24.migrations-advanced-part2",{"title":627,"path":628,"stem":629},"Управління Схемою та Database-First (Частина 1)","/csharp/ef-core/schema-management-part1","01.csharp/10.ef-core/25.schema-management-part1",{"title":631,"path":632,"stem":633},"Управління Схемою та Database-First (Частина 2)","/csharp/ef-core/schema-management-part2","01.csharp/10.ef-core/25.schema-management-part2",{"title":635,"path":636,"stem":637},"Продуктивність EF Core — Основи (Частина 1)","/csharp/ef-core/performance-fundamentals-part1","01.csharp/10.ef-core/26.performance-fundamentals-part1",{"title":639,"path":640,"stem":641},"Interceptors в EF Core (Частина 1)","/csharp/ef-core/interceptors-part1","01.csharp/10.ef-core/29.interceptors-part1",{"title":643,"path":644,"stem":645},"Interceptors в EF Core — Connection, Transaction та Materialization (Частина 2)","/csharp/ef-core/interceptors-part2","01.csharp/10.ef-core/29.interceptors-part2",{"title":647,"path":648,"stem":649},"План вивчення Entity Framework Core — Повний курс","/csharp/ef-core/implementation_plan","01.csharp/10.ef-core/implementation_plan",{"title":651,"icon":652,"path":653,"stem":654,"children":655,"page":59},"ASP.NET","i-devicon-dotnetcore","/csharp/aspnet","01.csharp/11.aspnet",[656,730,791,869,927,941,967,1057,1111,1182,1212,1289],{"title":657,"icon":658,"path":659,"stem":660,"children":661,"page":59},"Minimal API","i-lucide-network","/csharp/aspnet/minimal-api","01.csharp/11.aspnet/01.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 та еволюція фреймворку","/csharp/aspnet/minimal-api/introduction","01.csharp/11.aspnet/01.minimal-api/01.introduction",{"title":667,"path":668,"stem":669},"Перший додаток на ASP.NET Core","/csharp/aspnet/minimal-api/first-application","01.csharp/11.aspnet/01.minimal-api/02.first-application",{"title":671,"path":672,"stem":673},"WebApplication, Builder та Dependency Injection","/csharp/aspnet/minimal-api/webapplication-builder","01.csharp/11.aspnet/01.minimal-api/03.webapplication-builder",{"title":675,"path":676,"stem":677},"Конвеєр запитів та Middleware","/csharp/aspnet/minimal-api/request-pipeline-middleware","01.csharp/11.aspnet/01.minimal-api/04.request-pipeline-middleware",{"title":679,"path":680,"stem":681},"Маршрутизація в ASP.NET Core: Основи","/csharp/aspnet/minimal-api/routing-basics","01.csharp/11.aspnet/01.minimal-api/05.routing-basics",{"title":683,"path":684,"stem":685},"Маршрутизація в ASP.NET Core: Розширені можливості","/csharp/aspnet/minimal-api/routing-advanced","01.csharp/11.aspnet/01.minimal-api/06.routing-advanced",{"title":687,"path":688,"stem":689},"Статичні файли в ASP.NET Core","/csharp/aspnet/minimal-api/static-files","01.csharp/11.aspnet/01.minimal-api/07.static-files",{"title":691,"path":692,"stem":693},"Статичні Активи: MapStaticAssets (ASP.NET Core 9.0)","/csharp/aspnet/minimal-api/static-assets","01.csharp/11.aspnet/01.minimal-api/08.static-assets",{"title":695,"path":696,"stem":697},"Конфігурація в ASP.NET Core: Основи","/csharp/aspnet/minimal-api/configuration-fundamentals","01.csharp/11.aspnet/01.minimal-api/09.configuration-fundamentals",{"title":699,"path":700,"stem":701},"Конфігурація: Паттерн Options","/csharp/aspnet/minimal-api/configuration-options","01.csharp/11.aspnet/01.minimal-api/10.configuration-options",{"title":703,"path":704,"stem":705},"Логування в ASP.NET Core: Основи","/csharp/aspnet/minimal-api/logging-basics","01.csharp/11.aspnet/01.minimal-api/11.logging-basics",{"title":707,"path":708,"stem":709},"Логування: Serilog та Middleware","/csharp/aspnet/minimal-api/logging-advanced","01.csharp/11.aspnet/01.minimal-api/12.logging-advanced",{"title":711,"path":712,"stem":713},"Управління станом: HttpContext.Items та Cookies","/csharp/aspnet/minimal-api/state-management","01.csharp/11.aspnet/01.minimal-api/13.state-management",{"title":715,"path":716,"stem":717},"Стан сесії: Sessions","/csharp/aspnet/minimal-api/session-state","01.csharp/11.aspnet/01.minimal-api/14.session-state",{"title":719,"path":720,"stem":721},"Структура проєкту: від хаосу до архітектури","/csharp/aspnet/minimal-api/project-structure","01.csharp/11.aspnet/01.minimal-api/15.project-structure",{"title":723,"path":724,"stem":725},"Scalar у Minimal API: повний проєкт і Fluent OpenAPI","/csharp/aspnet/minimal-api/scalar-openapi-fluent","01.csharp/11.aspnet/01.minimal-api/16.scalar-openapi-fluent",{"title":727,"path":728,"stem":729},"Swagger / Swashbuckle у Minimal API: окремий класичний шлях","/csharp/aspnet/minimal-api/swagger-swashbuckle","01.csharp/11.aspnet/01.minimal-api/17.swagger-swashbuckle",{"title":731,"icon":658,"path":732,"stem":733,"children":734,"page":59},"API","/csharp/aspnet/api","01.csharp/11.aspnet/02.api",[735,739,743,747,751,755,759,763,767,771,775,779,783,787],{"title":736,"path":737,"stem":738},"Що таке API. Клієнт-серверна архітектура","/csharp/aspnet/api/what-is-api","01.csharp/11.aspnet/02.api/01.what-is-api",{"title":740,"path":741,"stem":742},"Формати даних: JSON, XML, TOML та бінарні формати","/csharp/aspnet/api/data-formats","01.csharp/11.aspnet/02.api/02.data-formats",{"title":744,"path":745,"stem":746},"Парадигми API та концепція REST","/csharp/aspnet/api/api-paradigms-rest","01.csharp/11.aspnet/02.api/03.api-paradigms-rest",{"title":748,"path":749,"stem":750},"HTTP-методи, статус-коди та заголовки","/csharp/aspnet/api/http-methods-status-codes","01.csharp/11.aspnet/02.api/04.http-methods-status-codes",{"title":752,"path":753,"stem":754},"Організація HTTP API за принципами REST","/csharp/aspnet/api/rest-organizing","01.csharp/11.aspnet/02.api/05.rest-organizing",{"title":756,"path":757,"stem":758},"Номенклатура URL та CRUD-операції","/csharp/aspnet/api/url-nomenclature-crud","01.csharp/11.aspnet/02.api/06.url-nomenclature-crud",{"title":760,"path":761,"stem":762},"Правила дизайну: іменування та стандарти","/csharp/aspnet/api/api-design-naming","01.csharp/11.aspnet/02.api/07.api-design-naming",{"title":764,"path":765,"stem":766},"Валідація, ліміти та обробка помилок","/csharp/aspnet/api/api-design-validation","01.csharp/11.aspnet/02.api/08.api-design-validation",{"title":768,"path":769,"stem":770},"Обробка помилок у Minimal API","/csharp/aspnet/api/error-handling-http","01.csharp/11.aspnet/02.api/09.error-handling-http",{"title":772,"path":773,"stem":774},"Ідемпотентність та синхронізація стану","/csharp/aspnet/api/idempotency-sync","01.csharp/11.aspnet/02.api/10.idempotency-sync",{"title":776,"path":777,"stem":778},"Пагінація та організація списків","/csharp/aspnet/api/pagination-lists","01.csharp/11.aspnet/02.api/11.pagination-lists",{"title":780,"path":781,"stem":782},"Безпека API, кешування та інтернаціоналізація","/csharp/aspnet/api/security-auth","01.csharp/11.aspnet/02.api/12.security-auth",{"title":784,"path":785,"stem":786},"Процес проєктування API та документування","/csharp/aspnet/api/api-design-process","01.csharp/11.aspnet/02.api/13.api-design-process",{"title":788,"path":789,"stem":790},"OpenAPI: контракт, специфікація та документація API","/csharp/aspnet/api/openapi","01.csharp/11.aspnet/02.api/14.openapi",{"title":792,"icon":793,"path":794,"stem":795,"children":796,"page":59},"Auth","i-lucide-shield-check","/csharp/aspnet/auth","01.csharp/11.aspnet/03.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},"Основи аутентифікації та авторизації","/csharp/aspnet/auth/auth-fundamentals","01.csharp/11.aspnet/03.auth/01.auth-fundamentals",{"title":802,"path":803,"stem":804},"JWT-аутентифікація","/csharp/aspnet/auth/jwt-authentication","01.csharp/11.aspnet/03.auth/02.jwt-authentication",{"title":806,"path":807,"stem":808},"Авторизація: ролі, політики та resource-based доступ","/csharp/aspnet/auth/authorization-policies","01.csharp/11.aspnet/03.auth/03.authorization-policies",{"title":810,"path":811,"stem":812},"Cookie-аутентифікація та ASP.NET Core Identity","/csharp/aspnet/auth/cookie-auth-identity","01.csharp/11.aspnet/03.auth/04.cookie-auth-identity",{"title":814,"path":815,"stem":816},"JWT + Refresh Tokens (HttpOnly Cookie)","/csharp/aspnet/auth/04b.identity-auth-jwt","01.csharp/11.aspnet/03.auth/04b.identity-auth-jwt",{"title":818,"path":819,"stem":820},"Identity: Підтвердження Email та Скидання Пароля","/csharp/aspnet/auth/identity-email-confirmation","01.csharp/11.aspnet/03.auth/05.identity-email-confirmation",{"title":822,"path":823,"stem":824},"Identity: Двофакторна Аутентифікація (2FA)","/csharp/aspnet/auth/identity-two-factor","01.csharp/11.aspnet/03.auth/06.identity-two-factor",{"title":826,"path":827,"stem":828},"Identity: Внутрішня Архітектура та Кастомізація","/csharp/aspnet/auth/identity-internals","01.csharp/11.aspnet/03.auth/07.identity-internals",{"title":830,"path":831,"stem":832},"OAuth 2.0 та зовнішні провайдери","/csharp/aspnet/auth/oauth-external-providers","01.csharp/11.aspnet/03.auth/08.oauth-external-providers",{"title":834,"path":835,"stem":836},"Безпека на практиці: CORS, HTTPS та захист від атак","/csharp/aspnet/auth/security-hardening","01.csharp/11.aspnet/03.auth/09.security-hardening",{"title":838,"path":839,"stem":840},"Теорія OAuth 2.0: Поняття, Аналогії та Флоу","/csharp/aspnet/auth/oauth-theory","01.csharp/11.aspnet/03.auth/10.oauth-theory",{"title":842,"path":843,"stem":844},"OIDC, OAuth 2.0 та Keycloak в ASP.NET Core","/csharp/aspnet/auth/oidc-keycloak","01.csharp/11.aspnet/03.auth/10.oidc-keycloak",{"title":846,"path":847,"stem":848},"API Keys аутентифікація в ASP.NET Core","/csharp/aspnet/auth/api-keys","01.csharp/11.aspnet/03.auth/11.api-keys",{"title":850,"path":851,"stem":852},"Rate Limiting та Throttling в ASP.NET Core","/csharp/aspnet/auth/rate-limiting","01.csharp/11.aspnet/03.auth/12.rate-limiting",{"title":854,"path":855,"stem":856},"Refresh Token Rotation в ASP.NET Core","/csharp/aspnet/auth/refresh-token-rotation","01.csharp/11.aspnet/03.auth/13.refresh-token-rotation",{"title":858,"path":859,"stem":860},"Certificate Authentication та mTLS в ASP.NET Core","/csharp/aspnet/auth/certificate-auth","01.csharp/11.aspnet/03.auth/14.certificate-auth",{"title":862,"path":863,"stem":864},"RBAC, ABAC та ReBAC в ASP.NET Core","/csharp/aspnet/auth/rbac-abac-rebac","01.csharp/11.aspnet/03.auth/15.rbac-abac-rebac",{"title":866,"path":867,"stem":868},"Multi-tenancy та ізоляція даних в ASP.NET Core","/csharp/aspnet/auth/multi-tenancy","01.csharp/11.aspnet/03.auth/16.multi-tenancy",{"title":870,"icon":871,"path":872,"stem":873,"children":874,"page":59},"Нотифікації","i-lucide-bell","/csharp/aspnet/notifications","01.csharp/11.aspnet/04.notifications",[875,879,883,887,891,895,899,903,907,911,915,919,923],{"title":876,"path":877,"stem":878},"In-App нотифікації через базу даних","/csharp/aspnet/notifications/in-app-database-notifications","01.csharp/11.aspnet/04.notifications/01.in-app-database-notifications",{"title":880,"path":881,"stem":882},"Polling: Регулярний запит оновлень","/csharp/aspnet/notifications/polling","01.csharp/11.aspnet/04.notifications/02.polling",{"title":884,"path":885,"stem":886},"Server-Sent Events: Однострімовий push від сервера","/csharp/aspnet/notifications/server-sent-events","01.csharp/11.aspnet/04.notifications/03.server-sent-events",{"title":888,"path":889,"stem":890},"WebSockets: Двостороннє з'єднання в реальному часі","/csharp/aspnet/notifications/websockets","01.csharp/11.aspnet/04.notifications/04.websockets",{"title":892,"path":893,"stem":894},"SignalR: Абстракція над транспортами реального часу","/csharp/aspnet/notifications/signalr","01.csharp/11.aspnet/04.notifications/05.signalr",{"title":896,"path":897,"stem":898},"Background Services: Фонові задачі в ASP.NET Core","/csharp/aspnet/notifications/background-services","01.csharp/11.aspnet/04.notifications/06.background-services",{"title":900,"path":901,"stem":902},"Web Push нотифікації","/csharp/aspnet/notifications/web-push","01.csharp/11.aspnet/04.notifications/07.web-push",{"title":904,"path":905,"stem":906},"Email нотифікації","/csharp/aspnet/notifications/email-notifications","01.csharp/11.aspnet/04.notifications/08.email-notifications",{"title":908,"path":909,"stem":910},"Порівняння підходів: Як вибрати правильну технологію нотифікацій","/csharp/aspnet/notifications/choosing-the-right-approach","01.csharp/11.aspnet/04.notifications/09.choosing-the-right-approach",{"title":912,"path":913,"stem":914},"Hangfire: Надійне планування фонових задач","/csharp/aspnet/notifications/hangfire","01.csharp/11.aspnet/04.notifications/10.hangfire",{"title":916,"path":917,"stem":918},"Практика: Конвертація зображень у WebP через Hangfire","/csharp/aspnet/notifications/hangfire-image-webp","01.csharp/11.aspnet/04.notifications/11.hangfire-image-webp",{"title":920,"path":921,"stem":922},"Практика: Підготовка відео до HLS-стрімінгу через Hangfire","/csharp/aspnet/notifications/hangfire-video-hls","01.csharp/11.aspnet/04.notifications/12.hangfire-video-hls",{"title":924,"path":925,"stem":926},"Telegram-нотифікації: від одного повідомлення до масових розсилок і мульти-канального підходу","/csharp/aspnet/notifications/telegram-notifications","01.csharp/11.aspnet/04.notifications/13.telegram-notifications",{"title":928,"icon":929,"path":930,"stem":931,"children":932,"page":59},"Інтернаціоналізація","i-lucide-languages","/csharp/aspnet/i18n","01.csharp/11.aspnet/05.i18n",[933,937],{"title":934,"path":935,"stem":936},"Інтернаціоналізація (i18n) у Minimal API: від A до Я","/csharp/aspnet/i18n/internationalization","01.csharp/11.aspnet/05.i18n/01.internationalization",{"title":938,"path":939,"stem":940},"Humanizer: людиномовні рядки у .NET","/csharp/aspnet/i18n/humanizer","01.csharp/11.aspnet/05.i18n/02.humanizer",{"title":942,"icon":943,"path":944,"stem":945,"children":946,"page":59},"Кешування","i-lucide-layers","/csharp/aspnet/caching","01.csharp/11.aspnet/06.caching",[947,951,955,959,963],{"title":948,"path":949,"stem":950},"Огляд кешування: чотири рівні і коли що обирати","/csharp/aspnet/caching/caching","01.csharp/11.aspnet/06.caching/01.caching",{"title":952,"path":953,"stem":954},"IMemoryCache: кеш в оперативній пам'яті","/csharp/aspnet/caching/memory-cache","01.csharp/11.aspnet/06.caching/02.memory-cache",{"title":956,"path":957,"stem":958},"IDistributedCache і Redis: розподілений кеш","/csharp/aspnet/caching/distributed-cache","01.csharp/11.aspnet/06.caching/03.distributed-cache",{"title":960,"path":961,"stem":962},"Response Cache: HTTP-кешування через Cache-Control","/csharp/aspnet/caching/response-cache","01.csharp/11.aspnet/06.caching/04.response-cache",{"title":964,"path":965,"stem":966},"Output Cache: серверний кеш HTTP-відповідей (.NET 7+)","/csharp/aspnet/caching/output-cache","01.csharp/11.aspnet/06.caching/05.output-cache",{"title":968,"icon":969,"path":970,"stem":971,"children":972,"page":59},"Тестування","i-lucide-test-tube","/csharp/aspnet/testing","01.csharp/11.aspnet/07.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},"Що таке тестування? Від інтуїції до науки","/csharp/aspnet/testing/what-is-testing","01.csharp/11.aspnet/07.testing/01.what-is-testing",{"title":978,"path":979,"stem":980},"Піраміда тестування — Стратегія, а не Догма","/csharp/aspnet/testing/testing-pyramid","01.csharp/11.aspnet/07.testing/02.testing-pyramid",{"title":982,"path":983,"stem":984},"Дві Школи Тестування — Лондон проти Детройту","/csharp/aspnet/testing/testing-schools","01.csharp/11.aspnet/07.testing/03.testing-schools",{"title":986,"path":987,"stem":988},"TDD та BDD — Тести як Дизайн-інструмент","/csharp/aspnet/testing/tdd-and-bdd","01.csharp/11.aspnet/07.testing/04.tdd-and-bdd",{"title":990,"path":991,"stem":992},"Що саме тестувати — Техніки аналізу та Циклomatична складність","/csharp/aspnet/testing/what-to-test","01.csharp/11.aspnet/07.testing/05.what-to-test",{"title":994,"path":995,"stem":996},"Тестові Фреймворки — Навіщо вони і що всередині","/csharp/aspnet/testing/test-frameworks","01.csharp/11.aspnet/07.testing/06.test-frameworks",{"title":998,"path":999,"stem":1000},"xUnit — Факти, Теорії та Lifecycle тестів","/csharp/aspnet/testing/xunit-basics","01.csharp/11.aspnet/07.testing/07.xunit-basics",{"title":1002,"path":1003,"stem":1004},"xUnit Advanced — Fixtures, Кастомізація та Розширення","/csharp/aspnet/testing/xunit-advanced","01.csharp/11.aspnet/07.testing/08.xunit-advanced",{"title":1006,"path":1007,"stem":1008},"Moq — Глибоке занурення в мокування","/csharp/aspnet/testing/mocking-with-moq","01.csharp/11.aspnet/07.testing/09.mocking-with-moq",{"title":1010,"path":1011,"stem":1012},"Тестування Баз Даних — EF Core, SQLite та Testcontainers","/csharp/aspnet/testing/database-testing","01.csharp/11.aspnet/07.testing/10.database-testing",{"title":1014,"path":1015,"stem":1016},"Integration Testing — Частина 1 [Теорія та WebApplicationFactory]","/csharp/aspnet/testing/integration-testing","01.csharp/11.aspnet/07.testing/11.integration-testing",{"title":1018,"path":1019,"stem":1020},"Інтеграційне тестування — Практика","/csharp/aspnet/testing/11a.integration-testing-practice","01.csharp/11.aspnet/07.testing/11a.integration-testing-practice",{"title":1022,"path":1023,"stem":1024},"Integration Testing — Частина 2 [Просунуті Сценарії та Testcontainers]","/csharp/aspnet/testing/integration-testing-advanced","01.csharp/11.aspnet/07.testing/12.integration-testing-advanced",{"title":1026,"path":1027,"stem":1028},"Професійний Postman: Колекції, Змінні та GitHub Інтеграція","/csharp/aspnet/testing/postman-professional","01.csharp/11.aspnet/07.testing/13.postman-professional",{"title":1030,"path":1031,"stem":1032},"HttpClient у Тестах Частина 1: Архітектура та MockHttpMessageHandler","/csharp/aspnet/testing/httpclient-testing","01.csharp/11.aspnet/07.testing/14.httpclient-testing",{"title":1034,"path":1035,"stem":1036},"HttpClient у Тестах Частина 2: WireMock.Net та Resilience","/csharp/aspnet/testing/wiremock-net","01.csharp/11.aspnet/07.testing/15.wiremock-net",{"title":1038,"path":1039,"stem":1040},"Патерни та Анти-патерни Тестування: Test Smells","/csharp/aspnet/testing/testing-patterns","01.csharp/11.aspnet/07.testing/16.testing-patterns",{"title":1042,"path":1043,"stem":1044},"Просунуті інструменти: Time, Snapshots та Властивості","/csharp/aspnet/testing/advanced-testing-tools","01.csharp/11.aspnet/07.testing/17.advanced-testing-tools",{"title":1046,"path":1047,"stem":1048},"Тестування Архітектури з NetArchTest","/csharp/aspnet/testing/architecture-testing","01.csharp/11.aspnet/07.testing/18.architecture-testing",{"title":1050,"path":1051,"stem":1052},"Тестування Продуктивності: BenchmarkDotNet, NBomber та k6","/csharp/aspnet/testing/performance-testing","01.csharp/11.aspnet/07.testing/19.performance-testing",{"title":1054,"path":1055,"stem":1056},"Залишок плану для курсу \"Тестування ASP.NET Minimal API\"","/csharp/aspnet/testing/remaining_plan","01.csharp/11.aspnet/07.testing/remaining_plan",{"title":1058,"icon":1059,"path":1060,"stem":1061,"children":1062,"page":59},"Платежі","i-lucide-credit-card","/csharp/aspnet/payments","01.csharp/11.aspnet/08.payments",[1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103,1107],{"title":1064,"path":1065,"stem":1066},"Основи платіжної інфраструктури","/csharp/aspnet/payments/payment-fundamentals","01.csharp/11.aspnet/08.payments/01.payment-fundamentals",{"title":1068,"path":1069,"stem":1070},"Методи оплати в Україні","/csharp/aspnet/payments/payment-methods-ukraine","01.csharp/11.aspnet/08.payments/02.payment-methods-ukraine",{"title":1072,"path":1073,"stem":1074},"PCI DSS та безпека платежів","/csharp/aspnet/payments/pci-dss-security","01.csharp/11.aspnet/08.payments/03.pci-dss-security",{"title":1076,"path":1077,"stem":1078},"Архітектура платіжної підсистеми","/csharp/aspnet/payments/payment-architecture","01.csharp/11.aspnet/08.payments/04.payment-architecture",{"title":1080,"path":1081,"stem":1082},"Інтеграція LiqPay (ПриватБанк)","/csharp/aspnet/payments/liqpay-integration","01.csharp/11.aspnet/08.payments/05.liqpay-integration",{"title":1084,"path":1085,"stem":1086},"Інтеграція Monobank Acquiring API","/csharp/aspnet/payments/monobank-acquiring","01.csharp/11.aspnet/08.payments/06.monobank-acquiring",{"title":1088,"path":1089,"stem":1090},"Інтеграція Stripe","/csharp/aspnet/payments/stripe-integration","01.csharp/11.aspnet/08.payments/07.stripe-integration",{"title":1092,"path":1093,"stem":1094},"Webhooks — глибоке занурення","/csharp/aspnet/payments/webhooks-deep-dive","01.csharp/11.aspnet/08.payments/08.webhooks-deep-dive",{"title":1096,"path":1097,"stem":1098},"Підписки та рекурентні платежі","/csharp/aspnet/payments/subscriptions-recurring","01.csharp/11.aspnet/08.payments/09.subscriptions-recurring",{"title":1100,"path":1101,"stem":1102},"Повернення коштів та диспути","/csharp/aspnet/payments/refunds-disputes","01.csharp/11.aspnet/08.payments/10.refunds-disputes",{"title":1104,"path":1105,"stem":1106},"Тестування платіжних інтеграцій","/csharp/aspnet/payments/testing-payments","01.csharp/11.aspnet/08.payments/11.testing-payments",{"title":1108,"path":1109,"stem":1110},"Чекліст виходу в Production","/csharp/aspnet/payments/production-checklist","01.csharp/11.aspnet/08.payments/12.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","/csharp/aspnet/libraries","01.csharp/11.aspnet/09.libraries",[1130,1134,1138,1142,1146,1150,1154,1158,1162,1166,1170,1174,1178],{"title":1131,"path":1132,"stem":1133},"Валідація з FluentValidation в ASP.NET Core","/csharp/aspnet/libraries/fluent-validation","01.csharp/11.aspnet/09.libraries/01.fluent-validation",{"title":1135,"path":1136,"stem":1137},"Маппінг об","/csharp/aspnet/libraries/mapster","01.csharp/11.aspnet/09.libraries/02.mapster",{"title":1139,"path":1140,"stem":1141},"Обробка помилок з ErrorOr та Result Pattern в ASP.NET Core","/csharp/aspnet/libraries/erroror-result-pattern","01.csharp/11.aspnet/09.libraries/03.erroror-result-pattern",{"title":1143,"path":1144,"stem":1145},"Структуроване логування з Serilog в ASP.NET Core","/csharp/aspnet/libraries/serilog","01.csharp/11.aspnet/09.libraries/04.serilog",{"title":1147,"path":1148,"stem":1149},"CQRS та Mediator з MediatR в ASP.NET Core","/csharp/aspnet/libraries/mediatr","01.csharp/11.aspnet/09.libraries/05.mediatr",{"title":1151,"path":1152,"stem":1153},"Відмовостійкість з Polly в ASP.NET Core","/csharp/aspnet/libraries/polly","01.csharp/11.aspnet/09.libraries/06.polly",{"title":1155,"path":1156,"stem":1157},"Health Checks в ASP.NET Core","/csharp/aspnet/libraries/health-checks","01.csharp/11.aspnet/09.libraries/07.health-checks",{"title":1159,"path":1160,"stem":1161},"Feature Management та Feature Flags в ASP.NET Core","/csharp/aspnet/libraries/feature-management","01.csharp/11.aspnet/09.libraries/08.feature-management",{"title":1163,"path":1164,"stem":1165},"Відправка Email з FluentEmail в ASP.NET Core","/csharp/aspnet/libraries/fluent-email","01.csharp/11.aspnet/09.libraries/09.fluent-email",{"title":1167,"path":1168,"stem":1169},"Генерація PDF з QuestPDF в ASP.NET Core","/csharp/aspnet/libraries/quest-pdf","01.csharp/11.aspnet/09.libraries/10.quest-pdf",{"title":1171,"path":1172,"stem":1173},"Генерація тестових даних з Bogus в ASP.NET Core","/csharp/aspnet/libraries/bogus","01.csharp/11.aspnet/09.libraries/11.bogus",{"title":1175,"path":1176,"stem":1177},"Humanizer та Guard Clauses в ASP.NET Core","/csharp/aspnet/libraries/humanizer-guard","01.csharp/11.aspnet/09.libraries/12.humanizer-guard",{"title":1179,"path":1180,"stem":1181},"План модуля 10.libraries — Популярні бібліотеки ASP.NET","/csharp/aspnet/libraries/plan","01.csharp/11.aspnet/09.libraries/plan",{"title":1183,"icon":1184,"path":1185,"stem":1186,"children":1187,"page":59},"Razor Pages","i-lucide-layout-template","/csharp/aspnet/razor-pages","01.csharp/11.aspnet/10.razor-pages",[1188,1192,1196,1200,1204,1208],{"title":1189,"path":1190,"stem":1191},"Від Minimal API до Razor Pages: концептуальний перехід","/csharp/aspnet/razor-pages/from-minimal-api","01.csharp/11.aspnet/10.razor-pages/01.from-minimal-api",{"title":1193,"path":1194,"stem":1195},"PageModel: логіка сторінки Razor Pages","/csharp/aspnet/razor-pages/page-model","01.csharp/11.aspnet/10.razor-pages/02.page-model",{"title":1197,"path":1198,"stem":1199},"Razor синтаксис: шаблонізатор у .cshtml","/csharp/aspnet/razor-pages/razor-syntax","01.csharp/11.aspnet/10.razor-pages/03.razor-syntax",{"title":1201,"path":1202,"stem":1203},"Tag Helpers: типізований HTML","/csharp/aspnet/razor-pages/tag-helpers","01.csharp/11.aspnet/10.razor-pages/04.tag-helpers",{"title":1205,"path":1206,"stem":1207},"Форми і валідація: повний цикл обробки даних","/csharp/aspnet/razor-pages/forms-validation","01.csharp/11.aspnet/10.razor-pages/05.forms-validation",{"title":1209,"path":1210,"stem":1211},"Практичний проєкт: TaskManager на Razor Pages","/csharp/aspnet/razor-pages/project-task-manager","01.csharp/11.aspnet/10.razor-pages/06.project-task-manager",{"title":1213,"path":1214,"stem":1215,"children":1216,"page":59},"ASP.NET Core MVC","/csharp/aspnet/mvc","01.csharp/11.aspnet/11.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: архітектура, що змінила веб","/csharp/aspnet/mvc/mvc-pattern","01.csharp/11.aspnet/11.mvc/01.mvc-pattern",{"title":1222,"path":1223,"stem":1224},"Від Razor Pages до MVC: концептуальний перехід","/csharp/aspnet/mvc/from-razor-pages","01.csharp/11.aspnet/11.mvc/02.from-razor-pages",{"title":1226,"path":1227,"stem":1228},"Controllers та Actions: серце MVC","/csharp/aspnet/mvc/controllers-actions","01.csharp/11.aspnet/11.mvc/03.controllers-actions",{"title":1230,"path":1231,"stem":1232},"Маршрутизація в MVC: Convention vs Attribute Routing","/csharp/aspnet/mvc/routing-mvc","01.csharp/11.aspnet/11.mvc/04.routing-mvc",{"title":1234,"path":1235,"stem":1236},"Model Binding: від HTTP до C#","/csharp/aspnet/mvc/model-binding","01.csharp/11.aspnet/11.mvc/05.model-binding",{"title":1238,"path":1239,"stem":1240},"Views, ViewData, ViewBag, TempData і ViewModel","/csharp/aspnet/mvc/views-viewdata-tempdata","01.csharp/11.aspnet/11.mvc/06.views-viewdata-tempdata",{"title":1242,"path":1243,"stem":1244},"Filters: аспектно-орієнтоване програмування в MVC","/csharp/aspnet/mvc/filters","01.csharp/11.aspnet/11.mvc/07.filters",{"title":1246,"path":1247,"stem":1248},"Areas: структурування великих застосунків","/csharp/aspnet/mvc/areas","01.csharp/11.aspnet/11.mvc/08.areas",{"title":1250,"path":1251,"stem":1252},"View Components: повторювані незалежні блоки UI","/csharp/aspnet/mvc/view-components","01.csharp/11.aspnet/11.mvc/09.view-components",{"title":1254,"path":1255,"stem":1256},"Display та Editor Templates","/csharp/aspnet/mvc/display-editor-templates","01.csharp/11.aspnet/11.mvc/10.display-editor-templates",{"title":1258,"path":1259,"stem":1260},"Валідація: IValidatableObject та FluentValidation","/csharp/aspnet/mvc/validation-advanced","01.csharp/11.aspnet/11.mvc/11.validation-advanced",{"title":1262,"path":1263,"stem":1264},"HTMX: інтерактивність через HTML-атрибути","/csharp/aspnet/mvc/htmx","01.csharp/11.aspnet/11.mvc/12.htmx",{"title":1266,"path":1267,"stem":1268},"HTMX у ASP.NET Core MVC: серверна інтеграція","/csharp/aspnet/mvc/ajax-htmx-mvc","01.csharp/11.aspnet/11.mvc/13.ajax-htmx-mvc",{"title":1270,"path":1271,"stem":1272},"Практичний проєкт: Каталог товарів з HTMX","/csharp/aspnet/mvc/htmx-project","01.csharp/11.aspnet/11.mvc/14.htmx-project",{"title":1274,"path":1275,"stem":1276},"Завантаження та обробка файлів","/csharp/aspnet/mvc/file-upload","01.csharp/11.aspnet/11.mvc/15.file-upload",{"title":1278,"path":1279,"stem":1280},"Глобалізація та Локалізація MVC","/csharp/aspnet/mvc/globalization-localization","01.csharp/11.aspnet/11.mvc/16.globalization-localization",{"title":1282,"path":1283,"stem":1284},"Підсумковий проєкт: Блог-платформа","/csharp/aspnet/mvc/mvc-project","01.csharp/11.aspnet/11.mvc/17.mvc-project",{"title":1286,"path":1287,"stem":1288},"План курсу: ASP.NET Core MVC","/csharp/aspnet/mvc/plan","01.csharp/11.aspnet/11.mvc/plan",{"title":1290,"path":1291,"stem":1292,"children":1293,"page":59},"Web Api","/csharp/aspnet/web-api","01.csharp/11.aspnet/12.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","/csharp/aspnet/web-api/from-minimal-api-to-controllers","01.csharp/11.aspnet/12.web-api/01.from-minimal-api-to-controllers",{"title":1299,"path":1300,"stem":1301},"ControllerBase, ActionResult\u003CT> та Response Types","/csharp/aspnet/web-api/controller-base-actionresult","01.csharp/11.aspnet/12.web-api/02.controller-base-actionresult",{"title":1303,"path":1304,"stem":1305},"Content Negotiation - JSON, XML та власні форматери","/csharp/aspnet/web-api/content-negotiation","01.csharp/11.aspnet/12.web-api/03.content-negotiation",{"title":1307,"path":1308,"stem":1309},"Версіонування API","/csharp/aspnet/web-api/api-versioning","01.csharp/11.aspnet/12.web-api/04.api-versioning",{"title":1311,"path":1312,"stem":1313},"ProblemDetails та структурована обробка помилок","/csharp/aspnet/web-api/problemdetails-error-handling","01.csharp/11.aspnet/12.web-api/05.problemdetails-error-handling",{"title":1315,"path":1316,"stem":1317},"Фільтри у Web API контексті","/csharp/aspnet/web-api/filters-for-api","01.csharp/11.aspnet/12.web-api/06.filters-for-api",{"title":1319,"path":1320,"stem":1321},"Пагінація, фільтрація та сортування","/csharp/aspnet/web-api/pagination-filtering-sorting","01.csharp/11.aspnet/12.web-api/07.pagination-filtering-sorting",{"title":1323,"path":1324,"stem":1325},"HATEOAS та Resource Expansion","/csharp/aspnet/web-api/hateoas-resource-expansion","01.csharp/11.aspnet/12.web-api/08.hateoas-resource-expansion",{"title":1327,"path":1328,"stem":1329},"Гібридна архітектура - Minimal API + Controllers","/csharp/aspnet/web-api/minimal-api-vs-controllers-hybrid","01.csharp/11.aspnet/12.web-api/09.minimal-api-vs-controllers-hybrid",{"title":1331,"path":1332,"stem":1333},"Документація API - Swashbuckle, NSwag та генерація клієнтів","/csharp/aspnet/web-api/api-documentation-generation","01.csharp/11.aspnet/12.web-api/10.api-documentation-generation",{"title":1335,"path":1336,"stem":1337},"Health Checks та моніторинг API","/csharp/aspnet/web-api/health-checks-monitoring","01.csharp/11.aspnet/12.web-api/11.health-checks-monitoring",{"title":1339,"path":1340,"stem":1341},"Підсумковий проєкт - Production-Ready REST API","/csharp/aspnet/web-api/web-api-project","01.csharp/11.aspnet/12.web-api/12.web-api-project",{"title":1343,"path":1344,"stem":1345},"План курсу: ASP.NET Core Web API (Controllers)","/csharp/aspnet/web-api/plan","01.csharp/11.aspnet/12.web-api/plan",{"title":1347,"icon":1348,"path":1349,"stem":1350,"children":1351,"page":59},"Desktop UI","i-lucide-app-window","/csharp/desktop-ui","01.csharp/12.desktop-ui",[1352,1356,1360,1364,1368,1372,1376,1380,1384,1388,1392,1396,1400,1404,1408,1412,1416,1420,1424,1428,1432,1436,1440,1444,1448,1452,1456,1460,1464,1468,1472,1476,1480,1484,1488,1492,1496,1500,1504,1508,1512,1516,1520,1524,1528,1532,1536,1540,1544,1548,1552,1556,1560,1564,1568,1572,1576,1580,1584,1588,1592,1596,1600,1604,1608,1612,1616,1620,1624,1628,1632],{"title":1353,"path":1354,"stem":1355},"Що таке десктопна розробка?","/csharp/desktop-ui/what-is-desktop-dev","01.csharp/12.desktop-ui/01.what-is-desktop-dev",{"title":1357,"path":1358,"stem":1359},"Архітектура WPF — як влаштований графічний інтерфейс","/csharp/desktop-ui/wpf-architecture","01.csharp/12.desktop-ui/02.wpf-architecture",{"title":1361,"path":1362,"stem":1363},"Перший WPF-проєкт — від нуля до вікна","/csharp/desktop-ui/first-wpf-app","01.csharp/12.desktop-ui/03.first-wpf-app",{"title":1365,"path":1366,"stem":1367},"Перший Avalonia-проєкт: WPF для всіх платформ","/csharp/desktop-ui/03a.first-avalonia-app","01.csharp/12.desktop-ui/03a.first-avalonia-app",{"title":1369,"path":1370,"stem":1371},"XAML: декларативний інтерфейс","/csharp/desktop-ui/xaml-basics","01.csharp/12.desktop-ui/04.xaml-basics",{"title":1373,"path":1374,"stem":1375},"Fluent UI у WPF — сучасний дизайн Windows 11","/csharp/desktop-ui/04a.wpf-fluent-ui","01.csharp/12.desktop-ui/04a.wpf-fluent-ui",{"title":1377,"path":1378,"stem":1379},"WPF UI — сучасна бібліотека Fluent контролів","/csharp/desktop-ui/04b.wpf-ui-library","01.csharp/12.desktop-ui/04b.wpf-ui-library",{"title":1381,"path":1382,"stem":1383},"HandyControl — велика бібліотека UI контролів для WPF","/csharp/desktop-ui/04c.handycontrol-library","01.csharp/12.desktop-ui/04c.handycontrol-library",{"title":1385,"path":1386,"stem":1387},"Простори імен та ресурси XAML","/csharp/desktop-ui/xaml-namespaces-resources","01.csharp/12.desktop-ui/05.xaml-namespaces-resources",{"title":1389,"path":1390,"stem":1391},"XAML в Avalonia: ключові відмінності від WPF","/csharp/desktop-ui/05a.avalonia-xaml-differences","01.csharp/12.desktop-ui/05a.avalonia-xaml-differences",{"title":1393,"path":1394,"stem":1395},"Розширення розмітки XAML (Markup Extensions)","/csharp/desktop-ui/xaml-markup-extensions","01.csharp/12.desktop-ui/06.xaml-markup-extensions",{"title":1397,"path":1398,"stem":1399},"Панелі Layout: StackPanel, WrapPanel, DockPanel","/csharp/desktop-ui/layout-panels-part1","01.csharp/12.desktop-ui/07.layout-panels-part1",{"title":1401,"path":1402,"stem":1403},"Grid, Canvas, UniformGrid","/csharp/desktop-ui/layout-panels-part2","01.csharp/12.desktop-ui/07.layout-panels-part2",{"title":1405,"path":1406,"stem":1407},"Просунуті техніки Layout","/csharp/desktop-ui/layout-advanced","01.csharp/12.desktop-ui/08.layout-advanced",{"title":1409,"path":1410,"stem":1411},"Адаптивний Layout та найкращі практики","/csharp/desktop-ui/layout-responsive","01.csharp/12.desktop-ui/09.layout-responsive",{"title":1413,"path":1414,"stem":1415},"Layout в Avalonia: відмінності та нові можливості","/csharp/desktop-ui/09a.layout-avalonia","01.csharp/12.desktop-ui/09a.layout-avalonia",{"title":1417,"path":1418,"stem":1419},"Button, Image, ProgressBar та інші базові контроли","/csharp/desktop-ui/basic-controls","01.csharp/12.desktop-ui/10.basic-controls",{"title":1421,"path":1422,"stem":1423},"Контроли в Avalonia: відмінності від WPF","/csharp/desktop-ui/10a.controls-avalonia","01.csharp/12.desktop-ui/10a.controls-avalonia",{"title":1425,"path":1426,"stem":1427},"Текстові контроли — TextBlock, TextBox, RichTextBox","/csharp/desktop-ui/text-controls","01.csharp/12.desktop-ui/11.text-controls",{"title":1429,"path":1430,"stem":1431},"Контроли вибору — CheckBox, RadioButton, ComboBox, ListBox, DatePicker","/csharp/desktop-ui/selection-controls","01.csharp/12.desktop-ui/12.selection-controls",{"title":1433,"path":1434,"stem":1435},"Content Model — GroupBox, Expander, TabControl, StatusBar","/csharp/desktop-ui/content-controls","01.csharp/12.desktop-ui/13.content-controls",{"title":1437,"path":1438,"stem":1439},"UI/UX принципи десктопних застосунків","/csharp/desktop-ui/13a.ui-ux-principles","01.csharp/12.desktop-ui/13a.ui-ux-principles",{"title":1441,"path":1442,"stem":1443},"Dependency Properties — Концепція та Value Resolution","/csharp/desktop-ui/dependency-properties-part1","01.csharp/12.desktop-ui/14.dependency-properties-part1",{"title":1445,"path":1446,"stem":1447},"Avalonia Property System — StyledProperty та DirectProperty","/csharp/desktop-ui/14a.avalonia-property-system","01.csharp/12.desktop-ui/14a.avalonia-property-system",{"title":1449,"path":1450,"stem":1451},"Attached Properties — Властивості без меж","/csharp/desktop-ui/attached-properties","01.csharp/12.desktop-ui/15.attached-properties",{"title":1453,"path":1454,"stem":1455},"Routed Events — Маршрутизація подій у WPF","/csharp/desktop-ui/routed-events","01.csharp/12.desktop-ui/16.routed-events",{"title":1457,"path":1458,"stem":1459},"Data Binding — Від Code-Behind до Декларативності","/csharp/desktop-ui/data-binding-basics-part1","01.csharp/12.desktop-ui/17.data-binding-basics-part1",{"title":1461,"path":1462,"stem":1463},"INotifyPropertyChanged — Живе оновлення UI","/csharp/desktop-ui/data-binding-basics-part2","01.csharp/12.desktop-ui/17.data-binding-basics-part2",{"title":1465,"path":1466,"stem":1467},"Compiled Bindings в Avalonia — Безпека на етапі компіляції","/csharp/desktop-ui/17a.avalonia-compiled-bindings","01.csharp/12.desktop-ui/17a.avalonia-compiled-bindings",{"title":1469,"path":1470,"stem":1471},"Просунутий Data Binding — ElementName, RelativeSource, MultiBinding","/csharp/desktop-ui/data-binding-advanced","01.csharp/12.desktop-ui/18.data-binding-advanced",{"title":1473,"path":1474,"stem":1475},"Value Converters — Перетворення типів даних у Data Binding","/csharp/desktop-ui/value-converters","01.csharp/12.desktop-ui/19.value-converters",{"title":1477,"path":1478,"stem":1479},"Data Templates — Візуалізація об'єктів у WPF","/csharp/desktop-ui/data-templates","01.csharp/12.desktop-ui/20.data-templates",{"title":1481,"path":1482,"stem":1483},"Collections Binding Part 1 — ObservableCollection та ItemsControl","/csharp/desktop-ui/collections-binding-part1","01.csharp/12.desktop-ui/21.collections-binding-part1",{"title":1485,"path":1486,"stem":1487},"Collections Binding Part 2 — ICollectionView, Filtering, Sorting та Virtualization","/csharp/desktop-ui/collections-binding-part2","01.csharp/12.desktop-ui/21.collections-binding-part2",{"title":1489,"path":1490,"stem":1491},"MVVM Pattern — Від Spaghetti Code до архітектури","/csharp/desktop-ui/mvvm-pattern","01.csharp/12.desktop-ui/22.mvvm-pattern",{"title":1493,"path":1494,"stem":1495},"ViewModel Implementation — Від BaseViewModel до валідації","/csharp/desktop-ui/viewmodel-implementation","01.csharp/12.desktop-ui/23.viewmodel-implementation",{"title":1497,"path":1498,"stem":1499},"Commands — Від event handlers до декларативних команд","/csharp/desktop-ui/commands","01.csharp/12.desktop-ui/24.commands",{"title":1501,"path":1502,"stem":1503},"MVVM Toolkit — MVVM без boilerplate через Source Generators","/csharp/desktop-ui/mvvm-toolkit","01.csharp/12.desktop-ui/25.mvvm-toolkit",{"title":1505,"path":1506,"stem":1507},"Messenger Pattern — Комунікація між ViewModel без прямих посилань","/csharp/desktop-ui/messenger-pattern","01.csharp/12.desktop-ui/26.messenger-pattern",{"title":1509,"path":1510,"stem":1511},"Стилі WPF — CSS для десктопу","/csharp/desktop-ui/styles-basics","01.csharp/12.desktop-ui/27.styles-basics",{"title":1513,"path":1514,"stem":1515},"CSS-like стилі Avalonia","/csharp/desktop-ui/27a.avalonia-css-styling","01.csharp/12.desktop-ui/27a.avalonia-css-styling",{"title":1517,"path":1518,"stem":1519},"Control Templates — Частина 1. Концепція та TemplateBinding","/csharp/desktop-ui/control-templates-part1","01.csharp/12.desktop-ui/28.control-templates-part1",{"title":1521,"path":1522,"stem":1523},"Control Templates — Частина 2. Named Parts та ContentPresenter","/csharp/desktop-ui/control-templates-part2","01.csharp/12.desktop-ui/28.control-templates-part2",{"title":1525,"path":1526,"stem":1527},"Control Themes в Avalonia — нова ера стилізації","/csharp/desktop-ui/28a.avalonia-control-themes","01.csharp/12.desktop-ui/28a.avalonia-control-themes",{"title":1529,"path":1530,"stem":1531},"Triggers та Visual State Manager у WPF","/csharp/desktop-ui/triggers-visual-states","01.csharp/12.desktop-ui/29.triggers-visual-states",{"title":1533,"path":1534,"stem":1535},"Pseudo-classes в Avalonia — замість WPF Triggers","/csharp/desktop-ui/29a.avalonia-pseudo-classes","01.csharp/12.desktop-ui/29a.avalonia-pseudo-classes",{"title":1537,"path":1538,"stem":1539},"Теми та ресурсні словники у WPF","/csharp/desktop-ui/resources-themes","01.csharp/12.desktop-ui/30.resources-themes",{"title":1541,"path":1542,"stem":1543},"Avalonia Themes — Fluent Design та система тематизації","/csharp/desktop-ui/30a.avalonia-themes-fluent","01.csharp/12.desktop-ui/30a.avalonia-themes-fluent",{"title":1545,"path":1546,"stem":1547},"Контроли колекцій — глибоке занурення","/csharp/desktop-ui/collection-controls","01.csharp/12.desktop-ui/31.collection-controls",{"title":1549,"path":1550,"stem":1551},"DataGrid — колонки та базове відображення","/csharp/desktop-ui/datagrid-part1","01.csharp/12.desktop-ui/32.datagrid-part1",{"title":1553,"path":1554,"stem":1555},"DataGrid — сортування, фільтрація, редагування","/csharp/desktop-ui/datagrid-part2","01.csharp/12.desktop-ui/32.datagrid-part2",{"title":1557,"path":1558,"stem":1559},"TreeView та GridView","/csharp/desktop-ui/treeview-listview","01.csharp/12.desktop-ui/33.treeview-listview",{"title":1561,"path":1562,"stem":1563},"Меню, Toolbar, ContextMenu, StatusBar","/csharp/desktop-ui/menus-toolbars","01.csharp/12.desktop-ui/34.menus-toolbars",{"title":1565,"path":1566,"stem":1567},"Навігація та керування вікнами. Частина 1: вікна та сторінки","/csharp/desktop-ui/navigation-windows-part1","01.csharp/12.desktop-ui/35.navigation-windows-part1",{"title":1569,"path":1570,"stem":1571},"Навігація та керування вікнами. Частина 2: MVVM-навігація","/csharp/desktop-ui/navigation-windows-part2","01.csharp/12.desktop-ui/35.navigation-windows-part2",{"title":1573,"path":1574,"stem":1575},"Avalonia — Навігація та діалоги","/csharp/desktop-ui/35a.avalonia-navigation-dialogs","01.csharp/12.desktop-ui/35a.avalonia-navigation-dialogs",{"title":1577,"path":1578,"stem":1579},"Діалоги та File Pickers у WPF","/csharp/desktop-ui/dialogs-file-pickers","01.csharp/12.desktop-ui/36.dialogs-file-pickers",{"title":1581,"path":1582,"stem":1583},"UserControl: компонентний підхід у WPF","/csharp/desktop-ui/user-controls","01.csharp/12.desktop-ui/37.user-controls",{"title":1585,"path":1586,"stem":1587},"Custom Controls: Lookless Controls у WPF","/csharp/desktop-ui/custom-controls","01.csharp/12.desktop-ui/38.custom-controls",{"title":1589,"path":1590,"stem":1591},"Avalonia TemplatedControl — Lookless Controls","/csharp/desktop-ui/38a.avalonia-templated-controls","01.csharp/12.desktop-ui/38a.avalonia-templated-controls",{"title":1593,"path":1594,"stem":1595},"Анімації у WPF: Storyboard та Easing Functions","/csharp/desktop-ui/animations-transitions","01.csharp/12.desktop-ui/39.animations-transitions",{"title":1597,"path":1598,"stem":1599},"Анімації в Avalonia","/csharp/desktop-ui/39a.avalonia-animations","01.csharp/12.desktop-ui/39a.avalonia-animations",{"title":1601,"path":1602,"stem":1603},"2D Графіка та Мультимедіа у WPF","/csharp/desktop-ui/media-graphics","01.csharp/12.desktop-ui/40.media-graphics",{"title":1605,"path":1606,"stem":1607},"Dependency Injection у WPF та Avalonia","/csharp/desktop-ui/di-integration","01.csharp/12.desktop-ui/41.di-integration",{"title":1609,"path":1610,"stem":1611},"SQLite та EF Core у десктопних додатках","/csharp/desktop-ui/data-persistence-part1","01.csharp/12.desktop-ui/42.data-persistence-part1",{"title":1613,"path":1614,"stem":1615},"Repository Pattern та Unit of Work","/csharp/desktop-ui/data-persistence-part2","01.csharp/12.desktop-ui/43.data-persistence-part2",{"title":1617,"path":1618,"stem":1619},"Тестування ViewModels","/csharp/desktop-ui/viewmodel-testing","01.csharp/12.desktop-ui/44.viewmodel-testing",{"title":1621,"path":1622,"stem":1623},"Avalonia Headless Testing — тестування UI без вікон","/csharp/desktop-ui/44a.avalonia-headless-testing","01.csharp/12.desktop-ui/44a.avalonia-headless-testing",{"title":1625,"path":1626,"stem":1627},"Кросплатформна розробка з Avalonia","/csharp/desktop-ui/avalonia-cross-platform","01.csharp/12.desktop-ui/45.avalonia-cross-platform",{"title":1629,"path":1630,"stem":1631},"Пакування та розгортання Avalonia додатків","/csharp/desktop-ui/avalonia-packaging-deployment","01.csharp/12.desktop-ui/46.avalonia-packaging-deployment",{"title":1633,"path":1634,"stem":1635},"Розгортання WPF застосунків","/csharp/desktop-ui/wpf-packaging-deployment","01.csharp/12.desktop-ui/47.wpf-packaging-deployment",{"title":1637,"path":1638,"stem":1639},"C# & .NET: The Ultimate Roadmap","/csharp/roadmap","01.csharp/roadmap",{"title":1641,"icon":1642,"path":1643,"stem":1644,"children":1645,"page":59},"C++","i-devicon-cplusplus","/cpp","02.cpp",[1646,1650,1654,1658,1662,1666,1670,1674,1678,1681,1685,1689,1693,1697,1701,1705,1709,1713,1717],{"title":1647,"path":1648,"stem":1649},"Вступ у програмування та алгоритми","/cpp/intro-algorithms","02.cpp/01.intro-algorithms",{"title":1651,"path":1652,"stem":1653},"Code Style: угоди про оформлення коду","/cpp/code-style","02.cpp/02.code-style",{"title":1655,"path":1656,"stem":1657},"Середовище розробки та перший проєкт","/cpp/ide-setup","02.cpp/03.ide-setup",{"title":1659,"path":1660,"stem":1661},"Вивід даних на екран","/cpp/data-output","02.cpp/04.data-output",{"title":1663,"path":1664,"stem":1665},"Типи даних, змінні та константи","/cpp/data-types-variables","02.cpp/05.data-types-variables",{"title":1667,"path":1668,"stem":1669},"Ввід даних з клавіатури","/cpp/data-input","02.cpp/06.data-input",{"title":1671,"path":1672,"stem":1673},"Оператори, перетворення типів та логічні операції","/cpp/operators-type-conversion","02.cpp/07.operators-type-conversion",{"title":1675,"path":1676,"stem":1677},"Цикли","/cpp/loops","02.cpp/08.loops",{"title":32,"path":1679,"stem":1680},"/cpp/arrays","02.cpp/09.arrays",{"title":1682,"path":1683,"stem":1684},"Алгоритми сортування та аналіз складності","/cpp/sorting","02.cpp/10.sorting",{"title":1686,"path":1687,"stem":1688},"Алгоритми пошуку","/cpp/searching","02.cpp/11.searching",{"title":1690,"path":1691,"stem":1692},"Функції: основи","/cpp/functions-basics","02.cpp/12.functions-basics",{"title":1694,"path":1695,"stem":1696},"Функції: прототипи, область видимості та додаткові можливості","/cpp/functions-scope","02.cpp/13.functions-scope",{"title":1698,"path":1699,"stem":1700},"Функції: перевантаження та шаблони","/cpp/functions-overloading-templates","02.cpp/14.functions-overloading-templates",{"title":1702,"path":1703,"stem":1704},"Вказівники: основи","/cpp/pointers-basics","02.cpp/15.pointers-basics",{"title":1706,"path":1707,"stem":1708},"Посилання (References)","/cpp/references","02.cpp/16.references",{"title":1710,"path":1711,"stem":1712},"Вказівники, const і масиви","/cpp/pointers-const-arrays","02.cpp/17.pointers-const-arrays",{"title":1714,"path":1715,"stem":1716},"Адресна арифметика","/cpp/pointer-arithmetic","02.cpp/18.pointer-arithmetic",{"title":1718,"path":1719,"stem":1720},"Динамічна пам'ять","/cpp/dynamic-memory","02.cpp/19.dynamic-memory",{"title":1722,"icon":1723,"path":1724,"stem":1725,"children":1726,"page":59},"JavaScript","i-devicon-javascript","/javascript","03.javascript",[1727,1753,1807,1829,2133,2171],{"title":1728,"icon":1729,"path":1730,"stem":1731,"children":1732,"page":59},"Events","i-lucide-mouse-pointer-click","/javascript/events","03.javascript/01.events",[1733,1737,1741,1745,1749],{"title":1734,"path":1735,"stem":1736},"Вступ до подій браузера","/javascript/events/intro","03.javascript/01.events/01.intro",{"title":1738,"path":1739,"stem":1740},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","/javascript/events/bubbling-capturing","03.javascript/01.events/02.bubbling-capturing",{"title":1742,"path":1743,"stem":1744},"Делегування подій (Event Delegation)","/javascript/events/delegate-events","03.javascript/01.events/03.delegate-events",{"title":1746,"path":1747,"stem":1748},"Типові дії браузера та preventDefault()","/javascript/events/prevent-default","03.javascript/01.events/04.prevent-default",{"title":1750,"path":1751,"stem":1752},"Запуск користувацьких подій (Custom Events)","/javascript/events/custom-events","03.javascript/01.events/05.custom-events",{"title":1754,"icon":1755,"path":1756,"stem":1757,"children":1758,"page":59},"Network","i-lucide-globe","/javascript/network","03.javascript/02.network",[1759,1763,1767,1771,1775,1779,1783,1787,1791,1795,1799,1803],{"title":1760,"path":1761,"stem":1762},"Fetch API - Сучасний підхід до HTTP-запитів","/javascript/network/01-fetch-api","03.javascript/02.network/01-fetch-api",{"title":1764,"path":1765,"stem":1766},"FormData - Робота з формами та файлами","/javascript/network/02-formdata","03.javascript/02.network/02-formdata",{"title":1768,"path":1769,"stem":1770},"Відстеження прогресу завантаження","/javascript/network/03-download-progress","03.javascript/02.network/03-download-progress",{"title":1772,"path":1773,"stem":1774},"Переривання fetch-запитів","/javascript/network/04-abort-requests","03.javascript/02.network/04-abort-requests",{"title":1776,"path":1777,"stem":1778},"CORS - Запити між різними джерелами","/javascript/network/05-cors","03.javascript/02.network/05-cors",{"title":1780,"path":1781,"stem":1782},"Fetch API - Повний довідник опцій","/javascript/network/06-fetch-options","03.javascript/02.network/06-fetch-options",{"title":1784,"path":1785,"stem":1786},"URL Objects - Робота з посиланнями","/javascript/network/07-url-objects","03.javascript/02.network/07-url-objects",{"title":1788,"path":1789,"stem":1790},"XMLHttpRequest - AJAX та низькорівневі запити","/javascript/network/08-xmlhttprequest","03.javascript/02.network/08-xmlhttprequest",{"title":1792,"path":1793,"stem":1794},"Відновлюване завантаження файлів","/javascript/network/09-resumable-upload","03.javascript/02.network/09-resumable-upload",{"title":1796,"path":1797,"stem":1798},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","/javascript/network/10-cookies","03.javascript/02.network/10-cookies",{"title":1800,"path":1801,"stem":1802},"js-cookie: Керування Cookies без Болю","/javascript/network/11-js-cookie","03.javascript/02.network/11-js-cookie",{"title":1804,"path":1805,"stem":1806},"Axios: Потужний HTTP-клієнт для JavaScript","/javascript/network/12-axios","03.javascript/02.network/12-axios",{"title":1808,"icon":1809,"path":1810,"stem":1811,"children":1812,"page":59},"Bom","i-lucide-monitor","/javascript/bom","03.javascript/03.bom",[1813,1817,1821,1825],{"title":1814,"path":1815,"stem":1816},"LocalStorage, SessionStorage та patterns збереження даних","/javascript/bom/01-localstorage","03.javascript/03.bom/01-localstorage",{"title":1818,"path":1819,"stem":1820},"Location Object - Керування адресою сторінки","/javascript/bom/02-location-object","03.javascript/03.bom/02-location-object",{"title":1822,"path":1823,"stem":1824},"History API - Керування історією браузера","/javascript/bom/03-history-api","03.javascript/03.bom/03-history-api",{"title":1826,"path":1827,"stem":1828},"Navigator Object - Ідентифікація та Можливості Пристрою","/javascript/bom/04-navigator-object","03.javascript/03.bom/04-navigator-object",{"title":1830,"icon":1831,"path":1832,"stem":1833,"children":1834},"React","i-devicon-react","/javascript/react","03.javascript/04.react/index",[1835,1836,1840,1844,1848,1852,1915,1950,2102],{"title":1830,"path":1832,"stem":1833},{"title":1837,"path":1838,"stem":1839},"Робота з Формами в React","/javascript/react/react-forms","03.javascript/04.react/01.react-forms",{"title":1841,"path":1842,"stem":1843},"React Hook Form: Професійна Робота з Формами","/javascript/react/react-hook-form","03.javascript/04.react/02.react-hook-form",{"title":1845,"path":1846,"stem":1847},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","/javascript/react/react-hook-form-new","03.javascript/04.react/02.react-hook-form-new",{"title":1849,"path":1850,"stem":1851},"Axios та React: Професійна Архітектура Запитів","/javascript/react/data-fetching-axios","03.javascript/04.react/03.data-fetching-axios",{"title":1853,"icon":132,"path":1854,"stem":1855,"children":1856},"Tanstack Query","/javascript/react/tanstack-query","03.javascript/04.react/04.tanstack-query/index",[1857,1859,1863,1867,1871,1875,1879,1883,1887,1891,1895,1899,1903,1907,1911],{"title":1858,"path":1854,"stem":1855},"TanStack Query: Майстерність Керування Станом Сервера",{"title":1860,"path":1861,"stem":1862},"Парадигма Server State: Чому useEffect недостатньо","/javascript/react/tanstack-query/server-state-paradigm","03.javascript/04.react/04.tanstack-query/01.server-state-paradigm",{"title":1864,"path":1865,"stem":1866},"Встановлення та Налаштування: Фундамент","/javascript/react/tanstack-query/installation-and-devtools","03.javascript/04.react/04.tanstack-query/02.installation-and-devtools",{"title":1868,"path":1869,"stem":1870},"Основи Запитів та Магія Ключів","/javascript/react/tanstack-query/query-basics-and-keys","03.javascript/04.react/04.tanstack-query/03.query-basics-and-keys",{"title":1872,"path":1873,"stem":1874},"Синхронізація Даних: Життєвий Цикл Запиту","/javascript/react/tanstack-query/data-synchronization","03.javascript/04.react/04.tanstack-query/04.data-synchronization",{"title":1876,"path":1877,"stem":1878},"Мутації та Інвалідація: Зміна Даних","/javascript/react/tanstack-query/mutations-and-invalidation","03.javascript/04.react/04.tanstack-query/05.mutations-and-invalidation",{"title":1880,"path":1881,"stem":1882},"Оптимістичні Оновлення: Швидше за Світло","/javascript/react/tanstack-query/optimistic-updates","03.javascript/04.react/04.tanstack-query/06.optimistic-updates",{"title":1884,"path":1885,"stem":1886},"Пагінація та Infinite Scroll","/javascript/react/tanstack-query/pagination-and-load-more","03.javascript/04.react/04.tanstack-query/07.pagination-and-load-more",{"title":1888,"path":1889,"stem":1890},"Просунуті Патерни та Оптимізація","/javascript/react/tanstack-query/advanced-patterns","03.javascript/04.react/04.tanstack-query/08.advanced-patterns",{"title":1892,"path":1893,"stem":1894},"Архітектура та Best Practices","/javascript/react/tanstack-query/architecture-and-best-practices","03.javascript/04.react/04.tanstack-query/09.architecture-and-best-practices",{"title":1896,"path":1897,"stem":1898},"Server-Side Rendering (SSR) та Гідратація","/javascript/react/tanstack-query/server-side-rendering","03.javascript/04.react/04.tanstack-query/10.server-side-rendering",{"title":1900,"path":1901,"stem":1902},"Стратегії Тестування","/javascript/react/tanstack-query/testing-strategies","03.javascript/04.react/04.tanstack-query/11.testing-strategies",{"title":1904,"path":1905,"stem":1906},"Аутентифікація та Обробка Помилок","/javascript/react/tanstack-query/authentication-and-errors","03.javascript/04.react/04.tanstack-query/12.authentication-and-errors",{"title":1908,"path":1909,"stem":1910},"React Suspense та Майбутнє","/javascript/react/tanstack-query/react-suspense","03.javascript/04.react/04.tanstack-query/13.react-suspense",{"title":1912,"path":1913,"stem":1914},"Глибоке Занурення в Продуктивність","/javascript/react/tanstack-query/performance-deep-dive","03.javascript/04.react/04.tanstack-query/14.performance-deep-dive",{"title":1916,"icon":1831,"path":1917,"stem":1918,"children":1919},"React Router","/javascript/react/react-router","03.javascript/04.react/05.react-router/index",[1920,1922,1926,1930,1934,1938,1942,1946],{"title":1921,"path":1917,"stem":1918},"React Router: Навігаційна система сучасного вебу",{"title":1923,"path":1924,"stem":1925},"Налаштування та Базовий Роутинг","/javascript/react/react-router/setup-and-basic-routing","03.javascript/04.react/05.react-router/01.setup-and-basic-routing",{"title":1927,"path":1928,"stem":1929},"Динамічна Навігація","/javascript/react/react-router/navigation-and-links","03.javascript/04.react/05.react-router/02.navigation-and-links",{"title":1931,"path":1932,"stem":1933},"Вкладені Маршрути та Макети","/javascript/react/react-router/nested-routes-and-layouts","03.javascript/04.react/05.react-router/03.nested-routes-and-layouts",{"title":1935,"path":1936,"stem":1937},"Динамічні Маршрути та Параметри","/javascript/react/react-router/dynamic-routing","03.javascript/04.react/05.react-router/04.dynamic-routing",{"title":1939,"path":1940,"stem":1941},"Data APIs: Loaders та Actions","/javascript/react/react-router/data-loading","03.javascript/04.react/05.react-router/05.data-loading",{"title":1943,"path":1944,"stem":1945},"Просунуті Патерни","/javascript/react/react-router/advanced-patterns","03.javascript/04.react/05.react-router/06.advanced-patterns",{"title":1947,"path":1948,"stem":1949},"Legacy Routing: Компонентний підхід","/javascript/react/react-router/legacy-routing","03.javascript/04.react/05.react-router/07.legacy-routing",{"title":1951,"icon":132,"path":1952,"stem":1953,"children":1954},"Redux","/javascript/react/redux","03.javascript/04.react/06.redux/index",[1955,1957,1973,2002,2011,2032,2048,2077],{"title":1956,"path":1952,"stem":1953},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":1958,"stem":1959,"children":1960,"page":59},"/javascript/react/redux/fundamentals","03.javascript/04.react/06.redux/01.fundamentals",[1961,1965,1969],{"title":1962,"path":1963,"stem":1964},"Вступ до State Management","/javascript/react/redux/fundamentals/intro-state-management","03.javascript/04.react/06.redux/01.fundamentals/01.intro-state-management",{"title":1966,"path":1967,"stem":1968},"Філософія Redux та Три Принципи","/javascript/react/redux/fundamentals/redux-philosophy","03.javascript/04.react/06.redux/01.fundamentals/02.redux-philosophy",{"title":1970,"path":1971,"stem":1972},"Чисті функції та Іммутабельність","/javascript/react/redux/fundamentals/pure-functions-immutability","03.javascript/04.react/06.redux/01.fundamentals/03.pure-functions-immutability",{"title":1974,"icon":132,"path":1975,"stem":1976,"children":1977,"page":59},"Classic Redux","/javascript/react/redux/classic-redux","03.javascript/04.react/06.redux/02.classic-redux",[1978,1982,1986,1990,1994,1998],{"title":1979,"path":1980,"stem":1981},"Створення Store (Classic Redux)","/javascript/react/redux/classic-redux/store-setup","03.javascript/04.react/06.redux/02.classic-redux/01.store-setup",{"title":1983,"path":1984,"stem":1985},"Actions, Constants та Action Creators","/javascript/react/redux/classic-redux/actions-constants","03.javascript/04.react/06.redux/02.classic-redux/02.actions-constants",{"title":1987,"path":1988,"stem":1989},"Логіка Reducers","/javascript/react/redux/classic-redux/reducers","03.javascript/04.react/06.redux/02.classic-redux/03.reducers",{"title":1991,"path":1992,"stem":1993},"Комбінування Reducers (Root Reducer)","/javascript/react/redux/classic-redux/data-flow","03.javascript/04.react/06.redux/02.classic-redux/04.data-flow",{"title":1995,"path":1996,"stem":1997},"Підключення до React (React-Redux)","/javascript/react/redux/classic-redux/react-redux-connection","03.javascript/04.react/06.redux/02.classic-redux/05.react-redux-connection",{"title":1999,"path":2000,"stem":2001},"Middleware та Асинхронність (Redux Thunk)","/javascript/react/redux/classic-redux/middleware-thunk","03.javascript/04.react/06.redux/02.classic-redux/06.middleware-thunk",{"title":2003,"icon":132,"path":2004,"stem":2005,"children":2006,"page":59},"Transition To Rtk","/javascript/react/redux/transition-to-rtk","03.javascript/04.react/06.redux/03.transition-to-rtk",[2007],{"title":2008,"path":2009,"stem":2010},"Проблеми класичного Redux","/javascript/react/redux/transition-to-rtk/problems-with-classic","03.javascript/04.react/06.redux/03.transition-to-rtk/01.problems-with-classic",{"title":2012,"icon":132,"path":2013,"stem":2014,"children":2015,"page":59},"Redux Toolkit","/javascript/react/redux/redux-toolkit","03.javascript/04.react/06.redux/04.redux-toolkit",[2016,2020,2024,2028],{"title":2017,"path":2018,"stem":2019},"Налаштування Store з configureStore","/javascript/react/redux/redux-toolkit/configure-store","03.javascript/04.react/06.redux/04.redux-toolkit/01.configure-store",{"title":2021,"path":2022,"stem":2023},"createSlice: Революція в Redux","/javascript/react/redux/redux-toolkit/create-slice","03.javascript/04.react/06.redux/04.redux-toolkit/02.create-slice",{"title":2025,"path":2026,"stem":2027},"Асинхронність з createAsyncThunk","/javascript/react/redux/redux-toolkit/async-thunks","03.javascript/04.react/06.redux/04.redux-toolkit/03.async-thunks",{"title":2029,"path":2030,"stem":2031},"04. Entity Adapter: Керування нормалізованим станом","/javascript/react/redux/redux-toolkit/entity-adapter","03.javascript/04.react/06.redux/04.redux-toolkit/04.entity-adapter",{"title":2033,"icon":92,"path":2034,"stem":2035,"children":2036,"page":59},"Advanced","/javascript/react/redux/advanced","03.javascript/04.react/06.redux/05.advanced",[2037,2041,2045],{"title":2038,"path":2039,"stem":2040},"Мемоізація та Селектори: Повний Гайд по Reselect","/javascript/react/redux/advanced/selectors-reselect","03.javascript/04.react/06.redux/05.advanced/01.selectors-reselect",{"title":2042,"path":2043,"stem":2044},"RTK Query: Архітектура Серверного Кешу","/javascript/react/redux/advanced/rtk-query-intro","03.javascript/04.react/06.redux/05.advanced/02.rtk-query-intro",{"title":1892,"path":2046,"stem":2047},"/javascript/react/redux/advanced/architecture-best-practices","03.javascript/04.react/06.redux/05.advanced/03.architecture-best-practices",{"title":2049,"icon":132,"path":2050,"stem":2051,"children":2052,"page":59},"Project Kanban","/javascript/react/redux/project-kanban","03.javascript/04.react/06.redux/06.project-kanban",[2053,2057,2061,2065,2069,2073],{"title":2054,"path":2055,"stem":2056},"Проєкт: Kanban Board (Trello Clone)","/javascript/react/redux/project-kanban/project-overview","03.javascript/04.react/06.redux/06.project-kanban/01.project-overview",{"title":2058,"path":2059,"stem":2060},"Налаштування та Типізація","/javascript/react/redux/project-kanban/setup-and-types","03.javascript/04.react/06.redux/06.project-kanban/02.setup-and-types",{"title":2062,"path":2063,"stem":2064},"Board Slice: Серце Дошки","/javascript/react/redux/project-kanban/board-slice","03.javascript/04.react/06.redux/06.project-kanban/03.board-slice",{"title":2066,"path":2067,"stem":2068},"Логіка Drag & Drop","/javascript/react/redux/project-kanban/drag-and-drop-logic","03.javascript/04.react/06.redux/06.project-kanban/04.drag-and-drop-logic",{"title":2070,"path":2071,"stem":2072},"Інтеграція з RTK Query","/javascript/react/redux/project-kanban/rtk-query-integration","03.javascript/04.react/06.redux/06.project-kanban/05.rtk-query-integration",{"title":2074,"path":2075,"stem":2076},"Optimistic Updates","/javascript/react/redux/project-kanban/optimistic-updates","03.javascript/04.react/06.redux/06.project-kanban/06.optimistic-updates",{"title":2078,"icon":132,"path":2079,"stem":2080,"children":2081,"page":59},"Testing","/javascript/react/redux/testing","03.javascript/04.react/06.redux/07.testing",[2082,2086,2090,2094,2098],{"title":2083,"path":2084,"stem":2085},"Тестування Redux","/javascript/react/redux/testing/intro-testing","03.javascript/04.react/06.redux/07.testing/01.intro-testing",{"title":2087,"path":2088,"stem":2089},"Тестування Reducers","/javascript/react/redux/testing/testing-reducers","03.javascript/04.react/06.redux/07.testing/02.testing-reducers",{"title":2091,"path":2092,"stem":2093},"Тестування Селекторів","/javascript/react/redux/testing/testing-selectors","03.javascript/04.react/06.redux/07.testing/03.testing-selectors",{"title":2095,"path":2096,"stem":2097},"Тестування Компонентів (Integration)","/javascript/react/redux/testing/testing-components","03.javascript/04.react/06.redux/07.testing/04.testing-components",{"title":2099,"path":2100,"stem":2101},"Тестування Async Thunks","/javascript/react/redux/testing/testing-thunks","03.javascript/04.react/06.redux/07.testing/05.testing-thunks",{"title":2103,"icon":132,"path":2104,"stem":2105,"children":2106},"Ui Libraries","/javascript/react/ui-libraries","03.javascript/04.react/07.ui-libraries/index",[2107,2109,2113,2117,2121,2125,2129],{"title":2108,"path":2104,"stem":2105},"UI Бібліотеки в React",{"title":2110,"path":2111,"stem":2112},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","/javascript/react/ui-libraries/introduction-to-ui-libraries","03.javascript/04.react/07.ui-libraries/01.introduction-to-ui-libraries",{"title":2114,"path":2115,"stem":2116},"Філософія shadcn/ui: \"Not a Component Library\"","/javascript/react/ui-libraries/shadcn-philosophy","03.javascript/04.react/07.ui-libraries/02.shadcn-philosophy",{"title":2118,"path":2119,"stem":2120},"Установка та Налаштування shadcn/ui","/javascript/react/ui-libraries/shadcn-installation","03.javascript/04.react/07.ui-libraries/03.shadcn-installation",{"title":2122,"path":2123,"stem":2124},"Базові Компоненти shadcn/ui: Фундамент Інтерфейсу","/javascript/react/ui-libraries/shadcn-components-basics","03.javascript/04.react/07.ui-libraries/04.shadcn-components-basics",{"title":2126,"path":2127,"stem":2128},"Компоненти Форм: Побудова Інтерактивних Form","/javascript/react/ui-libraries/shadcn-components-forms","03.javascript/04.react/07.ui-libraries/05.shadcn-components-forms",{"title":2130,"path":2131,"stem":2132},"Складні Компоненти: Dialog, Dropdown, Table та Command","/javascript/react/ui-libraries/shadcn-components-advanced","03.javascript/04.react/07.ui-libraries/06.shadcn-components-advanced",{"title":2134,"icon":2135,"path":2136,"stem":2137,"children":2138,"page":59},"TypeScript","i-devicon-typescript","/javascript/typescript","03.javascript/05.typescript",[2139,2143,2147,2151,2155,2159,2163,2167],{"title":2140,"path":2141,"stem":2142},"TypeScript: Броня для вашого коду","/javascript/typescript/intro-and-basic-types","03.javascript/05.typescript/01.intro-and-basic-types",{"title":2144,"path":2145,"stem":2146},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","/javascript/typescript/interfaces-and-advanced-types","03.javascript/05.typescript/02.interfaces-and-advanced-types",{"title":2148,"path":2149,"stem":2150},"Алхімія Типів: Generics та Utility Types","/javascript/typescript/generics-and-utilities","03.javascript/05.typescript/03.generics-and-utilities",{"title":2152,"path":2153,"stem":2154},"Архітектура та Шаблони: Класи в TypeScript","/javascript/typescript/classes-and-oop","03.javascript/05.typescript/04.classes-and-oop",{"title":2156,"path":2157,"stem":2158},"Продакшн та Екосистема: Advanced Config & Workflow","/javascript/typescript/advanced-patterns-and-config","03.javascript/05.typescript/05.advanced-patterns-and-config",{"title":2160,"path":2161,"stem":2162},"TypeScript у світі React","/javascript/typescript/react-basics","03.javascript/05.typescript/06.react-basics",{"title":2164,"path":2165,"stem":2166},"React + TypeScript: Продвинуті патерни","/javascript/typescript/react-advanced","03.javascript/05.typescript/07.react-advanced",{"title":2168,"path":2169,"stem":2170},"React + TypeScript: Екосистема та бібліотеки","/javascript/typescript/react-ecosystem","03.javascript/05.typescript/08.react-ecosystem",{"title":2172,"path":2173,"stem":2174},"Atomic Design","/javascript/atomic-design","03.javascript/2.atomic-design",{"title":2176,"icon":2177,"path":2178,"stem":2179,"children":2180,"page":59},"Java","i-devicon-java","/java","04.java",[2181,2184,2187,2191,2195,2199],{"title":162,"path":2182,"stem":2183},"/java/data-mapper-part1","04.java/01.data-mapper-part1",{"title":166,"path":2185,"stem":2186},"/java/data-mapper-part2","04.java/02.data-mapper-part2",{"title":2188,"path":2189,"stem":2190},"Service Layer: Організація бізнес-логіки","/java/service-layer","04.java/03.service-layer",{"title":2192,"path":2193,"stem":2194},"Rich Domain Model та State Pattern","/java/rich-domain-model","04.java/04.rich-domain-model",{"title":2196,"path":2197,"stem":2198},"Патерни для складної бізнес-логіки","/java/business-logic-patterns","04.java/05.business-logic-patterns",{"title":2200,"path":2201,"stem":2202},"Обробка помилок та валідація","/java/error-handling-validation","04.java/06.error-handling-validation",{"title":2204,"icon":2205,"path":2206,"stem":2207,"children":2208,"page":59},"Бази даних","i-lucide-database","/databases","06.databases",[2209,2239,2262,2299,2328,2346,2380,2392,2401],{"title":2210,"icon":2211,"path":2212,"stem":2213,"children":2214,"page":59},"Intro","i-lucide-play","/databases/intro","06.databases/01.intro",[2215,2219,2223,2227,2231,2235],{"title":2216,"path":2217,"stem":2218},"Введення в теорію баз даних","/databases/intro/introduction-to-databases","06.databases/01.intro/01.introduction-to-databases",{"title":2220,"path":2221,"stem":2222},"Реляційна модель даних","/databases/intro/relational-model-theory","06.databases/01.intro/02.relational-model-theory",{"title":2224,"path":2225,"stem":2226},"ER-моделювання","/databases/intro/er-modeling","06.databases/01.intro/03.er-modeling",{"title":2228,"path":2229,"stem":2230},"Логічне проектування БД","/databases/intro/logical-schema","06.databases/01.intro/04.logical-schema",{"title":2232,"path":2233,"stem":2234},"Класифікація таблиць","/databases/intro/table-classification","06.databases/01.intro/05.table-classification",{"title":2236,"path":2237,"stem":2238},"PlantUML для баз даних","/databases/intro/plantuml-diagrams","06.databases/01.intro/06.plantuml-diagrams",{"title":2240,"icon":2205,"path":2241,"stem":2242,"children":2243,"page":59},"MS SQL Server Start","/databases/ms-sql-server-start","06.databases/02.ms-sql-server-start",[2244,2248,2254,2258],{"title":2245,"path":2246,"stem":2247},"Типи даних у MS SQL Server","/databases/ms-sql-server-start/data-types","06.databases/02.ms-sql-server-start/01.data-types",{"title":2249,"path":2250,"stem":2251,"children":2252},"Індекси у MS SQL Server","/databases/ms-sql-server-start/sql-indexes","06.databases/02.ms-sql-server-start/02.sql-indexes",[2253],{"title":2249,"path":2250,"stem":2251},{"title":2255,"path":2256,"stem":2257},"Системні бази даних MS SQL Server","/databases/ms-sql-server-start/system-databases","06.databases/02.ms-sql-server-start/03.system-databases",{"title":2259,"path":2260,"stem":2261},"Огляд мови SQL та запитів","/databases/ms-sql-server-start/sql-queries-overview","06.databases/02.ms-sql-server-start/04.sql-queries-overview",{"title":2263,"icon":2205,"path":2264,"stem":2265,"children":2266,"page":59},"SQL","/databases/sql","06.databases/03.sql",[2267,2271,2275,2279,2283,2287,2291,2295],{"title":2268,"path":2269,"stem":2270},"Налаштування демонстраційної бази даних","/databases/sql/sample-database-setup","06.databases/03.sql/00.sample-database-setup",{"title":2272,"path":2273,"stem":2274},"DDL - Створення таблиць (CREATE TABLE)","/databases/sql/ddl-create-table","06.databases/03.sql/01.ddl-create-table",{"title":2276,"path":2277,"stem":2278},"DDL - Зміна та видалення таблиць (ALTER, DROP)","/databases/sql/ddl-alter-drop-table","06.databases/03.sql/02.ddl-alter-drop-table",{"title":2280,"path":2281,"stem":2282},"SELECT запити - Основи","/databases/sql/select-queries-fundamentals","06.databases/03.sql/03.select-queries-fundamentals",{"title":2284,"path":2285,"stem":2286},"SELECT запити - Розширені можливості","/databases/sql/select-queries-advanced","06.databases/03.sql/04.select-queries-advanced",{"title":2288,"path":2289,"stem":2290},"INSERT запити - Додавання даних","/databases/sql/insert-queries","06.databases/03.sql/05.insert-queries",{"title":2292,"path":2293,"stem":2294},"UPDATE та DELETE запити","/databases/sql/update-delete-queries","06.databases/03.sql/06.update-delete-queries",{"title":2296,"path":2297,"stem":2298},"Транзакції в SQL","/databases/sql/transactions","06.databases/03.sql/07.transactions",{"title":2300,"icon":2205,"path":2301,"stem":2302,"children":2303,"page":59},"Multi Table Databases","/databases/multi-table-databases","06.databases/04.multi-table-databases",[2304,2308,2312,2316,2320,2324],{"title":2305,"path":2306,"stem":2307},"Зв'язки та нормалізація БД","/databases/multi-table-databases/relationships-and-normalization","06.databases/04.multi-table-databases/00.relationships-and-normalization",{"title":2309,"path":2310,"stem":2311},"INNER JOIN - З'єднання таблиць","/databases/multi-table-databases/inner-join","06.databases/04.multi-table-databases/01.inner-join",{"title":2313,"path":2314,"stem":2315},"OUTER JOINs - LEFT, RIGHT, FULL","/databases/multi-table-databases/outer-joins","06.databases/04.multi-table-databases/02.outer-joins",{"title":2317,"path":2318,"stem":2319},"CROSS та SELF JOINs","/databases/multi-table-databases/cross-self-joins","06.databases/04.multi-table-databases/03.cross-self-joins",{"title":2321,"path":2322,"stem":2323},"Підзапити (Subqueries)","/databases/multi-table-databases/subqueries","06.databases/04.multi-table-databases/04.subqueries",{"title":2325,"path":2326,"stem":2327},"Агрегації з JOIN","/databases/multi-table-databases/aggregations-with-joins","06.databases/04.multi-table-databases/05.aggregations-with-joins",{"title":2329,"icon":2330,"path":2331,"stem":2332,"children":2333,"page":59},"Aggregate Functions","i-lucide-calculator","/databases/aggregate-functions","06.databases/05.aggregate-functions",[2334,2338,2342],{"title":2335,"path":2336,"stem":2337},"Функції агрегування в MS SQL Server","/databases/aggregate-functions/introduction-aggregate-functions","06.databases/05.aggregate-functions/01.introduction-aggregate-functions",{"title":2339,"path":2340,"stem":2341},"Групування даних в MS SQL Server","/databases/aggregate-functions/grouping-data","06.databases/05.aggregate-functions/02.grouping-data",{"title":2343,"path":2344,"stem":2345},"Підзапити з агрегатними функціями","/databases/aggregate-functions/subqueries-aggregates","06.databases/05.aggregate-functions/03.subqueries-aggregates",{"title":2347,"icon":2348,"path":2349,"stem":2350,"children":2351,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","/databases/triggers-stored-procedures","06.databases/07.triggers-stored-procedures",[2352,2356,2360,2364,2368,2372,2376],{"title":2353,"path":2354,"stem":2355},"DML-тригери","/databases/triggers-stored-procedures/dml-triggers","06.databases/07.triggers-stored-procedures/01.dml-triggers",{"title":2357,"path":2358,"stem":2359},"DDL-тригери","/databases/triggers-stored-procedures/ddl-triggers","06.databases/07.triggers-stored-procedures/02.ddl-triggers",{"title":2361,"path":2362,"stem":2363},"Transact-SQL розширення","/databases/triggers-stored-procedures/transact-sql-extensions","06.databases/07.triggers-stored-procedures/03.transact-sql-extensions",{"title":2365,"path":2366,"stem":2367},"Транзакції","/databases/triggers-stored-procedures/transactions","06.databases/07.triggers-stored-procedures/04.transactions",{"title":2369,"path":2370,"stem":2371},"Зберігаємі процедури","/databases/triggers-stored-procedures/stored-procedures","06.databases/07.triggers-stored-procedures/05.stored-procedures",{"title":2373,"path":2374,"stem":2375},"Користувацькі функції","/databases/triggers-stored-procedures/user-defined-functions","06.databases/07.triggers-stored-procedures/06.user-defined-functions",{"title":2377,"path":2378,"stem":2379},"Безпека баз даних","/databases/triggers-stored-procedures/security","06.databases/07.triggers-stored-procedures/08.security",{"title":2377,"icon":793,"path":2381,"stem":2382,"children":2383,"page":59},"/databases/security","06.databases/08.security",[2384,2388],{"title":2385,"path":2386,"stem":2387},"Вступ до безпеки баз даних","/databases/security/introduction","06.databases/08.security/01.introduction",{"title":2389,"path":2390,"stem":2391},"Системні представлення та метадані","/databases/security/system-views","06.databases/08.security/02.system-views",{"title":2393,"icon":2394,"path":2395,"stem":2396,"children":2397,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","/databases/backup-recovery","06.databases/09.backup-recovery",[2398],{"title":2393,"path":2399,"stem":2400},"/databases/backup-recovery/backup-restore","06.databases/09.backup-recovery/01.backup-restore",{"title":2402,"icon":2403,"path":2404,"stem":2405,"children":2406,"page":59},"Повнотекстовий пошук","i-lucide-search","/databases/full-text-search","06.databases/10.full-text-search",[2407],{"title":2402,"path":2408,"stem":2409},"/databases/full-text-search/full-text-search","06.databases/10.full-text-search/01.full-text-search",{"title":2411,"icon":2412,"path":2413,"stem":2414,"children":2415,"page":59},"Tools","i-lucide-wrench","/tools","07.tools",[2416],{"title":2417,"icon":2418,"path":2419,"stem":2420,"children":2421},"Docker","i-simple-icons-docker","/tools/docker","07.tools/01.docker/index",[2422,2424,2428,2432,2436,2440,2444,2448,2452,2456,2460,2464,2468,2472],{"title":2423,"path":2419,"stem":2420},"Docker: від нуля до production",{"title":2425,"path":2426,"stem":2427},"Контейнеризація — від проблеми до рішення","/tools/docker/containerization-concept","07.tools/01.docker/01.containerization-concept",{"title":2429,"path":2430,"stem":2431},"Docker — що це і навіщо?","/tools/docker/docker-what-and-why","07.tools/01.docker/02.docker-what-and-why",{"title":2433,"path":2434,"stem":2435},"Архітектура Docker Engine","/tools/docker/docker-architecture","07.tools/01.docker/03.docker-architecture",{"title":2437,"path":2438,"stem":2439},"Встановлення Docker","/tools/docker/installation","07.tools/01.docker/04.installation",{"title":2441,"path":2442,"stem":2443},"Перший контейнер — docker run","/tools/docker/first-container","07.tools/01.docker/05.first-container",{"title":2445,"path":2446,"stem":2447},"Життєвий цикл контейнера","/tools/docker/container-lifecycle","07.tools/01.docker/06.container-lifecycle",{"title":2449,"path":2450,"stem":2451},"Docker Images — фундаментальні концепції","/tools/docker/docker-images-fundamentals","07.tools/01.docker/07.docker-images-fundamentals",{"title":2453,"path":2454,"stem":2455},"Dockerfile — основи","/tools/docker/dockerfile-basics","07.tools/01.docker/08.dockerfile-basics",{"title":2457,"path":2458,"stem":2459},"Dockerfile — просунуті техніки","/tools/docker/dockerfile-advanced","07.tools/01.docker/09.dockerfile-advanced",{"title":2461,"path":2462,"stem":2463},"Build Context та кешування шарів","/tools/docker/build-context-and-cache","07.tools/01.docker/10.build-context-and-cache",{"title":2465,"path":2466,"stem":2467},"Реєстри Docker-образів","/tools/docker/image-registries","07.tools/01.docker/11.image-registries",{"title":2469,"path":2470,"stem":2471},"Контейнеризація .NET додатків","/tools/docker/dotnet-containerization","07.tools/01.docker/12.dotnet-containerization",{"title":2473,"path":2474,"stem":2475},"Томи та збереження даних","/tools/docker/volumes-and-data","07.tools/01.docker/13.volumes-and-data",{"title":2477,"icon":2478,"path":2479,"stem":2480,"children":2481,"page":59},"Software Engineering","i-lucide-code-2","/software-engineering","09.software-engineering",[2482,2486,2490,2494,2498,2502,2506,2510,2514,2518,2522],{"title":2483,"path":2484,"stem":2485},"1. Аналіз предметної області. Експертні знання та складність","/software-engineering/intro.subdomains","09.software-engineering/01.intro.subdomains",{"title":2487,"path":2488,"stem":2489},"2. Обмежені контексти. Інтеграція обмежених контекстів","/software-engineering/integrating-limited-contexts","09.software-engineering/02.integrating-limited-contexts",{"title":2491,"path":2492,"stem":2493},"3. Реалізація простої бізнес-логіки","/software-engineering/simple","09.software-engineering/03.simple",{"title":2495,"path":2496,"stem":2497},"4. Опрацювання складної бізнес-логіки","/software-engineering/complex-business-logic","09.software-engineering/04.complex-business-logic",{"title":2499,"path":2500,"stem":2501},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","/software-engineering/modelling-the-time-factor","09.software-engineering/05.modelling-the-time-factor",{"title":2503,"path":2504,"stem":2505},"6. Архітектурні патерни","/software-engineering/architectural-patterns","09.software-engineering/06.architectural-patterns",{"title":2507,"path":2508,"stem":2509},"Паттерни взаємодії","/software-engineering/patterns-of-interaction","09.software-engineering/07.patterns-of-interaction",{"title":2511,"path":2512,"stem":2513},"Евристика проєктування","/software-engineering/design-heuristics","09.software-engineering/08.design-heuristics",{"title":2515,"path":2516,"stem":2517},"Еволюція проєктних рішень","/software-engineering/evolution-of-design-solutions","09.software-engineering/09.evolution-of-design-solutions",{"title":2519,"path":2520,"stem":2521},"EventStorming","/software-engineering/eventstorming","09.software-engineering/10.eventstorming",{"title":2523,"path":2524,"stem":2525},"DDD на практиці","/software-engineering/ddd-in-practice","09.software-engineering/11.ddd-in-practice",{"title":2527,"icon":943,"path":2528,"stem":2529,"children":2530,"page":59},"DDD","/ddd","10.ddd",[2531,2535,2539,2543,2547,2551,2555,2559,2563,2567,2571,2575,2579],{"title":2532,"path":2533,"stem":2534},"Аналіз предметної області","/ddd/domain-analysis","10.ddd/01.domain-analysis",{"title":2536,"path":2537,"stem":2538},"Експертні знання про предметну область","/ddd/domain-expert-knowledge","10.ddd/02.domain-expert-knowledge",{"title":2540,"path":2541,"stem":2542},"Як осмислити складність предметної області","/ddd/managing-domain-complexity","10.ddd/03.managing-domain-complexity",{"title":2544,"path":2545,"stem":2546},"Інтеграція обмежених контекстів","/ddd/bounded-context-integration","10.ddd/04.bounded-context-integration",{"title":2548,"path":2549,"stem":2550},"Реалізація простої бізнес-логіки","/ddd/simple-business-logic","10.ddd/05.simple-business-logic",{"title":2552,"path":2553,"stem":2554},"Обробка складної бізнес-логіки","/ddd/complex-business-logic","10.ddd/06.complex-business-logic",{"title":2556,"path":2557,"stem":2558},"Моделювання фактора часу","/ddd/time-modeling","10.ddd/07.time-modeling",{"title":2560,"path":2561,"stem":2562},"Глава 8. Архітектурні Патерни","/ddd/architectural-patterns","10.ddd/08.architectural-patterns",{"title":2564,"path":2565,"stem":2566},"Глава 9. Патерни Взаємодії","/ddd/interaction-patterns","10.ddd/09.interaction-patterns",{"title":2568,"path":2569,"stem":2570},"Глава 10. Проектні Евристики","/ddd/design-heuristics","10.ddd/10.design-heuristics",{"title":2572,"path":2573,"stem":2574},"Глава 11. Еволюція Проектних Рішень","/ddd/evolution-of-design-decisions","10.ddd/11.evolution-of-design-decisions",{"title":2576,"path":2577,"stem":2578},"Глава 12. EventStorming","/ddd/event-storming","10.ddd/12.event-storming",{"title":2580,"path":2581,"stem":2582},"Глава 13. DDD на Практиці","/ddd/ddd-in-practice","10.ddd/13.ddd-in-practice",{"title":2584,"icon":2585,"path":2586,"stem":2587,"children":2588,"page":59},"Media Streaming","i-lucide-video","/media-streaming","11.media-streaming",[2589,2593,2597,2601,2605,2609,2613],{"title":2590,"path":2591,"stem":2592},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","/media-streaming/introduction","11.media-streaming/01.introduction",{"title":2594,"path":2595,"stem":2596},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","/media-streaming/audio-video-anatomy","11.media-streaming/02.audio-video-anatomy",{"title":2598,"path":2599,"stem":2600},"03. The Gym: FFmpeg Deep Dive","/media-streaming/ffmpeg-gym","11.media-streaming/03.ffmpeg-gym",{"title":2602,"path":2603,"stem":2604},"04. HLS Protocol: HTTP Live Streaming у Деталях","/media-streaming/hls-protocol","11.media-streaming/04.hls-protocol",{"title":2606,"path":2607,"stem":2608},"05. DASH Protocol: Відкритий Стандарт","/media-streaming/dash-protocol","11.media-streaming/05.dash-protocol",{"title":2610,"path":2611,"stem":2612},"06. Масштабування: CDN та Adaptive Bitrate","/media-streaming/cdn-and-adaptive-bitrate","11.media-streaming/06.cdn-and-adaptive-bitrate",{"title":2614,"path":2615,"stem":2616},"07. Війна із Затримкою (Latency)","/media-streaming/realtime-latency","11.media-streaming/07.realtime-latency",{"title":2618,"icon":2619,"path":2620,"stem":2621,"children":2622,"page":59},"HTML & CSS","i-devicon-html5","/html-css","12.html-css",[2623,2627,2631,2635,2639,2643,2647,2651,2655,2659,2663,2667,2671,2675,2679,2683,2687,2691,2695,2699,2703,2707,2711,2715,2719,2723,2727,2731,2735,2739],{"title":2624,"path":2625,"stem":2626},"Вступ до HTML. Структура документа","/html-css/intro-html-structure","12.html-css/01.intro-html-structure",{"title":2628,"path":2629,"stem":2630},"Форматування тексту в HTML","/html-css/html-text-formatting","12.html-css/02.html-text-formatting",{"title":2632,"path":2633,"stem":2634},"Посилання та зображення в HTML","/html-css/html-links-images","12.html-css/03.html-links-images",{"title":2636,"path":2637,"stem":2638},"Списки та таблиці в HTML","/html-css/html-lists-tables","12.html-css/04.html-lists-tables",{"title":2640,"path":2641,"stem":2642},"Форми в HTML","/html-css/html-forms","12.html-css/05.html-forms",{"title":2644,"path":2645,"stem":2646},"Семантичні елементи HTML5","/html-css/html-semantic-elements","12.html-css/06.html-semantic-elements",{"title":2648,"path":2649,"stem":2650},"Мультимедіа та розширені елементи HTML","/html-css/html-multimedia-advanced","12.html-css/07.html-multimedia-advanced",{"title":2652,"path":2653,"stem":2654},"Мікророзмітка та SEO в HTML","/html-css/html-microdata-seo","12.html-css/08.html-microdata-seo",{"title":2656,"path":2657,"stem":2658},"Вступ до CSS. Селектори та специфічність","/html-css/css-intro-selectors","12.html-css/09.css-intro-selectors",{"title":2660,"path":2661,"stem":2662},"Блокова модель CSS. Відступи. Box Sizing","/html-css/css-box-model","12.html-css/10.css-box-model",{"title":2664,"path":2665,"stem":2666},"Розміри у CSS: повний довідник одиниць і ключових слів","/html-css/10a.css-sizing","12.html-css/10a.css-sizing",{"title":2668,"path":2669,"stem":2670},"Типографіка в CSS. Шрифти та текст","/html-css/css-typography","12.html-css/11.css-typography",{"title":2672,"path":2673,"stem":2674},"Кольори та фони в CSS","/html-css/css-colors-backgrounds","12.html-css/12.css-colors-backgrounds",{"title":2676,"path":2677,"stem":2678},"Тіні та фільтри в CSS","/html-css/12b.css-shadows-filters","12.html-css/12b.css-shadows-filters",{"title":2680,"path":2681,"stem":2682},"CSS Flexbox: Фундамент гнучких макетів","/html-css/css-flexbox-fundamentals","12.html-css/13.css-flexbox-fundamentals",{"title":2684,"path":2685,"stem":2686},"CSS Flexbox: Вирівнювання та Позиціонування","/html-css/css-flexbox-alignment-sizing-and-patterns","12.html-css/14.css-flexbox-alignment-sizing-and-patterns",{"title":2688,"path":2689,"stem":2690},"CSS Grid. Двовимірний макет. Частина 1","/html-css/css-layout-grid","12.html-css/15.css-layout-grid",{"title":2692,"path":2693,"stem":2694},"CSS Grid. Двовимірний макет. Частина 2","/html-css/css-layout-grid-advanced","12.html-css/16.css-layout-grid-advanced",{"title":2696,"path":2697,"stem":2698},"Позиціонування в CSS. Z-index. Stacking Context","/html-css/css-positioning","12.html-css/17.css-positioning",{"title":2700,"path":2701,"stem":2702},"CSS Анімації та Переходи","/html-css/css-animations-transitions","12.html-css/18.css-animations-transitions",{"title":2704,"path":2705,"stem":2706},"Адаптивний дизайн. Media Queries. Частина 1","/html-css/css-responsive-media-queries","12.html-css/19.css-responsive-media-queries",{"title":2708,"path":2709,"stem":2710},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","/html-css/css-responsive-advanced","12.html-css/20.css-responsive-advanced",{"title":2712,"path":2713,"stem":2714},"CSS Custom Properties. Методології. Сучасний CSS","/html-css/css-variables-methodologies","12.html-css/21.css-variables-methodologies",{"title":2716,"path":2717,"stem":2718},"Сучасний CSS 2023–2025: Нові можливості","/html-css/css-modern-features","12.html-css/22.css-modern-features",{"title":2720,"path":2721,"stem":2722},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","/html-css/22a.css-nesting-modern-syntax","12.html-css/22a.css-nesting-modern-syntax",{"title":2724,"path":2725,"stem":2726},"CSS для форм та інтерактивних станів","/html-css/css-forms-interactive-states","12.html-css/23.css-forms-interactive-states",{"title":2728,"path":2729,"stem":2730},"Доступність у CSS (CSS Accessibility)","/html-css/css-accessibility","12.html-css/24.css-accessibility",{"title":2732,"path":2733,"stem":2734},"CSS-функції та сучасні sizing primitives","/html-css/css-functions-sizing","12.html-css/25.css-functions-sizing",{"title":2736,"path":2737,"stem":2738},"Rendering Pipeline і CSS Performance","/html-css/css-rendering-performance","12.html-css/26.css-rendering-performance",{"title":2740,"path":2741,"stem":2742},"CSS Best Practices: типові ситуації та правильні рішення","/html-css/css-best-practices","12.html-css/27.css-best-practices",{"title":2744,"path":2745,"stem":2746,"children":2747,"page":59},"Tailwind","/tailwind","21.tailwind",[2748,2752,2756,2760,2764,2768,2772,2776],{"title":2749,"path":2750,"stem":2751},"Що таке Tailwind CSS і навіщо він потрібен","/tailwind/tailwind-intro-philosophy","21.tailwind/01.tailwind-intro-philosophy",{"title":2753,"path":2754,"stem":2755},"Встановлення та налаштування Tailwind CSS v4","/tailwind/tailwind-installation-setup","21.tailwind/02.tailwind-installation-setup",{"title":2757,"path":2758,"stem":2759},"Utility-класи: основи та система Tailwind","/tailwind/tailwind-utility-classes-core","21.tailwind/03.tailwind-utility-classes-core",{"title":2761,"path":2762,"stem":2763},"Layout: Flexbox та Grid через Tailwind","/tailwind/tailwind-flexbox-grid","21.tailwind/04.tailwind-flexbox-grid",{"title":2765,"path":2766,"stem":2767},"Кастомізація теми через @theme у Tailwind v4","/tailwind/tailwind-theme-customization","21.tailwind/05.tailwind-theme-customization",{"title":2769,"path":2770,"stem":2771},"Варіанти: hover, focus, responsive, dark mode та нові v4","/tailwind/tailwind-variants-states","21.tailwind/06.tailwind-variants-states",{"title":2773,"path":2774,"stem":2775},"Типографіка та система кольорів у Tailwind v4","/tailwind/tailwind-typography-colors","21.tailwind/07.tailwind-typography-colors",{"title":2777,"path":2778,"stem":2779},"Компоненти та повторюваність: @apply, @utility та патерни","/tailwind/tailwind-components-patterns","21.tailwind/08.tailwind-components-patterns",{"title":2781,"path":2782,"stem":2783},"Showcase Компонентів kostyl.dev","/test-new-components","98.test-new-components",{"id":2785,"title":2664,"body":2786,"description":18584,"extension":18585,"links":18586,"meta":18587,"navigation":4757,"path":2665,"seo":18588,"stem":2666,"__hash__":18589},"docs/12.html-css/10a.css-sizing.md",{"type":2787,"value":2788,"toc":18514},"minimark",[2789,2793,2803,2842,2845,2857,2966,2969,2973,2981,2988,2993,2998,3013,3060,3063,3071,3106,3645,3664,3670,3753,3851,3868,3870,3874,3881,3887,3906,4672,4685,4697,4786,4792,4813,4879,4906,4932,4938,4947,4995,5497,5513,5580,5712,5714,5718,5721,5730,5754,6459,6466,6478,6509,6521,6524,6620,7235,7240,7308,7310,7314,7324,7328,7348,8243,8247,8254,8357,8450,8465,8467,8471,8478,8484,8493,8500,8508,8515,8529,8536,8548,9629,9639,9738,9740,9755,9759,9773,9850,10485,10492,10503,11397,11417,11419,11423,11441,11451,11575,12581,12642,12644,12660,12666,12675,12773,13504,13512,13529,13609,14526,14532,14544,14635,15528,15530,15537,15543,15689,16794,16796,16802,16811,16886,17720,17752,17754,17758,17971,17973,17977,18425,18427,18431,18438,18510],[2790,2791,2664],"h1",{"id":2792},"розміри-у-css-повний-довідник-одиниць-і-ключових-слів",[2794,2795,2797,2798,2802],"h2",{"id":2796},"чому-width-200px-це-лише-початок","Чому ",[2799,2800,2801],"code",{},"width: 200px"," — це лише початок",[2804,2805,2806,2807,2810,2811,2810,2814,2810,2817,2810,2820,2810,2823,2810,2826,2810,2829,2810,2832,2810,2835,2810,2838,2841],"p",{},"Уявіть такий сценарій: дизайнер передає вам макет. Кнопка має бути «великою». Картка — «половина екрана». Заголовок — «читабельним на будь-якому пристрої». І ось ви відкриваєте CSS і бачите дикий зоопарк: ",[2799,2808,2809],{},"px",", ",[2799,2812,2813],{},"em",[2799,2815,2816],{},"rem",[2799,2818,2819],{},"vw",[2799,2821,2822],{},"vh",[2799,2824,2825],{},"dvh",[2799,2827,2828],{},"cqw",[2799,2830,2831],{},"fr",[2799,2833,2834],{},"%",[2799,2836,2837],{},"ch",[2799,2839,2840],{},"min-content","... Котре з них «правильне»?",[2804,2843,2844],{},"Відповідь незручна: усі вони правильні — просто для різних задач. Вибір одиниці вимірювання — це архітектурне рішення, яке впливає на адаптивність, доступність та передбачуваність вашого коду.",[2804,2846,2847,2848,2853,2854,2856],{},"У ",[2849,2850,2852],"a",{"href":2851},"/12.html-css/10.css-box-model","попередній статті"," ми дізналися, що кожен елемент — це коробка з чотирма шарами. Тепер навчимося точно контролювати розмір цієї коробки — не тільки через ",[2799,2855,2801],{},", але й через десятки інших інструментів, які CSS надає для різних контекстів.",[2858,2859,2860],"mermaid",{},[2861,2862,2866],"pre",{"className":2863,"code":2864,"language":2858,"meta":2865,"style":2865},"language-mermaid shiki shiki-themes light-plus dark-plus dark-plus","graph TD\n    A[\"CSS Розміри\"] --> B[\"Абсолютні\\npx, pt, cm, mm\"]\n    A --> C[\"Відносні шрифтові\\nem, rem, ch, ex\"]\n    A --> D[\"Viewport\\nvw, vh, dvh, svh, lvh\"]\n    A --> E[\"Контейнерні\\ncqw, cqh, cqi\"]\n    A --> F[\"Intrinsic keywords\\nmin-content, max-content\\nfit-content, auto\"]\n    A --> G[\"Функції\\ncalc(), min(), max()\\nclamp()\"]\n    A --> H[\"Grid-специфічні\\nfr\"]\n    style A fill:#6366f1,color:#fff,stroke:#4f46e5\n    style B fill:#3b82f6,color:#fff,stroke:#2563eb\n    style C fill:#10b981,color:#fff,stroke:#059669\n    style D fill:#f59e0b,color:#fff,stroke:#d97706\n    style E fill:#ec4899,color:#fff,stroke:#db2777\n    style F fill:#8b5cf6,color:#fff,stroke:#7c3aed\n    style G fill:#06b6d4,color:#fff,stroke:#0891b2\n    style H fill:#64748b,color:#fff,stroke:#475569\n","",[2799,2867,2868,2876,2882,2888,2894,2900,2906,2912,2918,2924,2930,2936,2942,2948,2954,2960],{"__ignoreMap":2865},[2869,2870,2873],"span",{"class":2871,"line":2872},"line",1,[2869,2874,2875],{},"graph TD\n",[2869,2877,2879],{"class":2871,"line":2878},2,[2869,2880,2881],{},"    A[\"CSS Розміри\"] --> B[\"Абсолютні\\npx, pt, cm, mm\"]\n",[2869,2883,2885],{"class":2871,"line":2884},3,[2869,2886,2887],{},"    A --> C[\"Відносні шрифтові\\nem, rem, ch, ex\"]\n",[2869,2889,2891],{"class":2871,"line":2890},4,[2869,2892,2893],{},"    A --> D[\"Viewport\\nvw, vh, dvh, svh, lvh\"]\n",[2869,2895,2897],{"class":2871,"line":2896},5,[2869,2898,2899],{},"    A --> E[\"Контейнерні\\ncqw, cqh, cqi\"]\n",[2869,2901,2903],{"class":2871,"line":2902},6,[2869,2904,2905],{},"    A --> F[\"Intrinsic keywords\\nmin-content, max-content\\nfit-content, auto\"]\n",[2869,2907,2909],{"class":2871,"line":2908},7,[2869,2910,2911],{},"    A --> G[\"Функції\\ncalc(), min(), max()\\nclamp()\"]\n",[2869,2913,2915],{"class":2871,"line":2914},8,[2869,2916,2917],{},"    A --> H[\"Grid-специфічні\\nfr\"]\n",[2869,2919,2921],{"class":2871,"line":2920},9,[2869,2922,2923],{},"    style A fill:#6366f1,color:#fff,stroke:#4f46e5\n",[2869,2925,2927],{"class":2871,"line":2926},10,[2869,2928,2929],{},"    style B fill:#3b82f6,color:#fff,stroke:#2563eb\n",[2869,2931,2933],{"class":2871,"line":2932},11,[2869,2934,2935],{},"    style C fill:#10b981,color:#fff,stroke:#059669\n",[2869,2937,2939],{"class":2871,"line":2938},12,[2869,2940,2941],{},"    style D fill:#f59e0b,color:#fff,stroke:#d97706\n",[2869,2943,2945],{"class":2871,"line":2944},13,[2869,2946,2947],{},"    style E fill:#ec4899,color:#fff,stroke:#db2777\n",[2869,2949,2951],{"class":2871,"line":2950},14,[2869,2952,2953],{},"    style F fill:#8b5cf6,color:#fff,stroke:#7c3aed\n",[2869,2955,2957],{"class":2871,"line":2956},15,[2869,2958,2959],{},"    style G fill:#06b6d4,color:#fff,stroke:#0891b2\n",[2869,2961,2963],{"class":2871,"line":2962},16,[2869,2964,2965],{},"    style H fill:#64748b,color:#fff,stroke:#475569\n",[2967,2968],"hr",{},[2794,2970,2972],{"id":2971},"абсолютні-одиниці-absolute-units","Абсолютні одиниці (Absolute Units)",[2804,2974,2975,2976,2980],{},"Абсолютні одиниці — це фіксовані розміри, які ",[2977,2978,2979],"strong",{},"не залежать від контексту",": ні від батьківського елемента, ні від розміру вікна браузера, ні від налаштувань користувача.",[2982,2983,2985,2987],"h3",{"id":2984},"px-піксель-якого-не-існує",[2799,2986,2809],{}," — піксель, якого не існує",[2804,2989,2990,2992],{},[2799,2991,2809],{}," — найпоширеніша одиниця CSS, і водночас найбільш оманлива за назвою. Жоден сучасний пристрій не відображає «один CSS-піксель» як буквально один фізичний піксель екрана.",[2804,2994,2995],{},[2977,2996,2997],{},"Фізичний піксель vs CSS-піксель:",[2804,2999,3000,3001,3004,3005,3008,3009,3012],{},"Сучасні екрани мають ",[2977,3002,3003],{},"Device Pixel Ratio (DPR)"," — коефіцієнт, що показує, скільки фізичних пікселів відповідає одному CSS-пікселю. На MacBook Pro з Retina-дисплеєм DPR = 2: ",[2799,3006,3007],{},"1px CSS"," = ",[2799,3010,3011],{},"2×2 = 4 фізичні пікселі",". На iPhone 15 Pro — DPR = 3.",[2858,3014,3015],{},[2861,3016,3018],{"className":2863,"code":3017,"language":2858,"meta":2865,"style":2865},"graph LR\n    A[\"1px CSS\"] --> B[\"DPR 1\\n(звичайний монітор)\\n1 фіз. піксель\"]\n    A --> C[\"DPR 2\\n(Retina)\\n4 фіз. пікселі\"]\n    A --> D[\"DPR 3\\n(iPhone Pro)\\n9 фіз. пікселів\"]\n    style A fill:#6366f1,color:#fff\n    style B fill:#64748b,color:#fff\n    style C fill:#3b82f6,color:#fff\n    style D fill:#ec4899,color:#fff\n",[2799,3019,3020,3025,3030,3035,3040,3045,3050,3055],{"__ignoreMap":2865},[2869,3021,3022],{"class":2871,"line":2872},[2869,3023,3024],{},"graph LR\n",[2869,3026,3027],{"class":2871,"line":2878},[2869,3028,3029],{},"    A[\"1px CSS\"] --> B[\"DPR 1\\n(звичайний монітор)\\n1 фіз. піксель\"]\n",[2869,3031,3032],{"class":2871,"line":2884},[2869,3033,3034],{},"    A --> C[\"DPR 2\\n(Retina)\\n4 фіз. пікселі\"]\n",[2869,3036,3037],{"class":2871,"line":2890},[2869,3038,3039],{},"    A --> D[\"DPR 3\\n(iPhone Pro)\\n9 фіз. пікселів\"]\n",[2869,3041,3042],{"class":2871,"line":2896},[2869,3043,3044],{},"    style A fill:#6366f1,color:#fff\n",[2869,3046,3047],{"class":2871,"line":2902},[2869,3048,3049],{},"    style B fill:#64748b,color:#fff\n",[2869,3051,3052],{"class":2871,"line":2908},[2869,3053,3054],{},"    style C fill:#3b82f6,color:#fff\n",[2869,3056,3057],{"class":2871,"line":2914},[2869,3058,3059],{},"    style D fill:#ec4899,color:#fff\n",[2804,3061,3062],{},"Саме тому зображення мають бути вдвічі (або втричі) більшими за відображуваний розмір, щоб виглядати чітко на Retina-екранах.",[2804,3064,3065],{},[2977,3066,3067,3068,3070],{},"Коли використовувати ",[2799,3069,2809],{},":",[3072,3073,3074,3081,3087,3093,3099],"ul",{},[3075,3076,3077,3080],"li",{},[2799,3078,3079],{},"border: 1px solid"," — тонкі декоративні лінії",[3075,3082,3083,3086],{},[2799,3084,3085],{},"border-radius: 4px"," — невеликі заокруглення",[3075,3088,3089,3092],{},[2799,3090,3091],{},"box-shadow"," — тіні",[3075,3094,3095,3098],{},[2799,3096,3097],{},"outline-offset"," — зсув обідка фокусу",[3075,3100,3101,3102,3105],{},"Розміри іконок (",[2799,3103,3104],{},"width: 24px",") у контексті, де масштабування небажане",[3107,3108,3109,3247],"html-preview",{},[2861,3110,3114],{"className":3111,"code":3112,"language":3113,"meta":2865,"style":2865},"language-html shiki shiki-themes light-plus dark-plus dark-plus","\u003Cdiv class=\"px-demo\">\n  \u003Cdiv class=\"item\">border: 1px solid\u003C/div>\n  \u003Cdiv class=\"item radius\">border-radius: 8px\u003C/div>\n  \u003Cdiv class=\"item shadow\">box-shadow: 0 2px 8px\u003C/div>\n  \u003Cdiv class=\"item icon-size\">Іконка 24×24px\u003C/div>\n\u003C/div>\n","html",[2799,3115,3116,3141,3167,3191,3215,3239],{"__ignoreMap":2865},[2869,3117,3118,3122,3126,3130,3134,3138],{"class":2871,"line":2872},[2869,3119,3121],{"class":3120},"s0P7L","\u003C",[2869,3123,3125],{"class":3124},"sKtos","div",[2869,3127,3129],{"class":3128},"sa4r_"," class",[2869,3131,3133],{"class":3132},"sHH4Y","=",[2869,3135,3137],{"class":3136},"su9tN","\"px-demo\"",[2869,3139,3140],{"class":3120},">\n",[2869,3142,3143,3146,3148,3150,3152,3155,3158,3160,3163,3165],{"class":2871,"line":2878},[2869,3144,3145],{"class":3120},"  \u003C",[2869,3147,3125],{"class":3124},[2869,3149,3129],{"class":3128},[2869,3151,3133],{"class":3132},[2869,3153,3154],{"class":3136},"\"item\"",[2869,3156,3157],{"class":3120},">",[2869,3159,3079],{"class":3132},[2869,3161,3162],{"class":3120},"\u003C/",[2869,3164,3125],{"class":3124},[2869,3166,3140],{"class":3120},[2869,3168,3169,3171,3173,3175,3177,3180,3182,3185,3187,3189],{"class":2871,"line":2884},[2869,3170,3145],{"class":3120},[2869,3172,3125],{"class":3124},[2869,3174,3129],{"class":3128},[2869,3176,3133],{"class":3132},[2869,3178,3179],{"class":3136},"\"item radius\"",[2869,3181,3157],{"class":3120},[2869,3183,3184],{"class":3132},"border-radius: 8px",[2869,3186,3162],{"class":3120},[2869,3188,3125],{"class":3124},[2869,3190,3140],{"class":3120},[2869,3192,3193,3195,3197,3199,3201,3204,3206,3209,3211,3213],{"class":2871,"line":2890},[2869,3194,3145],{"class":3120},[2869,3196,3125],{"class":3124},[2869,3198,3129],{"class":3128},[2869,3200,3133],{"class":3132},[2869,3202,3203],{"class":3136},"\"item shadow\"",[2869,3205,3157],{"class":3120},[2869,3207,3208],{"class":3132},"box-shadow: 0 2px 8px",[2869,3210,3162],{"class":3120},[2869,3212,3125],{"class":3124},[2869,3214,3140],{"class":3120},[2869,3216,3217,3219,3221,3223,3225,3228,3230,3233,3235,3237],{"class":2871,"line":2896},[2869,3218,3145],{"class":3120},[2869,3220,3125],{"class":3124},[2869,3222,3129],{"class":3128},[2869,3224,3133],{"class":3132},[2869,3226,3227],{"class":3136},"\"item icon-size\"",[2869,3229,3157],{"class":3120},[2869,3231,3232],{"class":3132},"Іконка 24×24px",[2869,3234,3162],{"class":3120},[2869,3236,3125],{"class":3124},[2869,3238,3140],{"class":3120},[2869,3240,3241,3243,3245],{"class":2871,"line":2902},[2869,3242,3162],{"class":3120},[2869,3244,3125],{"class":3124},[2869,3246,3140],{"class":3120},[2861,3248,3252],{"className":3249,"code":3250,"language":3251,"meta":2865,"style":2865},"language-css shiki shiki-themes light-plus dark-plus dark-plus",".px-demo {\n  display: flex;\n  flex-wrap: wrap;\n  gap: 1rem;\n  padding: 1.5rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.85rem;\n}\n.item {\n  padding: 0.75rem 1.25rem;\n  background: white;\n  color: #1e293b;\n  border: 1px solid #e2e8f0;\n}\n.radius { border-radius: 8px; }\n.shadow { box-shadow: 0 2px 8px rgba(0,0,0,0.12); border: none; }\n.icon-size { width: 24px; height: 24px; background: #6366f1;\n  display: flex; align-items: center; justify-content: center;\n  color: white; font-size: 0; padding: 0; border: none; border-radius: 4px; }\n.icon-size::after { content: '★'; font-size: 14px; }\n","css",[2799,3253,3254,3263,3278,3290,3303,3315,3327,3344,3356,3361,3368,3382,3393,3405,3423,3427,3446,3503,3541,3571,3617],{"__ignoreMap":2865},[2869,3255,3256,3260],{"class":2871,"line":2872},[2869,3257,3259],{"class":3258},"sqdDX",".px-demo",[2869,3261,3262],{"class":3132}," {\n",[2869,3264,3265,3268,3271,3275],{"class":2871,"line":2878},[2869,3266,3267],{"class":3128},"  display",[2869,3269,3270],{"class":3132},": ",[2869,3272,3274],{"class":3273},"sDUd3","flex",[2869,3276,3277],{"class":3132},";\n",[2869,3279,3280,3283,3285,3288],{"class":2871,"line":2884},[2869,3281,3282],{"class":3128},"  flex-wrap",[2869,3284,3270],{"class":3132},[2869,3286,3287],{"class":3273},"wrap",[2869,3289,3277],{"class":3132},[2869,3291,3292,3295,3297,3301],{"class":2871,"line":2890},[2869,3293,3294],{"class":3128},"  gap",[2869,3296,3270],{"class":3132},[2869,3298,3300],{"class":3299},"sJj4R","1rem",[2869,3302,3277],{"class":3132},[2869,3304,3305,3308,3310,3313],{"class":2871,"line":2896},[2869,3306,3307],{"class":3128},"  padding",[2869,3309,3270],{"class":3132},[2869,3311,3312],{"class":3299},"1.5rem",[2869,3314,3277],{"class":3132},[2869,3316,3317,3320,3322,3325],{"class":2871,"line":2902},[2869,3318,3319],{"class":3128},"  background",[2869,3321,3270],{"class":3132},[2869,3323,3324],{"class":3273},"#f8fafc",[2869,3326,3277],{"class":3132},[2869,3328,3329,3332,3334,3337,3339,3342],{"class":2871,"line":2908},[2869,3330,3331],{"class":3128},"  font-family",[2869,3333,3270],{"class":3132},[2869,3335,3336],{"class":3273},"system-ui",[2869,3338,2810],{"class":3132},[2869,3340,3341],{"class":3273},"sans-serif",[2869,3343,3277],{"class":3132},[2869,3345,3346,3349,3351,3354],{"class":2871,"line":2914},[2869,3347,3348],{"class":3128},"  font-size",[2869,3350,3270],{"class":3132},[2869,3352,3353],{"class":3299},"0.85rem",[2869,3355,3277],{"class":3132},[2869,3357,3358],{"class":2871,"line":2920},[2869,3359,3360],{"class":3132},"}\n",[2869,3362,3363,3366],{"class":2871,"line":2926},[2869,3364,3365],{"class":3258},".item",[2869,3367,3262],{"class":3132},[2869,3369,3370,3372,3374,3377,3380],{"class":2871,"line":2932},[2869,3371,3307],{"class":3128},[2869,3373,3270],{"class":3132},[2869,3375,3376],{"class":3299},"0.75rem",[2869,3378,3379],{"class":3299}," 1.25rem",[2869,3381,3277],{"class":3132},[2869,3383,3384,3386,3388,3391],{"class":2871,"line":2938},[2869,3385,3319],{"class":3128},[2869,3387,3270],{"class":3132},[2869,3389,3390],{"class":3273},"white",[2869,3392,3277],{"class":3132},[2869,3394,3395,3398,3400,3403],{"class":2871,"line":2944},[2869,3396,3397],{"class":3128},"  color",[2869,3399,3270],{"class":3132},[2869,3401,3402],{"class":3273},"#1e293b",[2869,3404,3277],{"class":3132},[2869,3406,3407,3410,3412,3415,3418,3421],{"class":2871,"line":2950},[2869,3408,3409],{"class":3128},"  border",[2869,3411,3270],{"class":3132},[2869,3413,3414],{"class":3299},"1px",[2869,3416,3417],{"class":3273}," solid",[2869,3419,3420],{"class":3273}," #e2e8f0",[2869,3422,3277],{"class":3132},[2869,3424,3425],{"class":2871,"line":2956},[2869,3426,3360],{"class":3132},[2869,3428,3429,3432,3435,3438,3440,3443],{"class":2871,"line":2962},[2869,3430,3431],{"class":3258},".radius",[2869,3433,3434],{"class":3132}," { ",[2869,3436,3437],{"class":3128},"border-radius",[2869,3439,3270],{"class":3132},[2869,3441,3442],{"class":3299},"8px",[2869,3444,3445],{"class":3132},"; }\n",[2869,3447,3449,3452,3454,3456,3458,3461,3464,3467,3471,3474,3476,3479,3481,3483,3485,3487,3490,3493,3496,3498,3501],{"class":2871,"line":3448},17,[2869,3450,3451],{"class":3258},".shadow",[2869,3453,3434],{"class":3132},[2869,3455,3091],{"class":3128},[2869,3457,3270],{"class":3132},[2869,3459,3460],{"class":3299},"0",[2869,3462,3463],{"class":3299}," 2px",[2869,3465,3466],{"class":3299}," 8px",[2869,3468,3470],{"class":3469},"s8Opu"," rgba",[2869,3472,3473],{"class":3132},"(",[2869,3475,3460],{"class":3299},[2869,3477,3478],{"class":3132},",",[2869,3480,3460],{"class":3299},[2869,3482,3478],{"class":3132},[2869,3484,3460],{"class":3299},[2869,3486,3478],{"class":3132},[2869,3488,3489],{"class":3299},"0.12",[2869,3491,3492],{"class":3132},"); ",[2869,3494,3495],{"class":3128},"border",[2869,3497,3270],{"class":3132},[2869,3499,3500],{"class":3273},"none",[2869,3502,3445],{"class":3132},[2869,3504,3506,3509,3511,3514,3516,3519,3522,3525,3527,3529,3531,3534,3536,3539],{"class":2871,"line":3505},18,[2869,3507,3508],{"class":3258},".icon-size",[2869,3510,3434],{"class":3132},[2869,3512,3513],{"class":3128},"width",[2869,3515,3270],{"class":3132},[2869,3517,3518],{"class":3299},"24px",[2869,3520,3521],{"class":3132},"; ",[2869,3523,3524],{"class":3128},"height",[2869,3526,3270],{"class":3132},[2869,3528,3518],{"class":3299},[2869,3530,3521],{"class":3132},[2869,3532,3533],{"class":3128},"background",[2869,3535,3270],{"class":3132},[2869,3537,3538],{"class":3273},"#6366f1",[2869,3540,3277],{"class":3132},[2869,3542,3544,3546,3548,3550,3552,3555,3557,3560,3562,3565,3567,3569],{"class":2871,"line":3543},19,[2869,3545,3267],{"class":3128},[2869,3547,3270],{"class":3132},[2869,3549,3274],{"class":3273},[2869,3551,3521],{"class":3132},[2869,3553,3554],{"class":3128},"align-items",[2869,3556,3270],{"class":3132},[2869,3558,3559],{"class":3273},"center",[2869,3561,3521],{"class":3132},[2869,3563,3564],{"class":3128},"justify-content",[2869,3566,3270],{"class":3132},[2869,3568,3559],{"class":3273},[2869,3570,3277],{"class":3132},[2869,3572,3574,3576,3578,3580,3582,3585,3587,3589,3591,3594,3596,3598,3600,3602,3604,3606,3608,3610,3612,3615],{"class":2871,"line":3573},20,[2869,3575,3397],{"class":3128},[2869,3577,3270],{"class":3132},[2869,3579,3390],{"class":3273},[2869,3581,3521],{"class":3132},[2869,3583,3584],{"class":3128},"font-size",[2869,3586,3270],{"class":3132},[2869,3588,3460],{"class":3299},[2869,3590,3521],{"class":3132},[2869,3592,3593],{"class":3128},"padding",[2869,3595,3270],{"class":3132},[2869,3597,3460],{"class":3299},[2869,3599,3521],{"class":3132},[2869,3601,3495],{"class":3128},[2869,3603,3270],{"class":3132},[2869,3605,3500],{"class":3273},[2869,3607,3521],{"class":3132},[2869,3609,3437],{"class":3128},[2869,3611,3270],{"class":3132},[2869,3613,3614],{"class":3299},"4px",[2869,3616,3445],{"class":3132},[2869,3618,3620,3623,3625,3628,3630,3634,3636,3638,3640,3643],{"class":2871,"line":3619},21,[2869,3621,3622],{"class":3258},".icon-size::after",[2869,3624,3434],{"class":3132},[2869,3626,3627],{"class":3128},"content",[2869,3629,3270],{"class":3132},[2869,3631,3633],{"class":3632},"sbdoH","'★'",[2869,3635,3521],{"class":3132},[2869,3637,3584],{"class":3128},[2869,3639,3270],{"class":3132},[2869,3641,3642],{"class":3299},"14px",[2869,3644,3445],{"class":3132},[2982,3646,3648,3649,2810,3652,2810,3655,2810,3658,2810,3661],{"id":3647},"друкарські-одиниці-pt-cm-mm-in-pc","Друкарські одиниці: ",[2799,3650,3651],{},"pt",[2799,3653,3654],{},"cm",[2799,3656,3657],{},"mm",[2799,3659,3660],{},"in",[2799,3662,3663],{},"pc",[2804,3665,3666,3667,3070],{},"Ці одиниці мають чіткий фізичний зміст, але у веб-розробці майже не використовуються — крім ",[2799,3668,3669],{},"@media print",[3671,3672,3673,3689],"table",{},[3674,3675,3676],"thead",{},[3677,3678,3679,3683,3686],"tr",{},[3680,3681,3682],"th",{},"Одиниця",[3680,3684,3685],{},"Повна назва",[3680,3687,3688],{},"Еквівалент",[3690,3691,3692,3705,3717,3729,3741],"tbody",{},[3677,3693,3694,3699,3702],{},[3695,3696,3697],"td",{},[2799,3698,3651],{},[3695,3700,3701],{},"Point",[3695,3703,3704],{},"1/72 дюйма ≈ 1.33px",[3677,3706,3707,3711,3714],{},[3695,3708,3709],{},[2799,3710,3663],{},[3695,3712,3713],{},"Pica",[3695,3715,3716],{},"12pt ≈ 16px",[3677,3718,3719,3723,3726],{},[3695,3720,3721],{},[2799,3722,3660],{},[3695,3724,3725],{},"Inch (дюйм)",[3695,3727,3728],{},"96px",[3677,3730,3731,3735,3738],{},[3695,3732,3733],{},[2799,3734,3654],{},[3695,3736,3737],{},"Centimeter",[3695,3739,3740],{},"~37.8px",[3677,3742,3743,3747,3750],{},[3695,3744,3745],{},[2799,3746,3657],{},[3695,3748,3749],{},"Millimeter",[3695,3751,3752],{},"~3.78px",[2861,3754,3756],{"className":3249,"code":3755,"language":3251,"meta":2865,"style":2865},"/* Єдиний розумний контекст для друкарських одиниць */\n@media print {\n  body {\n    font-size: 12pt; /* Читабельно на папері */\n  }\n  h1 {\n    font-size: 24pt;\n  }\n  .page-break {\n    page-break-before: always;\n  }\n}\n",[2799,3757,3758,3764,3775,3782,3797,3802,3809,3820,3824,3831,3843,3847],{"__ignoreMap":2865},[2869,3759,3760],{"class":2871,"line":2872},[2869,3761,3763],{"class":3762},"spJ8K","/* Єдиний розумний контекст для друкарських одиниць */\n",[2869,3765,3766,3770,3773],{"class":2871,"line":2878},[2869,3767,3769],{"class":3768},"sCDza","@media",[2869,3771,3772],{"class":3273}," print",[2869,3774,3262],{"class":3132},[2869,3776,3777,3780],{"class":2871,"line":2884},[2869,3778,3779],{"class":3258},"  body",[2869,3781,3262],{"class":3132},[2869,3783,3784,3787,3789,3792,3794],{"class":2871,"line":2890},[2869,3785,3786],{"class":3128},"    font-size",[2869,3788,3270],{"class":3132},[2869,3790,3791],{"class":3299},"12pt",[2869,3793,3521],{"class":3132},[2869,3795,3796],{"class":3762},"/* Читабельно на папері */\n",[2869,3798,3799],{"class":2871,"line":2896},[2869,3800,3801],{"class":3132},"  }\n",[2869,3803,3804,3807],{"class":2871,"line":2902},[2869,3805,3806],{"class":3258},"  h1",[2869,3808,3262],{"class":3132},[2869,3810,3811,3813,3815,3818],{"class":2871,"line":2908},[2869,3812,3786],{"class":3128},[2869,3814,3270],{"class":3132},[2869,3816,3817],{"class":3299},"24pt",[2869,3819,3277],{"class":3132},[2869,3821,3822],{"class":2871,"line":2914},[2869,3823,3801],{"class":3132},[2869,3825,3826,3829],{"class":2871,"line":2920},[2869,3827,3828],{"class":3258},"  .page-break",[2869,3830,3262],{"class":3132},[2869,3832,3833,3836,3838,3841],{"class":2871,"line":2926},[2869,3834,3835],{"class":3128},"    page-break-before",[2869,3837,3270],{"class":3132},[2869,3839,3840],{"class":3273},"always",[2869,3842,3277],{"class":3132},[2869,3844,3845],{"class":2871,"line":2932},[2869,3846,3801],{"class":3132},[2869,3848,3849],{"class":2871,"line":2938},[2869,3850,3360],{"class":3132},[3852,3853,3854,3855,3857,3858,3860,3861,3863,3864,3867],"tip",{},"У веб-контексті ",[2799,3856,2809],{}," завжди кращий за ",[2799,3859,3651],{}," чи ",[2799,3862,3654],{},". Ці одиниці мають сенс лише якщо ви готуєте стилі для ",[2977,3865,3866],{},"друку",", де фізичний розмір критичний.",[2967,3869],{},[2794,3871,3873],{"id":3872},"відносні-шрифтові-одиниці-font-relative-units","Відносні шрифтові одиниці (Font-relative Units)",[2804,3875,3876,3877,3880],{},"На відміну від абсолютних, ці одиниці обчислюються ",[2977,3878,3879],{},"відносно розміру шрифту"," — або поточного елемента, або кореневого.",[2982,3882,3884,3886],{"id":3883},"em-магія-каскаду",[2799,3885,2813],{}," — магія каскаду",[2804,3888,3889,3891,3892,3894,3895,3898,3899,3901,3902,3905],{},[2799,3890,2813],{}," вираховується відносно ",[2799,3893,3584],{}," ",[2977,3896,3897],{},"самого елемента"," (або батьківського, якщо ",[2799,3900,3584],{}," не задано явно). На перший погляд, здається зручним, але має небезпечний побічний ефект — ",[2977,3903,3904],{},"ефект каскадного множення",".",[3107,3907,3908,4248],{},[2861,3909,3911],{"className":3111,"code":3910,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"em-demo\">\n  \u003Cp class=\"level-0\">Рівень 0 (font-size: 16px = базовий)\u003C/p>\n  \u003Cdiv class=\"nested-1\">\n    \u003Cp>Рівень 1 (font-size: 1.2em = 16 × 1.2 = 19.2px)\u003C/p>\n    \u003Cdiv class=\"nested-2\">\n      \u003Cp>Рівень 2 (font-size: 1.2em = 19.2 × 1.2 = 23px)\u003C/p>\n      \u003Cdiv class=\"nested-3\">\n        \u003Cp>Рівень 3 (font-size: 1.2em = 23 × 1.2 = 27.6px) 😱\u003C/p>\n      \u003C/div>\n    \u003C/div>\n  \u003C/div>\n  \u003Chr class=\"divider\"/>\n  \u003Cp class=\"rem-base\">А тепер з rem: завжди відносно кореня\u003C/p>\n  \u003Cdiv class=\"rem-nested-1\">\n    \u003Cp>Рівень 1 (font-size: 1.2rem = 16 × 1.2 = 19.2px)\u003C/p>\n    \u003Cdiv class=\"rem-nested-2\">\n      \u003Cp>Рівень 2 (font-size: 1.2rem = 16 × 1.2 = 19.2px — стабільно!)\u003C/p>\n      \u003Cdiv class=\"rem-nested-3\">\n        \u003Cp>Рівень 3 (font-size: 1.2rem = 19.2px — незмінно ✅)\u003C/p>\n      \u003C/div>\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,3912,3913,3928,3952,3967,3985,4000,4018,4033,4051,4060,4069,4078,4094,4118,4133,4150,4165,4182,4197,4214,4222,4230,4239],{"__ignoreMap":2865},[2869,3914,3915,3917,3919,3921,3923,3926],{"class":2871,"line":2872},[2869,3916,3121],{"class":3120},[2869,3918,3125],{"class":3124},[2869,3920,3129],{"class":3128},[2869,3922,3133],{"class":3132},[2869,3924,3925],{"class":3136},"\"em-demo\"",[2869,3927,3140],{"class":3120},[2869,3929,3930,3932,3934,3936,3938,3941,3943,3946,3948,3950],{"class":2871,"line":2878},[2869,3931,3145],{"class":3120},[2869,3933,2804],{"class":3124},[2869,3935,3129],{"class":3128},[2869,3937,3133],{"class":3132},[2869,3939,3940],{"class":3136},"\"level-0\"",[2869,3942,3157],{"class":3120},[2869,3944,3945],{"class":3132},"Рівень 0 (font-size: 16px = базовий)",[2869,3947,3162],{"class":3120},[2869,3949,2804],{"class":3124},[2869,3951,3140],{"class":3120},[2869,3953,3954,3956,3958,3960,3962,3965],{"class":2871,"line":2884},[2869,3955,3145],{"class":3120},[2869,3957,3125],{"class":3124},[2869,3959,3129],{"class":3128},[2869,3961,3133],{"class":3132},[2869,3963,3964],{"class":3136},"\"nested-1\"",[2869,3966,3140],{"class":3120},[2869,3968,3969,3972,3974,3976,3979,3981,3983],{"class":2871,"line":2890},[2869,3970,3971],{"class":3120},"    \u003C",[2869,3973,2804],{"class":3124},[2869,3975,3157],{"class":3120},[2869,3977,3978],{"class":3132},"Рівень 1 (font-size: 1.2em = 16 × 1.2 = 19.2px)",[2869,3980,3162],{"class":3120},[2869,3982,2804],{"class":3124},[2869,3984,3140],{"class":3120},[2869,3986,3987,3989,3991,3993,3995,3998],{"class":2871,"line":2896},[2869,3988,3971],{"class":3120},[2869,3990,3125],{"class":3124},[2869,3992,3129],{"class":3128},[2869,3994,3133],{"class":3132},[2869,3996,3997],{"class":3136},"\"nested-2\"",[2869,3999,3140],{"class":3120},[2869,4001,4002,4005,4007,4009,4012,4014,4016],{"class":2871,"line":2902},[2869,4003,4004],{"class":3120},"      \u003C",[2869,4006,2804],{"class":3124},[2869,4008,3157],{"class":3120},[2869,4010,4011],{"class":3132},"Рівень 2 (font-size: 1.2em = 19.2 × 1.2 = 23px)",[2869,4013,3162],{"class":3120},[2869,4015,2804],{"class":3124},[2869,4017,3140],{"class":3120},[2869,4019,4020,4022,4024,4026,4028,4031],{"class":2871,"line":2908},[2869,4021,4004],{"class":3120},[2869,4023,3125],{"class":3124},[2869,4025,3129],{"class":3128},[2869,4027,3133],{"class":3132},[2869,4029,4030],{"class":3136},"\"nested-3\"",[2869,4032,3140],{"class":3120},[2869,4034,4035,4038,4040,4042,4045,4047,4049],{"class":2871,"line":2914},[2869,4036,4037],{"class":3120},"        \u003C",[2869,4039,2804],{"class":3124},[2869,4041,3157],{"class":3120},[2869,4043,4044],{"class":3132},"Рівень 3 (font-size: 1.2em = 23 × 1.2 = 27.6px) 😱",[2869,4046,3162],{"class":3120},[2869,4048,2804],{"class":3124},[2869,4050,3140],{"class":3120},[2869,4052,4053,4056,4058],{"class":2871,"line":2920},[2869,4054,4055],{"class":3120},"      \u003C/",[2869,4057,3125],{"class":3124},[2869,4059,3140],{"class":3120},[2869,4061,4062,4065,4067],{"class":2871,"line":2926},[2869,4063,4064],{"class":3120},"    \u003C/",[2869,4066,3125],{"class":3124},[2869,4068,3140],{"class":3120},[2869,4070,4071,4074,4076],{"class":2871,"line":2932},[2869,4072,4073],{"class":3120},"  \u003C/",[2869,4075,3125],{"class":3124},[2869,4077,3140],{"class":3120},[2869,4079,4080,4082,4084,4086,4088,4091],{"class":2871,"line":2938},[2869,4081,3145],{"class":3120},[2869,4083,2967],{"class":3124},[2869,4085,3129],{"class":3128},[2869,4087,3133],{"class":3132},[2869,4089,4090],{"class":3136},"\"divider\"",[2869,4092,4093],{"class":3120},"/>\n",[2869,4095,4096,4098,4100,4102,4104,4107,4109,4112,4114,4116],{"class":2871,"line":2944},[2869,4097,3145],{"class":3120},[2869,4099,2804],{"class":3124},[2869,4101,3129],{"class":3128},[2869,4103,3133],{"class":3132},[2869,4105,4106],{"class":3136},"\"rem-base\"",[2869,4108,3157],{"class":3120},[2869,4110,4111],{"class":3132},"А тепер з rem: завжди відносно кореня",[2869,4113,3162],{"class":3120},[2869,4115,2804],{"class":3124},[2869,4117,3140],{"class":3120},[2869,4119,4120,4122,4124,4126,4128,4131],{"class":2871,"line":2950},[2869,4121,3145],{"class":3120},[2869,4123,3125],{"class":3124},[2869,4125,3129],{"class":3128},[2869,4127,3133],{"class":3132},[2869,4129,4130],{"class":3136},"\"rem-nested-1\"",[2869,4132,3140],{"class":3120},[2869,4134,4135,4137,4139,4141,4144,4146,4148],{"class":2871,"line":2956},[2869,4136,3971],{"class":3120},[2869,4138,2804],{"class":3124},[2869,4140,3157],{"class":3120},[2869,4142,4143],{"class":3132},"Рівень 1 (font-size: 1.2rem = 16 × 1.2 = 19.2px)",[2869,4145,3162],{"class":3120},[2869,4147,2804],{"class":3124},[2869,4149,3140],{"class":3120},[2869,4151,4152,4154,4156,4158,4160,4163],{"class":2871,"line":2962},[2869,4153,3971],{"class":3120},[2869,4155,3125],{"class":3124},[2869,4157,3129],{"class":3128},[2869,4159,3133],{"class":3132},[2869,4161,4162],{"class":3136},"\"rem-nested-2\"",[2869,4164,3140],{"class":3120},[2869,4166,4167,4169,4171,4173,4176,4178,4180],{"class":2871,"line":3448},[2869,4168,4004],{"class":3120},[2869,4170,2804],{"class":3124},[2869,4172,3157],{"class":3120},[2869,4174,4175],{"class":3132},"Рівень 2 (font-size: 1.2rem = 16 × 1.2 = 19.2px — стабільно!)",[2869,4177,3162],{"class":3120},[2869,4179,2804],{"class":3124},[2869,4181,3140],{"class":3120},[2869,4183,4184,4186,4188,4190,4192,4195],{"class":2871,"line":3505},[2869,4185,4004],{"class":3120},[2869,4187,3125],{"class":3124},[2869,4189,3129],{"class":3128},[2869,4191,3133],{"class":3132},[2869,4193,4194],{"class":3136},"\"rem-nested-3\"",[2869,4196,3140],{"class":3120},[2869,4198,4199,4201,4203,4205,4208,4210,4212],{"class":2871,"line":3543},[2869,4200,4037],{"class":3120},[2869,4202,2804],{"class":3124},[2869,4204,3157],{"class":3120},[2869,4206,4207],{"class":3132},"Рівень 3 (font-size: 1.2rem = 19.2px — незмінно ✅)",[2869,4209,3162],{"class":3120},[2869,4211,2804],{"class":3124},[2869,4213,3140],{"class":3120},[2869,4215,4216,4218,4220],{"class":2871,"line":3573},[2869,4217,4055],{"class":3120},[2869,4219,3125],{"class":3124},[2869,4221,3140],{"class":3120},[2869,4223,4224,4226,4228],{"class":2871,"line":3619},[2869,4225,4064],{"class":3120},[2869,4227,3125],{"class":3124},[2869,4229,3140],{"class":3120},[2869,4231,4233,4235,4237],{"class":2871,"line":4232},22,[2869,4234,4073],{"class":3120},[2869,4236,3125],{"class":3124},[2869,4238,3140],{"class":3120},[2869,4240,4242,4244,4246],{"class":2871,"line":4241},23,[2869,4243,3162],{"class":3120},[2869,4245,3125],{"class":3124},[2869,4247,3140],{"class":3120},[2861,4249,4251],{"className":3249,"code":4250,"language":3251,"meta":2865,"style":2865},".em-demo {\n  font-family: system-ui, sans-serif;\n  font-size: 16px;\n  padding: 1rem;\n  background: #f8fafc;\n  color: #1e293b;\n}\n.level-0 { margin: 0 0 0.5rem; }\n.nested-1 { font-size: 1.2em; padding-left: 1rem; border-left: 3px solid #ef4444; }\n.nested-2 { font-size: 1.2em; padding-left: 1rem; border-left: 3px solid #f97316; }\n.nested-3 { font-size: 1.2em; padding-left: 1rem; border-left: 3px solid #eab308; }\n.nested-1 p, .nested-2 p, .nested-3 p { margin: 0.25rem 0; }\n.divider { margin: 1rem 0; border: 1px solid #e2e8f0; }\n.rem-base { margin: 0 0 0.5rem; }\n.rem-nested-1 { font-size: 1.2rem; padding-left: 1rem; border-left: 3px solid #10b981; }\n.rem-nested-2 { font-size: 1.2rem; padding-left: 1rem; border-left: 3px solid #06b6d4; }\n.rem-nested-3 { font-size: 1.2rem; padding-left: 1rem; border-left: 3px solid #6366f1; }\n.rem-nested-1 p, .rem-nested-2 p, .rem-nested-3 p { margin: 0.25rem 0; }\n",[2799,4252,4253,4260,4274,4285,4295,4305,4315,4319,4341,4381,4417,4453,4485,4514,4533,4570,4606,4642],{"__ignoreMap":2865},[2869,4254,4255,4258],{"class":2871,"line":2872},[2869,4256,4257],{"class":3258},".em-demo",[2869,4259,3262],{"class":3132},[2869,4261,4262,4264,4266,4268,4270,4272],{"class":2871,"line":2878},[2869,4263,3331],{"class":3128},[2869,4265,3270],{"class":3132},[2869,4267,3336],{"class":3273},[2869,4269,2810],{"class":3132},[2869,4271,3341],{"class":3273},[2869,4273,3277],{"class":3132},[2869,4275,4276,4278,4280,4283],{"class":2871,"line":2884},[2869,4277,3348],{"class":3128},[2869,4279,3270],{"class":3132},[2869,4281,4282],{"class":3299},"16px",[2869,4284,3277],{"class":3132},[2869,4286,4287,4289,4291,4293],{"class":2871,"line":2890},[2869,4288,3307],{"class":3128},[2869,4290,3270],{"class":3132},[2869,4292,3300],{"class":3299},[2869,4294,3277],{"class":3132},[2869,4296,4297,4299,4301,4303],{"class":2871,"line":2896},[2869,4298,3319],{"class":3128},[2869,4300,3270],{"class":3132},[2869,4302,3324],{"class":3273},[2869,4304,3277],{"class":3132},[2869,4306,4307,4309,4311,4313],{"class":2871,"line":2902},[2869,4308,3397],{"class":3128},[2869,4310,3270],{"class":3132},[2869,4312,3402],{"class":3273},[2869,4314,3277],{"class":3132},[2869,4316,4317],{"class":2871,"line":2908},[2869,4318,3360],{"class":3132},[2869,4320,4321,4324,4326,4329,4331,4333,4336,4339],{"class":2871,"line":2914},[2869,4322,4323],{"class":3258},".level-0",[2869,4325,3434],{"class":3132},[2869,4327,4328],{"class":3128},"margin",[2869,4330,3270],{"class":3132},[2869,4332,3460],{"class":3299},[2869,4334,4335],{"class":3299}," 0",[2869,4337,4338],{"class":3299}," 0.5rem",[2869,4340,3445],{"class":3132},[2869,4342,4343,4346,4348,4350,4352,4355,4357,4360,4362,4364,4366,4369,4371,4374,4376,4379],{"class":2871,"line":2920},[2869,4344,4345],{"class":3258},".nested-1",[2869,4347,3434],{"class":3132},[2869,4349,3584],{"class":3128},[2869,4351,3270],{"class":3132},[2869,4353,4354],{"class":3299},"1.2em",[2869,4356,3521],{"class":3132},[2869,4358,4359],{"class":3128},"padding-left",[2869,4361,3270],{"class":3132},[2869,4363,3300],{"class":3299},[2869,4365,3521],{"class":3132},[2869,4367,4368],{"class":3128},"border-left",[2869,4370,3270],{"class":3132},[2869,4372,4373],{"class":3299},"3px",[2869,4375,3417],{"class":3273},[2869,4377,4378],{"class":3273}," #ef4444",[2869,4380,3445],{"class":3132},[2869,4382,4383,4386,4388,4390,4392,4394,4396,4398,4400,4402,4404,4406,4408,4410,4412,4415],{"class":2871,"line":2926},[2869,4384,4385],{"class":3258},".nested-2",[2869,4387,3434],{"class":3132},[2869,4389,3584],{"class":3128},[2869,4391,3270],{"class":3132},[2869,4393,4354],{"class":3299},[2869,4395,3521],{"class":3132},[2869,4397,4359],{"class":3128},[2869,4399,3270],{"class":3132},[2869,4401,3300],{"class":3299},[2869,4403,3521],{"class":3132},[2869,4405,4368],{"class":3128},[2869,4407,3270],{"class":3132},[2869,4409,4373],{"class":3299},[2869,4411,3417],{"class":3273},[2869,4413,4414],{"class":3273}," #f97316",[2869,4416,3445],{"class":3132},[2869,4418,4419,4422,4424,4426,4428,4430,4432,4434,4436,4438,4440,4442,4444,4446,4448,4451],{"class":2871,"line":2932},[2869,4420,4421],{"class":3258},".nested-3",[2869,4423,3434],{"class":3132},[2869,4425,3584],{"class":3128},[2869,4427,3270],{"class":3132},[2869,4429,4354],{"class":3299},[2869,4431,3521],{"class":3132},[2869,4433,4359],{"class":3128},[2869,4435,3270],{"class":3132},[2869,4437,3300],{"class":3299},[2869,4439,3521],{"class":3132},[2869,4441,4368],{"class":3128},[2869,4443,3270],{"class":3132},[2869,4445,4373],{"class":3299},[2869,4447,3417],{"class":3273},[2869,4449,4450],{"class":3273}," #eab308",[2869,4452,3445],{"class":3132},[2869,4454,4455,4457,4460,4462,4464,4466,4468,4470,4472,4474,4476,4478,4481,4483],{"class":2871,"line":2938},[2869,4456,4345],{"class":3258},[2869,4458,4459],{"class":3258}," p",[2869,4461,2810],{"class":3132},[2869,4463,4385],{"class":3258},[2869,4465,4459],{"class":3258},[2869,4467,2810],{"class":3132},[2869,4469,4421],{"class":3258},[2869,4471,4459],{"class":3258},[2869,4473,3434],{"class":3132},[2869,4475,4328],{"class":3128},[2869,4477,3270],{"class":3132},[2869,4479,4480],{"class":3299},"0.25rem",[2869,4482,4335],{"class":3299},[2869,4484,3445],{"class":3132},[2869,4486,4487,4490,4492,4494,4496,4498,4500,4502,4504,4506,4508,4510,4512],{"class":2871,"line":2944},[2869,4488,4489],{"class":3258},".divider",[2869,4491,3434],{"class":3132},[2869,4493,4328],{"class":3128},[2869,4495,3270],{"class":3132},[2869,4497,3300],{"class":3299},[2869,4499,4335],{"class":3299},[2869,4501,3521],{"class":3132},[2869,4503,3495],{"class":3128},[2869,4505,3270],{"class":3132},[2869,4507,3414],{"class":3299},[2869,4509,3417],{"class":3273},[2869,4511,3420],{"class":3273},[2869,4513,3445],{"class":3132},[2869,4515,4516,4519,4521,4523,4525,4527,4529,4531],{"class":2871,"line":2950},[2869,4517,4518],{"class":3258},".rem-base",[2869,4520,3434],{"class":3132},[2869,4522,4328],{"class":3128},[2869,4524,3270],{"class":3132},[2869,4526,3460],{"class":3299},[2869,4528,4335],{"class":3299},[2869,4530,4338],{"class":3299},[2869,4532,3445],{"class":3132},[2869,4534,4535,4538,4540,4542,4544,4547,4549,4551,4553,4555,4557,4559,4561,4563,4565,4568],{"class":2871,"line":2956},[2869,4536,4537],{"class":3258},".rem-nested-1",[2869,4539,3434],{"class":3132},[2869,4541,3584],{"class":3128},[2869,4543,3270],{"class":3132},[2869,4545,4546],{"class":3299},"1.2rem",[2869,4548,3521],{"class":3132},[2869,4550,4359],{"class":3128},[2869,4552,3270],{"class":3132},[2869,4554,3300],{"class":3299},[2869,4556,3521],{"class":3132},[2869,4558,4368],{"class":3128},[2869,4560,3270],{"class":3132},[2869,4562,4373],{"class":3299},[2869,4564,3417],{"class":3273},[2869,4566,4567],{"class":3273}," #10b981",[2869,4569,3445],{"class":3132},[2869,4571,4572,4575,4577,4579,4581,4583,4585,4587,4589,4591,4593,4595,4597,4599,4601,4604],{"class":2871,"line":2962},[2869,4573,4574],{"class":3258},".rem-nested-2",[2869,4576,3434],{"class":3132},[2869,4578,3584],{"class":3128},[2869,4580,3270],{"class":3132},[2869,4582,4546],{"class":3299},[2869,4584,3521],{"class":3132},[2869,4586,4359],{"class":3128},[2869,4588,3270],{"class":3132},[2869,4590,3300],{"class":3299},[2869,4592,3521],{"class":3132},[2869,4594,4368],{"class":3128},[2869,4596,3270],{"class":3132},[2869,4598,4373],{"class":3299},[2869,4600,3417],{"class":3273},[2869,4602,4603],{"class":3273}," #06b6d4",[2869,4605,3445],{"class":3132},[2869,4607,4608,4611,4613,4615,4617,4619,4621,4623,4625,4627,4629,4631,4633,4635,4637,4640],{"class":2871,"line":3448},[2869,4609,4610],{"class":3258},".rem-nested-3",[2869,4612,3434],{"class":3132},[2869,4614,3584],{"class":3128},[2869,4616,3270],{"class":3132},[2869,4618,4546],{"class":3299},[2869,4620,3521],{"class":3132},[2869,4622,4359],{"class":3128},[2869,4624,3270],{"class":3132},[2869,4626,3300],{"class":3299},[2869,4628,3521],{"class":3132},[2869,4630,4368],{"class":3128},[2869,4632,3270],{"class":3132},[2869,4634,4373],{"class":3299},[2869,4636,3417],{"class":3273},[2869,4638,4639],{"class":3273}," #6366f1",[2869,4641,3445],{"class":3132},[2869,4643,4644,4646,4648,4650,4652,4654,4656,4658,4660,4662,4664,4666,4668,4670],{"class":2871,"line":3505},[2869,4645,4537],{"class":3258},[2869,4647,4459],{"class":3258},[2869,4649,2810],{"class":3132},[2869,4651,4574],{"class":3258},[2869,4653,4459],{"class":3258},[2869,4655,2810],{"class":3132},[2869,4657,4610],{"class":3258},[2869,4659,4459],{"class":3258},[2869,4661,3434],{"class":3132},[2869,4663,4328],{"class":3128},[2869,4665,3270],{"class":3132},[2869,4667,4480],{"class":3299},[2869,4669,4335],{"class":3299},[2869,4671,3445],{"class":3132},[2804,4673,4674,4675,4677,4678,4680,4681,4684],{},"Зверніть увагу: ",[2799,4676,2813],{}," множиться при кожному вкладенні. Три рівні з ",[2799,4679,4354],{}," — і текст виріс майже вдвічі. Це ",[2977,4682,4683],{},"небажана поведінка"," у більшості сценаріїв.",[2804,4686,4687,4693,4694,3070],{},[2977,4688,4689,4690,4692],{},"Де ",[2799,4691,2813],{}," таки корисний:"," властивості елемента, що мають бути ",[2977,4695,4696],{},"пропорційні до його власного шрифту",[2861,4698,4700],{"className":3249,"code":4699,"language":3251,"meta":2865,"style":2865},".button {\n  font-size: 1rem;\n  padding: 0.6em 1.2em;  /* padding масштабується разом із font-size кнопки */\n  border-radius: 0.3em;\n}\n\n.button--large {\n  font-size: 1.25rem;\n  /* padding і border-radius автоматично стануть більшими через em */\n}\n",[2799,4701,4702,4709,4719,4737,4749,4753,4759,4766,4777,4782],{"__ignoreMap":2865},[2869,4703,4704,4707],{"class":2871,"line":2872},[2869,4705,4706],{"class":3258},".button",[2869,4708,3262],{"class":3132},[2869,4710,4711,4713,4715,4717],{"class":2871,"line":2878},[2869,4712,3348],{"class":3128},[2869,4714,3270],{"class":3132},[2869,4716,3300],{"class":3299},[2869,4718,3277],{"class":3132},[2869,4720,4721,4723,4725,4728,4731,4734],{"class":2871,"line":2884},[2869,4722,3307],{"class":3128},[2869,4724,3270],{"class":3132},[2869,4726,4727],{"class":3299},"0.6em",[2869,4729,4730],{"class":3299}," 1.2em",[2869,4732,4733],{"class":3132},";  ",[2869,4735,4736],{"class":3762},"/* padding масштабується разом із font-size кнопки */\n",[2869,4738,4739,4742,4744,4747],{"class":2871,"line":2890},[2869,4740,4741],{"class":3128},"  border-radius",[2869,4743,3270],{"class":3132},[2869,4745,4746],{"class":3299},"0.3em",[2869,4748,3277],{"class":3132},[2869,4750,4751],{"class":2871,"line":2896},[2869,4752,3360],{"class":3132},[2869,4754,4755],{"class":2871,"line":2902},[2869,4756,4758],{"emptyLinePlaceholder":4757},true,"\n",[2869,4760,4761,4764],{"class":2871,"line":2908},[2869,4762,4763],{"class":3258},".button--large",[2869,4765,3262],{"class":3132},[2869,4767,4768,4770,4772,4775],{"class":2871,"line":2914},[2869,4769,3348],{"class":3128},[2869,4771,3270],{"class":3132},[2869,4773,4774],{"class":3299},"1.25rem",[2869,4776,3277],{"class":3132},[2869,4778,4779],{"class":2871,"line":2920},[2869,4780,4781],{"class":3762},"  /* padding і border-radius автоматично стануть більшими через em */\n",[2869,4783,4784],{"class":2871,"line":2926},[2869,4785,3360],{"class":3132},[2982,4787,4789,4791],{"id":4788},"rem-надійна-альтернатива",[2799,4790,2816],{}," — надійна альтернатива",[2804,4793,4794,4796,4797,3894,4799,3894,4802,4805,4806,4809,4810,4812],{},[2799,4795,2816],{}," (root em) завжди вираховується відносно ",[2799,4798,3584],{},[2977,4800,4801],{},"кореневого елемента",[2799,4803,4804],{},"\u003Chtml>"," (",[2799,4807,4808],{},":root","). За замовчуванням — ",[2799,4811,4282],{},", але користувач може змінити це у налаштуваннях браузера.",[2861,4814,4816],{"className":3249,"code":4815,"language":3251,"meta":2865,"style":2865},":root {\n  font-size: 16px; /* базовий розмір — 1rem = 16px */\n}\n\n/* Або зручний трюк: 1rem = 10px */\n:root {\n  font-size: 62.5%; /* 62.5% від 16px = 10px */\n}\n/* Але! Це ламає налаштування доступності користувача — не рекомендується */\n",[2799,4817,4818,4824,4837,4841,4845,4850,4856,4870,4874],{"__ignoreMap":2865},[2869,4819,4820,4822],{"class":2871,"line":2872},[2869,4821,4808],{"class":3258},[2869,4823,3262],{"class":3132},[2869,4825,4826,4828,4830,4832,4834],{"class":2871,"line":2878},[2869,4827,3348],{"class":3128},[2869,4829,3270],{"class":3132},[2869,4831,4282],{"class":3299},[2869,4833,3521],{"class":3132},[2869,4835,4836],{"class":3762},"/* базовий розмір — 1rem = 16px */\n",[2869,4838,4839],{"class":2871,"line":2884},[2869,4840,3360],{"class":3132},[2869,4842,4843],{"class":2871,"line":2890},[2869,4844,4758],{"emptyLinePlaceholder":4757},[2869,4846,4847],{"class":2871,"line":2896},[2869,4848,4849],{"class":3762},"/* Або зручний трюк: 1rem = 10px */\n",[2869,4851,4852,4854],{"class":2871,"line":2902},[2869,4853,4808],{"class":3258},[2869,4855,3262],{"class":3132},[2869,4857,4858,4860,4862,4865,4867],{"class":2871,"line":2908},[2869,4859,3348],{"class":3128},[2869,4861,3270],{"class":3132},[2869,4863,4864],{"class":3299},"62.5%",[2869,4866,3521],{"class":3132},[2869,4868,4869],{"class":3762},"/* 62.5% від 16px = 10px */\n",[2869,4871,4872],{"class":2871,"line":2914},[2869,4873,3360],{"class":3132},[2869,4875,4876],{"class":2871,"line":2920},[2869,4877,4878],{"class":3762},"/* Але! Це ламає налаштування доступності користувача — не рекомендується */\n",[4880,4881,4882,4883,4886,4887,4890,4891,4893,4894,4897,4898,3905],"warning",{},"Не задавайте ",[2799,4884,4885],{},"font-size: 62.5%"," або ",[2799,4888,4889],{},"font-size: 10px"," на ",[2799,4892,4808],{},". Це скасовує ",[2977,4895,4896],{},"налаштування розміру шрифту"," у браузері, яке використовують люди зі слабким зором. Принцип доступності: ",[2977,4899,4900,4901,3894,4903,4905],{},"базовий ",[2799,4902,3584],{},[2799,4904,4808],{}," має бути відносним або не задаватися взагалі",[2804,4907,4908,3894,4911,4913,4914,2810,4916,2810,4919,4921,4922,4924,4925,4913,4927,4921,4929,4931],{},[2977,4909,4910],{},"Правило великого пальця:",[2799,4912,2816],{}," для ",[2799,4915,3584],{},[2799,4917,4918],{},"spacing",[2799,4920,3513],{},"/",[2799,4923,3524],{}," компонентів; ",[2799,4926,2813],{},[2799,4928,3593],{},[2799,4930,4328],{}," всередині компонента, що мають бути пропорційні до шрифту.",[2982,4933,4935,4937],{"id":4934},"ch-ширина-символу-0",[2799,4936,2837],{}," — ширина символу «0»",[2804,4939,4940,4943,4944,4946],{},[2799,4941,4942],{},"1ch"," = ширина символу нуля (",[2799,4945,3460],{},") у поточному шрифті. Ідеальна одиниця для обмеження ширини текстових блоків:",[2861,4948,4950],{"className":3249,"code":4949,"language":3251,"meta":2865,"style":2865},"/* Класичний патерн читабельного тексту */\n.article-body {\n  max-width: 65ch; /* ~65 символів у рядку — оптимум для читання */\n  margin-inline: auto;\n}\n",[2799,4951,4952,4957,4964,4979,4991],{"__ignoreMap":2865},[2869,4953,4954],{"class":2871,"line":2872},[2869,4955,4956],{"class":3762},"/* Класичний патерн читабельного тексту */\n",[2869,4958,4959,4962],{"class":2871,"line":2878},[2869,4960,4961],{"class":3258},".article-body",[2869,4963,3262],{"class":3132},[2869,4965,4966,4969,4971,4974,4976],{"class":2871,"line":2884},[2869,4967,4968],{"class":3128},"  max-width",[2869,4970,3270],{"class":3132},[2869,4972,4973],{"class":3299},"65ch",[2869,4975,3521],{"class":3132},[2869,4977,4978],{"class":3762},"/* ~65 символів у рядку — оптимум для читання */\n",[2869,4980,4981,4984,4986,4989],{"class":2871,"line":2890},[2869,4982,4983],{"class":3128},"  margin-inline",[2869,4985,3270],{"class":3132},[2869,4987,4988],{"class":3273},"auto",[2869,4990,3277],{"class":3132},[2869,4992,4993],{"class":2871,"line":2896},[2869,4994,3360],{"class":3132},[3107,4996,4997,5196],{},[2861,4998,5000],{"className":3111,"code":4999,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"ch-demo\">\n  \u003Cdiv class=\"narrow-col\">\n    \u003Ch3>max-width: 45ch\u003C/h3>\n    \u003Cp>Вузька колонка — гарна для коротких нотаток або коментарів у бічній панелі.\u003C/p>\n  \u003C/div>\n  \u003Cdiv class=\"reading-col\">\n    \u003Ch3>max-width: 65ch\u003C/h3>\n    \u003Cp>Оптимальна ширина для читання довгих текстів. Дослідження показують, що 50–75 символів у рядку — ідеальна довжина для комфортного читання.\u003C/p>\n  \u003C/div>\n  \u003Cdiv class=\"wide-col\">\n    \u003Ch3>max-width: 90ch\u003C/h3>\n    \u003Cp>Широка колонка — підходить для таблиць, коду або двоколонкового верстання всередині.\u003C/p>\n  \u003C/div>\n\u003C/div>\n",[2799,5001,5002,5017,5032,5049,5066,5074,5089,5106,5123,5131,5146,5163,5180,5188],{"__ignoreMap":2865},[2869,5003,5004,5006,5008,5010,5012,5015],{"class":2871,"line":2872},[2869,5005,3121],{"class":3120},[2869,5007,3125],{"class":3124},[2869,5009,3129],{"class":3128},[2869,5011,3133],{"class":3132},[2869,5013,5014],{"class":3136},"\"ch-demo\"",[2869,5016,3140],{"class":3120},[2869,5018,5019,5021,5023,5025,5027,5030],{"class":2871,"line":2878},[2869,5020,3145],{"class":3120},[2869,5022,3125],{"class":3124},[2869,5024,3129],{"class":3128},[2869,5026,3133],{"class":3132},[2869,5028,5029],{"class":3136},"\"narrow-col\"",[2869,5031,3140],{"class":3120},[2869,5033,5034,5036,5038,5040,5043,5045,5047],{"class":2871,"line":2884},[2869,5035,3971],{"class":3120},[2869,5037,2982],{"class":3124},[2869,5039,3157],{"class":3120},[2869,5041,5042],{"class":3132},"max-width: 45ch",[2869,5044,3162],{"class":3120},[2869,5046,2982],{"class":3124},[2869,5048,3140],{"class":3120},[2869,5050,5051,5053,5055,5057,5060,5062,5064],{"class":2871,"line":2890},[2869,5052,3971],{"class":3120},[2869,5054,2804],{"class":3124},[2869,5056,3157],{"class":3120},[2869,5058,5059],{"class":3132},"Вузька колонка — гарна для коротких нотаток або коментарів у бічній панелі.",[2869,5061,3162],{"class":3120},[2869,5063,2804],{"class":3124},[2869,5065,3140],{"class":3120},[2869,5067,5068,5070,5072],{"class":2871,"line":2896},[2869,5069,4073],{"class":3120},[2869,5071,3125],{"class":3124},[2869,5073,3140],{"class":3120},[2869,5075,5076,5078,5080,5082,5084,5087],{"class":2871,"line":2902},[2869,5077,3145],{"class":3120},[2869,5079,3125],{"class":3124},[2869,5081,3129],{"class":3128},[2869,5083,3133],{"class":3132},[2869,5085,5086],{"class":3136},"\"reading-col\"",[2869,5088,3140],{"class":3120},[2869,5090,5091,5093,5095,5097,5100,5102,5104],{"class":2871,"line":2908},[2869,5092,3971],{"class":3120},[2869,5094,2982],{"class":3124},[2869,5096,3157],{"class":3120},[2869,5098,5099],{"class":3132},"max-width: 65ch",[2869,5101,3162],{"class":3120},[2869,5103,2982],{"class":3124},[2869,5105,3140],{"class":3120},[2869,5107,5108,5110,5112,5114,5117,5119,5121],{"class":2871,"line":2914},[2869,5109,3971],{"class":3120},[2869,5111,2804],{"class":3124},[2869,5113,3157],{"class":3120},[2869,5115,5116],{"class":3132},"Оптимальна ширина для читання довгих текстів. Дослідження показують, що 50–75 символів у рядку — ідеальна довжина для комфортного читання.",[2869,5118,3162],{"class":3120},[2869,5120,2804],{"class":3124},[2869,5122,3140],{"class":3120},[2869,5124,5125,5127,5129],{"class":2871,"line":2920},[2869,5126,4073],{"class":3120},[2869,5128,3125],{"class":3124},[2869,5130,3140],{"class":3120},[2869,5132,5133,5135,5137,5139,5141,5144],{"class":2871,"line":2926},[2869,5134,3145],{"class":3120},[2869,5136,3125],{"class":3124},[2869,5138,3129],{"class":3128},[2869,5140,3133],{"class":3132},[2869,5142,5143],{"class":3136},"\"wide-col\"",[2869,5145,3140],{"class":3120},[2869,5147,5148,5150,5152,5154,5157,5159,5161],{"class":2871,"line":2932},[2869,5149,3971],{"class":3120},[2869,5151,2982],{"class":3124},[2869,5153,3157],{"class":3120},[2869,5155,5156],{"class":3132},"max-width: 90ch",[2869,5158,3162],{"class":3120},[2869,5160,2982],{"class":3124},[2869,5162,3140],{"class":3120},[2869,5164,5165,5167,5169,5171,5174,5176,5178],{"class":2871,"line":2938},[2869,5166,3971],{"class":3120},[2869,5168,2804],{"class":3124},[2869,5170,3157],{"class":3120},[2869,5172,5173],{"class":3132},"Широка колонка — підходить для таблиць, коду або двоколонкового верстання всередині.",[2869,5175,3162],{"class":3120},[2869,5177,2804],{"class":3124},[2869,5179,3140],{"class":3120},[2869,5181,5182,5184,5186],{"class":2871,"line":2944},[2869,5183,4073],{"class":3120},[2869,5185,3125],{"class":3124},[2869,5187,3140],{"class":3120},[2869,5189,5190,5192,5194],{"class":2871,"line":2950},[2869,5191,3162],{"class":3120},[2869,5193,3125],{"class":3124},[2869,5195,3140],{"class":3120},[2861,5197,5199],{"className":3249,"code":5198,"language":3251,"meta":2865,"style":2865},".ch-demo {\n  display: flex;\n  flex-direction: column;\n  gap: 1rem;\n  padding: 1.25rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.9rem;\n  color: #1e293b;\n}\n.narrow-col, .reading-col, .wide-col {\n  background: white;\n  border-radius: 8px;\n  padding: 1rem;\n  border-left: 4px solid;\n}\n.narrow-col  { max-width: 45ch; border-color: #ec4899; }\n.reading-col { max-width: 65ch; border-color: #10b981; }\n.wide-col    { max-width: 90ch; border-color: #6366f1; }\nh3 { margin: 0 0 0.5rem; font-size: 0.85rem; opacity: 0.6; }\np  { margin: 0; line-height: 1.6; }\n",[2799,5200,5201,5208,5218,5230,5240,5250,5260,5274,5285,5295,5299,5316,5326,5336,5346,5359,5363,5390,5413,5437,5473],{"__ignoreMap":2865},[2869,5202,5203,5206],{"class":2871,"line":2872},[2869,5204,5205],{"class":3258},".ch-demo",[2869,5207,3262],{"class":3132},[2869,5209,5210,5212,5214,5216],{"class":2871,"line":2878},[2869,5211,3267],{"class":3128},[2869,5213,3270],{"class":3132},[2869,5215,3274],{"class":3273},[2869,5217,3277],{"class":3132},[2869,5219,5220,5223,5225,5228],{"class":2871,"line":2884},[2869,5221,5222],{"class":3128},"  flex-direction",[2869,5224,3270],{"class":3132},[2869,5226,5227],{"class":3273},"column",[2869,5229,3277],{"class":3132},[2869,5231,5232,5234,5236,5238],{"class":2871,"line":2890},[2869,5233,3294],{"class":3128},[2869,5235,3270],{"class":3132},[2869,5237,3300],{"class":3299},[2869,5239,3277],{"class":3132},[2869,5241,5242,5244,5246,5248],{"class":2871,"line":2896},[2869,5243,3307],{"class":3128},[2869,5245,3270],{"class":3132},[2869,5247,4774],{"class":3299},[2869,5249,3277],{"class":3132},[2869,5251,5252,5254,5256,5258],{"class":2871,"line":2902},[2869,5253,3319],{"class":3128},[2869,5255,3270],{"class":3132},[2869,5257,3324],{"class":3273},[2869,5259,3277],{"class":3132},[2869,5261,5262,5264,5266,5268,5270,5272],{"class":2871,"line":2908},[2869,5263,3331],{"class":3128},[2869,5265,3270],{"class":3132},[2869,5267,3336],{"class":3273},[2869,5269,2810],{"class":3132},[2869,5271,3341],{"class":3273},[2869,5273,3277],{"class":3132},[2869,5275,5276,5278,5280,5283],{"class":2871,"line":2914},[2869,5277,3348],{"class":3128},[2869,5279,3270],{"class":3132},[2869,5281,5282],{"class":3299},"0.9rem",[2869,5284,3277],{"class":3132},[2869,5286,5287,5289,5291,5293],{"class":2871,"line":2920},[2869,5288,3397],{"class":3128},[2869,5290,3270],{"class":3132},[2869,5292,3402],{"class":3273},[2869,5294,3277],{"class":3132},[2869,5296,5297],{"class":2871,"line":2926},[2869,5298,3360],{"class":3132},[2869,5300,5301,5304,5306,5309,5311,5314],{"class":2871,"line":2932},[2869,5302,5303],{"class":3258},".narrow-col",[2869,5305,2810],{"class":3132},[2869,5307,5308],{"class":3258},".reading-col",[2869,5310,2810],{"class":3132},[2869,5312,5313],{"class":3258},".wide-col",[2869,5315,3262],{"class":3132},[2869,5317,5318,5320,5322,5324],{"class":2871,"line":2938},[2869,5319,3319],{"class":3128},[2869,5321,3270],{"class":3132},[2869,5323,3390],{"class":3273},[2869,5325,3277],{"class":3132},[2869,5327,5328,5330,5332,5334],{"class":2871,"line":2944},[2869,5329,4741],{"class":3128},[2869,5331,3270],{"class":3132},[2869,5333,3442],{"class":3299},[2869,5335,3277],{"class":3132},[2869,5337,5338,5340,5342,5344],{"class":2871,"line":2950},[2869,5339,3307],{"class":3128},[2869,5341,3270],{"class":3132},[2869,5343,3300],{"class":3299},[2869,5345,3277],{"class":3132},[2869,5347,5348,5351,5353,5355,5357],{"class":2871,"line":2956},[2869,5349,5350],{"class":3128},"  border-left",[2869,5352,3270],{"class":3132},[2869,5354,3614],{"class":3299},[2869,5356,3417],{"class":3273},[2869,5358,3277],{"class":3132},[2869,5360,5361],{"class":2871,"line":2962},[2869,5362,3360],{"class":3132},[2869,5364,5365,5367,5370,5373,5375,5378,5380,5383,5385,5388],{"class":2871,"line":3448},[2869,5366,5303],{"class":3258},[2869,5368,5369],{"class":3132},"  { ",[2869,5371,5372],{"class":3128},"max-width",[2869,5374,3270],{"class":3132},[2869,5376,5377],{"class":3299},"45ch",[2869,5379,3521],{"class":3132},[2869,5381,5382],{"class":3128},"border-color",[2869,5384,3270],{"class":3132},[2869,5386,5387],{"class":3273},"#ec4899",[2869,5389,3445],{"class":3132},[2869,5391,5392,5394,5396,5398,5400,5402,5404,5406,5408,5411],{"class":2871,"line":3505},[2869,5393,5308],{"class":3258},[2869,5395,3434],{"class":3132},[2869,5397,5372],{"class":3128},[2869,5399,3270],{"class":3132},[2869,5401,4973],{"class":3299},[2869,5403,3521],{"class":3132},[2869,5405,5382],{"class":3128},[2869,5407,3270],{"class":3132},[2869,5409,5410],{"class":3273},"#10b981",[2869,5412,3445],{"class":3132},[2869,5414,5415,5417,5420,5422,5424,5427,5429,5431,5433,5435],{"class":2871,"line":3543},[2869,5416,5313],{"class":3258},[2869,5418,5419],{"class":3132},"    { ",[2869,5421,5372],{"class":3128},[2869,5423,3270],{"class":3132},[2869,5425,5426],{"class":3299},"90ch",[2869,5428,3521],{"class":3132},[2869,5430,5382],{"class":3128},[2869,5432,3270],{"class":3132},[2869,5434,3538],{"class":3273},[2869,5436,3445],{"class":3132},[2869,5438,5439,5441,5443,5445,5447,5449,5451,5453,5455,5457,5459,5461,5463,5466,5468,5471],{"class":2871,"line":3573},[2869,5440,2982],{"class":3258},[2869,5442,3434],{"class":3132},[2869,5444,4328],{"class":3128},[2869,5446,3270],{"class":3132},[2869,5448,3460],{"class":3299},[2869,5450,4335],{"class":3299},[2869,5452,4338],{"class":3299},[2869,5454,3521],{"class":3132},[2869,5456,3584],{"class":3128},[2869,5458,3270],{"class":3132},[2869,5460,3353],{"class":3299},[2869,5462,3521],{"class":3132},[2869,5464,5465],{"class":3128},"opacity",[2869,5467,3270],{"class":3132},[2869,5469,5470],{"class":3299},"0.6",[2869,5472,3445],{"class":3132},[2869,5474,5475,5477,5479,5481,5483,5485,5487,5490,5492,5495],{"class":2871,"line":3619},[2869,5476,2804],{"class":3258},[2869,5478,5369],{"class":3132},[2869,5480,4328],{"class":3128},[2869,5482,3270],{"class":3132},[2869,5484,3460],{"class":3299},[2869,5486,3521],{"class":3132},[2869,5488,5489],{"class":3128},"line-height",[2869,5491,3270],{"class":3132},[2869,5493,5494],{"class":3299},"1.6",[2869,5496,3445],{"class":3132},[2982,5498,5500,2810,5503,2810,5506,2810,5509,5512],{"id":5499},"ex-lh-rlh-cap-спеціалізовані-шрифтові-одиниці",[2799,5501,5502],{},"ex",[2799,5504,5505],{},"lh",[2799,5507,5508],{},"rlh",[2799,5510,5511],{},"cap"," — спеціалізовані шрифтові одиниці",[3671,5514,5515,5527],{},[3674,5516,5517],{},[3677,5518,5519,5521,5524],{},[3680,5520,3682],{},[3680,5522,5523],{},"Значення",[3680,5525,5526],{},"Типове застосування",[3690,5528,5529,5541,5553,5568],{},[3677,5530,5531,5535,5538],{},[3695,5532,5533],{},[2799,5534,5502],{},[3695,5536,5537],{},"Висота рядкової літери (≈ висота «x»)",[3695,5539,5540],{},"Вирівнювання дрібних деталей",[3677,5542,5543,5547,5550],{},[3695,5544,5545],{},[2799,5546,5511],{},[3695,5548,5549],{},"Висота заголовної літери",[3695,5551,5552],{},"Орнаменти, декоративні елементи",[3677,5554,5555,5559,5565],{},[3695,5556,5557],{},[2799,5558,5505],{},[3695,5560,5561,5562,5564],{},"Висота рядка (",[2799,5563,5489],{},") елемента",[3695,5566,5567],{},"Відступи кратні висоті рядка",[3677,5569,5570,5574,5577],{},[3695,5571,5572],{},[2799,5573,5508],{},[3695,5575,5576],{},"Висота рядка кореневого елемента",[3695,5578,5579],{},"Вертикальний ритм",[2861,5581,5583],{"className":3249,"code":5582,"language":3251,"meta":2865,"style":2865},"/* Практичний приклад: drop cap (буквиця) */\n.dropcap::first-letter {\n  font-size: 3cap; /* Висота 3 заголовних літер */\n  float: left;\n  margin-right: 0.1em;\n  line-height: 1;\n  font-weight: bold;\n  color: #6366f1;\n}\n\n/* Відступи між секціями кратні висоті рядка */\n.section + .section {\n  margin-top: 2lh;\n}\n",[2799,5584,5585,5590,5597,5612,5624,5636,5648,5660,5670,5674,5678,5683,5695,5708],{"__ignoreMap":2865},[2869,5586,5587],{"class":2871,"line":2872},[2869,5588,5589],{"class":3762},"/* Практичний приклад: drop cap (буквиця) */\n",[2869,5591,5592,5595],{"class":2871,"line":2878},[2869,5593,5594],{"class":3258},".dropcap::first-letter",[2869,5596,3262],{"class":3132},[2869,5598,5599,5601,5603,5606,5609],{"class":2871,"line":2884},[2869,5600,3348],{"class":3128},[2869,5602,3270],{"class":3132},[2869,5604,5605],{"class":3299},"3",[2869,5607,5608],{"class":3132},"cap; ",[2869,5610,5611],{"class":3762},"/* Висота 3 заголовних літер */\n",[2869,5613,5614,5617,5619,5622],{"class":2871,"line":2890},[2869,5615,5616],{"class":3128},"  float",[2869,5618,3270],{"class":3132},[2869,5620,5621],{"class":3273},"left",[2869,5623,3277],{"class":3132},[2869,5625,5626,5629,5631,5634],{"class":2871,"line":2896},[2869,5627,5628],{"class":3128},"  margin-right",[2869,5630,3270],{"class":3132},[2869,5632,5633],{"class":3299},"0.1em",[2869,5635,3277],{"class":3132},[2869,5637,5638,5641,5643,5646],{"class":2871,"line":2902},[2869,5639,5640],{"class":3128},"  line-height",[2869,5642,3270],{"class":3132},[2869,5644,5645],{"class":3299},"1",[2869,5647,3277],{"class":3132},[2869,5649,5650,5653,5655,5658],{"class":2871,"line":2908},[2869,5651,5652],{"class":3128},"  font-weight",[2869,5654,3270],{"class":3132},[2869,5656,5657],{"class":3273},"bold",[2869,5659,3277],{"class":3132},[2869,5661,5662,5664,5666,5668],{"class":2871,"line":2914},[2869,5663,3397],{"class":3128},[2869,5665,3270],{"class":3132},[2869,5667,3538],{"class":3273},[2869,5669,3277],{"class":3132},[2869,5671,5672],{"class":2871,"line":2920},[2869,5673,3360],{"class":3132},[2869,5675,5676],{"class":2871,"line":2926},[2869,5677,4758],{"emptyLinePlaceholder":4757},[2869,5679,5680],{"class":2871,"line":2932},[2869,5681,5682],{"class":3762},"/* Відступи між секціями кратні висоті рядка */\n",[2869,5684,5685,5688,5691,5693],{"class":2871,"line":2938},[2869,5686,5687],{"class":3258},".section",[2869,5689,5690],{"class":3132}," + ",[2869,5692,5687],{"class":3258},[2869,5694,3262],{"class":3132},[2869,5696,5697,5700,5702,5705],{"class":2871,"line":2944},[2869,5698,5699],{"class":3128},"  margin-top",[2869,5701,3270],{"class":3132},[2869,5703,5704],{"class":3299},"2",[2869,5706,5707],{"class":3132},"lh;\n",[2869,5709,5710],{"class":2871,"line":2950},[2869,5711,3360],{"class":3132},[2967,5713],{},[2794,5715,5717],{"id":5716},"viewport-відносні-одиниці","Viewport-відносні одиниці",[2804,5719,5720],{},"Viewport — це видима область браузерного вікна. Viewport-одиниці дозволяють задавати розміри відносно цієї області.",[2982,5722,5724,5726,5727,5729],{"id":5723},"vw-та-vh-базові-viewport-одиниці",[2799,5725,2819],{}," та ",[2799,5728,2822],{}," — базові viewport-одиниці",[3072,5731,5732,5738,5744],{},[3075,5733,5734,5737],{},[2799,5735,5736],{},"1vw"," = 1% ширини viewport",[3075,5739,5740,5743],{},[2799,5741,5742],{},"1vh"," = 1% висоти viewport",[3075,5745,5746,5749,5750,5753],{},[2799,5747,5748],{},"100vw"," = повна ширина, ",[2799,5751,5752],{},"100vh"," = повна висота",[3107,5755,5756,5912],{},[2861,5757,5759],{"className":3111,"code":5758,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"vp-demo\">\n  \u003Cdiv class=\"hero-section\">\n    \u003Ch2>Hero-секція\u003C/h2>\n    \u003Cp>height: 40vh — займає 40% висоти viewport\u003C/p>\n    \u003Cdiv class=\"vw-bar\">Цей елемент: width: 60vw\u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"fluid-type-demo\">\n    \u003Cp class=\"fluid-text\">font-size: 3vw — масштабується з шириною вікна\u003C/p>\n  \u003C/div>\n\u003C/div>\n",[2799,5760,5761,5776,5791,5808,5825,5849,5857,5872,5896,5904],{"__ignoreMap":2865},[2869,5762,5763,5765,5767,5769,5771,5774],{"class":2871,"line":2872},[2869,5764,3121],{"class":3120},[2869,5766,3125],{"class":3124},[2869,5768,3129],{"class":3128},[2869,5770,3133],{"class":3132},[2869,5772,5773],{"class":3136},"\"vp-demo\"",[2869,5775,3140],{"class":3120},[2869,5777,5778,5780,5782,5784,5786,5789],{"class":2871,"line":2878},[2869,5779,3145],{"class":3120},[2869,5781,3125],{"class":3124},[2869,5783,3129],{"class":3128},[2869,5785,3133],{"class":3132},[2869,5787,5788],{"class":3136},"\"hero-section\"",[2869,5790,3140],{"class":3120},[2869,5792,5793,5795,5797,5799,5802,5804,5806],{"class":2871,"line":2884},[2869,5794,3971],{"class":3120},[2869,5796,2794],{"class":3124},[2869,5798,3157],{"class":3120},[2869,5800,5801],{"class":3132},"Hero-секція",[2869,5803,3162],{"class":3120},[2869,5805,2794],{"class":3124},[2869,5807,3140],{"class":3120},[2869,5809,5810,5812,5814,5816,5819,5821,5823],{"class":2871,"line":2890},[2869,5811,3971],{"class":3120},[2869,5813,2804],{"class":3124},[2869,5815,3157],{"class":3120},[2869,5817,5818],{"class":3132},"height: 40vh — займає 40% висоти viewport",[2869,5820,3162],{"class":3120},[2869,5822,2804],{"class":3124},[2869,5824,3140],{"class":3120},[2869,5826,5827,5829,5831,5833,5835,5838,5840,5843,5845,5847],{"class":2871,"line":2896},[2869,5828,3971],{"class":3120},[2869,5830,3125],{"class":3124},[2869,5832,3129],{"class":3128},[2869,5834,3133],{"class":3132},[2869,5836,5837],{"class":3136},"\"vw-bar\"",[2869,5839,3157],{"class":3120},[2869,5841,5842],{"class":3132},"Цей елемент: width: 60vw",[2869,5844,3162],{"class":3120},[2869,5846,3125],{"class":3124},[2869,5848,3140],{"class":3120},[2869,5850,5851,5853,5855],{"class":2871,"line":2902},[2869,5852,4073],{"class":3120},[2869,5854,3125],{"class":3124},[2869,5856,3140],{"class":3120},[2869,5858,5859,5861,5863,5865,5867,5870],{"class":2871,"line":2908},[2869,5860,3145],{"class":3120},[2869,5862,3125],{"class":3124},[2869,5864,3129],{"class":3128},[2869,5866,3133],{"class":3132},[2869,5868,5869],{"class":3136},"\"fluid-type-demo\"",[2869,5871,3140],{"class":3120},[2869,5873,5874,5876,5878,5880,5882,5885,5887,5890,5892,5894],{"class":2871,"line":2914},[2869,5875,3971],{"class":3120},[2869,5877,2804],{"class":3124},[2869,5879,3129],{"class":3128},[2869,5881,3133],{"class":3132},[2869,5883,5884],{"class":3136},"\"fluid-text\"",[2869,5886,3157],{"class":3120},[2869,5888,5889],{"class":3132},"font-size: 3vw — масштабується з шириною вікна",[2869,5891,3162],{"class":3120},[2869,5893,2804],{"class":3124},[2869,5895,3140],{"class":3120},[2869,5897,5898,5900,5902],{"class":2871,"line":2920},[2869,5899,4073],{"class":3120},[2869,5901,3125],{"class":3124},[2869,5903,3140],{"class":3120},[2869,5905,5906,5908,5910],{"class":2871,"line":2926},[2869,5907,3162],{"class":3120},[2869,5909,3125],{"class":3124},[2869,5911,3140],{"class":3120},[2861,5913,5915],{"className":3249,"code":5914,"language":3251,"meta":2865,"style":2865},".vp-demo {\n  font-family: system-ui, sans-serif;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.75rem;\n  padding: 1rem;\n  background: #f1f5f9;\n}\n.hero-section {\n  height: 40vh;\n  background: linear-gradient(135deg, #6366f1, #8b5cf6);\n  border-radius: 10px;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  gap: 0.5rem;\n  color: white;\n  text-align: center;\n  padding: 1rem;\n}\n.hero-section h2 { margin: 0; font-size: 1.5rem; }\n.hero-section p { margin: 0; font-size: 0.85rem; opacity: 0.8; }\n.vw-bar {\n  width: 60vw;\n  max-width: 100%;\n  background: rgba(255,255,255,0.2);\n  border-radius: 6px;\n  padding: 0.4rem 0.75rem;\n  font-size: 0.8rem;\n  text-align: center;\n}\n.fluid-type-demo {\n  background: white;\n  border-radius: 8px;\n  padding: 1rem;\n  border: 1px solid #e2e8f0;\n}\n.fluid-text {\n  margin: 0;\n  font-size: clamp(0.875rem, 3vw, 1.5rem);\n  color: #6366f1;\n  font-weight: 600;\n}\n",[2799,5916,5917,5924,5938,5948,5958,5968,5978,5988,5999,6003,6010,6022,6048,6059,6069,6079,6090,6101,6112,6122,6133,6143,6147,6172,6206,6214,6227,6239,6269,6281,6296,6308,6319,6324,6332,6343,6354,6365,6380,6385,6393,6405,6431,6442,6454],{"__ignoreMap":2865},[2869,5918,5919,5922],{"class":2871,"line":2872},[2869,5920,5921],{"class":3258},".vp-demo",[2869,5923,3262],{"class":3132},[2869,5925,5926,5928,5930,5932,5934,5936],{"class":2871,"line":2878},[2869,5927,3331],{"class":3128},[2869,5929,3270],{"class":3132},[2869,5931,3336],{"class":3273},[2869,5933,2810],{"class":3132},[2869,5935,3341],{"class":3273},[2869,5937,3277],{"class":3132},[2869,5939,5940,5942,5944,5946],{"class":2871,"line":2884},[2869,5941,3397],{"class":3128},[2869,5943,3270],{"class":3132},[2869,5945,3402],{"class":3273},[2869,5947,3277],{"class":3132},[2869,5949,5950,5952,5954,5956],{"class":2871,"line":2890},[2869,5951,3267],{"class":3128},[2869,5953,3270],{"class":3132},[2869,5955,3274],{"class":3273},[2869,5957,3277],{"class":3132},[2869,5959,5960,5962,5964,5966],{"class":2871,"line":2896},[2869,5961,5222],{"class":3128},[2869,5963,3270],{"class":3132},[2869,5965,5227],{"class":3273},[2869,5967,3277],{"class":3132},[2869,5969,5970,5972,5974,5976],{"class":2871,"line":2902},[2869,5971,3294],{"class":3128},[2869,5973,3270],{"class":3132},[2869,5975,3376],{"class":3299},[2869,5977,3277],{"class":3132},[2869,5979,5980,5982,5984,5986],{"class":2871,"line":2908},[2869,5981,3307],{"class":3128},[2869,5983,3270],{"class":3132},[2869,5985,3300],{"class":3299},[2869,5987,3277],{"class":3132},[2869,5989,5990,5992,5994,5997],{"class":2871,"line":2914},[2869,5991,3319],{"class":3128},[2869,5993,3270],{"class":3132},[2869,5995,5996],{"class":3273},"#f1f5f9",[2869,5998,3277],{"class":3132},[2869,6000,6001],{"class":2871,"line":2920},[2869,6002,3360],{"class":3132},[2869,6004,6005,6008],{"class":2871,"line":2926},[2869,6006,6007],{"class":3258},".hero-section",[2869,6009,3262],{"class":3132},[2869,6011,6012,6015,6017,6020],{"class":2871,"line":2932},[2869,6013,6014],{"class":3128},"  height",[2869,6016,3270],{"class":3132},[2869,6018,6019],{"class":3299},"40vh",[2869,6021,3277],{"class":3132},[2869,6023,6024,6026,6028,6031,6033,6036,6038,6040,6042,6045],{"class":2871,"line":2938},[2869,6025,3319],{"class":3128},[2869,6027,3270],{"class":3132},[2869,6029,6030],{"class":3469},"linear-gradient",[2869,6032,3473],{"class":3132},[2869,6034,6035],{"class":3299},"135deg",[2869,6037,2810],{"class":3132},[2869,6039,3538],{"class":3273},[2869,6041,2810],{"class":3132},[2869,6043,6044],{"class":3273},"#8b5cf6",[2869,6046,6047],{"class":3132},");\n",[2869,6049,6050,6052,6054,6057],{"class":2871,"line":2944},[2869,6051,4741],{"class":3128},[2869,6053,3270],{"class":3132},[2869,6055,6056],{"class":3299},"10px",[2869,6058,3277],{"class":3132},[2869,6060,6061,6063,6065,6067],{"class":2871,"line":2950},[2869,6062,3267],{"class":3128},[2869,6064,3270],{"class":3132},[2869,6066,3274],{"class":3273},[2869,6068,3277],{"class":3132},[2869,6070,6071,6073,6075,6077],{"class":2871,"line":2956},[2869,6072,5222],{"class":3128},[2869,6074,3270],{"class":3132},[2869,6076,5227],{"class":3273},[2869,6078,3277],{"class":3132},[2869,6080,6081,6084,6086,6088],{"class":2871,"line":2962},[2869,6082,6083],{"class":3128},"  align-items",[2869,6085,3270],{"class":3132},[2869,6087,3559],{"class":3273},[2869,6089,3277],{"class":3132},[2869,6091,6092,6095,6097,6099],{"class":2871,"line":3448},[2869,6093,6094],{"class":3128},"  justify-content",[2869,6096,3270],{"class":3132},[2869,6098,3559],{"class":3273},[2869,6100,3277],{"class":3132},[2869,6102,6103,6105,6107,6110],{"class":2871,"line":3505},[2869,6104,3294],{"class":3128},[2869,6106,3270],{"class":3132},[2869,6108,6109],{"class":3299},"0.5rem",[2869,6111,3277],{"class":3132},[2869,6113,6114,6116,6118,6120],{"class":2871,"line":3543},[2869,6115,3397],{"class":3128},[2869,6117,3270],{"class":3132},[2869,6119,3390],{"class":3273},[2869,6121,3277],{"class":3132},[2869,6123,6124,6127,6129,6131],{"class":2871,"line":3573},[2869,6125,6126],{"class":3128},"  text-align",[2869,6128,3270],{"class":3132},[2869,6130,3559],{"class":3273},[2869,6132,3277],{"class":3132},[2869,6134,6135,6137,6139,6141],{"class":2871,"line":3619},[2869,6136,3307],{"class":3128},[2869,6138,3270],{"class":3132},[2869,6140,3300],{"class":3299},[2869,6142,3277],{"class":3132},[2869,6144,6145],{"class":2871,"line":4232},[2869,6146,3360],{"class":3132},[2869,6148,6149,6151,6154,6156,6158,6160,6162,6164,6166,6168,6170],{"class":2871,"line":4241},[2869,6150,6007],{"class":3258},[2869,6152,6153],{"class":3258}," h2",[2869,6155,3434],{"class":3132},[2869,6157,4328],{"class":3128},[2869,6159,3270],{"class":3132},[2869,6161,3460],{"class":3299},[2869,6163,3521],{"class":3132},[2869,6165,3584],{"class":3128},[2869,6167,3270],{"class":3132},[2869,6169,3312],{"class":3299},[2869,6171,3445],{"class":3132},[2869,6173,6175,6177,6179,6181,6183,6185,6187,6189,6191,6193,6195,6197,6199,6201,6204],{"class":2871,"line":6174},24,[2869,6176,6007],{"class":3258},[2869,6178,4459],{"class":3258},[2869,6180,3434],{"class":3132},[2869,6182,4328],{"class":3128},[2869,6184,3270],{"class":3132},[2869,6186,3460],{"class":3299},[2869,6188,3521],{"class":3132},[2869,6190,3584],{"class":3128},[2869,6192,3270],{"class":3132},[2869,6194,3353],{"class":3299},[2869,6196,3521],{"class":3132},[2869,6198,5465],{"class":3128},[2869,6200,3270],{"class":3132},[2869,6202,6203],{"class":3299},"0.8",[2869,6205,3445],{"class":3132},[2869,6207,6209,6212],{"class":2871,"line":6208},25,[2869,6210,6211],{"class":3258},".vw-bar",[2869,6213,3262],{"class":3132},[2869,6215,6217,6220,6222,6225],{"class":2871,"line":6216},26,[2869,6218,6219],{"class":3128},"  width",[2869,6221,3270],{"class":3132},[2869,6223,6224],{"class":3299},"60vw",[2869,6226,3277],{"class":3132},[2869,6228,6230,6232,6234,6237],{"class":2871,"line":6229},27,[2869,6231,4968],{"class":3128},[2869,6233,3270],{"class":3132},[2869,6235,6236],{"class":3299},"100%",[2869,6238,3277],{"class":3132},[2869,6240,6242,6244,6246,6249,6251,6254,6256,6258,6260,6262,6264,6267],{"class":2871,"line":6241},28,[2869,6243,3319],{"class":3128},[2869,6245,3270],{"class":3132},[2869,6247,6248],{"class":3469},"rgba",[2869,6250,3473],{"class":3132},[2869,6252,6253],{"class":3299},"255",[2869,6255,3478],{"class":3132},[2869,6257,6253],{"class":3299},[2869,6259,3478],{"class":3132},[2869,6261,6253],{"class":3299},[2869,6263,3478],{"class":3132},[2869,6265,6266],{"class":3299},"0.2",[2869,6268,6047],{"class":3132},[2869,6270,6272,6274,6276,6279],{"class":2871,"line":6271},29,[2869,6273,4741],{"class":3128},[2869,6275,3270],{"class":3132},[2869,6277,6278],{"class":3299},"6px",[2869,6280,3277],{"class":3132},[2869,6282,6284,6286,6288,6291,6294],{"class":2871,"line":6283},30,[2869,6285,3307],{"class":3128},[2869,6287,3270],{"class":3132},[2869,6289,6290],{"class":3299},"0.4rem",[2869,6292,6293],{"class":3299}," 0.75rem",[2869,6295,3277],{"class":3132},[2869,6297,6299,6301,6303,6306],{"class":2871,"line":6298},31,[2869,6300,3348],{"class":3128},[2869,6302,3270],{"class":3132},[2869,6304,6305],{"class":3299},"0.8rem",[2869,6307,3277],{"class":3132},[2869,6309,6311,6313,6315,6317],{"class":2871,"line":6310},32,[2869,6312,6126],{"class":3128},[2869,6314,3270],{"class":3132},[2869,6316,3559],{"class":3273},[2869,6318,3277],{"class":3132},[2869,6320,6322],{"class":2871,"line":6321},33,[2869,6323,3360],{"class":3132},[2869,6325,6327,6330],{"class":2871,"line":6326},34,[2869,6328,6329],{"class":3258},".fluid-type-demo",[2869,6331,3262],{"class":3132},[2869,6333,6335,6337,6339,6341],{"class":2871,"line":6334},35,[2869,6336,3319],{"class":3128},[2869,6338,3270],{"class":3132},[2869,6340,3390],{"class":3273},[2869,6342,3277],{"class":3132},[2869,6344,6346,6348,6350,6352],{"class":2871,"line":6345},36,[2869,6347,4741],{"class":3128},[2869,6349,3270],{"class":3132},[2869,6351,3442],{"class":3299},[2869,6353,3277],{"class":3132},[2869,6355,6357,6359,6361,6363],{"class":2871,"line":6356},37,[2869,6358,3307],{"class":3128},[2869,6360,3270],{"class":3132},[2869,6362,3300],{"class":3299},[2869,6364,3277],{"class":3132},[2869,6366,6368,6370,6372,6374,6376,6378],{"class":2871,"line":6367},38,[2869,6369,3409],{"class":3128},[2869,6371,3270],{"class":3132},[2869,6373,3414],{"class":3299},[2869,6375,3417],{"class":3273},[2869,6377,3420],{"class":3273},[2869,6379,3277],{"class":3132},[2869,6381,6383],{"class":2871,"line":6382},39,[2869,6384,3360],{"class":3132},[2869,6386,6388,6391],{"class":2871,"line":6387},40,[2869,6389,6390],{"class":3258},".fluid-text",[2869,6392,3262],{"class":3132},[2869,6394,6396,6399,6401,6403],{"class":2871,"line":6395},41,[2869,6397,6398],{"class":3128},"  margin",[2869,6400,3270],{"class":3132},[2869,6402,3460],{"class":3299},[2869,6404,3277],{"class":3132},[2869,6406,6408,6410,6412,6415,6417,6420,6422,6425,6427,6429],{"class":2871,"line":6407},42,[2869,6409,3348],{"class":3128},[2869,6411,3270],{"class":3132},[2869,6413,6414],{"class":3469},"clamp",[2869,6416,3473],{"class":3132},[2869,6418,6419],{"class":3299},"0.875rem",[2869,6421,2810],{"class":3132},[2869,6423,6424],{"class":3299},"3vw",[2869,6426,2810],{"class":3132},[2869,6428,3312],{"class":3299},[2869,6430,6047],{"class":3132},[2869,6432,6434,6436,6438,6440],{"class":2871,"line":6433},43,[2869,6435,3397],{"class":3128},[2869,6437,3270],{"class":3132},[2869,6439,3538],{"class":3273},[2869,6441,3277],{"class":3132},[2869,6443,6445,6447,6449,6452],{"class":2871,"line":6444},44,[2869,6446,5652],{"class":3128},[2869,6448,3270],{"class":3132},[2869,6450,6451],{"class":3299},"600",[2869,6453,3277],{"class":3132},[2869,6455,6457],{"class":2871,"line":6456},45,[2869,6458,3360],{"class":3132},[2982,6460,6462,6463,6465],{"id":6461},"проблема-vh-на-мобільних-адрес-бар","Проблема ",[2799,6464,2822],{}," на мобільних: адрес-бар",[2804,6467,6468,6471,6472,6474,6475,6477],{},[2977,6469,6470],{},"Найвідоміший підводний камінь",": на мобільних браузерах ",[2799,6473,5752],{}," включає простір, що займає адресний рядок (URL bar), навіть коли він видимий. При скролі адрес-бар ховається, і ",[2799,6476,5752],{}," раптово стає більшим. Результат — елементи, що \"стрибають\" або обрізаються.",[2858,6479,6480],{},[2861,6481,6483],{"className":2863,"code":6482,"language":2858,"meta":2865,"style":2865},"graph LR\n  A[\"Сторінка завантажена\\n(адресний рядок видимий)\"] -->|\"100vh = вся висота\\nвключно з адрес-баром\"| B[\"Hero виходить\\nза межі екрана ❌\"]\n  C[\"Після прокручування\\n(адресний рядок прихований)\"] -->|\"100vh збільшується\"| D[\"Hero 'стрибає' ❌\"]\n  style B fill:#ef4444,color:#fff\n  style D fill:#ef4444,color:#fff\n",[2799,6484,6485,6489,6494,6499,6504],{"__ignoreMap":2865},[2869,6486,6487],{"class":2871,"line":2872},[2869,6488,3024],{},[2869,6490,6491],{"class":2871,"line":2878},[2869,6492,6493],{},"  A[\"Сторінка завантажена\\n(адресний рядок видимий)\"] -->|\"100vh = вся висота\\nвключно з адрес-баром\"| B[\"Hero виходить\\nза межі екрана ❌\"]\n",[2869,6495,6496],{"class":2871,"line":2884},[2869,6497,6498],{},"  C[\"Після прокручування\\n(адресний рядок прихований)\"] -->|\"100vh збільшується\"| D[\"Hero 'стрибає' ❌\"]\n",[2869,6500,6501],{"class":2871,"line":2890},[2869,6502,6503],{},"  style B fill:#ef4444,color:#fff\n",[2869,6505,6506],{"class":2871,"line":2896},[2869,6507,6508],{},"  style D fill:#ef4444,color:#fff\n",[2982,6510,6512,2810,6515,2810,6518,6520],{"id":6511},"svh-lvh-dvh-нові-одиниці-viewport-2022",[2799,6513,6514],{},"svh",[2799,6516,6517],{},"lvh",[2799,6519,2825],{}," — нові одиниці viewport (2022+)",[2804,6522,6523],{},"Специфікація CSS Values Level 4 ввела три нових варіанти, що вирішують проблему адрес-бара:",[3671,6525,6526,6538],{},[3674,6527,6528],{},[3677,6529,6530,6532,6535],{},[3680,6531,3682],{},[3680,6533,6534],{},"Назва",[3680,6536,6537],{},"Що враховує",[3690,6539,6540,6555,6570,6585,6604],{},[3677,6541,6542,6546,6549],{},[3695,6543,6544],{},[2799,6545,6514],{},[3695,6547,6548],{},"Small Viewport Height",[3695,6550,6551,6554],{},[2977,6552,6553],{},"Мінімальна"," висота viewport (адрес-бар видимий)",[3677,6556,6557,6561,6564],{},[3695,6558,6559],{},[2799,6560,6517],{},[3695,6562,6563],{},"Large Viewport Height",[3695,6565,6566,6569],{},[2977,6567,6568],{},"Максимальна"," висота viewport (адрес-бар прихований)",[3677,6571,6572,6576,6579],{},[3695,6573,6574],{},[2799,6575,2825],{},[3695,6577,6578],{},"Dynamic Viewport Height",[3695,6580,6581,6584],{},[2977,6582,6583],{},"Динамічна"," — оновлюється в реальному часі",[3677,6586,6587,6598,6601],{},[3695,6588,6589,2810,6592,2810,6595],{},[2799,6590,6591],{},"svw",[2799,6593,6594],{},"lvw",[2799,6596,6597],{},"dvw",[3695,6599,6600],{},"Аналоги по ширині",[3695,6602,6603],{},"Те саме для горизонталі",[3677,6605,6606,6614,6617],{},[3695,6607,6608,2810,6611],{},[2799,6609,6610],{},"vmin",[2799,6612,6613],{},"vmax",[3695,6615,6616],{},"Min / Max",[3695,6618,6619],{},"Менша / більша зі сторін viewport",[3107,6621,6622,6862],{},[2861,6623,6625],{"className":3111,"code":6624,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"dvh-demo\">\n  \u003Cdiv class=\"comparison\">\n    \u003Cdiv class=\"vh-box bad\">\n      \u003Cspan class=\"label\">100vh\u003C/span>\n      \u003Cp>Може виходити за межі на мобільних — не рахує адресний рядок коректно\u003C/p>\n    \u003C/div>\n    \u003Cdiv class=\"vh-box good\">\n      \u003Cspan class=\"label\">100dvh\u003C/span>\n      \u003Cp>Динамічно адаптується — завжди рівно 100% видимої висоти\u003C/p>\n    \u003C/div>\n    \u003Cdiv class=\"vh-box safe\">\n      \u003Cspan class=\"label\">100svh\u003C/span>\n      \u003Cp>Найменший viewport — безпечно, ніколи не обріжеться\u003C/p>\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,6626,6627,6642,6657,6672,6695,6712,6720,6735,6758,6775,6783,6798,6821,6838,6846,6854],{"__ignoreMap":2865},[2869,6628,6629,6631,6633,6635,6637,6640],{"class":2871,"line":2872},[2869,6630,3121],{"class":3120},[2869,6632,3125],{"class":3124},[2869,6634,3129],{"class":3128},[2869,6636,3133],{"class":3132},[2869,6638,6639],{"class":3136},"\"dvh-demo\"",[2869,6641,3140],{"class":3120},[2869,6643,6644,6646,6648,6650,6652,6655],{"class":2871,"line":2878},[2869,6645,3145],{"class":3120},[2869,6647,3125],{"class":3124},[2869,6649,3129],{"class":3128},[2869,6651,3133],{"class":3132},[2869,6653,6654],{"class":3136},"\"comparison\"",[2869,6656,3140],{"class":3120},[2869,6658,6659,6661,6663,6665,6667,6670],{"class":2871,"line":2884},[2869,6660,3971],{"class":3120},[2869,6662,3125],{"class":3124},[2869,6664,3129],{"class":3128},[2869,6666,3133],{"class":3132},[2869,6668,6669],{"class":3136},"\"vh-box bad\"",[2869,6671,3140],{"class":3120},[2869,6673,6674,6676,6678,6680,6682,6685,6687,6689,6691,6693],{"class":2871,"line":2890},[2869,6675,4004],{"class":3120},[2869,6677,2869],{"class":3124},[2869,6679,3129],{"class":3128},[2869,6681,3133],{"class":3132},[2869,6683,6684],{"class":3136},"\"label\"",[2869,6686,3157],{"class":3120},[2869,6688,5752],{"class":3132},[2869,6690,3162],{"class":3120},[2869,6692,2869],{"class":3124},[2869,6694,3140],{"class":3120},[2869,6696,6697,6699,6701,6703,6706,6708,6710],{"class":2871,"line":2896},[2869,6698,4004],{"class":3120},[2869,6700,2804],{"class":3124},[2869,6702,3157],{"class":3120},[2869,6704,6705],{"class":3132},"Може виходити за межі на мобільних — не рахує адресний рядок коректно",[2869,6707,3162],{"class":3120},[2869,6709,2804],{"class":3124},[2869,6711,3140],{"class":3120},[2869,6713,6714,6716,6718],{"class":2871,"line":2902},[2869,6715,4064],{"class":3120},[2869,6717,3125],{"class":3124},[2869,6719,3140],{"class":3120},[2869,6721,6722,6724,6726,6728,6730,6733],{"class":2871,"line":2908},[2869,6723,3971],{"class":3120},[2869,6725,3125],{"class":3124},[2869,6727,3129],{"class":3128},[2869,6729,3133],{"class":3132},[2869,6731,6732],{"class":3136},"\"vh-box good\"",[2869,6734,3140],{"class":3120},[2869,6736,6737,6739,6741,6743,6745,6747,6749,6752,6754,6756],{"class":2871,"line":2914},[2869,6738,4004],{"class":3120},[2869,6740,2869],{"class":3124},[2869,6742,3129],{"class":3128},[2869,6744,3133],{"class":3132},[2869,6746,6684],{"class":3136},[2869,6748,3157],{"class":3120},[2869,6750,6751],{"class":3132},"100dvh",[2869,6753,3162],{"class":3120},[2869,6755,2869],{"class":3124},[2869,6757,3140],{"class":3120},[2869,6759,6760,6762,6764,6766,6769,6771,6773],{"class":2871,"line":2920},[2869,6761,4004],{"class":3120},[2869,6763,2804],{"class":3124},[2869,6765,3157],{"class":3120},[2869,6767,6768],{"class":3132},"Динамічно адаптується — завжди рівно 100% видимої висоти",[2869,6770,3162],{"class":3120},[2869,6772,2804],{"class":3124},[2869,6774,3140],{"class":3120},[2869,6776,6777,6779,6781],{"class":2871,"line":2926},[2869,6778,4064],{"class":3120},[2869,6780,3125],{"class":3124},[2869,6782,3140],{"class":3120},[2869,6784,6785,6787,6789,6791,6793,6796],{"class":2871,"line":2932},[2869,6786,3971],{"class":3120},[2869,6788,3125],{"class":3124},[2869,6790,3129],{"class":3128},[2869,6792,3133],{"class":3132},[2869,6794,6795],{"class":3136},"\"vh-box safe\"",[2869,6797,3140],{"class":3120},[2869,6799,6800,6802,6804,6806,6808,6810,6812,6815,6817,6819],{"class":2871,"line":2938},[2869,6801,4004],{"class":3120},[2869,6803,2869],{"class":3124},[2869,6805,3129],{"class":3128},[2869,6807,3133],{"class":3132},[2869,6809,6684],{"class":3136},[2869,6811,3157],{"class":3120},[2869,6813,6814],{"class":3132},"100svh",[2869,6816,3162],{"class":3120},[2869,6818,2869],{"class":3124},[2869,6820,3140],{"class":3120},[2869,6822,6823,6825,6827,6829,6832,6834,6836],{"class":2871,"line":2944},[2869,6824,4004],{"class":3120},[2869,6826,2804],{"class":3124},[2869,6828,3157],{"class":3120},[2869,6830,6831],{"class":3132},"Найменший viewport — безпечно, ніколи не обріжеться",[2869,6833,3162],{"class":3120},[2869,6835,2804],{"class":3124},[2869,6837,3140],{"class":3120},[2869,6839,6840,6842,6844],{"class":2871,"line":2950},[2869,6841,4064],{"class":3120},[2869,6843,3125],{"class":3124},[2869,6845,3140],{"class":3120},[2869,6847,6848,6850,6852],{"class":2871,"line":2956},[2869,6849,4073],{"class":3120},[2869,6851,3125],{"class":3124},[2869,6853,3140],{"class":3120},[2869,6855,6856,6858,6860],{"class":2871,"line":2962},[2869,6857,3162],{"class":3120},[2869,6859,3125],{"class":3124},[2869,6861,3140],{"class":3120},[2861,6863,6865],{"className":3249,"code":6864,"language":3251,"meta":2865,"style":2865},".dvh-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n}\n.comparison {\n  display: flex;\n  gap: 0.75rem;\n  flex-wrap: wrap;\n}\n.vh-box {\n  flex: 1;\n  min-width: 140px;\n  padding: 1rem;\n  border-radius: 10px;\n  display: flex;\n  flex-direction: column;\n  gap: 0.5rem;\n  color: white;\n}\n.vh-box .label {\n  font-size: 1.1rem;\n  font-weight: 800;\n  font-family: monospace;\n}\n.vh-box p {\n  margin: 0;\n  font-size: 0.78rem;\n  opacity: 0.9;\n  line-height: 1.4;\n}\n.bad  { background: linear-gradient(135deg, #ef4444, #dc2626); }\n.good { background: linear-gradient(135deg, #10b981, #059669); }\n.safe { background: linear-gradient(135deg, #6366f1, #4f46e5); }\n",[2799,6866,6867,6874,6884,6894,6908,6912,6919,6929,6939,6949,6953,6960,6971,6983,6993,7003,7013,7023,7033,7043,7047,7056,7067,7078,7089,7093,7101,7111,7122,7134,7145,7149,7179,7207],{"__ignoreMap":2865},[2869,6868,6869,6872],{"class":2871,"line":2872},[2869,6870,6871],{"class":3258},".dvh-demo",[2869,6873,3262],{"class":3132},[2869,6875,6876,6878,6880,6882],{"class":2871,"line":2878},[2869,6877,3307],{"class":3128},[2869,6879,3270],{"class":3132},[2869,6881,3300],{"class":3299},[2869,6883,3277],{"class":3132},[2869,6885,6886,6888,6890,6892],{"class":2871,"line":2884},[2869,6887,3319],{"class":3128},[2869,6889,3270],{"class":3132},[2869,6891,3324],{"class":3273},[2869,6893,3277],{"class":3132},[2869,6895,6896,6898,6900,6902,6904,6906],{"class":2871,"line":2890},[2869,6897,3331],{"class":3128},[2869,6899,3270],{"class":3132},[2869,6901,3336],{"class":3273},[2869,6903,2810],{"class":3132},[2869,6905,3341],{"class":3273},[2869,6907,3277],{"class":3132},[2869,6909,6910],{"class":2871,"line":2896},[2869,6911,3360],{"class":3132},[2869,6913,6914,6917],{"class":2871,"line":2902},[2869,6915,6916],{"class":3258},".comparison",[2869,6918,3262],{"class":3132},[2869,6920,6921,6923,6925,6927],{"class":2871,"line":2908},[2869,6922,3267],{"class":3128},[2869,6924,3270],{"class":3132},[2869,6926,3274],{"class":3273},[2869,6928,3277],{"class":3132},[2869,6930,6931,6933,6935,6937],{"class":2871,"line":2914},[2869,6932,3294],{"class":3128},[2869,6934,3270],{"class":3132},[2869,6936,3376],{"class":3299},[2869,6938,3277],{"class":3132},[2869,6940,6941,6943,6945,6947],{"class":2871,"line":2920},[2869,6942,3282],{"class":3128},[2869,6944,3270],{"class":3132},[2869,6946,3287],{"class":3273},[2869,6948,3277],{"class":3132},[2869,6950,6951],{"class":2871,"line":2926},[2869,6952,3360],{"class":3132},[2869,6954,6955,6958],{"class":2871,"line":2932},[2869,6956,6957],{"class":3258},".vh-box",[2869,6959,3262],{"class":3132},[2869,6961,6962,6965,6967,6969],{"class":2871,"line":2938},[2869,6963,6964],{"class":3128},"  flex",[2869,6966,3270],{"class":3132},[2869,6968,5645],{"class":3299},[2869,6970,3277],{"class":3132},[2869,6972,6973,6976,6978,6981],{"class":2871,"line":2944},[2869,6974,6975],{"class":3128},"  min-width",[2869,6977,3270],{"class":3132},[2869,6979,6980],{"class":3299},"140px",[2869,6982,3277],{"class":3132},[2869,6984,6985,6987,6989,6991],{"class":2871,"line":2950},[2869,6986,3307],{"class":3128},[2869,6988,3270],{"class":3132},[2869,6990,3300],{"class":3299},[2869,6992,3277],{"class":3132},[2869,6994,6995,6997,6999,7001],{"class":2871,"line":2956},[2869,6996,4741],{"class":3128},[2869,6998,3270],{"class":3132},[2869,7000,6056],{"class":3299},[2869,7002,3277],{"class":3132},[2869,7004,7005,7007,7009,7011],{"class":2871,"line":2962},[2869,7006,3267],{"class":3128},[2869,7008,3270],{"class":3132},[2869,7010,3274],{"class":3273},[2869,7012,3277],{"class":3132},[2869,7014,7015,7017,7019,7021],{"class":2871,"line":3448},[2869,7016,5222],{"class":3128},[2869,7018,3270],{"class":3132},[2869,7020,5227],{"class":3273},[2869,7022,3277],{"class":3132},[2869,7024,7025,7027,7029,7031],{"class":2871,"line":3505},[2869,7026,3294],{"class":3128},[2869,7028,3270],{"class":3132},[2869,7030,6109],{"class":3299},[2869,7032,3277],{"class":3132},[2869,7034,7035,7037,7039,7041],{"class":2871,"line":3543},[2869,7036,3397],{"class":3128},[2869,7038,3270],{"class":3132},[2869,7040,3390],{"class":3273},[2869,7042,3277],{"class":3132},[2869,7044,7045],{"class":2871,"line":3573},[2869,7046,3360],{"class":3132},[2869,7048,7049,7051,7054],{"class":2871,"line":3619},[2869,7050,6957],{"class":3258},[2869,7052,7053],{"class":3258}," .label",[2869,7055,3262],{"class":3132},[2869,7057,7058,7060,7062,7065],{"class":2871,"line":4232},[2869,7059,3348],{"class":3128},[2869,7061,3270],{"class":3132},[2869,7063,7064],{"class":3299},"1.1rem",[2869,7066,3277],{"class":3132},[2869,7068,7069,7071,7073,7076],{"class":2871,"line":4241},[2869,7070,5652],{"class":3128},[2869,7072,3270],{"class":3132},[2869,7074,7075],{"class":3299},"800",[2869,7077,3277],{"class":3132},[2869,7079,7080,7082,7084,7087],{"class":2871,"line":6174},[2869,7081,3331],{"class":3128},[2869,7083,3270],{"class":3132},[2869,7085,7086],{"class":3273},"monospace",[2869,7088,3277],{"class":3132},[2869,7090,7091],{"class":2871,"line":6208},[2869,7092,3360],{"class":3132},[2869,7094,7095,7097,7099],{"class":2871,"line":6216},[2869,7096,6957],{"class":3258},[2869,7098,4459],{"class":3258},[2869,7100,3262],{"class":3132},[2869,7102,7103,7105,7107,7109],{"class":2871,"line":6229},[2869,7104,6398],{"class":3128},[2869,7106,3270],{"class":3132},[2869,7108,3460],{"class":3299},[2869,7110,3277],{"class":3132},[2869,7112,7113,7115,7117,7120],{"class":2871,"line":6241},[2869,7114,3348],{"class":3128},[2869,7116,3270],{"class":3132},[2869,7118,7119],{"class":3299},"0.78rem",[2869,7121,3277],{"class":3132},[2869,7123,7124,7127,7129,7132],{"class":2871,"line":6271},[2869,7125,7126],{"class":3128},"  opacity",[2869,7128,3270],{"class":3132},[2869,7130,7131],{"class":3299},"0.9",[2869,7133,3277],{"class":3132},[2869,7135,7136,7138,7140,7143],{"class":2871,"line":6283},[2869,7137,5640],{"class":3128},[2869,7139,3270],{"class":3132},[2869,7141,7142],{"class":3299},"1.4",[2869,7144,3277],{"class":3132},[2869,7146,7147],{"class":2871,"line":6298},[2869,7148,3360],{"class":3132},[2869,7150,7151,7154,7156,7158,7160,7162,7164,7166,7168,7171,7173,7176],{"class":2871,"line":6310},[2869,7152,7153],{"class":3258},".bad",[2869,7155,5369],{"class":3132},[2869,7157,3533],{"class":3128},[2869,7159,3270],{"class":3132},[2869,7161,6030],{"class":3469},[2869,7163,3473],{"class":3132},[2869,7165,6035],{"class":3299},[2869,7167,2810],{"class":3132},[2869,7169,7170],{"class":3273},"#ef4444",[2869,7172,2810],{"class":3132},[2869,7174,7175],{"class":3273},"#dc2626",[2869,7177,7178],{"class":3132},"); }\n",[2869,7180,7181,7184,7186,7188,7190,7192,7194,7196,7198,7200,7202,7205],{"class":2871,"line":6321},[2869,7182,7183],{"class":3258},".good",[2869,7185,3434],{"class":3132},[2869,7187,3533],{"class":3128},[2869,7189,3270],{"class":3132},[2869,7191,6030],{"class":3469},[2869,7193,3473],{"class":3132},[2869,7195,6035],{"class":3299},[2869,7197,2810],{"class":3132},[2869,7199,5410],{"class":3273},[2869,7201,2810],{"class":3132},[2869,7203,7204],{"class":3273},"#059669",[2869,7206,7178],{"class":3132},[2869,7208,7209,7212,7214,7216,7218,7220,7222,7224,7226,7228,7230,7233],{"class":2871,"line":6326},[2869,7210,7211],{"class":3258},".safe",[2869,7213,3434],{"class":3132},[2869,7215,3533],{"class":3128},[2869,7217,3270],{"class":3132},[2869,7219,6030],{"class":3469},[2869,7221,3473],{"class":3132},[2869,7223,6035],{"class":3299},[2869,7225,2810],{"class":3132},[2869,7227,3538],{"class":3273},[2869,7229,2810],{"class":3132},[2869,7231,7232],{"class":3273},"#4f46e5",[2869,7234,7178],{"class":3132},[2804,7236,7237],{},[2977,7238,7239],{},"Рекомендація для full-page layouts:",[2861,7241,7243],{"className":3249,"code":7242,"language":3251,"meta":2865,"style":2865},"/* Замість 100vh — використовуйте dvh або svh */\n.hero {\n  min-height: 100dvh; /* динамічно адаптується */\n}\n\n/* Або більш консервативно — svh для стабільності */\n.fullscreen-modal {\n  height: 100svh; /* завжди вміщується, навіть з адрес-баром */\n}\n",[2799,7244,7245,7250,7257,7271,7275,7279,7284,7291,7304],{"__ignoreMap":2865},[2869,7246,7247],{"class":2871,"line":2872},[2869,7248,7249],{"class":3762},"/* Замість 100vh — використовуйте dvh або svh */\n",[2869,7251,7252,7255],{"class":2871,"line":2878},[2869,7253,7254],{"class":3258},".hero",[2869,7256,3262],{"class":3132},[2869,7258,7259,7262,7264,7266,7268],{"class":2871,"line":2884},[2869,7260,7261],{"class":3128},"  min-height",[2869,7263,3270],{"class":3132},[2869,7265,6751],{"class":3299},[2869,7267,3521],{"class":3132},[2869,7269,7270],{"class":3762},"/* динамічно адаптується */\n",[2869,7272,7273],{"class":2871,"line":2890},[2869,7274,3360],{"class":3132},[2869,7276,7277],{"class":2871,"line":2896},[2869,7278,4758],{"emptyLinePlaceholder":4757},[2869,7280,7281],{"class":2871,"line":2902},[2869,7282,7283],{"class":3762},"/* Або більш консервативно — svh для стабільності */\n",[2869,7285,7286,7289],{"class":2871,"line":2908},[2869,7287,7288],{"class":3258},".fullscreen-modal",[2869,7290,3262],{"class":3132},[2869,7292,7293,7295,7297,7299,7301],{"class":2871,"line":2914},[2869,7294,6014],{"class":3128},[2869,7296,3270],{"class":3132},[2869,7298,6814],{"class":3299},[2869,7300,3521],{"class":3132},[2869,7302,7303],{"class":3762},"/* завжди вміщується, навіть з адрес-баром */\n",[2869,7305,7306],{"class":2871,"line":2920},[2869,7307,3360],{"class":3132},[2967,7309],{},[2794,7311,7313],{"id":7312},"контейнерні-одиниці-container-query-units","Контейнерні одиниці (Container Query Units)",[2804,7315,7316,7317,7320,7321,3905],{},"Це одне з найреволюційніших нововведень сучасного CSS. Якщо viewport-одиниці реагують на розмір ",[2977,7318,7319],{},"вікна браузера",", контейнерні одиниці реагують на розмір ",[2977,7322,7323],{},"найближчого контейнера",[2982,7325,7327],{"id":7326},"проблема-яку-вони-вирішують","Проблема, яку вони вирішують",[2804,7329,7330,7331,7334,7335,7338,7339,4886,7341,7343,7344,7347],{},"Уявіть компонент картки, що розміщується в різних контейнерах: одного разу — у широкому ",[2799,7332,7333],{},"main",", іншого — у вузькому ",[2799,7336,7337],{},"aside",". З ",[2799,7340,2819],{},[2799,7342,2834],{}," вона реагує на viewport, але не знає, ",[2977,7345,7346],{},"у якому конкретно місці вона знаходиться",". Контейнерні одиниці — знають.",[3107,7349,7350,7723],{},[2861,7351,7353],{"className":3111,"code":7352,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"cq-demo\">\n  \u003Ch3 class=\"demo-label\">Container Query Units в дії\u003C/h3>\n  \u003Cdiv class=\"layout-row\">\n    \u003Cdiv class=\"container-narrow\">\n      \u003Cp class=\"container-label\">Вузький контейнер (~30%)\u003C/p>\n      \u003Cdiv class=\"adaptive-card\">\n        \u003Cdiv class=\"card-icon\">🎨\u003C/div>\n        \u003Cdiv class=\"card-content\">\n          \u003Cstrong>CSS Design\u003C/strong>\n          \u003Cp>Текст адаптується до контейнера\u003C/p>\n        \u003C/div>\n      \u003C/div>\n    \u003C/div>\n    \u003Cdiv class=\"container-wide\">\n      \u003Cp class=\"container-label\">Широкий контейнер (~70%)\u003C/p>\n      \u003Cdiv class=\"adaptive-card\">\n        \u003Cdiv class=\"card-icon\">🎨\u003C/div>\n        \u003Cdiv class=\"card-content\">\n          \u003Cstrong>CSS Design\u003C/strong>\n          \u003Cp>Той самий компонент — більший шрифт\u003C/p>\n        \u003C/div>\n      \u003C/div>\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,7354,7355,7370,7394,7409,7424,7448,7463,7487,7502,7520,7537,7546,7554,7562,7577,7600,7614,7636,7650,7666,7683,7691,7699,7707,7715],{"__ignoreMap":2865},[2869,7356,7357,7359,7361,7363,7365,7368],{"class":2871,"line":2872},[2869,7358,3121],{"class":3120},[2869,7360,3125],{"class":3124},[2869,7362,3129],{"class":3128},[2869,7364,3133],{"class":3132},[2869,7366,7367],{"class":3136},"\"cq-demo\"",[2869,7369,3140],{"class":3120},[2869,7371,7372,7374,7376,7378,7380,7383,7385,7388,7390,7392],{"class":2871,"line":2878},[2869,7373,3145],{"class":3120},[2869,7375,2982],{"class":3124},[2869,7377,3129],{"class":3128},[2869,7379,3133],{"class":3132},[2869,7381,7382],{"class":3136},"\"demo-label\"",[2869,7384,3157],{"class":3120},[2869,7386,7387],{"class":3132},"Container Query Units в дії",[2869,7389,3162],{"class":3120},[2869,7391,2982],{"class":3124},[2869,7393,3140],{"class":3120},[2869,7395,7396,7398,7400,7402,7404,7407],{"class":2871,"line":2884},[2869,7397,3145],{"class":3120},[2869,7399,3125],{"class":3124},[2869,7401,3129],{"class":3128},[2869,7403,3133],{"class":3132},[2869,7405,7406],{"class":3136},"\"layout-row\"",[2869,7408,3140],{"class":3120},[2869,7410,7411,7413,7415,7417,7419,7422],{"class":2871,"line":2890},[2869,7412,3971],{"class":3120},[2869,7414,3125],{"class":3124},[2869,7416,3129],{"class":3128},[2869,7418,3133],{"class":3132},[2869,7420,7421],{"class":3136},"\"container-narrow\"",[2869,7423,3140],{"class":3120},[2869,7425,7426,7428,7430,7432,7434,7437,7439,7442,7444,7446],{"class":2871,"line":2896},[2869,7427,4004],{"class":3120},[2869,7429,2804],{"class":3124},[2869,7431,3129],{"class":3128},[2869,7433,3133],{"class":3132},[2869,7435,7436],{"class":3136},"\"container-label\"",[2869,7438,3157],{"class":3120},[2869,7440,7441],{"class":3132},"Вузький контейнер (~30%)",[2869,7443,3162],{"class":3120},[2869,7445,2804],{"class":3124},[2869,7447,3140],{"class":3120},[2869,7449,7450,7452,7454,7456,7458,7461],{"class":2871,"line":2902},[2869,7451,4004],{"class":3120},[2869,7453,3125],{"class":3124},[2869,7455,3129],{"class":3128},[2869,7457,3133],{"class":3132},[2869,7459,7460],{"class":3136},"\"adaptive-card\"",[2869,7462,3140],{"class":3120},[2869,7464,7465,7467,7469,7471,7473,7476,7478,7481,7483,7485],{"class":2871,"line":2908},[2869,7466,4037],{"class":3120},[2869,7468,3125],{"class":3124},[2869,7470,3129],{"class":3128},[2869,7472,3133],{"class":3132},[2869,7474,7475],{"class":3136},"\"card-icon\"",[2869,7477,3157],{"class":3120},[2869,7479,7480],{"class":3132},"🎨",[2869,7482,3162],{"class":3120},[2869,7484,3125],{"class":3124},[2869,7486,3140],{"class":3120},[2869,7488,7489,7491,7493,7495,7497,7500],{"class":2871,"line":2914},[2869,7490,4037],{"class":3120},[2869,7492,3125],{"class":3124},[2869,7494,3129],{"class":3128},[2869,7496,3133],{"class":3132},[2869,7498,7499],{"class":3136},"\"card-content\"",[2869,7501,3140],{"class":3120},[2869,7503,7504,7507,7509,7511,7514,7516,7518],{"class":2871,"line":2920},[2869,7505,7506],{"class":3120},"          \u003C",[2869,7508,2977],{"class":3124},[2869,7510,3157],{"class":3120},[2869,7512,7513],{"class":3132},"CSS Design",[2869,7515,3162],{"class":3120},[2869,7517,2977],{"class":3124},[2869,7519,3140],{"class":3120},[2869,7521,7522,7524,7526,7528,7531,7533,7535],{"class":2871,"line":2926},[2869,7523,7506],{"class":3120},[2869,7525,2804],{"class":3124},[2869,7527,3157],{"class":3120},[2869,7529,7530],{"class":3132},"Текст адаптується до контейнера",[2869,7532,3162],{"class":3120},[2869,7534,2804],{"class":3124},[2869,7536,3140],{"class":3120},[2869,7538,7539,7542,7544],{"class":2871,"line":2932},[2869,7540,7541],{"class":3120},"        \u003C/",[2869,7543,3125],{"class":3124},[2869,7545,3140],{"class":3120},[2869,7547,7548,7550,7552],{"class":2871,"line":2938},[2869,7549,4055],{"class":3120},[2869,7551,3125],{"class":3124},[2869,7553,3140],{"class":3120},[2869,7555,7556,7558,7560],{"class":2871,"line":2944},[2869,7557,4064],{"class":3120},[2869,7559,3125],{"class":3124},[2869,7561,3140],{"class":3120},[2869,7563,7564,7566,7568,7570,7572,7575],{"class":2871,"line":2950},[2869,7565,3971],{"class":3120},[2869,7567,3125],{"class":3124},[2869,7569,3129],{"class":3128},[2869,7571,3133],{"class":3132},[2869,7573,7574],{"class":3136},"\"container-wide\"",[2869,7576,3140],{"class":3120},[2869,7578,7579,7581,7583,7585,7587,7589,7591,7594,7596,7598],{"class":2871,"line":2956},[2869,7580,4004],{"class":3120},[2869,7582,2804],{"class":3124},[2869,7584,3129],{"class":3128},[2869,7586,3133],{"class":3132},[2869,7588,7436],{"class":3136},[2869,7590,3157],{"class":3120},[2869,7592,7593],{"class":3132},"Широкий контейнер (~70%)",[2869,7595,3162],{"class":3120},[2869,7597,2804],{"class":3124},[2869,7599,3140],{"class":3120},[2869,7601,7602,7604,7606,7608,7610,7612],{"class":2871,"line":2962},[2869,7603,4004],{"class":3120},[2869,7605,3125],{"class":3124},[2869,7607,3129],{"class":3128},[2869,7609,3133],{"class":3132},[2869,7611,7460],{"class":3136},[2869,7613,3140],{"class":3120},[2869,7615,7616,7618,7620,7622,7624,7626,7628,7630,7632,7634],{"class":2871,"line":3448},[2869,7617,4037],{"class":3120},[2869,7619,3125],{"class":3124},[2869,7621,3129],{"class":3128},[2869,7623,3133],{"class":3132},[2869,7625,7475],{"class":3136},[2869,7627,3157],{"class":3120},[2869,7629,7480],{"class":3132},[2869,7631,3162],{"class":3120},[2869,7633,3125],{"class":3124},[2869,7635,3140],{"class":3120},[2869,7637,7638,7640,7642,7644,7646,7648],{"class":2871,"line":3505},[2869,7639,4037],{"class":3120},[2869,7641,3125],{"class":3124},[2869,7643,3129],{"class":3128},[2869,7645,3133],{"class":3132},[2869,7647,7499],{"class":3136},[2869,7649,3140],{"class":3120},[2869,7651,7652,7654,7656,7658,7660,7662,7664],{"class":2871,"line":3543},[2869,7653,7506],{"class":3120},[2869,7655,2977],{"class":3124},[2869,7657,3157],{"class":3120},[2869,7659,7513],{"class":3132},[2869,7661,3162],{"class":3120},[2869,7663,2977],{"class":3124},[2869,7665,3140],{"class":3120},[2869,7667,7668,7670,7672,7674,7677,7679,7681],{"class":2871,"line":3573},[2869,7669,7506],{"class":3120},[2869,7671,2804],{"class":3124},[2869,7673,3157],{"class":3120},[2869,7675,7676],{"class":3132},"Той самий компонент — більший шрифт",[2869,7678,3162],{"class":3120},[2869,7680,2804],{"class":3124},[2869,7682,3140],{"class":3120},[2869,7684,7685,7687,7689],{"class":2871,"line":3619},[2869,7686,7541],{"class":3120},[2869,7688,3125],{"class":3124},[2869,7690,3140],{"class":3120},[2869,7692,7693,7695,7697],{"class":2871,"line":4232},[2869,7694,4055],{"class":3120},[2869,7696,3125],{"class":3124},[2869,7698,3140],{"class":3120},[2869,7700,7701,7703,7705],{"class":2871,"line":4241},[2869,7702,4064],{"class":3120},[2869,7704,3125],{"class":3124},[2869,7706,3140],{"class":3120},[2869,7708,7709,7711,7713],{"class":2871,"line":6174},[2869,7710,4073],{"class":3120},[2869,7712,3125],{"class":3124},[2869,7714,3140],{"class":3120},[2869,7716,7717,7719,7721],{"class":2871,"line":6208},[2869,7718,3162],{"class":3120},[2869,7720,3125],{"class":3124},[2869,7722,3140],{"class":3120},[2861,7724,7726],{"className":3249,"code":7725,"language":3251,"meta":2865,"style":2865},".cq-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  color: #1e293b;\n}\n.demo-label {\n  margin: 0 0 0.75rem;\n  font-size: 0.85rem;\n  color: #64748b;\n  font-weight: 600;\n}\n.layout-row {\n  display: flex;\n  gap: 0.75rem;\n}\n.container-narrow {\n  flex: 3;\n  container-type: inline-size;\n}\n.container-wide {\n  flex: 7;\n  container-type: inline-size;\n}\n.container-label {\n  margin: 0 0 0.5rem;\n  font-size: 0.7rem;\n  color: #94a3b8;\n  text-transform: uppercase;\n  letter-spacing: 0.05em;\n}\n.adaptive-card {\n  background: white;\n  border: 1px solid #e2e8f0;\n  border-radius: 8px;\n  padding: 0.75rem;\n  display: flex;\n  align-items: center;\n  gap: 0.5rem;\n}\n.card-icon {\n  font-size: 4cqi;\n  line-height: 1;\n  flex-shrink: 0;\n}\n.card-content strong {\n  display: block;\n  font-size: 3cqi;\n  line-height: 1.2;\n}\n.card-content p {\n  margin: 0.2rem 0 0;\n  font-size: 2.5cqi;\n  color: #64748b;\n  line-height: 1.3;\n}\n",[2799,7727,7728,7735,7745,7755,7769,7779,7783,7790,7804,7814,7825,7835,7839,7846,7856,7866,7870,7877,7887,7895,7899,7906,7917,7923,7927,7934,7948,7959,7970,7982,7994,7998,8005,8015,8029,8039,8049,8059,8069,8079,8083,8090,8101,8111,8122,8126,8137,8149,8161,8173,8178,8187,8203,8215,8226,8238],{"__ignoreMap":2865},[2869,7729,7730,7733],{"class":2871,"line":2872},[2869,7731,7732],{"class":3258},".cq-demo",[2869,7734,3262],{"class":3132},[2869,7736,7737,7739,7741,7743],{"class":2871,"line":2878},[2869,7738,3307],{"class":3128},[2869,7740,3270],{"class":3132},[2869,7742,3300],{"class":3299},[2869,7744,3277],{"class":3132},[2869,7746,7747,7749,7751,7753],{"class":2871,"line":2884},[2869,7748,3319],{"class":3128},[2869,7750,3270],{"class":3132},[2869,7752,3324],{"class":3273},[2869,7754,3277],{"class":3132},[2869,7756,7757,7759,7761,7763,7765,7767],{"class":2871,"line":2890},[2869,7758,3331],{"class":3128},[2869,7760,3270],{"class":3132},[2869,7762,3336],{"class":3273},[2869,7764,2810],{"class":3132},[2869,7766,3341],{"class":3273},[2869,7768,3277],{"class":3132},[2869,7770,7771,7773,7775,7777],{"class":2871,"line":2896},[2869,7772,3397],{"class":3128},[2869,7774,3270],{"class":3132},[2869,7776,3402],{"class":3273},[2869,7778,3277],{"class":3132},[2869,7780,7781],{"class":2871,"line":2902},[2869,7782,3360],{"class":3132},[2869,7784,7785,7788],{"class":2871,"line":2908},[2869,7786,7787],{"class":3258},".demo-label",[2869,7789,3262],{"class":3132},[2869,7791,7792,7794,7796,7798,7800,7802],{"class":2871,"line":2914},[2869,7793,6398],{"class":3128},[2869,7795,3270],{"class":3132},[2869,7797,3460],{"class":3299},[2869,7799,4335],{"class":3299},[2869,7801,6293],{"class":3299},[2869,7803,3277],{"class":3132},[2869,7805,7806,7808,7810,7812],{"class":2871,"line":2920},[2869,7807,3348],{"class":3128},[2869,7809,3270],{"class":3132},[2869,7811,3353],{"class":3299},[2869,7813,3277],{"class":3132},[2869,7815,7816,7818,7820,7823],{"class":2871,"line":2926},[2869,7817,3397],{"class":3128},[2869,7819,3270],{"class":3132},[2869,7821,7822],{"class":3273},"#64748b",[2869,7824,3277],{"class":3132},[2869,7826,7827,7829,7831,7833],{"class":2871,"line":2932},[2869,7828,5652],{"class":3128},[2869,7830,3270],{"class":3132},[2869,7832,6451],{"class":3299},[2869,7834,3277],{"class":3132},[2869,7836,7837],{"class":2871,"line":2938},[2869,7838,3360],{"class":3132},[2869,7840,7841,7844],{"class":2871,"line":2944},[2869,7842,7843],{"class":3258},".layout-row",[2869,7845,3262],{"class":3132},[2869,7847,7848,7850,7852,7854],{"class":2871,"line":2950},[2869,7849,3267],{"class":3128},[2869,7851,3270],{"class":3132},[2869,7853,3274],{"class":3273},[2869,7855,3277],{"class":3132},[2869,7857,7858,7860,7862,7864],{"class":2871,"line":2956},[2869,7859,3294],{"class":3128},[2869,7861,3270],{"class":3132},[2869,7863,3376],{"class":3299},[2869,7865,3277],{"class":3132},[2869,7867,7868],{"class":2871,"line":2962},[2869,7869,3360],{"class":3132},[2869,7871,7872,7875],{"class":2871,"line":3448},[2869,7873,7874],{"class":3258},".container-narrow",[2869,7876,3262],{"class":3132},[2869,7878,7879,7881,7883,7885],{"class":2871,"line":3505},[2869,7880,6964],{"class":3128},[2869,7882,3270],{"class":3132},[2869,7884,5605],{"class":3299},[2869,7886,3277],{"class":3132},[2869,7888,7889,7892],{"class":2871,"line":3543},[2869,7890,7891],{"class":3128},"  container-type",[2869,7893,7894],{"class":3132},": inline-size;\n",[2869,7896,7897],{"class":2871,"line":3573},[2869,7898,3360],{"class":3132},[2869,7900,7901,7904],{"class":2871,"line":3619},[2869,7902,7903],{"class":3258},".container-wide",[2869,7905,3262],{"class":3132},[2869,7907,7908,7910,7912,7915],{"class":2871,"line":4232},[2869,7909,6964],{"class":3128},[2869,7911,3270],{"class":3132},[2869,7913,7914],{"class":3299},"7",[2869,7916,3277],{"class":3132},[2869,7918,7919,7921],{"class":2871,"line":4241},[2869,7920,7891],{"class":3128},[2869,7922,7894],{"class":3132},[2869,7924,7925],{"class":2871,"line":6174},[2869,7926,3360],{"class":3132},[2869,7928,7929,7932],{"class":2871,"line":6208},[2869,7930,7931],{"class":3258},".container-label",[2869,7933,3262],{"class":3132},[2869,7935,7936,7938,7940,7942,7944,7946],{"class":2871,"line":6216},[2869,7937,6398],{"class":3128},[2869,7939,3270],{"class":3132},[2869,7941,3460],{"class":3299},[2869,7943,4335],{"class":3299},[2869,7945,4338],{"class":3299},[2869,7947,3277],{"class":3132},[2869,7949,7950,7952,7954,7957],{"class":2871,"line":6229},[2869,7951,3348],{"class":3128},[2869,7953,3270],{"class":3132},[2869,7955,7956],{"class":3299},"0.7rem",[2869,7958,3277],{"class":3132},[2869,7960,7961,7963,7965,7968],{"class":2871,"line":6241},[2869,7962,3397],{"class":3128},[2869,7964,3270],{"class":3132},[2869,7966,7967],{"class":3273},"#94a3b8",[2869,7969,3277],{"class":3132},[2869,7971,7972,7975,7977,7980],{"class":2871,"line":6271},[2869,7973,7974],{"class":3128},"  text-transform",[2869,7976,3270],{"class":3132},[2869,7978,7979],{"class":3273},"uppercase",[2869,7981,3277],{"class":3132},[2869,7983,7984,7987,7989,7992],{"class":2871,"line":6283},[2869,7985,7986],{"class":3128},"  letter-spacing",[2869,7988,3270],{"class":3132},[2869,7990,7991],{"class":3299},"0.05em",[2869,7993,3277],{"class":3132},[2869,7995,7996],{"class":2871,"line":6298},[2869,7997,3360],{"class":3132},[2869,7999,8000,8003],{"class":2871,"line":6310},[2869,8001,8002],{"class":3258},".adaptive-card",[2869,8004,3262],{"class":3132},[2869,8006,8007,8009,8011,8013],{"class":2871,"line":6321},[2869,8008,3319],{"class":3128},[2869,8010,3270],{"class":3132},[2869,8012,3390],{"class":3273},[2869,8014,3277],{"class":3132},[2869,8016,8017,8019,8021,8023,8025,8027],{"class":2871,"line":6326},[2869,8018,3409],{"class":3128},[2869,8020,3270],{"class":3132},[2869,8022,3414],{"class":3299},[2869,8024,3417],{"class":3273},[2869,8026,3420],{"class":3273},[2869,8028,3277],{"class":3132},[2869,8030,8031,8033,8035,8037],{"class":2871,"line":6334},[2869,8032,4741],{"class":3128},[2869,8034,3270],{"class":3132},[2869,8036,3442],{"class":3299},[2869,8038,3277],{"class":3132},[2869,8040,8041,8043,8045,8047],{"class":2871,"line":6345},[2869,8042,3307],{"class":3128},[2869,8044,3270],{"class":3132},[2869,8046,3376],{"class":3299},[2869,8048,3277],{"class":3132},[2869,8050,8051,8053,8055,8057],{"class":2871,"line":6356},[2869,8052,3267],{"class":3128},[2869,8054,3270],{"class":3132},[2869,8056,3274],{"class":3273},[2869,8058,3277],{"class":3132},[2869,8060,8061,8063,8065,8067],{"class":2871,"line":6367},[2869,8062,6083],{"class":3128},[2869,8064,3270],{"class":3132},[2869,8066,3559],{"class":3273},[2869,8068,3277],{"class":3132},[2869,8070,8071,8073,8075,8077],{"class":2871,"line":6382},[2869,8072,3294],{"class":3128},[2869,8074,3270],{"class":3132},[2869,8076,6109],{"class":3299},[2869,8078,3277],{"class":3132},[2869,8080,8081],{"class":2871,"line":6387},[2869,8082,3360],{"class":3132},[2869,8084,8085,8088],{"class":2871,"line":6395},[2869,8086,8087],{"class":3258},".card-icon",[2869,8089,3262],{"class":3132},[2869,8091,8092,8094,8096,8099],{"class":2871,"line":6407},[2869,8093,3348],{"class":3128},[2869,8095,3270],{"class":3132},[2869,8097,8098],{"class":3299},"4cqi",[2869,8100,3277],{"class":3132},[2869,8102,8103,8105,8107,8109],{"class":2871,"line":6433},[2869,8104,5640],{"class":3128},[2869,8106,3270],{"class":3132},[2869,8108,5645],{"class":3299},[2869,8110,3277],{"class":3132},[2869,8112,8113,8116,8118,8120],{"class":2871,"line":6444},[2869,8114,8115],{"class":3128},"  flex-shrink",[2869,8117,3270],{"class":3132},[2869,8119,3460],{"class":3299},[2869,8121,3277],{"class":3132},[2869,8123,8124],{"class":2871,"line":6456},[2869,8125,3360],{"class":3132},[2869,8127,8129,8132,8135],{"class":2871,"line":8128},46,[2869,8130,8131],{"class":3258},".card-content",[2869,8133,8134],{"class":3258}," strong",[2869,8136,3262],{"class":3132},[2869,8138,8140,8142,8144,8147],{"class":2871,"line":8139},47,[2869,8141,3267],{"class":3128},[2869,8143,3270],{"class":3132},[2869,8145,8146],{"class":3273},"block",[2869,8148,3277],{"class":3132},[2869,8150,8152,8154,8156,8159],{"class":2871,"line":8151},48,[2869,8153,3348],{"class":3128},[2869,8155,3270],{"class":3132},[2869,8157,8158],{"class":3299},"3cqi",[2869,8160,3277],{"class":3132},[2869,8162,8164,8166,8168,8171],{"class":2871,"line":8163},49,[2869,8165,5640],{"class":3128},[2869,8167,3270],{"class":3132},[2869,8169,8170],{"class":3299},"1.2",[2869,8172,3277],{"class":3132},[2869,8174,8176],{"class":2871,"line":8175},50,[2869,8177,3360],{"class":3132},[2869,8179,8181,8183,8185],{"class":2871,"line":8180},51,[2869,8182,8131],{"class":3258},[2869,8184,4459],{"class":3258},[2869,8186,3262],{"class":3132},[2869,8188,8190,8192,8194,8197,8199,8201],{"class":2871,"line":8189},52,[2869,8191,6398],{"class":3128},[2869,8193,3270],{"class":3132},[2869,8195,8196],{"class":3299},"0.2rem",[2869,8198,4335],{"class":3299},[2869,8200,4335],{"class":3299},[2869,8202,3277],{"class":3132},[2869,8204,8206,8208,8210,8213],{"class":2871,"line":8205},53,[2869,8207,3348],{"class":3128},[2869,8209,3270],{"class":3132},[2869,8211,8212],{"class":3299},"2.5cqi",[2869,8214,3277],{"class":3132},[2869,8216,8218,8220,8222,8224],{"class":2871,"line":8217},54,[2869,8219,3397],{"class":3128},[2869,8221,3270],{"class":3132},[2869,8223,7822],{"class":3273},[2869,8225,3277],{"class":3132},[2869,8227,8229,8231,8233,8236],{"class":2871,"line":8228},55,[2869,8230,5640],{"class":3128},[2869,8232,3270],{"class":3132},[2869,8234,8235],{"class":3299},"1.3",[2869,8237,3277],{"class":3132},[2869,8239,8241],{"class":2871,"line":8240},56,[2869,8242,3360],{"class":3132},[2982,8244,8246],{"id":8245},"синтаксис-контейнерних-одиниць","Синтаксис контейнерних одиниць",[2804,8248,8249,8250,8253],{},"Спочатку потрібно ",[2977,8251,8252],{},"зареєструвати контейнер",", а потім використовувати одиниці всередині нього:",[2861,8255,8257],{"className":3249,"code":8256,"language":3251,"meta":2865,"style":2865},"/* Крок 1: оголошуємо елемент контейнером */\n.card-wrapper {\n  container-type: inline-size; /* або: size | normal */\n  container-name: card; /* необов'язково — для іменованих контейнерів */\n}\n\n/* Скорочення */\n.card-wrapper {\n  container: card / inline-size;\n}\n\n/* Крок 2: використовуємо cq-одиниці всередині */\n.card-title {\n  font-size: 5cqi; /* 5% від inline-size контейнера */\n}\n",[2799,8258,8259,8264,8271,8281,8292,8296,8300,8305,8311,8319,8323,8327,8332,8339,8353],{"__ignoreMap":2865},[2869,8260,8261],{"class":2871,"line":2872},[2869,8262,8263],{"class":3762},"/* Крок 1: оголошуємо елемент контейнером */\n",[2869,8265,8266,8269],{"class":2871,"line":2878},[2869,8267,8268],{"class":3258},".card-wrapper",[2869,8270,3262],{"class":3132},[2869,8272,8273,8275,8278],{"class":2871,"line":2884},[2869,8274,7891],{"class":3128},[2869,8276,8277],{"class":3132},": inline-size; ",[2869,8279,8280],{"class":3762},"/* або: size | normal */\n",[2869,8282,8283,8286,8289],{"class":2871,"line":2890},[2869,8284,8285],{"class":3128},"  container-name",[2869,8287,8288],{"class":3132},": card; ",[2869,8290,8291],{"class":3762},"/* необов'язково — для іменованих контейнерів */\n",[2869,8293,8294],{"class":2871,"line":2896},[2869,8295,3360],{"class":3132},[2869,8297,8298],{"class":2871,"line":2902},[2869,8299,4758],{"emptyLinePlaceholder":4757},[2869,8301,8302],{"class":2871,"line":2908},[2869,8303,8304],{"class":3762},"/* Скорочення */\n",[2869,8306,8307,8309],{"class":2871,"line":2914},[2869,8308,8268],{"class":3258},[2869,8310,3262],{"class":3132},[2869,8312,8313,8316],{"class":2871,"line":2920},[2869,8314,8315],{"class":3128},"  container",[2869,8317,8318],{"class":3132},": card / inline-size;\n",[2869,8320,8321],{"class":2871,"line":2926},[2869,8322,3360],{"class":3132},[2869,8324,8325],{"class":2871,"line":2932},[2869,8326,4758],{"emptyLinePlaceholder":4757},[2869,8328,8329],{"class":2871,"line":2938},[2869,8330,8331],{"class":3762},"/* Крок 2: використовуємо cq-одиниці всередині */\n",[2869,8333,8334,8337],{"class":2871,"line":2944},[2869,8335,8336],{"class":3258},".card-title",[2869,8338,3262],{"class":3132},[2869,8340,8341,8343,8345,8348,8350],{"class":2871,"line":2950},[2869,8342,3348],{"class":3128},[2869,8344,3270],{"class":3132},[2869,8346,8347],{"class":3299},"5cqi",[2869,8349,3521],{"class":3132},[2869,8351,8352],{"class":3762},"/* 5% від inline-size контейнера */\n",[2869,8354,8355],{"class":2871,"line":2956},[2869,8356,3360],{"class":3132},[3671,8358,8359,8371],{},[3674,8360,8361],{},[3677,8362,8363,8365,8368],{},[3680,8364,3682],{},[3680,8366,8367],{},"Розшифровка",[3680,8369,8370],{},"Відносно",[3690,8372,8373,8385,8398,8411,8424,8437],{},[3677,8374,8375,8379,8382],{},[3695,8376,8377],{},[2799,8378,2828],{},[3695,8380,8381],{},"Container Query Width",[3695,8383,8384],{},"Ширина контейнера",[3677,8386,8387,8392,8395],{},[3695,8388,8389],{},[2799,8390,8391],{},"cqh",[3695,8393,8394],{},"Container Query Height",[3695,8396,8397],{},"Висота контейнера",[3677,8399,8400,8405,8408],{},[3695,8401,8402],{},[2799,8403,8404],{},"cqi",[3695,8406,8407],{},"Container Query Inline",[3695,8409,8410],{},"Inline-вісь контейнера",[3677,8412,8413,8418,8421],{},[3695,8414,8415],{},[2799,8416,8417],{},"cqb",[3695,8419,8420],{},"Container Query Block",[3695,8422,8423],{},"Block-вісь контейнера",[3677,8425,8426,8431,8434],{},[3695,8427,8428],{},[2799,8429,8430],{},"cqmin",[3695,8432,8433],{},"Container Query Min",[3695,8435,8436],{},"Менша зі сторін",[3677,8438,8439,8444,8447],{},[3695,8440,8441],{},[2799,8442,8443],{},"cqmax",[3695,8445,8446],{},"Container Query Max",[3695,8448,8449],{},"Більша зі сторін",[8451,8452,8453,8456,8457,8460,8461,8464],"note",{},[2799,8454,8455],{},"container-type: inline-size"," — найпоширеніший варіант: контейнер реагує лише на ширину. ",[2799,8458,8459],{},"size"," — реагує і на ширину, і на висоту, але вимагає явно заданої висоти контейнера. ",[2977,8462,8463],{},"Підтримка:"," Chrome 105+, Firefox 110+, Safari 16+",[2967,8466],{},[2794,8468,8470],{"id":8469},"intrinsic-розміри-коли-вміст-диктує-розмір","Intrinsic розміри: коли вміст диктує розмір",[2804,8472,8473,8474,8477],{},"CSS дозволяє ",[2977,8475,8476],{},"передати рішення про розмір самому вмісту"," — через спеціальні ключові слова. Це принципово різний підхід: замість того, щоб ми вказували число, браузер сам обчислює розмір, виходячи з вмісту елемента.",[2982,8479,8481,8483],{"id":8480},"min-content-мінімум-без-втрат",[2799,8482,2840],{}," — мінімум без втрат",[2804,8485,8486,8488,8489,8492],{},[2799,8487,2840],{}," — це ",[2977,8490,8491],{},"найменший розмір, при якому вміст не втрачається",". Для тексту це ширина найдовшого нерозривного слова або рядка. Для зображення — його природна ширина.",[2982,8494,8496,8499],{"id":8495},"max-content-без-переносів-взагалі",[2799,8497,8498],{},"max-content"," — без переносів взагалі",[2804,8501,8502,8488,8504,8507],{},[2799,8503,8498],{},[2977,8505,8506],{},"розмір, при якому весь вміст розміщується в один рядок"," без жодного переносу.",[2982,8509,8511,8514],{"id":8510},"fit-content-компромісне-рішення",[2799,8512,8513],{},"fit-content"," — компромісне рішення",[2804,8516,8517,8519,8520,8522,8523,8525,8526,3905],{},[2799,8518,8513],{}," — веде себе як ",[2799,8521,8498],{}," доти, доки не досягне доступного простору. Тоді починає переносити вміст, як ",[2799,8524,2840],{},". Фактично: ",[2799,8527,8528],{},"min(max-content, max(min-content, available-space))",[2982,8530,8532,8535],{"id":8531},"fit-contentvalue-функція-з-обмеженням",[2799,8533,8534],{},"fit-content(value)"," — функція з обмеженням",[2804,8537,8538,8541,8542,8544,8545,3905],{},[2799,8539,8540],{},"fit-content(300px)"," — те саме, що ",[2799,8543,8513],{},", але з явним обмеженням максимуму: не більше ",[2799,8546,8547],{},"300px",[3107,8549,8550,9056],{},[2861,8551,8553],{"className":3111,"code":8552,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"intrinsic-demo\">\n  \u003Cp class=\"demo-note\">Один і той самий текст — різні ключові слова:\u003C/p>\n  \u003Cdiv class=\"showcase\">\n    \u003Cdiv class=\"box min-c\">\n      \u003Cspan class=\"kw\">min-content\u003C/span>\n      \u003Cp>Дуже довге речення з багатьма словами для демонстрації\u003C/p>\n    \u003C/div>\n    \u003Cdiv class=\"box max-c\">\n      \u003Cspan class=\"kw\">max-content\u003C/span>\n      \u003Cp>Дуже довге речення з багатьма словами для демонстрації\u003C/p>\n    \u003C/div>\n    \u003Cdiv class=\"box fit-c\">\n      \u003Cspan class=\"kw\">fit-content\u003C/span>\n      \u003Cp>Дуже довге речення з багатьма словами для демонстрації\u003C/p>\n    \u003C/div>\n    \u003Cdiv class=\"box fit-300\">\n      \u003Cspan class=\"kw\">fit-content(200px)\u003C/span>\n      \u003Cp>Дуже довге речення з багатьма словами для демонстрації\u003C/p>\n    \u003C/div>\n  \u003C/div>\n  \u003Cp class=\"demo-note\">Та ж концепція у grid-колонках:\u003C/p>\n  \u003Cdiv class=\"grid-demo\">\n    \u003Cdiv class=\"g-header\">min-content\u003C/div>\n    \u003Cdiv class=\"g-header\">max-content\u003C/div>\n    \u003Cdiv class=\"g-header\">fit-content(150px)\u003C/div>\n    \u003Cdiv class=\"g-cell\">Коротко\u003C/div>\n    \u003Cdiv class=\"g-cell\">Трохи довший текст тут\u003C/div>\n    \u003Cdiv class=\"g-cell\">Дуже довгий текст що може переноситись\u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,8554,8555,8570,8594,8609,8624,8647,8664,8672,8687,8709,8725,8733,8748,8770,8786,8794,8809,8832,8848,8856,8864,8887,8902,8925,8947,8970,8994,9017,9040,9048],{"__ignoreMap":2865},[2869,8556,8557,8559,8561,8563,8565,8568],{"class":2871,"line":2872},[2869,8558,3121],{"class":3120},[2869,8560,3125],{"class":3124},[2869,8562,3129],{"class":3128},[2869,8564,3133],{"class":3132},[2869,8566,8567],{"class":3136},"\"intrinsic-demo\"",[2869,8569,3140],{"class":3120},[2869,8571,8572,8574,8576,8578,8580,8583,8585,8588,8590,8592],{"class":2871,"line":2878},[2869,8573,3145],{"class":3120},[2869,8575,2804],{"class":3124},[2869,8577,3129],{"class":3128},[2869,8579,3133],{"class":3132},[2869,8581,8582],{"class":3136},"\"demo-note\"",[2869,8584,3157],{"class":3120},[2869,8586,8587],{"class":3132},"Один і той самий текст — різні ключові слова:",[2869,8589,3162],{"class":3120},[2869,8591,2804],{"class":3124},[2869,8593,3140],{"class":3120},[2869,8595,8596,8598,8600,8602,8604,8607],{"class":2871,"line":2884},[2869,8597,3145],{"class":3120},[2869,8599,3125],{"class":3124},[2869,8601,3129],{"class":3128},[2869,8603,3133],{"class":3132},[2869,8605,8606],{"class":3136},"\"showcase\"",[2869,8608,3140],{"class":3120},[2869,8610,8611,8613,8615,8617,8619,8622],{"class":2871,"line":2890},[2869,8612,3971],{"class":3120},[2869,8614,3125],{"class":3124},[2869,8616,3129],{"class":3128},[2869,8618,3133],{"class":3132},[2869,8620,8621],{"class":3136},"\"box min-c\"",[2869,8623,3140],{"class":3120},[2869,8625,8626,8628,8630,8632,8634,8637,8639,8641,8643,8645],{"class":2871,"line":2896},[2869,8627,4004],{"class":3120},[2869,8629,2869],{"class":3124},[2869,8631,3129],{"class":3128},[2869,8633,3133],{"class":3132},[2869,8635,8636],{"class":3136},"\"kw\"",[2869,8638,3157],{"class":3120},[2869,8640,2840],{"class":3132},[2869,8642,3162],{"class":3120},[2869,8644,2869],{"class":3124},[2869,8646,3140],{"class":3120},[2869,8648,8649,8651,8653,8655,8658,8660,8662],{"class":2871,"line":2902},[2869,8650,4004],{"class":3120},[2869,8652,2804],{"class":3124},[2869,8654,3157],{"class":3120},[2869,8656,8657],{"class":3132},"Дуже довге речення з багатьма словами для демонстрації",[2869,8659,3162],{"class":3120},[2869,8661,2804],{"class":3124},[2869,8663,3140],{"class":3120},[2869,8665,8666,8668,8670],{"class":2871,"line":2908},[2869,8667,4064],{"class":3120},[2869,8669,3125],{"class":3124},[2869,8671,3140],{"class":3120},[2869,8673,8674,8676,8678,8680,8682,8685],{"class":2871,"line":2914},[2869,8675,3971],{"class":3120},[2869,8677,3125],{"class":3124},[2869,8679,3129],{"class":3128},[2869,8681,3133],{"class":3132},[2869,8683,8684],{"class":3136},"\"box max-c\"",[2869,8686,3140],{"class":3120},[2869,8688,8689,8691,8693,8695,8697,8699,8701,8703,8705,8707],{"class":2871,"line":2920},[2869,8690,4004],{"class":3120},[2869,8692,2869],{"class":3124},[2869,8694,3129],{"class":3128},[2869,8696,3133],{"class":3132},[2869,8698,8636],{"class":3136},[2869,8700,3157],{"class":3120},[2869,8702,8498],{"class":3132},[2869,8704,3162],{"class":3120},[2869,8706,2869],{"class":3124},[2869,8708,3140],{"class":3120},[2869,8710,8711,8713,8715,8717,8719,8721,8723],{"class":2871,"line":2926},[2869,8712,4004],{"class":3120},[2869,8714,2804],{"class":3124},[2869,8716,3157],{"class":3120},[2869,8718,8657],{"class":3132},[2869,8720,3162],{"class":3120},[2869,8722,2804],{"class":3124},[2869,8724,3140],{"class":3120},[2869,8726,8727,8729,8731],{"class":2871,"line":2932},[2869,8728,4064],{"class":3120},[2869,8730,3125],{"class":3124},[2869,8732,3140],{"class":3120},[2869,8734,8735,8737,8739,8741,8743,8746],{"class":2871,"line":2938},[2869,8736,3971],{"class":3120},[2869,8738,3125],{"class":3124},[2869,8740,3129],{"class":3128},[2869,8742,3133],{"class":3132},[2869,8744,8745],{"class":3136},"\"box fit-c\"",[2869,8747,3140],{"class":3120},[2869,8749,8750,8752,8754,8756,8758,8760,8762,8764,8766,8768],{"class":2871,"line":2944},[2869,8751,4004],{"class":3120},[2869,8753,2869],{"class":3124},[2869,8755,3129],{"class":3128},[2869,8757,3133],{"class":3132},[2869,8759,8636],{"class":3136},[2869,8761,3157],{"class":3120},[2869,8763,8513],{"class":3132},[2869,8765,3162],{"class":3120},[2869,8767,2869],{"class":3124},[2869,8769,3140],{"class":3120},[2869,8771,8772,8774,8776,8778,8780,8782,8784],{"class":2871,"line":2950},[2869,8773,4004],{"class":3120},[2869,8775,2804],{"class":3124},[2869,8777,3157],{"class":3120},[2869,8779,8657],{"class":3132},[2869,8781,3162],{"class":3120},[2869,8783,2804],{"class":3124},[2869,8785,3140],{"class":3120},[2869,8787,8788,8790,8792],{"class":2871,"line":2956},[2869,8789,4064],{"class":3120},[2869,8791,3125],{"class":3124},[2869,8793,3140],{"class":3120},[2869,8795,8796,8798,8800,8802,8804,8807],{"class":2871,"line":2962},[2869,8797,3971],{"class":3120},[2869,8799,3125],{"class":3124},[2869,8801,3129],{"class":3128},[2869,8803,3133],{"class":3132},[2869,8805,8806],{"class":3136},"\"box fit-300\"",[2869,8808,3140],{"class":3120},[2869,8810,8811,8813,8815,8817,8819,8821,8823,8826,8828,8830],{"class":2871,"line":3448},[2869,8812,4004],{"class":3120},[2869,8814,2869],{"class":3124},[2869,8816,3129],{"class":3128},[2869,8818,3133],{"class":3132},[2869,8820,8636],{"class":3136},[2869,8822,3157],{"class":3120},[2869,8824,8825],{"class":3132},"fit-content(200px)",[2869,8827,3162],{"class":3120},[2869,8829,2869],{"class":3124},[2869,8831,3140],{"class":3120},[2869,8833,8834,8836,8838,8840,8842,8844,8846],{"class":2871,"line":3505},[2869,8835,4004],{"class":3120},[2869,8837,2804],{"class":3124},[2869,8839,3157],{"class":3120},[2869,8841,8657],{"class":3132},[2869,8843,3162],{"class":3120},[2869,8845,2804],{"class":3124},[2869,8847,3140],{"class":3120},[2869,8849,8850,8852,8854],{"class":2871,"line":3543},[2869,8851,4064],{"class":3120},[2869,8853,3125],{"class":3124},[2869,8855,3140],{"class":3120},[2869,8857,8858,8860,8862],{"class":2871,"line":3573},[2869,8859,4073],{"class":3120},[2869,8861,3125],{"class":3124},[2869,8863,3140],{"class":3120},[2869,8865,8866,8868,8870,8872,8874,8876,8878,8881,8883,8885],{"class":2871,"line":3619},[2869,8867,3145],{"class":3120},[2869,8869,2804],{"class":3124},[2869,8871,3129],{"class":3128},[2869,8873,3133],{"class":3132},[2869,8875,8582],{"class":3136},[2869,8877,3157],{"class":3120},[2869,8879,8880],{"class":3132},"Та ж концепція у grid-колонках:",[2869,8882,3162],{"class":3120},[2869,8884,2804],{"class":3124},[2869,8886,3140],{"class":3120},[2869,8888,8889,8891,8893,8895,8897,8900],{"class":2871,"line":4232},[2869,8890,3145],{"class":3120},[2869,8892,3125],{"class":3124},[2869,8894,3129],{"class":3128},[2869,8896,3133],{"class":3132},[2869,8898,8899],{"class":3136},"\"grid-demo\"",[2869,8901,3140],{"class":3120},[2869,8903,8904,8906,8908,8910,8912,8915,8917,8919,8921,8923],{"class":2871,"line":4241},[2869,8905,3971],{"class":3120},[2869,8907,3125],{"class":3124},[2869,8909,3129],{"class":3128},[2869,8911,3133],{"class":3132},[2869,8913,8914],{"class":3136},"\"g-header\"",[2869,8916,3157],{"class":3120},[2869,8918,2840],{"class":3132},[2869,8920,3162],{"class":3120},[2869,8922,3125],{"class":3124},[2869,8924,3140],{"class":3120},[2869,8926,8927,8929,8931,8933,8935,8937,8939,8941,8943,8945],{"class":2871,"line":6174},[2869,8928,3971],{"class":3120},[2869,8930,3125],{"class":3124},[2869,8932,3129],{"class":3128},[2869,8934,3133],{"class":3132},[2869,8936,8914],{"class":3136},[2869,8938,3157],{"class":3120},[2869,8940,8498],{"class":3132},[2869,8942,3162],{"class":3120},[2869,8944,3125],{"class":3124},[2869,8946,3140],{"class":3120},[2869,8948,8949,8951,8953,8955,8957,8959,8961,8964,8966,8968],{"class":2871,"line":6208},[2869,8950,3971],{"class":3120},[2869,8952,3125],{"class":3124},[2869,8954,3129],{"class":3128},[2869,8956,3133],{"class":3132},[2869,8958,8914],{"class":3136},[2869,8960,3157],{"class":3120},[2869,8962,8963],{"class":3132},"fit-content(150px)",[2869,8965,3162],{"class":3120},[2869,8967,3125],{"class":3124},[2869,8969,3140],{"class":3120},[2869,8971,8972,8974,8976,8978,8980,8983,8985,8988,8990,8992],{"class":2871,"line":6216},[2869,8973,3971],{"class":3120},[2869,8975,3125],{"class":3124},[2869,8977,3129],{"class":3128},[2869,8979,3133],{"class":3132},[2869,8981,8982],{"class":3136},"\"g-cell\"",[2869,8984,3157],{"class":3120},[2869,8986,8987],{"class":3132},"Коротко",[2869,8989,3162],{"class":3120},[2869,8991,3125],{"class":3124},[2869,8993,3140],{"class":3120},[2869,8995,8996,8998,9000,9002,9004,9006,9008,9011,9013,9015],{"class":2871,"line":6229},[2869,8997,3971],{"class":3120},[2869,8999,3125],{"class":3124},[2869,9001,3129],{"class":3128},[2869,9003,3133],{"class":3132},[2869,9005,8982],{"class":3136},[2869,9007,3157],{"class":3120},[2869,9009,9010],{"class":3132},"Трохи довший текст тут",[2869,9012,3162],{"class":3120},[2869,9014,3125],{"class":3124},[2869,9016,3140],{"class":3120},[2869,9018,9019,9021,9023,9025,9027,9029,9031,9034,9036,9038],{"class":2871,"line":6241},[2869,9020,3971],{"class":3120},[2869,9022,3125],{"class":3124},[2869,9024,3129],{"class":3128},[2869,9026,3133],{"class":3132},[2869,9028,8982],{"class":3136},[2869,9030,3157],{"class":3120},[2869,9032,9033],{"class":3132},"Дуже довгий текст що може переноситись",[2869,9035,3162],{"class":3120},[2869,9037,3125],{"class":3124},[2869,9039,3140],{"class":3120},[2869,9041,9042,9044,9046],{"class":2871,"line":6271},[2869,9043,4073],{"class":3120},[2869,9045,3125],{"class":3124},[2869,9047,3140],{"class":3120},[2869,9049,9050,9052,9054],{"class":2871,"line":6283},[2869,9051,3162],{"class":3120},[2869,9053,3125],{"class":3124},[2869,9055,3140],{"class":3120},[2861,9057,9059],{"className":3249,"code":9058,"language":3251,"meta":2865,"style":2865},".intrinsic-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.85rem;\n  color: #1e293b;\n}\n.demo-note { margin: 0 0 0.75rem; color: #64748b; font-style: italic; }\n.showcase { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1rem; }\n.box {\n  background: white;\n  border: 1px solid #e2e8f0;\n  border-radius: 6px;\n  padding: 0.5rem 0.75rem;\n  overflow: hidden;\n}\n.box p { margin: 0; line-height: 1.4; }\n.kw { display: block; font-family: monospace; font-size: 0.75rem; font-weight: 700; margin-bottom: 0.25rem; color: #6366f1; }\n.min-c { width: min-content; }\n.max-c { width: max-content; max-width: 100%; }\n.fit-c { width: fit-content; }\n.fit-300 { width: fit-content(200px); }\n.grid-demo {\n  display: grid;\n  grid-template-columns: min-content max-content fit-content(150px);\n  gap: 2px;\n  overflow-x: auto;\n}\n.g-header {\n  background: #6366f1;\n  color: white;\n  padding: 0.4rem 0.6rem;\n  font-size: 0.72rem;\n  font-weight: 700;\n  font-family: monospace;\n}\n.g-cell {\n  background: white;\n  border: 1px solid #e2e8f0;\n  padding: 0.4rem 0.6rem;\n  font-size: 0.78rem;\n}\n",[2799,9060,9061,9068,9078,9088,9102,9112,9122,9126,9164,9207,9214,9224,9238,9248,9260,9272,9276,9300,9358,9373,9396,9411,9431,9438,9449,9471,9482,9493,9497,9504,9514,9524,9537,9548,9558,9568,9572,9579,9589,9603,9615,9625],{"__ignoreMap":2865},[2869,9062,9063,9066],{"class":2871,"line":2872},[2869,9064,9065],{"class":3258},".intrinsic-demo",[2869,9067,3262],{"class":3132},[2869,9069,9070,9072,9074,9076],{"class":2871,"line":2878},[2869,9071,3307],{"class":3128},[2869,9073,3270],{"class":3132},[2869,9075,3300],{"class":3299},[2869,9077,3277],{"class":3132},[2869,9079,9080,9082,9084,9086],{"class":2871,"line":2884},[2869,9081,3319],{"class":3128},[2869,9083,3270],{"class":3132},[2869,9085,3324],{"class":3273},[2869,9087,3277],{"class":3132},[2869,9089,9090,9092,9094,9096,9098,9100],{"class":2871,"line":2890},[2869,9091,3331],{"class":3128},[2869,9093,3270],{"class":3132},[2869,9095,3336],{"class":3273},[2869,9097,2810],{"class":3132},[2869,9099,3341],{"class":3273},[2869,9101,3277],{"class":3132},[2869,9103,9104,9106,9108,9110],{"class":2871,"line":2896},[2869,9105,3348],{"class":3128},[2869,9107,3270],{"class":3132},[2869,9109,3353],{"class":3299},[2869,9111,3277],{"class":3132},[2869,9113,9114,9116,9118,9120],{"class":2871,"line":2902},[2869,9115,3397],{"class":3128},[2869,9117,3270],{"class":3132},[2869,9119,3402],{"class":3273},[2869,9121,3277],{"class":3132},[2869,9123,9124],{"class":2871,"line":2908},[2869,9125,3360],{"class":3132},[2869,9127,9128,9131,9133,9135,9137,9139,9141,9143,9145,9148,9150,9152,9154,9157,9159,9162],{"class":2871,"line":2914},[2869,9129,9130],{"class":3258},".demo-note",[2869,9132,3434],{"class":3132},[2869,9134,4328],{"class":3128},[2869,9136,3270],{"class":3132},[2869,9138,3460],{"class":3299},[2869,9140,4335],{"class":3299},[2869,9142,6293],{"class":3299},[2869,9144,3521],{"class":3132},[2869,9146,9147],{"class":3128},"color",[2869,9149,3270],{"class":3132},[2869,9151,7822],{"class":3273},[2869,9153,3521],{"class":3132},[2869,9155,9156],{"class":3128},"font-style",[2869,9158,3270],{"class":3132},[2869,9160,9161],{"class":3273},"italic",[2869,9163,3445],{"class":3132},[2869,9165,9166,9169,9171,9174,9176,9178,9180,9183,9185,9187,9189,9192,9194,9196,9198,9201,9203,9205],{"class":2871,"line":2920},[2869,9167,9168],{"class":3258},".showcase",[2869,9170,3434],{"class":3132},[2869,9172,9173],{"class":3128},"display",[2869,9175,3270],{"class":3132},[2869,9177,3274],{"class":3273},[2869,9179,3521],{"class":3132},[2869,9181,9182],{"class":3128},"flex-direction",[2869,9184,3270],{"class":3132},[2869,9186,5227],{"class":3273},[2869,9188,3521],{"class":3132},[2869,9190,9191],{"class":3128},"gap",[2869,9193,3270],{"class":3132},[2869,9195,6109],{"class":3299},[2869,9197,3521],{"class":3132},[2869,9199,9200],{"class":3128},"margin-bottom",[2869,9202,3270],{"class":3132},[2869,9204,3300],{"class":3299},[2869,9206,3445],{"class":3132},[2869,9208,9209,9212],{"class":2871,"line":2926},[2869,9210,9211],{"class":3258},".box",[2869,9213,3262],{"class":3132},[2869,9215,9216,9218,9220,9222],{"class":2871,"line":2932},[2869,9217,3319],{"class":3128},[2869,9219,3270],{"class":3132},[2869,9221,3390],{"class":3273},[2869,9223,3277],{"class":3132},[2869,9225,9226,9228,9230,9232,9234,9236],{"class":2871,"line":2938},[2869,9227,3409],{"class":3128},[2869,9229,3270],{"class":3132},[2869,9231,3414],{"class":3299},[2869,9233,3417],{"class":3273},[2869,9235,3420],{"class":3273},[2869,9237,3277],{"class":3132},[2869,9239,9240,9242,9244,9246],{"class":2871,"line":2944},[2869,9241,4741],{"class":3128},[2869,9243,3270],{"class":3132},[2869,9245,6278],{"class":3299},[2869,9247,3277],{"class":3132},[2869,9249,9250,9252,9254,9256,9258],{"class":2871,"line":2950},[2869,9251,3307],{"class":3128},[2869,9253,3270],{"class":3132},[2869,9255,6109],{"class":3299},[2869,9257,6293],{"class":3299},[2869,9259,3277],{"class":3132},[2869,9261,9262,9265,9267,9270],{"class":2871,"line":2956},[2869,9263,9264],{"class":3128},"  overflow",[2869,9266,3270],{"class":3132},[2869,9268,9269],{"class":3273},"hidden",[2869,9271,3277],{"class":3132},[2869,9273,9274],{"class":2871,"line":2962},[2869,9275,3360],{"class":3132},[2869,9277,9278,9280,9282,9284,9286,9288,9290,9292,9294,9296,9298],{"class":2871,"line":3448},[2869,9279,9211],{"class":3258},[2869,9281,4459],{"class":3258},[2869,9283,3434],{"class":3132},[2869,9285,4328],{"class":3128},[2869,9287,3270],{"class":3132},[2869,9289,3460],{"class":3299},[2869,9291,3521],{"class":3132},[2869,9293,5489],{"class":3128},[2869,9295,3270],{"class":3132},[2869,9297,7142],{"class":3299},[2869,9299,3445],{"class":3132},[2869,9301,9302,9305,9307,9309,9311,9313,9315,9318,9320,9322,9324,9326,9328,9330,9332,9335,9337,9340,9342,9344,9346,9348,9350,9352,9354,9356],{"class":2871,"line":3505},[2869,9303,9304],{"class":3258},".kw",[2869,9306,3434],{"class":3132},[2869,9308,9173],{"class":3128},[2869,9310,3270],{"class":3132},[2869,9312,8146],{"class":3273},[2869,9314,3521],{"class":3132},[2869,9316,9317],{"class":3128},"font-family",[2869,9319,3270],{"class":3132},[2869,9321,7086],{"class":3273},[2869,9323,3521],{"class":3132},[2869,9325,3584],{"class":3128},[2869,9327,3270],{"class":3132},[2869,9329,3376],{"class":3299},[2869,9331,3521],{"class":3132},[2869,9333,9334],{"class":3128},"font-weight",[2869,9336,3270],{"class":3132},[2869,9338,9339],{"class":3299},"700",[2869,9341,3521],{"class":3132},[2869,9343,9200],{"class":3128},[2869,9345,3270],{"class":3132},[2869,9347,4480],{"class":3299},[2869,9349,3521],{"class":3132},[2869,9351,9147],{"class":3128},[2869,9353,3270],{"class":3132},[2869,9355,3538],{"class":3273},[2869,9357,3445],{"class":3132},[2869,9359,9360,9363,9365,9367,9369,9371],{"class":2871,"line":3543},[2869,9361,9362],{"class":3258},".min-c",[2869,9364,3434],{"class":3132},[2869,9366,3513],{"class":3128},[2869,9368,3270],{"class":3132},[2869,9370,2840],{"class":3273},[2869,9372,3445],{"class":3132},[2869,9374,9375,9378,9380,9382,9384,9386,9388,9390,9392,9394],{"class":2871,"line":3573},[2869,9376,9377],{"class":3258},".max-c",[2869,9379,3434],{"class":3132},[2869,9381,3513],{"class":3128},[2869,9383,3270],{"class":3132},[2869,9385,8498],{"class":3273},[2869,9387,3521],{"class":3132},[2869,9389,5372],{"class":3128},[2869,9391,3270],{"class":3132},[2869,9393,6236],{"class":3299},[2869,9395,3445],{"class":3132},[2869,9397,9398,9401,9403,9405,9407,9409],{"class":2871,"line":3619},[2869,9399,9400],{"class":3258},".fit-c",[2869,9402,3434],{"class":3132},[2869,9404,3513],{"class":3128},[2869,9406,3270],{"class":3132},[2869,9408,8513],{"class":3273},[2869,9410,3445],{"class":3132},[2869,9412,9413,9416,9418,9420,9422,9424,9426,9429],{"class":2871,"line":4232},[2869,9414,9415],{"class":3258},".fit-300",[2869,9417,3434],{"class":3132},[2869,9419,3513],{"class":3128},[2869,9421,3270],{"class":3132},[2869,9423,8513],{"class":3469},[2869,9425,3473],{"class":3132},[2869,9427,9428],{"class":3299},"200px",[2869,9430,7178],{"class":3132},[2869,9432,9433,9436],{"class":2871,"line":4241},[2869,9434,9435],{"class":3258},".grid-demo",[2869,9437,3262],{"class":3132},[2869,9439,9440,9442,9444,9447],{"class":2871,"line":6174},[2869,9441,3267],{"class":3128},[2869,9443,3270],{"class":3132},[2869,9445,9446],{"class":3273},"grid",[2869,9448,3277],{"class":3132},[2869,9450,9451,9454,9456,9458,9461,9464,9466,9469],{"class":2871,"line":6208},[2869,9452,9453],{"class":3128},"  grid-template-columns",[2869,9455,3270],{"class":3132},[2869,9457,2840],{"class":3273},[2869,9459,9460],{"class":3273}," max-content",[2869,9462,9463],{"class":3469}," fit-content",[2869,9465,3473],{"class":3132},[2869,9467,9468],{"class":3299},"150px",[2869,9470,6047],{"class":3132},[2869,9472,9473,9475,9477,9480],{"class":2871,"line":6216},[2869,9474,3294],{"class":3128},[2869,9476,3270],{"class":3132},[2869,9478,9479],{"class":3299},"2px",[2869,9481,3277],{"class":3132},[2869,9483,9484,9487,9489,9491],{"class":2871,"line":6229},[2869,9485,9486],{"class":3128},"  overflow-x",[2869,9488,3270],{"class":3132},[2869,9490,4988],{"class":3273},[2869,9492,3277],{"class":3132},[2869,9494,9495],{"class":2871,"line":6241},[2869,9496,3360],{"class":3132},[2869,9498,9499,9502],{"class":2871,"line":6271},[2869,9500,9501],{"class":3258},".g-header",[2869,9503,3262],{"class":3132},[2869,9505,9506,9508,9510,9512],{"class":2871,"line":6283},[2869,9507,3319],{"class":3128},[2869,9509,3270],{"class":3132},[2869,9511,3538],{"class":3273},[2869,9513,3277],{"class":3132},[2869,9515,9516,9518,9520,9522],{"class":2871,"line":6298},[2869,9517,3397],{"class":3128},[2869,9519,3270],{"class":3132},[2869,9521,3390],{"class":3273},[2869,9523,3277],{"class":3132},[2869,9525,9526,9528,9530,9532,9535],{"class":2871,"line":6310},[2869,9527,3307],{"class":3128},[2869,9529,3270],{"class":3132},[2869,9531,6290],{"class":3299},[2869,9533,9534],{"class":3299}," 0.6rem",[2869,9536,3277],{"class":3132},[2869,9538,9539,9541,9543,9546],{"class":2871,"line":6321},[2869,9540,3348],{"class":3128},[2869,9542,3270],{"class":3132},[2869,9544,9545],{"class":3299},"0.72rem",[2869,9547,3277],{"class":3132},[2869,9549,9550,9552,9554,9556],{"class":2871,"line":6326},[2869,9551,5652],{"class":3128},[2869,9553,3270],{"class":3132},[2869,9555,9339],{"class":3299},[2869,9557,3277],{"class":3132},[2869,9559,9560,9562,9564,9566],{"class":2871,"line":6334},[2869,9561,3331],{"class":3128},[2869,9563,3270],{"class":3132},[2869,9565,7086],{"class":3273},[2869,9567,3277],{"class":3132},[2869,9569,9570],{"class":2871,"line":6345},[2869,9571,3360],{"class":3132},[2869,9573,9574,9577],{"class":2871,"line":6356},[2869,9575,9576],{"class":3258},".g-cell",[2869,9578,3262],{"class":3132},[2869,9580,9581,9583,9585,9587],{"class":2871,"line":6367},[2869,9582,3319],{"class":3128},[2869,9584,3270],{"class":3132},[2869,9586,3390],{"class":3273},[2869,9588,3277],{"class":3132},[2869,9590,9591,9593,9595,9597,9599,9601],{"class":2871,"line":6382},[2869,9592,3409],{"class":3128},[2869,9594,3270],{"class":3132},[2869,9596,3414],{"class":3299},[2869,9598,3417],{"class":3273},[2869,9600,3420],{"class":3273},[2869,9602,3277],{"class":3132},[2869,9604,9605,9607,9609,9611,9613],{"class":2871,"line":6387},[2869,9606,3307],{"class":3128},[2869,9608,3270],{"class":3132},[2869,9610,6290],{"class":3299},[2869,9612,9534],{"class":3299},[2869,9614,3277],{"class":3132},[2869,9616,9617,9619,9621,9623],{"class":2871,"line":6395},[2869,9618,3348],{"class":3128},[2869,9620,3270],{"class":3132},[2869,9622,7119],{"class":3299},[2869,9624,3277],{"class":3132},[2869,9626,9627],{"class":2871,"line":6407},[2869,9628,3360],{"class":3132},[2804,9630,9631,9632,9635,9636,3070],{},"Особливо важливі ці ключові слова у ",[2977,9633,9634],{},"Grid Layout"," у рядку ",[2799,9637,9638],{},"grid-template-columns",[2861,9640,9642],{"className":3249,"code":9641,"language":3251,"meta":2865,"style":2865},".layout {\n  display: grid;\n  /* Перша колонка — під вміст, друга — залишок */\n  grid-template-columns: max-content 1fr;\n}\n\n.nav {\n  display: grid;\n  /* Кожна колонка — під свій вміст, але не більше 200px */\n  grid-template-columns: repeat(auto-fill, fit-content(200px));\n}\n",[2799,9643,9644,9651,9661,9666,9679,9683,9687,9694,9704,9709,9734],{"__ignoreMap":2865},[2869,9645,9646,9649],{"class":2871,"line":2872},[2869,9647,9648],{"class":3258},".layout",[2869,9650,3262],{"class":3132},[2869,9652,9653,9655,9657,9659],{"class":2871,"line":2878},[2869,9654,3267],{"class":3128},[2869,9656,3270],{"class":3132},[2869,9658,9446],{"class":3273},[2869,9660,3277],{"class":3132},[2869,9662,9663],{"class":2871,"line":2884},[2869,9664,9665],{"class":3762},"  /* Перша колонка — під вміст, друга — залишок */\n",[2869,9667,9668,9670,9672,9674,9677],{"class":2871,"line":2890},[2869,9669,9453],{"class":3128},[2869,9671,3270],{"class":3132},[2869,9673,8498],{"class":3273},[2869,9675,9676],{"class":3299}," 1fr",[2869,9678,3277],{"class":3132},[2869,9680,9681],{"class":2871,"line":2896},[2869,9682,3360],{"class":3132},[2869,9684,9685],{"class":2871,"line":2902},[2869,9686,4758],{"emptyLinePlaceholder":4757},[2869,9688,9689,9692],{"class":2871,"line":2908},[2869,9690,9691],{"class":3258},".nav",[2869,9693,3262],{"class":3132},[2869,9695,9696,9698,9700,9702],{"class":2871,"line":2914},[2869,9697,3267],{"class":3128},[2869,9699,3270],{"class":3132},[2869,9701,9446],{"class":3273},[2869,9703,3277],{"class":3132},[2869,9705,9706],{"class":2871,"line":2920},[2869,9707,9708],{"class":3762},"  /* Кожна колонка — під свій вміст, але не більше 200px */\n",[2869,9710,9711,9713,9715,9718,9720,9723,9725,9727,9729,9731],{"class":2871,"line":2926},[2869,9712,9453],{"class":3128},[2869,9714,3270],{"class":3132},[2869,9716,9717],{"class":3469},"repeat",[2869,9719,3473],{"class":3132},[2869,9721,9722],{"class":3273},"auto-fill",[2869,9724,2810],{"class":3132},[2869,9726,8513],{"class":3469},[2869,9728,3473],{"class":3132},[2869,9730,9428],{"class":3299},[2869,9732,9733],{"class":3132},"));\n",[2869,9735,9736],{"class":2871,"line":2932},[2869,9737,3360],{"class":3132},[2967,9739],{},[2794,9741,9743,2810,9745,9747,9748,4921,9751,9754],{"id":9742},"width-height-та-їх-min-max-варіанти",[2799,9744,3513],{},[2799,9746,3524],{}," та їх ",[2799,9749,9750],{},"min-",[2799,9752,9753],{},"max-"," варіанти",[2982,9756,9758],{"id":9757},"паттерн-fluid-container","Паттерн: fluid container",[2804,9760,9761,9762,9765,9766,9769,9770,3070],{},"Один із найважливіших патернів у сучасній верстці — елемент, що ",[2977,9763,9764],{},"займає все доступне місце",", але ",[2977,9767,9768],{},"не перевищує певний максимум"," і ",[2977,9771,9772],{},"не стискається нижче певного мінімуму",[2861,9774,9776],{"className":3249,"code":9775,"language":3251,"meta":2865,"style":2865},"/* Класичний fluid container */\n.container {\n  width: 100%;          /* займає все доступне */\n  max-width: 1200px;    /* але не більше 1200px */\n  margin-inline: auto;  /* центруємо */\n  padding-inline: 1rem; /* горизонтальні відступи */\n}\n",[2799,9777,9778,9783,9790,9804,9819,9832,9846],{"__ignoreMap":2865},[2869,9779,9780],{"class":2871,"line":2872},[2869,9781,9782],{"class":3762},"/* Класичний fluid container */\n",[2869,9784,9785,9788],{"class":2871,"line":2878},[2869,9786,9787],{"class":3258},".container",[2869,9789,3262],{"class":3132},[2869,9791,9792,9794,9796,9798,9801],{"class":2871,"line":2884},[2869,9793,6219],{"class":3128},[2869,9795,3270],{"class":3132},[2869,9797,6236],{"class":3299},[2869,9799,9800],{"class":3132},";          ",[2869,9802,9803],{"class":3762},"/* займає все доступне */\n",[2869,9805,9806,9808,9810,9813,9816],{"class":2871,"line":2890},[2869,9807,4968],{"class":3128},[2869,9809,3270],{"class":3132},[2869,9811,9812],{"class":3299},"1200px",[2869,9814,9815],{"class":3132},";    ",[2869,9817,9818],{"class":3762},"/* але не більше 1200px */\n",[2869,9820,9821,9823,9825,9827,9829],{"class":2871,"line":2896},[2869,9822,4983],{"class":3128},[2869,9824,3270],{"class":3132},[2869,9826,4988],{"class":3273},[2869,9828,4733],{"class":3132},[2869,9830,9831],{"class":3762},"/* центруємо */\n",[2869,9833,9834,9837,9839,9841,9843],{"class":2871,"line":2902},[2869,9835,9836],{"class":3128},"  padding-inline",[2869,9838,3270],{"class":3132},[2869,9840,3300],{"class":3299},[2869,9842,3521],{"class":3132},[2869,9844,9845],{"class":3762},"/* горизонтальні відступи */\n",[2869,9847,9848],{"class":2871,"line":2908},[2869,9849,3360],{"class":3132},[3107,9851,9852,10044],{},[2861,9853,9855],{"className":3111,"code":9854,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"fluid-demo\">\n  \u003Cdiv class=\"fluid-container\">\n    \u003Cdiv class=\"content-block\">\n      \u003Ch3>Fluid Container\u003C/h3>\n      \u003Cp>\u003Ccode>width: 100%; max-width: 900px; margin: 0 auto;\u003C/code>\u003C/p>\n      \u003Cp>Цей блок займає всю доступну ширину, але обмежений 900px. Спробуйте змінити розмір вікна.\u003C/p>\n    \u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"text-container\">\n    \u003Cp>А цей текстовий контейнер використовує \u003Ccode>max-width: 65ch\u003C/code> — ніколи не буде більше 65 символів у рядку, але звужується на малих екранах.\u003C/p>\n  \u003C/div>\n\u003C/div>\n",[2799,9856,9857,9872,9887,9902,9919,9946,9963,9971,9979,9994,10028,10036],{"__ignoreMap":2865},[2869,9858,9859,9861,9863,9865,9867,9870],{"class":2871,"line":2872},[2869,9860,3121],{"class":3120},[2869,9862,3125],{"class":3124},[2869,9864,3129],{"class":3128},[2869,9866,3133],{"class":3132},[2869,9868,9869],{"class":3136},"\"fluid-demo\"",[2869,9871,3140],{"class":3120},[2869,9873,9874,9876,9878,9880,9882,9885],{"class":2871,"line":2878},[2869,9875,3145],{"class":3120},[2869,9877,3125],{"class":3124},[2869,9879,3129],{"class":3128},[2869,9881,3133],{"class":3132},[2869,9883,9884],{"class":3136},"\"fluid-container\"",[2869,9886,3140],{"class":3120},[2869,9888,9889,9891,9893,9895,9897,9900],{"class":2871,"line":2884},[2869,9890,3971],{"class":3120},[2869,9892,3125],{"class":3124},[2869,9894,3129],{"class":3128},[2869,9896,3133],{"class":3132},[2869,9898,9899],{"class":3136},"\"content-block\"",[2869,9901,3140],{"class":3120},[2869,9903,9904,9906,9908,9910,9913,9915,9917],{"class":2871,"line":2890},[2869,9905,4004],{"class":3120},[2869,9907,2982],{"class":3124},[2869,9909,3157],{"class":3120},[2869,9911,9912],{"class":3132},"Fluid Container",[2869,9914,3162],{"class":3120},[2869,9916,2982],{"class":3124},[2869,9918,3140],{"class":3120},[2869,9920,9921,9923,9925,9928,9930,9932,9935,9937,9939,9942,9944],{"class":2871,"line":2896},[2869,9922,4004],{"class":3120},[2869,9924,2804],{"class":3124},[2869,9926,9927],{"class":3120},">\u003C",[2869,9929,2799],{"class":3124},[2869,9931,3157],{"class":3120},[2869,9933,9934],{"class":3132},"width: 100%; max-width: 900px; margin: 0 auto;",[2869,9936,3162],{"class":3120},[2869,9938,2799],{"class":3124},[2869,9940,9941],{"class":3120},">\u003C/",[2869,9943,2804],{"class":3124},[2869,9945,3140],{"class":3120},[2869,9947,9948,9950,9952,9954,9957,9959,9961],{"class":2871,"line":2902},[2869,9949,4004],{"class":3120},[2869,9951,2804],{"class":3124},[2869,9953,3157],{"class":3120},[2869,9955,9956],{"class":3132},"Цей блок займає всю доступну ширину, але обмежений 900px. Спробуйте змінити розмір вікна.",[2869,9958,3162],{"class":3120},[2869,9960,2804],{"class":3124},[2869,9962,3140],{"class":3120},[2869,9964,9965,9967,9969],{"class":2871,"line":2908},[2869,9966,4064],{"class":3120},[2869,9968,3125],{"class":3124},[2869,9970,3140],{"class":3120},[2869,9972,9973,9975,9977],{"class":2871,"line":2914},[2869,9974,4073],{"class":3120},[2869,9976,3125],{"class":3124},[2869,9978,3140],{"class":3120},[2869,9980,9981,9983,9985,9987,9989,9992],{"class":2871,"line":2920},[2869,9982,3145],{"class":3120},[2869,9984,3125],{"class":3124},[2869,9986,3129],{"class":3128},[2869,9988,3133],{"class":3132},[2869,9990,9991],{"class":3136},"\"text-container\"",[2869,9993,3140],{"class":3120},[2869,9995,9996,9998,10000,10002,10005,10007,10009,10011,10013,10015,10017,10019,10022,10024,10026],{"class":2871,"line":2926},[2869,9997,3971],{"class":3120},[2869,9999,2804],{"class":3124},[2869,10001,3157],{"class":3120},[2869,10003,10004],{"class":3132},"А цей текстовий контейнер використовує ",[2869,10006,3121],{"class":3120},[2869,10008,2799],{"class":3124},[2869,10010,3157],{"class":3120},[2869,10012,5099],{"class":3132},[2869,10014,3162],{"class":3120},[2869,10016,2799],{"class":3124},[2869,10018,3157],{"class":3120},[2869,10020,10021],{"class":3132}," — ніколи не буде більше 65 символів у рядку, але звужується на малих екранах.",[2869,10023,3162],{"class":3120},[2869,10025,2804],{"class":3124},[2869,10027,3140],{"class":3120},[2869,10029,10030,10032,10034],{"class":2871,"line":2932},[2869,10031,4073],{"class":3120},[2869,10033,3125],{"class":3124},[2869,10035,3140],{"class":3120},[2869,10037,10038,10040,10042],{"class":2871,"line":2938},[2869,10039,3162],{"class":3120},[2869,10041,3125],{"class":3124},[2869,10043,3140],{"class":3120},[2861,10045,10047],{"className":3249,"code":10046,"language":3251,"meta":2865,"style":2865},".fluid-demo {\n  background: #f1f5f9;\n  padding: 1rem;\n  font-family: system-ui, sans-serif;\n  font-size: 0.875rem;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.75rem;\n}\n.fluid-container {\n  width: 100%;\n  max-width: 900px;\n  margin: 0 auto;\n  background: white;\n  border-radius: 10px;\n  border: 2px solid #6366f1;\n  padding: 1rem;\n}\n.content-block h3 { margin: 0 0 0.5rem; font-size: 1rem; color: #6366f1; }\n.content-block p { margin: 0.25rem 0; line-height: 1.5; }\n.content-block code { background: #f1f5f9; padding: 0.1em 0.3em; border-radius: 4px; font-size: 0.85em; }\n.text-container {\n  max-width: 65ch;\n  margin: 0 auto;\n  background: #ede9fe;\n  border-radius: 8px;\n  padding: 0.75rem 1rem;\n  border-left: 4px solid #8b5cf6;\n  line-height: 1.6;\n}\n.text-container code { background: white; padding: 0.1em 0.3em; border-radius: 4px; font-size: 0.85em; font-weight: 600; }\n",[2799,10048,10049,10056,10066,10076,10090,10100,10110,10120,10130,10140,10144,10151,10161,10172,10185,10195,10205,10219,10229,10233,10271,10298,10343,10350,10360,10372,10383,10393,10406,10421,10431,10435],{"__ignoreMap":2865},[2869,10050,10051,10054],{"class":2871,"line":2872},[2869,10052,10053],{"class":3258},".fluid-demo",[2869,10055,3262],{"class":3132},[2869,10057,10058,10060,10062,10064],{"class":2871,"line":2878},[2869,10059,3319],{"class":3128},[2869,10061,3270],{"class":3132},[2869,10063,5996],{"class":3273},[2869,10065,3277],{"class":3132},[2869,10067,10068,10070,10072,10074],{"class":2871,"line":2884},[2869,10069,3307],{"class":3128},[2869,10071,3270],{"class":3132},[2869,10073,3300],{"class":3299},[2869,10075,3277],{"class":3132},[2869,10077,10078,10080,10082,10084,10086,10088],{"class":2871,"line":2890},[2869,10079,3331],{"class":3128},[2869,10081,3270],{"class":3132},[2869,10083,3336],{"class":3273},[2869,10085,2810],{"class":3132},[2869,10087,3341],{"class":3273},[2869,10089,3277],{"class":3132},[2869,10091,10092,10094,10096,10098],{"class":2871,"line":2896},[2869,10093,3348],{"class":3128},[2869,10095,3270],{"class":3132},[2869,10097,6419],{"class":3299},[2869,10099,3277],{"class":3132},[2869,10101,10102,10104,10106,10108],{"class":2871,"line":2902},[2869,10103,3397],{"class":3128},[2869,10105,3270],{"class":3132},[2869,10107,3402],{"class":3273},[2869,10109,3277],{"class":3132},[2869,10111,10112,10114,10116,10118],{"class":2871,"line":2908},[2869,10113,3267],{"class":3128},[2869,10115,3270],{"class":3132},[2869,10117,3274],{"class":3273},[2869,10119,3277],{"class":3132},[2869,10121,10122,10124,10126,10128],{"class":2871,"line":2914},[2869,10123,5222],{"class":3128},[2869,10125,3270],{"class":3132},[2869,10127,5227],{"class":3273},[2869,10129,3277],{"class":3132},[2869,10131,10132,10134,10136,10138],{"class":2871,"line":2920},[2869,10133,3294],{"class":3128},[2869,10135,3270],{"class":3132},[2869,10137,3376],{"class":3299},[2869,10139,3277],{"class":3132},[2869,10141,10142],{"class":2871,"line":2926},[2869,10143,3360],{"class":3132},[2869,10145,10146,10149],{"class":2871,"line":2932},[2869,10147,10148],{"class":3258},".fluid-container",[2869,10150,3262],{"class":3132},[2869,10152,10153,10155,10157,10159],{"class":2871,"line":2938},[2869,10154,6219],{"class":3128},[2869,10156,3270],{"class":3132},[2869,10158,6236],{"class":3299},[2869,10160,3277],{"class":3132},[2869,10162,10163,10165,10167,10170],{"class":2871,"line":2944},[2869,10164,4968],{"class":3128},[2869,10166,3270],{"class":3132},[2869,10168,10169],{"class":3299},"900px",[2869,10171,3277],{"class":3132},[2869,10173,10174,10176,10178,10180,10183],{"class":2871,"line":2950},[2869,10175,6398],{"class":3128},[2869,10177,3270],{"class":3132},[2869,10179,3460],{"class":3299},[2869,10181,10182],{"class":3273}," auto",[2869,10184,3277],{"class":3132},[2869,10186,10187,10189,10191,10193],{"class":2871,"line":2956},[2869,10188,3319],{"class":3128},[2869,10190,3270],{"class":3132},[2869,10192,3390],{"class":3273},[2869,10194,3277],{"class":3132},[2869,10196,10197,10199,10201,10203],{"class":2871,"line":2962},[2869,10198,4741],{"class":3128},[2869,10200,3270],{"class":3132},[2869,10202,6056],{"class":3299},[2869,10204,3277],{"class":3132},[2869,10206,10207,10209,10211,10213,10215,10217],{"class":2871,"line":3448},[2869,10208,3409],{"class":3128},[2869,10210,3270],{"class":3132},[2869,10212,9479],{"class":3299},[2869,10214,3417],{"class":3273},[2869,10216,4639],{"class":3273},[2869,10218,3277],{"class":3132},[2869,10220,10221,10223,10225,10227],{"class":2871,"line":3505},[2869,10222,3307],{"class":3128},[2869,10224,3270],{"class":3132},[2869,10226,3300],{"class":3299},[2869,10228,3277],{"class":3132},[2869,10230,10231],{"class":2871,"line":3543},[2869,10232,3360],{"class":3132},[2869,10234,10235,10238,10241,10243,10245,10247,10249,10251,10253,10255,10257,10259,10261,10263,10265,10267,10269],{"class":2871,"line":3573},[2869,10236,10237],{"class":3258},".content-block",[2869,10239,10240],{"class":3258}," h3",[2869,10242,3434],{"class":3132},[2869,10244,4328],{"class":3128},[2869,10246,3270],{"class":3132},[2869,10248,3460],{"class":3299},[2869,10250,4335],{"class":3299},[2869,10252,4338],{"class":3299},[2869,10254,3521],{"class":3132},[2869,10256,3584],{"class":3128},[2869,10258,3270],{"class":3132},[2869,10260,3300],{"class":3299},[2869,10262,3521],{"class":3132},[2869,10264,9147],{"class":3128},[2869,10266,3270],{"class":3132},[2869,10268,3538],{"class":3273},[2869,10270,3445],{"class":3132},[2869,10272,10273,10275,10277,10279,10281,10283,10285,10287,10289,10291,10293,10296],{"class":2871,"line":3619},[2869,10274,10237],{"class":3258},[2869,10276,4459],{"class":3258},[2869,10278,3434],{"class":3132},[2869,10280,4328],{"class":3128},[2869,10282,3270],{"class":3132},[2869,10284,4480],{"class":3299},[2869,10286,4335],{"class":3299},[2869,10288,3521],{"class":3132},[2869,10290,5489],{"class":3128},[2869,10292,3270],{"class":3132},[2869,10294,10295],{"class":3299},"1.5",[2869,10297,3445],{"class":3132},[2869,10299,10300,10302,10305,10307,10309,10311,10313,10315,10317,10319,10321,10324,10326,10328,10330,10332,10334,10336,10338,10341],{"class":2871,"line":4232},[2869,10301,10237],{"class":3258},[2869,10303,10304],{"class":3258}," code",[2869,10306,3434],{"class":3132},[2869,10308,3533],{"class":3128},[2869,10310,3270],{"class":3132},[2869,10312,5996],{"class":3273},[2869,10314,3521],{"class":3132},[2869,10316,3593],{"class":3128},[2869,10318,3270],{"class":3132},[2869,10320,5633],{"class":3299},[2869,10322,10323],{"class":3299}," 0.3em",[2869,10325,3521],{"class":3132},[2869,10327,3437],{"class":3128},[2869,10329,3270],{"class":3132},[2869,10331,3614],{"class":3299},[2869,10333,3521],{"class":3132},[2869,10335,3584],{"class":3128},[2869,10337,3270],{"class":3132},[2869,10339,10340],{"class":3299},"0.85em",[2869,10342,3445],{"class":3132},[2869,10344,10345,10348],{"class":2871,"line":4241},[2869,10346,10347],{"class":3258},".text-container",[2869,10349,3262],{"class":3132},[2869,10351,10352,10354,10356,10358],{"class":2871,"line":6174},[2869,10353,4968],{"class":3128},[2869,10355,3270],{"class":3132},[2869,10357,4973],{"class":3299},[2869,10359,3277],{"class":3132},[2869,10361,10362,10364,10366,10368,10370],{"class":2871,"line":6208},[2869,10363,6398],{"class":3128},[2869,10365,3270],{"class":3132},[2869,10367,3460],{"class":3299},[2869,10369,10182],{"class":3273},[2869,10371,3277],{"class":3132},[2869,10373,10374,10376,10378,10381],{"class":2871,"line":6216},[2869,10375,3319],{"class":3128},[2869,10377,3270],{"class":3132},[2869,10379,10380],{"class":3273},"#ede9fe",[2869,10382,3277],{"class":3132},[2869,10384,10385,10387,10389,10391],{"class":2871,"line":6229},[2869,10386,4741],{"class":3128},[2869,10388,3270],{"class":3132},[2869,10390,3442],{"class":3299},[2869,10392,3277],{"class":3132},[2869,10394,10395,10397,10399,10401,10404],{"class":2871,"line":6241},[2869,10396,3307],{"class":3128},[2869,10398,3270],{"class":3132},[2869,10400,3376],{"class":3299},[2869,10402,10403],{"class":3299}," 1rem",[2869,10405,3277],{"class":3132},[2869,10407,10408,10410,10412,10414,10416,10419],{"class":2871,"line":6271},[2869,10409,5350],{"class":3128},[2869,10411,3270],{"class":3132},[2869,10413,3614],{"class":3299},[2869,10415,3417],{"class":3273},[2869,10417,10418],{"class":3273}," #8b5cf6",[2869,10420,3277],{"class":3132},[2869,10422,10423,10425,10427,10429],{"class":2871,"line":6283},[2869,10424,5640],{"class":3128},[2869,10426,3270],{"class":3132},[2869,10428,5494],{"class":3299},[2869,10430,3277],{"class":3132},[2869,10432,10433],{"class":2871,"line":6298},[2869,10434,3360],{"class":3132},[2869,10436,10437,10439,10441,10443,10445,10447,10449,10451,10453,10455,10457,10459,10461,10463,10465,10467,10469,10471,10473,10475,10477,10479,10481,10483],{"class":2871,"line":6310},[2869,10438,10347],{"class":3258},[2869,10440,10304],{"class":3258},[2869,10442,3434],{"class":3132},[2869,10444,3533],{"class":3128},[2869,10446,3270],{"class":3132},[2869,10448,3390],{"class":3273},[2869,10450,3521],{"class":3132},[2869,10452,3593],{"class":3128},[2869,10454,3270],{"class":3132},[2869,10456,5633],{"class":3299},[2869,10458,10323],{"class":3299},[2869,10460,3521],{"class":3132},[2869,10462,3437],{"class":3128},[2869,10464,3270],{"class":3132},[2869,10466,3614],{"class":3299},[2869,10468,3521],{"class":3132},[2869,10470,3584],{"class":3128},[2869,10472,3270],{"class":3132},[2869,10474,10340],{"class":3299},[2869,10476,3521],{"class":3132},[2869,10478,9334],{"class":3128},[2869,10480,3270],{"class":3132},[2869,10482,6451],{"class":3299},[2869,10484,3445],{"class":3132},[2982,10486,2797,10488,10491],{"id":10487},"чому-height-100-не-завжди-працює",[2799,10489,10490],{},"height: 100%"," не завжди працює",[2804,10493,10494,10495,10497,10498,10500,10501,3905],{},"Це одне з найчастіших питань новачків. Якщо задати ",[2799,10496,10490],{},", але батьківський елемент не має явно заданої висоти — нічого не відбудеться. Браузер не може обчислити ",[2799,10499,6236],{}," від ",[2799,10502,4988],{},[3107,10504,10505,10813],{},[2861,10506,10508],{"className":3111,"code":10507,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"height-demo\">\n  \u003Cdiv class=\"broken-case\">\n    \u003Cp class=\"case-label\">❌ Зламаний: height: 100%\u003C/p>\n    \u003Cdiv class=\"parent-no-height\">\n      \u003Cdiv class=\"child-100p\">Я хочу бути 100% висоти батька, але батько — auto!\u003C/div>\n    \u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"fixed-case\">\n    \u003Cp class=\"case-label\">✅ Виправлений: батько має висоту\u003C/p>\n    \u003Cdiv class=\"parent-has-height\">\n      \u003Cdiv class=\"child-100p-ok\">Тепер я справді займаю 100% батька!\u003C/div>\n    \u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"dvh-case\">\n    \u003Cp class=\"case-label\">✅ Full-page: min-height: 100dvh на батьку\u003C/p>\n    \u003Cdiv class=\"parent-dvh\">\n      \u003Cdiv class=\"child-fill\">Я заповнюю весь контейнер через flex: 1\u003C/div>\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,10509,10510,10525,10540,10564,10579,10603,10611,10619,10634,10657,10672,10696,10704,10712,10727,10750,10765,10789,10797,10805],{"__ignoreMap":2865},[2869,10511,10512,10514,10516,10518,10520,10523],{"class":2871,"line":2872},[2869,10513,3121],{"class":3120},[2869,10515,3125],{"class":3124},[2869,10517,3129],{"class":3128},[2869,10519,3133],{"class":3132},[2869,10521,10522],{"class":3136},"\"height-demo\"",[2869,10524,3140],{"class":3120},[2869,10526,10527,10529,10531,10533,10535,10538],{"class":2871,"line":2878},[2869,10528,3145],{"class":3120},[2869,10530,3125],{"class":3124},[2869,10532,3129],{"class":3128},[2869,10534,3133],{"class":3132},[2869,10536,10537],{"class":3136},"\"broken-case\"",[2869,10539,3140],{"class":3120},[2869,10541,10542,10544,10546,10548,10550,10553,10555,10558,10560,10562],{"class":2871,"line":2884},[2869,10543,3971],{"class":3120},[2869,10545,2804],{"class":3124},[2869,10547,3129],{"class":3128},[2869,10549,3133],{"class":3132},[2869,10551,10552],{"class":3136},"\"case-label\"",[2869,10554,3157],{"class":3120},[2869,10556,10557],{"class":3132},"❌ Зламаний: height: 100%",[2869,10559,3162],{"class":3120},[2869,10561,2804],{"class":3124},[2869,10563,3140],{"class":3120},[2869,10565,10566,10568,10570,10572,10574,10577],{"class":2871,"line":2890},[2869,10567,3971],{"class":3120},[2869,10569,3125],{"class":3124},[2869,10571,3129],{"class":3128},[2869,10573,3133],{"class":3132},[2869,10575,10576],{"class":3136},"\"parent-no-height\"",[2869,10578,3140],{"class":3120},[2869,10580,10581,10583,10585,10587,10589,10592,10594,10597,10599,10601],{"class":2871,"line":2896},[2869,10582,4004],{"class":3120},[2869,10584,3125],{"class":3124},[2869,10586,3129],{"class":3128},[2869,10588,3133],{"class":3132},[2869,10590,10591],{"class":3136},"\"child-100p\"",[2869,10593,3157],{"class":3120},[2869,10595,10596],{"class":3132},"Я хочу бути 100% висоти батька, але батько — auto!",[2869,10598,3162],{"class":3120},[2869,10600,3125],{"class":3124},[2869,10602,3140],{"class":3120},[2869,10604,10605,10607,10609],{"class":2871,"line":2902},[2869,10606,4064],{"class":3120},[2869,10608,3125],{"class":3124},[2869,10610,3140],{"class":3120},[2869,10612,10613,10615,10617],{"class":2871,"line":2908},[2869,10614,4073],{"class":3120},[2869,10616,3125],{"class":3124},[2869,10618,3140],{"class":3120},[2869,10620,10621,10623,10625,10627,10629,10632],{"class":2871,"line":2914},[2869,10622,3145],{"class":3120},[2869,10624,3125],{"class":3124},[2869,10626,3129],{"class":3128},[2869,10628,3133],{"class":3132},[2869,10630,10631],{"class":3136},"\"fixed-case\"",[2869,10633,3140],{"class":3120},[2869,10635,10636,10638,10640,10642,10644,10646,10648,10651,10653,10655],{"class":2871,"line":2920},[2869,10637,3971],{"class":3120},[2869,10639,2804],{"class":3124},[2869,10641,3129],{"class":3128},[2869,10643,3133],{"class":3132},[2869,10645,10552],{"class":3136},[2869,10647,3157],{"class":3120},[2869,10649,10650],{"class":3132},"✅ Виправлений: батько має висоту",[2869,10652,3162],{"class":3120},[2869,10654,2804],{"class":3124},[2869,10656,3140],{"class":3120},[2869,10658,10659,10661,10663,10665,10667,10670],{"class":2871,"line":2926},[2869,10660,3971],{"class":3120},[2869,10662,3125],{"class":3124},[2869,10664,3129],{"class":3128},[2869,10666,3133],{"class":3132},[2869,10668,10669],{"class":3136},"\"parent-has-height\"",[2869,10671,3140],{"class":3120},[2869,10673,10674,10676,10678,10680,10682,10685,10687,10690,10692,10694],{"class":2871,"line":2932},[2869,10675,4004],{"class":3120},[2869,10677,3125],{"class":3124},[2869,10679,3129],{"class":3128},[2869,10681,3133],{"class":3132},[2869,10683,10684],{"class":3136},"\"child-100p-ok\"",[2869,10686,3157],{"class":3120},[2869,10688,10689],{"class":3132},"Тепер я справді займаю 100% батька!",[2869,10691,3162],{"class":3120},[2869,10693,3125],{"class":3124},[2869,10695,3140],{"class":3120},[2869,10697,10698,10700,10702],{"class":2871,"line":2938},[2869,10699,4064],{"class":3120},[2869,10701,3125],{"class":3124},[2869,10703,3140],{"class":3120},[2869,10705,10706,10708,10710],{"class":2871,"line":2944},[2869,10707,4073],{"class":3120},[2869,10709,3125],{"class":3124},[2869,10711,3140],{"class":3120},[2869,10713,10714,10716,10718,10720,10722,10725],{"class":2871,"line":2950},[2869,10715,3145],{"class":3120},[2869,10717,3125],{"class":3124},[2869,10719,3129],{"class":3128},[2869,10721,3133],{"class":3132},[2869,10723,10724],{"class":3136},"\"dvh-case\"",[2869,10726,3140],{"class":3120},[2869,10728,10729,10731,10733,10735,10737,10739,10741,10744,10746,10748],{"class":2871,"line":2956},[2869,10730,3971],{"class":3120},[2869,10732,2804],{"class":3124},[2869,10734,3129],{"class":3128},[2869,10736,3133],{"class":3132},[2869,10738,10552],{"class":3136},[2869,10740,3157],{"class":3120},[2869,10742,10743],{"class":3132},"✅ Full-page: min-height: 100dvh на батьку",[2869,10745,3162],{"class":3120},[2869,10747,2804],{"class":3124},[2869,10749,3140],{"class":3120},[2869,10751,10752,10754,10756,10758,10760,10763],{"class":2871,"line":2962},[2869,10753,3971],{"class":3120},[2869,10755,3125],{"class":3124},[2869,10757,3129],{"class":3128},[2869,10759,3133],{"class":3132},[2869,10761,10762],{"class":3136},"\"parent-dvh\"",[2869,10764,3140],{"class":3120},[2869,10766,10767,10769,10771,10773,10775,10778,10780,10783,10785,10787],{"class":2871,"line":3448},[2869,10768,4004],{"class":3120},[2869,10770,3125],{"class":3124},[2869,10772,3129],{"class":3128},[2869,10774,3133],{"class":3132},[2869,10776,10777],{"class":3136},"\"child-fill\"",[2869,10779,3157],{"class":3120},[2869,10781,10782],{"class":3132},"Я заповнюю весь контейнер через flex: 1",[2869,10784,3162],{"class":3120},[2869,10786,3125],{"class":3124},[2869,10788,3140],{"class":3120},[2869,10790,10791,10793,10795],{"class":2871,"line":3505},[2869,10792,4064],{"class":3120},[2869,10794,3125],{"class":3124},[2869,10796,3140],{"class":3120},[2869,10798,10799,10801,10803],{"class":2871,"line":3543},[2869,10800,4073],{"class":3120},[2869,10802,3125],{"class":3124},[2869,10804,3140],{"class":3120},[2869,10806,10807,10809,10811],{"class":2871,"line":3573},[2869,10808,3162],{"class":3120},[2869,10810,3125],{"class":3124},[2869,10812,3140],{"class":3120},[2861,10814,10816],{"className":3249,"code":10815,"language":3251,"meta":2865,"style":2865},".height-demo {\n  display: flex;\n  gap: 0.75rem;\n  flex-wrap: wrap;\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.8rem;\n  color: #1e293b;\n}\n.case-label { margin: 0 0 0.4rem; font-weight: 700; }\n.broken-case, .fixed-case, .dvh-case { flex: 1; min-width: 140px; }\n.parent-no-height {\n  background: #fee2e2;\n  border: 2px dashed #ef4444;\n  border-radius: 6px;\n  padding: 0.5rem;\n  /* Немає висоти — auto */\n}\n.child-100p {\n  height: 100%;\n  background: #fca5a5;\n  padding: 0.5rem;\n  border-radius: 4px;\n  line-height: 1.3;\n}\n.parent-has-height {\n  background: #dcfce7;\n  border: 2px solid #10b981;\n  border-radius: 6px;\n  height: 100px;\n  padding: 0.5rem;\n}\n.child-100p-ok {\n  height: 100%;\n  background: #6ee7b7;\n  padding: 0.5rem;\n  border-radius: 4px;\n  display: flex;\n  align-items: center;\n}\n.parent-dvh {\n  background: #ede9fe;\n  border: 2px solid #8b5cf6;\n  border-radius: 6px;\n  min-height: 100px;\n  display: flex;\n  flex-direction: column;\n  padding: 0.5rem;\n}\n.child-fill {\n  flex: 1;\n  background: #c4b5fd;\n  padding: 0.5rem;\n  border-radius: 4px;\n  display: flex;\n  align-items: center;\n}\n",[2799,10817,10818,10825,10835,10845,10855,10865,10875,10889,10899,10909,10913,10941,10975,10982,10993,11008,11018,11028,11033,11037,11044,11054,11065,11075,11085,11095,11099,11106,11117,11131,11141,11152,11162,11166,11173,11183,11194,11204,11214,11224,11234,11238,11245,11255,11269,11279,11289,11299,11309,11319,11323,11330,11340,11351,11361,11371,11381,11392],{"__ignoreMap":2865},[2869,10819,10820,10823],{"class":2871,"line":2872},[2869,10821,10822],{"class":3258},".height-demo",[2869,10824,3262],{"class":3132},[2869,10826,10827,10829,10831,10833],{"class":2871,"line":2878},[2869,10828,3267],{"class":3128},[2869,10830,3270],{"class":3132},[2869,10832,3274],{"class":3273},[2869,10834,3277],{"class":3132},[2869,10836,10837,10839,10841,10843],{"class":2871,"line":2884},[2869,10838,3294],{"class":3128},[2869,10840,3270],{"class":3132},[2869,10842,3376],{"class":3299},[2869,10844,3277],{"class":3132},[2869,10846,10847,10849,10851,10853],{"class":2871,"line":2890},[2869,10848,3282],{"class":3128},[2869,10850,3270],{"class":3132},[2869,10852,3287],{"class":3273},[2869,10854,3277],{"class":3132},[2869,10856,10857,10859,10861,10863],{"class":2871,"line":2896},[2869,10858,3307],{"class":3128},[2869,10860,3270],{"class":3132},[2869,10862,3300],{"class":3299},[2869,10864,3277],{"class":3132},[2869,10866,10867,10869,10871,10873],{"class":2871,"line":2902},[2869,10868,3319],{"class":3128},[2869,10870,3270],{"class":3132},[2869,10872,3324],{"class":3273},[2869,10874,3277],{"class":3132},[2869,10876,10877,10879,10881,10883,10885,10887],{"class":2871,"line":2908},[2869,10878,3331],{"class":3128},[2869,10880,3270],{"class":3132},[2869,10882,3336],{"class":3273},[2869,10884,2810],{"class":3132},[2869,10886,3341],{"class":3273},[2869,10888,3277],{"class":3132},[2869,10890,10891,10893,10895,10897],{"class":2871,"line":2914},[2869,10892,3348],{"class":3128},[2869,10894,3270],{"class":3132},[2869,10896,6305],{"class":3299},[2869,10898,3277],{"class":3132},[2869,10900,10901,10903,10905,10907],{"class":2871,"line":2920},[2869,10902,3397],{"class":3128},[2869,10904,3270],{"class":3132},[2869,10906,3402],{"class":3273},[2869,10908,3277],{"class":3132},[2869,10910,10911],{"class":2871,"line":2926},[2869,10912,3360],{"class":3132},[2869,10914,10915,10918,10920,10922,10924,10926,10928,10931,10933,10935,10937,10939],{"class":2871,"line":2932},[2869,10916,10917],{"class":3258},".case-label",[2869,10919,3434],{"class":3132},[2869,10921,4328],{"class":3128},[2869,10923,3270],{"class":3132},[2869,10925,3460],{"class":3299},[2869,10927,4335],{"class":3299},[2869,10929,10930],{"class":3299}," 0.4rem",[2869,10932,3521],{"class":3132},[2869,10934,9334],{"class":3128},[2869,10936,3270],{"class":3132},[2869,10938,9339],{"class":3299},[2869,10940,3445],{"class":3132},[2869,10942,10943,10946,10948,10951,10953,10956,10958,10960,10962,10964,10966,10969,10971,10973],{"class":2871,"line":2938},[2869,10944,10945],{"class":3258},".broken-case",[2869,10947,2810],{"class":3132},[2869,10949,10950],{"class":3258},".fixed-case",[2869,10952,2810],{"class":3132},[2869,10954,10955],{"class":3258},".dvh-case",[2869,10957,3434],{"class":3132},[2869,10959,3274],{"class":3128},[2869,10961,3270],{"class":3132},[2869,10963,5645],{"class":3299},[2869,10965,3521],{"class":3132},[2869,10967,10968],{"class":3128},"min-width",[2869,10970,3270],{"class":3132},[2869,10972,6980],{"class":3299},[2869,10974,3445],{"class":3132},[2869,10976,10977,10980],{"class":2871,"line":2944},[2869,10978,10979],{"class":3258},".parent-no-height",[2869,10981,3262],{"class":3132},[2869,10983,10984,10986,10988,10991],{"class":2871,"line":2950},[2869,10985,3319],{"class":3128},[2869,10987,3270],{"class":3132},[2869,10989,10990],{"class":3273},"#fee2e2",[2869,10992,3277],{"class":3132},[2869,10994,10995,10997,10999,11001,11004,11006],{"class":2871,"line":2956},[2869,10996,3409],{"class":3128},[2869,10998,3270],{"class":3132},[2869,11000,9479],{"class":3299},[2869,11002,11003],{"class":3273}," dashed",[2869,11005,4378],{"class":3273},[2869,11007,3277],{"class":3132},[2869,11009,11010,11012,11014,11016],{"class":2871,"line":2962},[2869,11011,4741],{"class":3128},[2869,11013,3270],{"class":3132},[2869,11015,6278],{"class":3299},[2869,11017,3277],{"class":3132},[2869,11019,11020,11022,11024,11026],{"class":2871,"line":3448},[2869,11021,3307],{"class":3128},[2869,11023,3270],{"class":3132},[2869,11025,6109],{"class":3299},[2869,11027,3277],{"class":3132},[2869,11029,11030],{"class":2871,"line":3505},[2869,11031,11032],{"class":3762},"  /* Немає висоти — auto */\n",[2869,11034,11035],{"class":2871,"line":3543},[2869,11036,3360],{"class":3132},[2869,11038,11039,11042],{"class":2871,"line":3573},[2869,11040,11041],{"class":3258},".child-100p",[2869,11043,3262],{"class":3132},[2869,11045,11046,11048,11050,11052],{"class":2871,"line":3619},[2869,11047,6014],{"class":3128},[2869,11049,3270],{"class":3132},[2869,11051,6236],{"class":3299},[2869,11053,3277],{"class":3132},[2869,11055,11056,11058,11060,11063],{"class":2871,"line":4232},[2869,11057,3319],{"class":3128},[2869,11059,3270],{"class":3132},[2869,11061,11062],{"class":3273},"#fca5a5",[2869,11064,3277],{"class":3132},[2869,11066,11067,11069,11071,11073],{"class":2871,"line":4241},[2869,11068,3307],{"class":3128},[2869,11070,3270],{"class":3132},[2869,11072,6109],{"class":3299},[2869,11074,3277],{"class":3132},[2869,11076,11077,11079,11081,11083],{"class":2871,"line":6174},[2869,11078,4741],{"class":3128},[2869,11080,3270],{"class":3132},[2869,11082,3614],{"class":3299},[2869,11084,3277],{"class":3132},[2869,11086,11087,11089,11091,11093],{"class":2871,"line":6208},[2869,11088,5640],{"class":3128},[2869,11090,3270],{"class":3132},[2869,11092,8235],{"class":3299},[2869,11094,3277],{"class":3132},[2869,11096,11097],{"class":2871,"line":6216},[2869,11098,3360],{"class":3132},[2869,11100,11101,11104],{"class":2871,"line":6229},[2869,11102,11103],{"class":3258},".parent-has-height",[2869,11105,3262],{"class":3132},[2869,11107,11108,11110,11112,11115],{"class":2871,"line":6241},[2869,11109,3319],{"class":3128},[2869,11111,3270],{"class":3132},[2869,11113,11114],{"class":3273},"#dcfce7",[2869,11116,3277],{"class":3132},[2869,11118,11119,11121,11123,11125,11127,11129],{"class":2871,"line":6271},[2869,11120,3409],{"class":3128},[2869,11122,3270],{"class":3132},[2869,11124,9479],{"class":3299},[2869,11126,3417],{"class":3273},[2869,11128,4567],{"class":3273},[2869,11130,3277],{"class":3132},[2869,11132,11133,11135,11137,11139],{"class":2871,"line":6283},[2869,11134,4741],{"class":3128},[2869,11136,3270],{"class":3132},[2869,11138,6278],{"class":3299},[2869,11140,3277],{"class":3132},[2869,11142,11143,11145,11147,11150],{"class":2871,"line":6298},[2869,11144,6014],{"class":3128},[2869,11146,3270],{"class":3132},[2869,11148,11149],{"class":3299},"100px",[2869,11151,3277],{"class":3132},[2869,11153,11154,11156,11158,11160],{"class":2871,"line":6310},[2869,11155,3307],{"class":3128},[2869,11157,3270],{"class":3132},[2869,11159,6109],{"class":3299},[2869,11161,3277],{"class":3132},[2869,11163,11164],{"class":2871,"line":6321},[2869,11165,3360],{"class":3132},[2869,11167,11168,11171],{"class":2871,"line":6326},[2869,11169,11170],{"class":3258},".child-100p-ok",[2869,11172,3262],{"class":3132},[2869,11174,11175,11177,11179,11181],{"class":2871,"line":6334},[2869,11176,6014],{"class":3128},[2869,11178,3270],{"class":3132},[2869,11180,6236],{"class":3299},[2869,11182,3277],{"class":3132},[2869,11184,11185,11187,11189,11192],{"class":2871,"line":6345},[2869,11186,3319],{"class":3128},[2869,11188,3270],{"class":3132},[2869,11190,11191],{"class":3273},"#6ee7b7",[2869,11193,3277],{"class":3132},[2869,11195,11196,11198,11200,11202],{"class":2871,"line":6356},[2869,11197,3307],{"class":3128},[2869,11199,3270],{"class":3132},[2869,11201,6109],{"class":3299},[2869,11203,3277],{"class":3132},[2869,11205,11206,11208,11210,11212],{"class":2871,"line":6367},[2869,11207,4741],{"class":3128},[2869,11209,3270],{"class":3132},[2869,11211,3614],{"class":3299},[2869,11213,3277],{"class":3132},[2869,11215,11216,11218,11220,11222],{"class":2871,"line":6382},[2869,11217,3267],{"class":3128},[2869,11219,3270],{"class":3132},[2869,11221,3274],{"class":3273},[2869,11223,3277],{"class":3132},[2869,11225,11226,11228,11230,11232],{"class":2871,"line":6387},[2869,11227,6083],{"class":3128},[2869,11229,3270],{"class":3132},[2869,11231,3559],{"class":3273},[2869,11233,3277],{"class":3132},[2869,11235,11236],{"class":2871,"line":6395},[2869,11237,3360],{"class":3132},[2869,11239,11240,11243],{"class":2871,"line":6407},[2869,11241,11242],{"class":3258},".parent-dvh",[2869,11244,3262],{"class":3132},[2869,11246,11247,11249,11251,11253],{"class":2871,"line":6433},[2869,11248,3319],{"class":3128},[2869,11250,3270],{"class":3132},[2869,11252,10380],{"class":3273},[2869,11254,3277],{"class":3132},[2869,11256,11257,11259,11261,11263,11265,11267],{"class":2871,"line":6444},[2869,11258,3409],{"class":3128},[2869,11260,3270],{"class":3132},[2869,11262,9479],{"class":3299},[2869,11264,3417],{"class":3273},[2869,11266,10418],{"class":3273},[2869,11268,3277],{"class":3132},[2869,11270,11271,11273,11275,11277],{"class":2871,"line":6456},[2869,11272,4741],{"class":3128},[2869,11274,3270],{"class":3132},[2869,11276,6278],{"class":3299},[2869,11278,3277],{"class":3132},[2869,11280,11281,11283,11285,11287],{"class":2871,"line":8128},[2869,11282,7261],{"class":3128},[2869,11284,3270],{"class":3132},[2869,11286,11149],{"class":3299},[2869,11288,3277],{"class":3132},[2869,11290,11291,11293,11295,11297],{"class":2871,"line":8139},[2869,11292,3267],{"class":3128},[2869,11294,3270],{"class":3132},[2869,11296,3274],{"class":3273},[2869,11298,3277],{"class":3132},[2869,11300,11301,11303,11305,11307],{"class":2871,"line":8151},[2869,11302,5222],{"class":3128},[2869,11304,3270],{"class":3132},[2869,11306,5227],{"class":3273},[2869,11308,3277],{"class":3132},[2869,11310,11311,11313,11315,11317],{"class":2871,"line":8163},[2869,11312,3307],{"class":3128},[2869,11314,3270],{"class":3132},[2869,11316,6109],{"class":3299},[2869,11318,3277],{"class":3132},[2869,11320,11321],{"class":2871,"line":8175},[2869,11322,3360],{"class":3132},[2869,11324,11325,11328],{"class":2871,"line":8180},[2869,11326,11327],{"class":3258},".child-fill",[2869,11329,3262],{"class":3132},[2869,11331,11332,11334,11336,11338],{"class":2871,"line":8189},[2869,11333,6964],{"class":3128},[2869,11335,3270],{"class":3132},[2869,11337,5645],{"class":3299},[2869,11339,3277],{"class":3132},[2869,11341,11342,11344,11346,11349],{"class":2871,"line":8205},[2869,11343,3319],{"class":3128},[2869,11345,3270],{"class":3132},[2869,11347,11348],{"class":3273},"#c4b5fd",[2869,11350,3277],{"class":3132},[2869,11352,11353,11355,11357,11359],{"class":2871,"line":8217},[2869,11354,3307],{"class":3128},[2869,11356,3270],{"class":3132},[2869,11358,6109],{"class":3299},[2869,11360,3277],{"class":3132},[2869,11362,11363,11365,11367,11369],{"class":2871,"line":8228},[2869,11364,4741],{"class":3128},[2869,11366,3270],{"class":3132},[2869,11368,3614],{"class":3299},[2869,11370,3277],{"class":3132},[2869,11372,11373,11375,11377,11379],{"class":2871,"line":8240},[2869,11374,3267],{"class":3128},[2869,11376,3270],{"class":3132},[2869,11378,3274],{"class":3273},[2869,11380,3277],{"class":3132},[2869,11382,11384,11386,11388,11390],{"class":2871,"line":11383},57,[2869,11385,6083],{"class":3128},[2869,11387,3270],{"class":3132},[2869,11389,3559],{"class":3273},[2869,11391,3277],{"class":3132},[2869,11393,11395],{"class":2871,"line":11394},58,[2869,11396,3360],{"class":3132},[2804,11398,11399,11404,11405,11408,11409,11412,11413,11416],{},[2977,11400,11401,11402,3070],{},"Рішення для ",[2799,11403,10490],{}," батько повинен мати явну висоту, або ж використати ",[2799,11406,11407],{},"display: flex"," / ",[2799,11410,11411],{},"display: grid"," з ",[2799,11414,11415],{},"flex: 1"," на дочірньому елементі.",[2967,11418],{},[2794,11420,11422],{"id":11421},"логічні-властивості-logical-properties","Логічні властивості (Logical Properties)",[2804,11424,11425,11426,2810,11428,2810,11430,2810,11433,11436,11437,11440],{},"Традиційні CSS-властивості — ",[2799,11427,3513],{},[2799,11429,3524],{},[2799,11431,11432],{},"margin-left",[2799,11434,11435],{},"padding-top"," — прив'язані до ",[2977,11438,11439],{},"фізичних осей",": горизонталь та вертикаль. Але у світі існують мови, що пишуться справа наліво (арабська, іврит) або зверху вниз (японська). Для них поняття «ліво» та «право» втрачають сенс.",[2804,11442,11443,11446,11447,11450],{},[2977,11444,11445],{},"Логічні властивості"," оперують ",[2977,11448,11449],{},"відносними осями",": inline (завжди вздовж напрямку тексту) та block (перпендикулярно тексту).",[3671,11452,11453,11469],{},[3674,11454,11455],{},[3677,11456,11457,11460,11463],{},[3680,11458,11459],{},"Фізична",[3680,11461,11462],{},"Логічна",[3680,11464,11465,11466],{},"Для ",[2799,11467,11468],{},"writing-mode: horizontal-tb",[3690,11470,11471,11485,11499,11513,11528,11542,11559],{},[3677,11472,11473,11477,11482],{},[3695,11474,11475],{},[2799,11476,3513],{},[3695,11478,11479],{},[2799,11480,11481],{},"inline-size",[3695,11483,11484],{},"горизонталь",[3677,11486,11487,11491,11496],{},[3695,11488,11489],{},[2799,11490,3524],{},[3695,11492,11493],{},[2799,11494,11495],{},"block-size",[3695,11497,11498],{},"вертикаль",[3677,11500,11501,11505,11510],{},[3695,11502,11503],{},[2799,11504,11432],{},[3695,11506,11507],{},[2799,11508,11509],{},"margin-inline-start",[3695,11511,11512],{},"ліво (для LTR) або право (для RTL)",[3677,11514,11515,11520,11525],{},[3695,11516,11517],{},[2799,11518,11519],{},"margin-right",[3695,11521,11522],{},[2799,11523,11524],{},"margin-inline-end",[3695,11526,11527],{},"право (для LTR) або ліво (для RTL)",[3677,11529,11530,11534,11539],{},[3695,11531,11532],{},[2799,11533,11435],{},[3695,11535,11536],{},[2799,11537,11538],{},"padding-block-start",[3695,11540,11541],{},"верх",[3677,11543,11544,11551,11556],{},[3695,11545,11546,5690,11549],{},[2799,11547,11548],{},"margin-top",[2799,11550,9200],{},[3695,11552,11553],{},[2799,11554,11555],{},"margin-block",[3695,11557,11558],{},"скорочення: верх+низ",[3677,11560,11561,11567,11572],{},[3695,11562,11563,5690,11565],{},[2799,11564,11432],{},[2799,11566,11519],{},[3695,11568,11569],{},[2799,11570,11571],{},"margin-inline",[3695,11573,11574],{},"скорочення: ліво+право",[3107,11576,11577,11912],{},[2861,11578,11580],{"className":3111,"code":11579,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"logical-demo\">\n  \u003Cdiv class=\"ltr-box\">\n    \u003Cp class=\"mode-label\">LTR (зліва направо — укр, англ)\u003C/p>\n    \u003Cdiv class=\"logical-element\">\n      Елемент з \u003Ccode>margin-inline-start: 2rem\u003C/code>\n    \u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"rtl-box\" dir=\"rtl\">\n    \u003Cp class=\"mode-label\">RTL (справа наліво — арабська, іврит)\u003C/p>\n    \u003Cdiv class=\"logical-element\">\n      العنصر مع \u003Ccode>margin-inline-start: 2rem\u003C/code>\n    \u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"shorthand-demo\">\n    \u003Cdiv class=\"padding-logical\">\n      \u003Ccode>padding-inline: 2rem;\u003Cbr>padding-block: 0.5rem;\u003C/code>\n    \u003C/div>\n    \u003Cdiv class=\"margin-auto\">\n      \u003Ccode>margin-inline: auto\u003C/code>\u003Cbr>\n      (центрування без margin: 0 auto)\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,11581,11582,11597,11612,11636,11651,11671,11679,11687,11710,11733,11747,11766,11774,11782,11797,11812,11839,11847,11862,11883,11888,11896,11904],{"__ignoreMap":2865},[2869,11583,11584,11586,11588,11590,11592,11595],{"class":2871,"line":2872},[2869,11585,3121],{"class":3120},[2869,11587,3125],{"class":3124},[2869,11589,3129],{"class":3128},[2869,11591,3133],{"class":3132},[2869,11593,11594],{"class":3136},"\"logical-demo\"",[2869,11596,3140],{"class":3120},[2869,11598,11599,11601,11603,11605,11607,11610],{"class":2871,"line":2878},[2869,11600,3145],{"class":3120},[2869,11602,3125],{"class":3124},[2869,11604,3129],{"class":3128},[2869,11606,3133],{"class":3132},[2869,11608,11609],{"class":3136},"\"ltr-box\"",[2869,11611,3140],{"class":3120},[2869,11613,11614,11616,11618,11620,11622,11625,11627,11630,11632,11634],{"class":2871,"line":2884},[2869,11615,3971],{"class":3120},[2869,11617,2804],{"class":3124},[2869,11619,3129],{"class":3128},[2869,11621,3133],{"class":3132},[2869,11623,11624],{"class":3136},"\"mode-label\"",[2869,11626,3157],{"class":3120},[2869,11628,11629],{"class":3132},"LTR (зліва направо — укр, англ)",[2869,11631,3162],{"class":3120},[2869,11633,2804],{"class":3124},[2869,11635,3140],{"class":3120},[2869,11637,11638,11640,11642,11644,11646,11649],{"class":2871,"line":2890},[2869,11639,3971],{"class":3120},[2869,11641,3125],{"class":3124},[2869,11643,3129],{"class":3128},[2869,11645,3133],{"class":3132},[2869,11647,11648],{"class":3136},"\"logical-element\"",[2869,11650,3140],{"class":3120},[2869,11652,11653,11656,11658,11660,11662,11665,11667,11669],{"class":2871,"line":2896},[2869,11654,11655],{"class":3132},"      Елемент з ",[2869,11657,3121],{"class":3120},[2869,11659,2799],{"class":3124},[2869,11661,3157],{"class":3120},[2869,11663,11664],{"class":3132},"margin-inline-start: 2rem",[2869,11666,3162],{"class":3120},[2869,11668,2799],{"class":3124},[2869,11670,3140],{"class":3120},[2869,11672,11673,11675,11677],{"class":2871,"line":2902},[2869,11674,4064],{"class":3120},[2869,11676,3125],{"class":3124},[2869,11678,3140],{"class":3120},[2869,11680,11681,11683,11685],{"class":2871,"line":2908},[2869,11682,4073],{"class":3120},[2869,11684,3125],{"class":3124},[2869,11686,3140],{"class":3120},[2869,11688,11689,11691,11693,11695,11697,11700,11703,11705,11708],{"class":2871,"line":2914},[2869,11690,3145],{"class":3120},[2869,11692,3125],{"class":3124},[2869,11694,3129],{"class":3128},[2869,11696,3133],{"class":3132},[2869,11698,11699],{"class":3136},"\"rtl-box\"",[2869,11701,11702],{"class":3128}," dir",[2869,11704,3133],{"class":3132},[2869,11706,11707],{"class":3136},"\"rtl\"",[2869,11709,3140],{"class":3120},[2869,11711,11712,11714,11716,11718,11720,11722,11724,11727,11729,11731],{"class":2871,"line":2920},[2869,11713,3971],{"class":3120},[2869,11715,2804],{"class":3124},[2869,11717,3129],{"class":3128},[2869,11719,3133],{"class":3132},[2869,11721,11624],{"class":3136},[2869,11723,3157],{"class":3120},[2869,11725,11726],{"class":3132},"RTL (справа наліво — арабська, іврит)",[2869,11728,3162],{"class":3120},[2869,11730,2804],{"class":3124},[2869,11732,3140],{"class":3120},[2869,11734,11735,11737,11739,11741,11743,11745],{"class":2871,"line":2926},[2869,11736,3971],{"class":3120},[2869,11738,3125],{"class":3124},[2869,11740,3129],{"class":3128},[2869,11742,3133],{"class":3132},[2869,11744,11648],{"class":3136},[2869,11746,3140],{"class":3120},[2869,11748,11749,11752,11754,11756,11758,11760,11762,11764],{"class":2871,"line":2932},[2869,11750,11751],{"class":3132},"      العنصر مع ",[2869,11753,3121],{"class":3120},[2869,11755,2799],{"class":3124},[2869,11757,3157],{"class":3120},[2869,11759,11664],{"class":3132},[2869,11761,3162],{"class":3120},[2869,11763,2799],{"class":3124},[2869,11765,3140],{"class":3120},[2869,11767,11768,11770,11772],{"class":2871,"line":2938},[2869,11769,4064],{"class":3120},[2869,11771,3125],{"class":3124},[2869,11773,3140],{"class":3120},[2869,11775,11776,11778,11780],{"class":2871,"line":2944},[2869,11777,4073],{"class":3120},[2869,11779,3125],{"class":3124},[2869,11781,3140],{"class":3120},[2869,11783,11784,11786,11788,11790,11792,11795],{"class":2871,"line":2950},[2869,11785,3145],{"class":3120},[2869,11787,3125],{"class":3124},[2869,11789,3129],{"class":3128},[2869,11791,3133],{"class":3132},[2869,11793,11794],{"class":3136},"\"shorthand-demo\"",[2869,11796,3140],{"class":3120},[2869,11798,11799,11801,11803,11805,11807,11810],{"class":2871,"line":2956},[2869,11800,3971],{"class":3120},[2869,11802,3125],{"class":3124},[2869,11804,3129],{"class":3128},[2869,11806,3133],{"class":3132},[2869,11808,11809],{"class":3136},"\"padding-logical\"",[2869,11811,3140],{"class":3120},[2869,11813,11814,11816,11818,11820,11823,11825,11828,11830,11833,11835,11837],{"class":2871,"line":2962},[2869,11815,4004],{"class":3120},[2869,11817,2799],{"class":3124},[2869,11819,3157],{"class":3120},[2869,11821,11822],{"class":3132},"padding-inline: 2rem;",[2869,11824,3121],{"class":3120},[2869,11826,11827],{"class":3124},"br",[2869,11829,3157],{"class":3120},[2869,11831,11832],{"class":3132},"padding-block: 0.5rem;",[2869,11834,3162],{"class":3120},[2869,11836,2799],{"class":3124},[2869,11838,3140],{"class":3120},[2869,11840,11841,11843,11845],{"class":2871,"line":3448},[2869,11842,4064],{"class":3120},[2869,11844,3125],{"class":3124},[2869,11846,3140],{"class":3120},[2869,11848,11849,11851,11853,11855,11857,11860],{"class":2871,"line":3505},[2869,11850,3971],{"class":3120},[2869,11852,3125],{"class":3124},[2869,11854,3129],{"class":3128},[2869,11856,3133],{"class":3132},[2869,11858,11859],{"class":3136},"\"margin-auto\"",[2869,11861,3140],{"class":3120},[2869,11863,11864,11866,11868,11870,11873,11875,11877,11879,11881],{"class":2871,"line":3543},[2869,11865,4004],{"class":3120},[2869,11867,2799],{"class":3124},[2869,11869,3157],{"class":3120},[2869,11871,11872],{"class":3132},"margin-inline: auto",[2869,11874,3162],{"class":3120},[2869,11876,2799],{"class":3124},[2869,11878,9927],{"class":3120},[2869,11880,11827],{"class":3124},[2869,11882,3140],{"class":3120},[2869,11884,11885],{"class":2871,"line":3573},[2869,11886,11887],{"class":3132},"      (центрування без margin: 0 auto)\n",[2869,11889,11890,11892,11894],{"class":2871,"line":3619},[2869,11891,4064],{"class":3120},[2869,11893,3125],{"class":3124},[2869,11895,3140],{"class":3120},[2869,11897,11898,11900,11902],{"class":2871,"line":4232},[2869,11899,4073],{"class":3120},[2869,11901,3125],{"class":3124},[2869,11903,3140],{"class":3120},[2869,11905,11906,11908,11910],{"class":2871,"line":4241},[2869,11907,3162],{"class":3120},[2869,11909,3125],{"class":3124},[2869,11911,3140],{"class":3120},[2861,11913,11915],{"className":3249,"code":11914,"language":3251,"meta":2865,"style":2865},".logical-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.82rem;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.75rem;\n}\n.ltr-box, .rtl-box {\n  background: white;\n  border-radius: 8px;\n  padding: 0.75rem;\n  border: 1px solid #e2e8f0;\n}\n.mode-label { margin: 0 0 0.5rem; font-weight: 700; font-size: 0.78rem; color: #64748b; }\n.logical-element {\n  background: #ede9fe;\n  border-left: 4px solid #6366f1;\n  padding: 0.5rem 0.75rem;\n  border-radius: 4px;\n  margin-inline-start: 2rem;\n  line-height: 1.4;\n}\n.ltr-box .logical-element { border-color: #6366f1; background: #ede9fe; }\n.rtl-box .logical-element { border-color: #ec4899; background: #fce7f3; border-right: 4px solid #ec4899; border-left: none; }\n.logical-element code { background: rgba(255,255,255,0.7); padding: 0.1em 0.3em; border-radius: 3px; font-size: 0.9em; }\n.shorthand-demo { display: flex; gap: 0.5rem; flex-wrap: wrap; }\n.padding-logical, .margin-auto {\n  flex: 1; min-width: 140px;\n  background: white;\n  border: 1px solid #e2e8f0;\n  border-radius: 6px;\n}\n.padding-logical {\n  padding-inline: 2rem;\n  padding-block: 0.5rem;\n  color: #1e293b;\n}\n.margin-auto {\n  width: max-content;\n  max-width: 100%;\n  margin-inline: auto;\n  padding: 0.5rem 1rem;\n  text-align: center;\n  background: #dcfce7;\n  border-color: #10b981;\n}\n.padding-logical code, .margin-auto code { font-size: 0.78rem; font-family: monospace; }\n",[2799,11916,11917,11924,11934,11944,11958,11969,11979,11989,11999,12009,12013,12025,12035,12045,12055,12069,12073,12116,12123,12133,12147,12159,12169,12181,12191,12195,12220,12267,12327,12359,12371,12389,12399,12413,12423,12427,12433,12443,12454,12464,12468,12474,12484,12494,12504,12516,12526,12536,12547,12551],{"__ignoreMap":2865},[2869,11918,11919,11922],{"class":2871,"line":2872},[2869,11920,11921],{"class":3258},".logical-demo",[2869,11923,3262],{"class":3132},[2869,11925,11926,11928,11930,11932],{"class":2871,"line":2878},[2869,11927,3307],{"class":3128},[2869,11929,3270],{"class":3132},[2869,11931,3300],{"class":3299},[2869,11933,3277],{"class":3132},[2869,11935,11936,11938,11940,11942],{"class":2871,"line":2884},[2869,11937,3319],{"class":3128},[2869,11939,3270],{"class":3132},[2869,11941,3324],{"class":3273},[2869,11943,3277],{"class":3132},[2869,11945,11946,11948,11950,11952,11954,11956],{"class":2871,"line":2890},[2869,11947,3331],{"class":3128},[2869,11949,3270],{"class":3132},[2869,11951,3336],{"class":3273},[2869,11953,2810],{"class":3132},[2869,11955,3341],{"class":3273},[2869,11957,3277],{"class":3132},[2869,11959,11960,11962,11964,11967],{"class":2871,"line":2896},[2869,11961,3348],{"class":3128},[2869,11963,3270],{"class":3132},[2869,11965,11966],{"class":3299},"0.82rem",[2869,11968,3277],{"class":3132},[2869,11970,11971,11973,11975,11977],{"class":2871,"line":2902},[2869,11972,3397],{"class":3128},[2869,11974,3270],{"class":3132},[2869,11976,3402],{"class":3273},[2869,11978,3277],{"class":3132},[2869,11980,11981,11983,11985,11987],{"class":2871,"line":2908},[2869,11982,3267],{"class":3128},[2869,11984,3270],{"class":3132},[2869,11986,3274],{"class":3273},[2869,11988,3277],{"class":3132},[2869,11990,11991,11993,11995,11997],{"class":2871,"line":2914},[2869,11992,5222],{"class":3128},[2869,11994,3270],{"class":3132},[2869,11996,5227],{"class":3273},[2869,11998,3277],{"class":3132},[2869,12000,12001,12003,12005,12007],{"class":2871,"line":2920},[2869,12002,3294],{"class":3128},[2869,12004,3270],{"class":3132},[2869,12006,3376],{"class":3299},[2869,12008,3277],{"class":3132},[2869,12010,12011],{"class":2871,"line":2926},[2869,12012,3360],{"class":3132},[2869,12014,12015,12018,12020,12023],{"class":2871,"line":2932},[2869,12016,12017],{"class":3258},".ltr-box",[2869,12019,2810],{"class":3132},[2869,12021,12022],{"class":3258},".rtl-box",[2869,12024,3262],{"class":3132},[2869,12026,12027,12029,12031,12033],{"class":2871,"line":2938},[2869,12028,3319],{"class":3128},[2869,12030,3270],{"class":3132},[2869,12032,3390],{"class":3273},[2869,12034,3277],{"class":3132},[2869,12036,12037,12039,12041,12043],{"class":2871,"line":2944},[2869,12038,4741],{"class":3128},[2869,12040,3270],{"class":3132},[2869,12042,3442],{"class":3299},[2869,12044,3277],{"class":3132},[2869,12046,12047,12049,12051,12053],{"class":2871,"line":2950},[2869,12048,3307],{"class":3128},[2869,12050,3270],{"class":3132},[2869,12052,3376],{"class":3299},[2869,12054,3277],{"class":3132},[2869,12056,12057,12059,12061,12063,12065,12067],{"class":2871,"line":2956},[2869,12058,3409],{"class":3128},[2869,12060,3270],{"class":3132},[2869,12062,3414],{"class":3299},[2869,12064,3417],{"class":3273},[2869,12066,3420],{"class":3273},[2869,12068,3277],{"class":3132},[2869,12070,12071],{"class":2871,"line":2962},[2869,12072,3360],{"class":3132},[2869,12074,12075,12078,12080,12082,12084,12086,12088,12090,12092,12094,12096,12098,12100,12102,12104,12106,12108,12110,12112,12114],{"class":2871,"line":3448},[2869,12076,12077],{"class":3258},".mode-label",[2869,12079,3434],{"class":3132},[2869,12081,4328],{"class":3128},[2869,12083,3270],{"class":3132},[2869,12085,3460],{"class":3299},[2869,12087,4335],{"class":3299},[2869,12089,4338],{"class":3299},[2869,12091,3521],{"class":3132},[2869,12093,9334],{"class":3128},[2869,12095,3270],{"class":3132},[2869,12097,9339],{"class":3299},[2869,12099,3521],{"class":3132},[2869,12101,3584],{"class":3128},[2869,12103,3270],{"class":3132},[2869,12105,7119],{"class":3299},[2869,12107,3521],{"class":3132},[2869,12109,9147],{"class":3128},[2869,12111,3270],{"class":3132},[2869,12113,7822],{"class":3273},[2869,12115,3445],{"class":3132},[2869,12117,12118,12121],{"class":2871,"line":3505},[2869,12119,12120],{"class":3258},".logical-element",[2869,12122,3262],{"class":3132},[2869,12124,12125,12127,12129,12131],{"class":2871,"line":3543},[2869,12126,3319],{"class":3128},[2869,12128,3270],{"class":3132},[2869,12130,10380],{"class":3273},[2869,12132,3277],{"class":3132},[2869,12134,12135,12137,12139,12141,12143,12145],{"class":2871,"line":3573},[2869,12136,5350],{"class":3128},[2869,12138,3270],{"class":3132},[2869,12140,3614],{"class":3299},[2869,12142,3417],{"class":3273},[2869,12144,4639],{"class":3273},[2869,12146,3277],{"class":3132},[2869,12148,12149,12151,12153,12155,12157],{"class":2871,"line":3619},[2869,12150,3307],{"class":3128},[2869,12152,3270],{"class":3132},[2869,12154,6109],{"class":3299},[2869,12156,6293],{"class":3299},[2869,12158,3277],{"class":3132},[2869,12160,12161,12163,12165,12167],{"class":2871,"line":4232},[2869,12162,4741],{"class":3128},[2869,12164,3270],{"class":3132},[2869,12166,3614],{"class":3299},[2869,12168,3277],{"class":3132},[2869,12170,12171,12174,12176,12179],{"class":2871,"line":4241},[2869,12172,12173],{"class":3128},"  margin-inline-start",[2869,12175,3270],{"class":3132},[2869,12177,12178],{"class":3299},"2rem",[2869,12180,3277],{"class":3132},[2869,12182,12183,12185,12187,12189],{"class":2871,"line":6174},[2869,12184,5640],{"class":3128},[2869,12186,3270],{"class":3132},[2869,12188,7142],{"class":3299},[2869,12190,3277],{"class":3132},[2869,12192,12193],{"class":2871,"line":6208},[2869,12194,3360],{"class":3132},[2869,12196,12197,12199,12202,12204,12206,12208,12210,12212,12214,12216,12218],{"class":2871,"line":6216},[2869,12198,12017],{"class":3258},[2869,12200,12201],{"class":3258}," .logical-element",[2869,12203,3434],{"class":3132},[2869,12205,5382],{"class":3128},[2869,12207,3270],{"class":3132},[2869,12209,3538],{"class":3273},[2869,12211,3521],{"class":3132},[2869,12213,3533],{"class":3128},[2869,12215,3270],{"class":3132},[2869,12217,10380],{"class":3273},[2869,12219,3445],{"class":3132},[2869,12221,12222,12224,12226,12228,12230,12232,12234,12236,12238,12240,12243,12245,12248,12250,12252,12254,12257,12259,12261,12263,12265],{"class":2871,"line":6229},[2869,12223,12022],{"class":3258},[2869,12225,12201],{"class":3258},[2869,12227,3434],{"class":3132},[2869,12229,5382],{"class":3128},[2869,12231,3270],{"class":3132},[2869,12233,5387],{"class":3273},[2869,12235,3521],{"class":3132},[2869,12237,3533],{"class":3128},[2869,12239,3270],{"class":3132},[2869,12241,12242],{"class":3273},"#fce7f3",[2869,12244,3521],{"class":3132},[2869,12246,12247],{"class":3128},"border-right",[2869,12249,3270],{"class":3132},[2869,12251,3614],{"class":3299},[2869,12253,3417],{"class":3273},[2869,12255,12256],{"class":3273}," #ec4899",[2869,12258,3521],{"class":3132},[2869,12260,4368],{"class":3128},[2869,12262,3270],{"class":3132},[2869,12264,3500],{"class":3273},[2869,12266,3445],{"class":3132},[2869,12268,12269,12271,12273,12275,12277,12279,12281,12283,12285,12287,12289,12291,12293,12295,12298,12300,12302,12304,12306,12308,12310,12312,12314,12316,12318,12320,12322,12325],{"class":2871,"line":6241},[2869,12270,12120],{"class":3258},[2869,12272,10304],{"class":3258},[2869,12274,3434],{"class":3132},[2869,12276,3533],{"class":3128},[2869,12278,3270],{"class":3132},[2869,12280,6248],{"class":3469},[2869,12282,3473],{"class":3132},[2869,12284,6253],{"class":3299},[2869,12286,3478],{"class":3132},[2869,12288,6253],{"class":3299},[2869,12290,3478],{"class":3132},[2869,12292,6253],{"class":3299},[2869,12294,3478],{"class":3132},[2869,12296,12297],{"class":3299},"0.7",[2869,12299,3492],{"class":3132},[2869,12301,3593],{"class":3128},[2869,12303,3270],{"class":3132},[2869,12305,5633],{"class":3299},[2869,12307,10323],{"class":3299},[2869,12309,3521],{"class":3132},[2869,12311,3437],{"class":3128},[2869,12313,3270],{"class":3132},[2869,12315,4373],{"class":3299},[2869,12317,3521],{"class":3132},[2869,12319,3584],{"class":3128},[2869,12321,3270],{"class":3132},[2869,12323,12324],{"class":3299},"0.9em",[2869,12326,3445],{"class":3132},[2869,12328,12329,12332,12334,12336,12338,12340,12342,12344,12346,12348,12350,12353,12355,12357],{"class":2871,"line":6271},[2869,12330,12331],{"class":3258},".shorthand-demo",[2869,12333,3434],{"class":3132},[2869,12335,9173],{"class":3128},[2869,12337,3270],{"class":3132},[2869,12339,3274],{"class":3273},[2869,12341,3521],{"class":3132},[2869,12343,9191],{"class":3128},[2869,12345,3270],{"class":3132},[2869,12347,6109],{"class":3299},[2869,12349,3521],{"class":3132},[2869,12351,12352],{"class":3128},"flex-wrap",[2869,12354,3270],{"class":3132},[2869,12356,3287],{"class":3273},[2869,12358,3445],{"class":3132},[2869,12360,12361,12364,12366,12369],{"class":2871,"line":6283},[2869,12362,12363],{"class":3258},".padding-logical",[2869,12365,2810],{"class":3132},[2869,12367,12368],{"class":3258},".margin-auto",[2869,12370,3262],{"class":3132},[2869,12372,12373,12375,12377,12379,12381,12383,12385,12387],{"class":2871,"line":6298},[2869,12374,6964],{"class":3128},[2869,12376,3270],{"class":3132},[2869,12378,5645],{"class":3299},[2869,12380,3521],{"class":3132},[2869,12382,10968],{"class":3128},[2869,12384,3270],{"class":3132},[2869,12386,6980],{"class":3299},[2869,12388,3277],{"class":3132},[2869,12390,12391,12393,12395,12397],{"class":2871,"line":6310},[2869,12392,3319],{"class":3128},[2869,12394,3270],{"class":3132},[2869,12396,3390],{"class":3273},[2869,12398,3277],{"class":3132},[2869,12400,12401,12403,12405,12407,12409,12411],{"class":2871,"line":6321},[2869,12402,3409],{"class":3128},[2869,12404,3270],{"class":3132},[2869,12406,3414],{"class":3299},[2869,12408,3417],{"class":3273},[2869,12410,3420],{"class":3273},[2869,12412,3277],{"class":3132},[2869,12414,12415,12417,12419,12421],{"class":2871,"line":6326},[2869,12416,4741],{"class":3128},[2869,12418,3270],{"class":3132},[2869,12420,6278],{"class":3299},[2869,12422,3277],{"class":3132},[2869,12424,12425],{"class":2871,"line":6334},[2869,12426,3360],{"class":3132},[2869,12428,12429,12431],{"class":2871,"line":6345},[2869,12430,12363],{"class":3258},[2869,12432,3262],{"class":3132},[2869,12434,12435,12437,12439,12441],{"class":2871,"line":6356},[2869,12436,9836],{"class":3128},[2869,12438,3270],{"class":3132},[2869,12440,12178],{"class":3299},[2869,12442,3277],{"class":3132},[2869,12444,12445,12448,12450,12452],{"class":2871,"line":6367},[2869,12446,12447],{"class":3128},"  padding-block",[2869,12449,3270],{"class":3132},[2869,12451,6109],{"class":3299},[2869,12453,3277],{"class":3132},[2869,12455,12456,12458,12460,12462],{"class":2871,"line":6382},[2869,12457,3397],{"class":3128},[2869,12459,3270],{"class":3132},[2869,12461,3402],{"class":3273},[2869,12463,3277],{"class":3132},[2869,12465,12466],{"class":2871,"line":6387},[2869,12467,3360],{"class":3132},[2869,12469,12470,12472],{"class":2871,"line":6395},[2869,12471,12368],{"class":3258},[2869,12473,3262],{"class":3132},[2869,12475,12476,12478,12480,12482],{"class":2871,"line":6407},[2869,12477,6219],{"class":3128},[2869,12479,3270],{"class":3132},[2869,12481,8498],{"class":3273},[2869,12483,3277],{"class":3132},[2869,12485,12486,12488,12490,12492],{"class":2871,"line":6433},[2869,12487,4968],{"class":3128},[2869,12489,3270],{"class":3132},[2869,12491,6236],{"class":3299},[2869,12493,3277],{"class":3132},[2869,12495,12496,12498,12500,12502],{"class":2871,"line":6444},[2869,12497,4983],{"class":3128},[2869,12499,3270],{"class":3132},[2869,12501,4988],{"class":3273},[2869,12503,3277],{"class":3132},[2869,12505,12506,12508,12510,12512,12514],{"class":2871,"line":6456},[2869,12507,3307],{"class":3128},[2869,12509,3270],{"class":3132},[2869,12511,6109],{"class":3299},[2869,12513,10403],{"class":3299},[2869,12515,3277],{"class":3132},[2869,12517,12518,12520,12522,12524],{"class":2871,"line":8128},[2869,12519,6126],{"class":3128},[2869,12521,3270],{"class":3132},[2869,12523,3559],{"class":3273},[2869,12525,3277],{"class":3132},[2869,12527,12528,12530,12532,12534],{"class":2871,"line":8139},[2869,12529,3319],{"class":3128},[2869,12531,3270],{"class":3132},[2869,12533,11114],{"class":3273},[2869,12535,3277],{"class":3132},[2869,12537,12538,12541,12543,12545],{"class":2871,"line":8151},[2869,12539,12540],{"class":3128},"  border-color",[2869,12542,3270],{"class":3132},[2869,12544,5410],{"class":3273},[2869,12546,3277],{"class":3132},[2869,12548,12549],{"class":2871,"line":8163},[2869,12550,3360],{"class":3132},[2869,12552,12553,12555,12557,12559,12561,12563,12565,12567,12569,12571,12573,12575,12577,12579],{"class":2871,"line":8175},[2869,12554,12363],{"class":3258},[2869,12556,10304],{"class":3258},[2869,12558,2810],{"class":3132},[2869,12560,12368],{"class":3258},[2869,12562,10304],{"class":3258},[2869,12564,3434],{"class":3132},[2869,12566,3584],{"class":3128},[2869,12568,3270],{"class":3132},[2869,12570,7119],{"class":3299},[2869,12572,3521],{"class":3132},[2869,12574,9317],{"class":3128},[2869,12576,3270],{"class":3132},[2869,12578,7086],{"class":3273},[2869,12580,3445],{"class":3132},[3852,12582,12583,12586],{},[2804,12584,12585],{},"Використовуйте логічні скорочення замість фізичних у компонентах, що потенційно можуть бути використані в міжнародних проєктах:",[2861,12587,12589],{"className":3249,"code":12588,"language":3251,"meta":2865,"style":2865},"/* ❌ Фізичне — ламається в RTL */\n.card { margin-left: auto; margin-right: auto; }\n\n/* ✅ Логічне — працює скрізь */\n.card { margin-inline: auto; }\n",[2799,12590,12591,12596,12619,12623,12628],{"__ignoreMap":2865},[2869,12592,12593],{"class":2871,"line":2872},[2869,12594,12595],{"class":3762},"/* ❌ Фізичне — ламається в RTL */\n",[2869,12597,12598,12601,12603,12605,12607,12609,12611,12613,12615,12617],{"class":2871,"line":2878},[2869,12599,12600],{"class":3258},".card",[2869,12602,3434],{"class":3132},[2869,12604,11432],{"class":3128},[2869,12606,3270],{"class":3132},[2869,12608,4988],{"class":3273},[2869,12610,3521],{"class":3132},[2869,12612,11519],{"class":3128},[2869,12614,3270],{"class":3132},[2869,12616,4988],{"class":3273},[2869,12618,3445],{"class":3132},[2869,12620,12621],{"class":2871,"line":2884},[2869,12622,4758],{"emptyLinePlaceholder":4757},[2869,12624,12625],{"class":2871,"line":2890},[2869,12626,12627],{"class":3762},"/* ✅ Логічне — працює скрізь */\n",[2869,12629,12630,12632,12634,12636,12638,12640],{"class":2871,"line":2896},[2869,12631,12600],{"class":3258},[2869,12633,3434],{"class":3132},[2869,12635,11571],{"class":3128},[2869,12637,3270],{"class":3132},[2869,12639,4988],{"class":3273},[2869,12641,3445],{"class":3132},[2967,12643],{},[2794,12645,12647,12648,2810,12651,2810,12654,2810,12657],{"id":12646},"css-функції-для-розмірів-calc-min-max-clamp","CSS-функції для розмірів: ",[2799,12649,12650],{},"calc()",[2799,12652,12653],{},"min()",[2799,12655,12656],{},"max()",[2799,12658,12659],{},"clamp()",[2982,12661,12663,12665],{"id":12662},"calc-арифметика-між-будь-якими-одиницями",[2799,12664,12650],{}," — арифметика між будь-якими одиницями",[2804,12667,12668,12670,12671,12674],{},[2799,12669,12650],{}," дозволяє ",[2977,12672,12673],{},"змішувати різні одиниці"," в одному виразі — те, що неможливо зробити статичним числом:",[2861,12676,12678],{"className":3249,"code":12677,"language":3251,"meta":2865,"style":2865},".element {\n  /* Займаємо всю ширину, мінус фіксований sidebar */\n  width: calc(100% - 280px);\n\n  /* Відступ кратний розміру шрифту, але з фіксованим мінімумом */\n  padding: calc(1rem + 5px);\n\n  /* Вертикальний відступ пропорційний viewport */\n  margin-top: calc(5vh - 1rem);\n}\n",[2799,12679,12680,12687,12692,12713,12717,12722,12741,12745,12750,12769],{"__ignoreMap":2865},[2869,12681,12682,12685],{"class":2871,"line":2872},[2869,12683,12684],{"class":3258},".element",[2869,12686,3262],{"class":3132},[2869,12688,12689],{"class":2871,"line":2878},[2869,12690,12691],{"class":3762},"  /* Займаємо всю ширину, мінус фіксований sidebar */\n",[2869,12693,12694,12696,12698,12701,12703,12705,12708,12711],{"class":2871,"line":2884},[2869,12695,6219],{"class":3128},[2869,12697,3270],{"class":3132},[2869,12699,12700],{"class":3469},"calc",[2869,12702,3473],{"class":3132},[2869,12704,6236],{"class":3299},[2869,12706,12707],{"class":3132}," - ",[2869,12709,12710],{"class":3299},"280px",[2869,12712,6047],{"class":3132},[2869,12714,12715],{"class":2871,"line":2890},[2869,12716,4758],{"emptyLinePlaceholder":4757},[2869,12718,12719],{"class":2871,"line":2896},[2869,12720,12721],{"class":3762},"  /* Відступ кратний розміру шрифту, але з фіксованим мінімумом */\n",[2869,12723,12724,12726,12728,12730,12732,12734,12736,12739],{"class":2871,"line":2902},[2869,12725,3307],{"class":3128},[2869,12727,3270],{"class":3132},[2869,12729,12700],{"class":3469},[2869,12731,3473],{"class":3132},[2869,12733,3300],{"class":3299},[2869,12735,5690],{"class":3132},[2869,12737,12738],{"class":3299},"5px",[2869,12740,6047],{"class":3132},[2869,12742,12743],{"class":2871,"line":2908},[2869,12744,4758],{"emptyLinePlaceholder":4757},[2869,12746,12747],{"class":2871,"line":2914},[2869,12748,12749],{"class":3762},"  /* Вертикальний відступ пропорційний viewport */\n",[2869,12751,12752,12754,12756,12758,12760,12763,12765,12767],{"class":2871,"line":2920},[2869,12753,5699],{"class":3128},[2869,12755,3270],{"class":3132},[2869,12757,12700],{"class":3469},[2869,12759,3473],{"class":3132},[2869,12761,12762],{"class":3299},"5vh",[2869,12764,12707],{"class":3132},[2869,12766,3300],{"class":3299},[2869,12768,6047],{"class":3132},[2869,12770,12771],{"class":2871,"line":2926},[2869,12772,3360],{"class":3132},[3107,12774,12775,12960],{},[2861,12776,12778],{"className":3111,"code":12777,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"calc-demo\">\n  \u003Cdiv class=\"layout-calc\">\n    \u003Caside class=\"sidebar-calc\">Sidebar\u003Cbr>\u003Ccode>280px\u003C/code>\u003C/aside>\n    \u003Cmain class=\"main-calc\">\n      Main content\u003Cbr>\n      \u003Ccode>width: calc(100% - 280px - 1rem)\u003C/code>\n    \u003C/main>\n  \u003C/div>\n  \u003Cdiv class=\"padding-calc\">\n    \u003Ccode>padding: calc(0.5rem + 1vw)\u003C/code> — мінімум 0.5rem + трохи від viewport\n  \u003C/div>\n\u003C/div>\n",[2799,12779,12780,12795,12810,12850,12865,12876,12893,12901,12909,12924,12944,12952],{"__ignoreMap":2865},[2869,12781,12782,12784,12786,12788,12790,12793],{"class":2871,"line":2872},[2869,12783,3121],{"class":3120},[2869,12785,3125],{"class":3124},[2869,12787,3129],{"class":3128},[2869,12789,3133],{"class":3132},[2869,12791,12792],{"class":3136},"\"calc-demo\"",[2869,12794,3140],{"class":3120},[2869,12796,12797,12799,12801,12803,12805,12808],{"class":2871,"line":2878},[2869,12798,3145],{"class":3120},[2869,12800,3125],{"class":3124},[2869,12802,3129],{"class":3128},[2869,12804,3133],{"class":3132},[2869,12806,12807],{"class":3136},"\"layout-calc\"",[2869,12809,3140],{"class":3120},[2869,12811,12812,12814,12816,12818,12820,12823,12825,12828,12830,12832,12834,12836,12838,12840,12842,12844,12846,12848],{"class":2871,"line":2884},[2869,12813,3971],{"class":3120},[2869,12815,7337],{"class":3124},[2869,12817,3129],{"class":3128},[2869,12819,3133],{"class":3132},[2869,12821,12822],{"class":3136},"\"sidebar-calc\"",[2869,12824,3157],{"class":3120},[2869,12826,12827],{"class":3132},"Sidebar",[2869,12829,3121],{"class":3120},[2869,12831,11827],{"class":3124},[2869,12833,9927],{"class":3120},[2869,12835,2799],{"class":3124},[2869,12837,3157],{"class":3120},[2869,12839,12710],{"class":3132},[2869,12841,3162],{"class":3120},[2869,12843,2799],{"class":3124},[2869,12845,9941],{"class":3120},[2869,12847,7337],{"class":3124},[2869,12849,3140],{"class":3120},[2869,12851,12852,12854,12856,12858,12860,12863],{"class":2871,"line":2890},[2869,12853,3971],{"class":3120},[2869,12855,7333],{"class":3124},[2869,12857,3129],{"class":3128},[2869,12859,3133],{"class":3132},[2869,12861,12862],{"class":3136},"\"main-calc\"",[2869,12864,3140],{"class":3120},[2869,12866,12867,12870,12872,12874],{"class":2871,"line":2896},[2869,12868,12869],{"class":3132},"      Main content",[2869,12871,3121],{"class":3120},[2869,12873,11827],{"class":3124},[2869,12875,3140],{"class":3120},[2869,12877,12878,12880,12882,12884,12887,12889,12891],{"class":2871,"line":2902},[2869,12879,4004],{"class":3120},[2869,12881,2799],{"class":3124},[2869,12883,3157],{"class":3120},[2869,12885,12886],{"class":3132},"width: calc(100% - 280px - 1rem)",[2869,12888,3162],{"class":3120},[2869,12890,2799],{"class":3124},[2869,12892,3140],{"class":3120},[2869,12894,12895,12897,12899],{"class":2871,"line":2908},[2869,12896,4064],{"class":3120},[2869,12898,7333],{"class":3124},[2869,12900,3140],{"class":3120},[2869,12902,12903,12905,12907],{"class":2871,"line":2914},[2869,12904,4073],{"class":3120},[2869,12906,3125],{"class":3124},[2869,12908,3140],{"class":3120},[2869,12910,12911,12913,12915,12917,12919,12922],{"class":2871,"line":2920},[2869,12912,3145],{"class":3120},[2869,12914,3125],{"class":3124},[2869,12916,3129],{"class":3128},[2869,12918,3133],{"class":3132},[2869,12920,12921],{"class":3136},"\"padding-calc\"",[2869,12923,3140],{"class":3120},[2869,12925,12926,12928,12930,12932,12935,12937,12939,12941],{"class":2871,"line":2926},[2869,12927,3971],{"class":3120},[2869,12929,2799],{"class":3124},[2869,12931,3157],{"class":3120},[2869,12933,12934],{"class":3132},"padding: calc(0.5rem + 1vw)",[2869,12936,3162],{"class":3120},[2869,12938,2799],{"class":3124},[2869,12940,3157],{"class":3120},[2869,12942,12943],{"class":3132}," — мінімум 0.5rem + трохи від viewport\n",[2869,12945,12946,12948,12950],{"class":2871,"line":2932},[2869,12947,4073],{"class":3120},[2869,12949,3125],{"class":3124},[2869,12951,3140],{"class":3120},[2869,12953,12954,12956,12958],{"class":2871,"line":2938},[2869,12955,3162],{"class":3120},[2869,12957,3125],{"class":3124},[2869,12959,3140],{"class":3120},[2861,12961,12963],{"className":3249,"code":12962,"language":3251,"meta":2865,"style":2865},".calc-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.82rem;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.75rem;\n}\n.layout-calc {\n  display: flex;\n  gap: 0.5rem;\n  height: 80px;\n}\n.sidebar-calc {\n  width: 110px;\n  flex-shrink: 0;\n  background: #6366f1;\n  color: white;\n  border-radius: 6px;\n  padding: 0.5rem;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  text-align: center;\n}\n.sidebar-calc code { font-size: 0.7rem; opacity: 0.8; }\n.main-calc {\n  width: calc(100% - 110px - 0.5rem);\n  background: white;\n  border: 1px solid #e2e8f0;\n  border-radius: 6px;\n  padding: 0.5rem;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  overflow: hidden;\n}\n.main-calc code { font-size: 0.7rem; color: #6366f1; }\n.padding-calc {\n  background: white;\n  border: 1px solid #e2e8f0;\n  border-radius: 6px;\n  padding: calc(0.5rem + 1vw);\n  line-height: 1.4;\n}\n.padding-calc code { background: #f1f5f9; padding: 0.1em 0.3em; border-radius: 3px; color: #6366f1; }\n",[2799,12964,12965,12972,12982,12992,13006,13016,13026,13036,13046,13056,13060,13067,13077,13087,13098,13102,13109,13120,13130,13140,13150,13160,13170,13180,13190,13200,13210,13220,13224,13248,13255,13277,13287,13301,13311,13321,13331,13341,13351,13361,13365,13389,13396,13406,13420,13430,13448,13458,13462],{"__ignoreMap":2865},[2869,12966,12967,12970],{"class":2871,"line":2872},[2869,12968,12969],{"class":3258},".calc-demo",[2869,12971,3262],{"class":3132},[2869,12973,12974,12976,12978,12980],{"class":2871,"line":2878},[2869,12975,3307],{"class":3128},[2869,12977,3270],{"class":3132},[2869,12979,3300],{"class":3299},[2869,12981,3277],{"class":3132},[2869,12983,12984,12986,12988,12990],{"class":2871,"line":2884},[2869,12985,3319],{"class":3128},[2869,12987,3270],{"class":3132},[2869,12989,3324],{"class":3273},[2869,12991,3277],{"class":3132},[2869,12993,12994,12996,12998,13000,13002,13004],{"class":2871,"line":2890},[2869,12995,3331],{"class":3128},[2869,12997,3270],{"class":3132},[2869,12999,3336],{"class":3273},[2869,13001,2810],{"class":3132},[2869,13003,3341],{"class":3273},[2869,13005,3277],{"class":3132},[2869,13007,13008,13010,13012,13014],{"class":2871,"line":2896},[2869,13009,3348],{"class":3128},[2869,13011,3270],{"class":3132},[2869,13013,11966],{"class":3299},[2869,13015,3277],{"class":3132},[2869,13017,13018,13020,13022,13024],{"class":2871,"line":2902},[2869,13019,3397],{"class":3128},[2869,13021,3270],{"class":3132},[2869,13023,3402],{"class":3273},[2869,13025,3277],{"class":3132},[2869,13027,13028,13030,13032,13034],{"class":2871,"line":2908},[2869,13029,3267],{"class":3128},[2869,13031,3270],{"class":3132},[2869,13033,3274],{"class":3273},[2869,13035,3277],{"class":3132},[2869,13037,13038,13040,13042,13044],{"class":2871,"line":2914},[2869,13039,5222],{"class":3128},[2869,13041,3270],{"class":3132},[2869,13043,5227],{"class":3273},[2869,13045,3277],{"class":3132},[2869,13047,13048,13050,13052,13054],{"class":2871,"line":2920},[2869,13049,3294],{"class":3128},[2869,13051,3270],{"class":3132},[2869,13053,3376],{"class":3299},[2869,13055,3277],{"class":3132},[2869,13057,13058],{"class":2871,"line":2926},[2869,13059,3360],{"class":3132},[2869,13061,13062,13065],{"class":2871,"line":2932},[2869,13063,13064],{"class":3258},".layout-calc",[2869,13066,3262],{"class":3132},[2869,13068,13069,13071,13073,13075],{"class":2871,"line":2938},[2869,13070,3267],{"class":3128},[2869,13072,3270],{"class":3132},[2869,13074,3274],{"class":3273},[2869,13076,3277],{"class":3132},[2869,13078,13079,13081,13083,13085],{"class":2871,"line":2944},[2869,13080,3294],{"class":3128},[2869,13082,3270],{"class":3132},[2869,13084,6109],{"class":3299},[2869,13086,3277],{"class":3132},[2869,13088,13089,13091,13093,13096],{"class":2871,"line":2950},[2869,13090,6014],{"class":3128},[2869,13092,3270],{"class":3132},[2869,13094,13095],{"class":3299},"80px",[2869,13097,3277],{"class":3132},[2869,13099,13100],{"class":2871,"line":2956},[2869,13101,3360],{"class":3132},[2869,13103,13104,13107],{"class":2871,"line":2962},[2869,13105,13106],{"class":3258},".sidebar-calc",[2869,13108,3262],{"class":3132},[2869,13110,13111,13113,13115,13118],{"class":2871,"line":3448},[2869,13112,6219],{"class":3128},[2869,13114,3270],{"class":3132},[2869,13116,13117],{"class":3299},"110px",[2869,13119,3277],{"class":3132},[2869,13121,13122,13124,13126,13128],{"class":2871,"line":3505},[2869,13123,8115],{"class":3128},[2869,13125,3270],{"class":3132},[2869,13127,3460],{"class":3299},[2869,13129,3277],{"class":3132},[2869,13131,13132,13134,13136,13138],{"class":2871,"line":3543},[2869,13133,3319],{"class":3128},[2869,13135,3270],{"class":3132},[2869,13137,3538],{"class":3273},[2869,13139,3277],{"class":3132},[2869,13141,13142,13144,13146,13148],{"class":2871,"line":3573},[2869,13143,3397],{"class":3128},[2869,13145,3270],{"class":3132},[2869,13147,3390],{"class":3273},[2869,13149,3277],{"class":3132},[2869,13151,13152,13154,13156,13158],{"class":2871,"line":3619},[2869,13153,4741],{"class":3128},[2869,13155,3270],{"class":3132},[2869,13157,6278],{"class":3299},[2869,13159,3277],{"class":3132},[2869,13161,13162,13164,13166,13168],{"class":2871,"line":4232},[2869,13163,3307],{"class":3128},[2869,13165,3270],{"class":3132},[2869,13167,6109],{"class":3299},[2869,13169,3277],{"class":3132},[2869,13171,13172,13174,13176,13178],{"class":2871,"line":4241},[2869,13173,3267],{"class":3128},[2869,13175,3270],{"class":3132},[2869,13177,3274],{"class":3273},[2869,13179,3277],{"class":3132},[2869,13181,13182,13184,13186,13188],{"class":2871,"line":6174},[2869,13183,5222],{"class":3128},[2869,13185,3270],{"class":3132},[2869,13187,5227],{"class":3273},[2869,13189,3277],{"class":3132},[2869,13191,13192,13194,13196,13198],{"class":2871,"line":6208},[2869,13193,6083],{"class":3128},[2869,13195,3270],{"class":3132},[2869,13197,3559],{"class":3273},[2869,13199,3277],{"class":3132},[2869,13201,13202,13204,13206,13208],{"class":2871,"line":6216},[2869,13203,6094],{"class":3128},[2869,13205,3270],{"class":3132},[2869,13207,3559],{"class":3273},[2869,13209,3277],{"class":3132},[2869,13211,13212,13214,13216,13218],{"class":2871,"line":6229},[2869,13213,6126],{"class":3128},[2869,13215,3270],{"class":3132},[2869,13217,3559],{"class":3273},[2869,13219,3277],{"class":3132},[2869,13221,13222],{"class":2871,"line":6241},[2869,13223,3360],{"class":3132},[2869,13225,13226,13228,13230,13232,13234,13236,13238,13240,13242,13244,13246],{"class":2871,"line":6271},[2869,13227,13106],{"class":3258},[2869,13229,10304],{"class":3258},[2869,13231,3434],{"class":3132},[2869,13233,3584],{"class":3128},[2869,13235,3270],{"class":3132},[2869,13237,7956],{"class":3299},[2869,13239,3521],{"class":3132},[2869,13241,5465],{"class":3128},[2869,13243,3270],{"class":3132},[2869,13245,6203],{"class":3299},[2869,13247,3445],{"class":3132},[2869,13249,13250,13253],{"class":2871,"line":6283},[2869,13251,13252],{"class":3258},".main-calc",[2869,13254,3262],{"class":3132},[2869,13256,13257,13259,13261,13263,13265,13267,13269,13271,13273,13275],{"class":2871,"line":6298},[2869,13258,6219],{"class":3128},[2869,13260,3270],{"class":3132},[2869,13262,12700],{"class":3469},[2869,13264,3473],{"class":3132},[2869,13266,6236],{"class":3299},[2869,13268,12707],{"class":3132},[2869,13270,13117],{"class":3299},[2869,13272,12707],{"class":3132},[2869,13274,6109],{"class":3299},[2869,13276,6047],{"class":3132},[2869,13278,13279,13281,13283,13285],{"class":2871,"line":6310},[2869,13280,3319],{"class":3128},[2869,13282,3270],{"class":3132},[2869,13284,3390],{"class":3273},[2869,13286,3277],{"class":3132},[2869,13288,13289,13291,13293,13295,13297,13299],{"class":2871,"line":6321},[2869,13290,3409],{"class":3128},[2869,13292,3270],{"class":3132},[2869,13294,3414],{"class":3299},[2869,13296,3417],{"class":3273},[2869,13298,3420],{"class":3273},[2869,13300,3277],{"class":3132},[2869,13302,13303,13305,13307,13309],{"class":2871,"line":6326},[2869,13304,4741],{"class":3128},[2869,13306,3270],{"class":3132},[2869,13308,6278],{"class":3299},[2869,13310,3277],{"class":3132},[2869,13312,13313,13315,13317,13319],{"class":2871,"line":6334},[2869,13314,3307],{"class":3128},[2869,13316,3270],{"class":3132},[2869,13318,6109],{"class":3299},[2869,13320,3277],{"class":3132},[2869,13322,13323,13325,13327,13329],{"class":2871,"line":6345},[2869,13324,3267],{"class":3128},[2869,13326,3270],{"class":3132},[2869,13328,3274],{"class":3273},[2869,13330,3277],{"class":3132},[2869,13332,13333,13335,13337,13339],{"class":2871,"line":6356},[2869,13334,5222],{"class":3128},[2869,13336,3270],{"class":3132},[2869,13338,5227],{"class":3273},[2869,13340,3277],{"class":3132},[2869,13342,13343,13345,13347,13349],{"class":2871,"line":6367},[2869,13344,6094],{"class":3128},[2869,13346,3270],{"class":3132},[2869,13348,3559],{"class":3273},[2869,13350,3277],{"class":3132},[2869,13352,13353,13355,13357,13359],{"class":2871,"line":6382},[2869,13354,9264],{"class":3128},[2869,13356,3270],{"class":3132},[2869,13358,9269],{"class":3273},[2869,13360,3277],{"class":3132},[2869,13362,13363],{"class":2871,"line":6387},[2869,13364,3360],{"class":3132},[2869,13366,13367,13369,13371,13373,13375,13377,13379,13381,13383,13385,13387],{"class":2871,"line":6395},[2869,13368,13252],{"class":3258},[2869,13370,10304],{"class":3258},[2869,13372,3434],{"class":3132},[2869,13374,3584],{"class":3128},[2869,13376,3270],{"class":3132},[2869,13378,7956],{"class":3299},[2869,13380,3521],{"class":3132},[2869,13382,9147],{"class":3128},[2869,13384,3270],{"class":3132},[2869,13386,3538],{"class":3273},[2869,13388,3445],{"class":3132},[2869,13390,13391,13394],{"class":2871,"line":6407},[2869,13392,13393],{"class":3258},".padding-calc",[2869,13395,3262],{"class":3132},[2869,13397,13398,13400,13402,13404],{"class":2871,"line":6433},[2869,13399,3319],{"class":3128},[2869,13401,3270],{"class":3132},[2869,13403,3390],{"class":3273},[2869,13405,3277],{"class":3132},[2869,13407,13408,13410,13412,13414,13416,13418],{"class":2871,"line":6444},[2869,13409,3409],{"class":3128},[2869,13411,3270],{"class":3132},[2869,13413,3414],{"class":3299},[2869,13415,3417],{"class":3273},[2869,13417,3420],{"class":3273},[2869,13419,3277],{"class":3132},[2869,13421,13422,13424,13426,13428],{"class":2871,"line":6456},[2869,13423,4741],{"class":3128},[2869,13425,3270],{"class":3132},[2869,13427,6278],{"class":3299},[2869,13429,3277],{"class":3132},[2869,13431,13432,13434,13436,13438,13440,13442,13444,13446],{"class":2871,"line":8128},[2869,13433,3307],{"class":3128},[2869,13435,3270],{"class":3132},[2869,13437,12700],{"class":3469},[2869,13439,3473],{"class":3132},[2869,13441,6109],{"class":3299},[2869,13443,5690],{"class":3132},[2869,13445,5736],{"class":3299},[2869,13447,6047],{"class":3132},[2869,13449,13450,13452,13454,13456],{"class":2871,"line":8139},[2869,13451,5640],{"class":3128},[2869,13453,3270],{"class":3132},[2869,13455,7142],{"class":3299},[2869,13457,3277],{"class":3132},[2869,13459,13460],{"class":2871,"line":8151},[2869,13461,3360],{"class":3132},[2869,13463,13464,13466,13468,13470,13472,13474,13476,13478,13480,13482,13484,13486,13488,13490,13492,13494,13496,13498,13500,13502],{"class":2871,"line":8163},[2869,13465,13393],{"class":3258},[2869,13467,10304],{"class":3258},[2869,13469,3434],{"class":3132},[2869,13471,3533],{"class":3128},[2869,13473,3270],{"class":3132},[2869,13475,5996],{"class":3273},[2869,13477,3521],{"class":3132},[2869,13479,3593],{"class":3128},[2869,13481,3270],{"class":3132},[2869,13483,5633],{"class":3299},[2869,13485,10323],{"class":3299},[2869,13487,3521],{"class":3132},[2869,13489,3437],{"class":3128},[2869,13491,3270],{"class":3132},[2869,13493,4373],{"class":3299},[2869,13495,3521],{"class":3132},[2869,13497,9147],{"class":3128},[2869,13499,3270],{"class":3132},[2869,13501,3538],{"class":3273},[2869,13503,3445],{"class":3132},[2982,13505,13507,5726,13509,13511],{"id":13506},"min-та-max-умовні-розміри",[2799,13508,12653],{},[2799,13510,12656],{}," — умовні розміри",[2804,13513,13514,13517,13518,13521,13522,13525,13526,3905],{},[2799,13515,13516],{},"min(a, b)"," повертає ",[2977,13519,13520],{},"менше"," з двох значень. ",[2799,13523,13524],{},"max(a, b)"," — ",[2977,13527,13528],{},"більше",[2861,13530,13532],{"className":3249,"code":13531,"language":3251,"meta":2865,"style":2865},"/* min(): не більше за 600px, але адаптується на менших екранах */\n.card {\n  width: min(100%, 600px);\n}\n\n/* max(): не менше за 200px, але розширюється */\n.sidebar {\n  width: max(200px, 20%);\n}\n",[2799,13533,13534,13539,13545,13565,13569,13573,13578,13585,13605],{"__ignoreMap":2865},[2869,13535,13536],{"class":2871,"line":2872},[2869,13537,13538],{"class":3762},"/* min(): не більше за 600px, але адаптується на менших екранах */\n",[2869,13540,13541,13543],{"class":2871,"line":2878},[2869,13542,12600],{"class":3258},[2869,13544,3262],{"class":3132},[2869,13546,13547,13549,13551,13554,13556,13558,13560,13563],{"class":2871,"line":2884},[2869,13548,6219],{"class":3128},[2869,13550,3270],{"class":3132},[2869,13552,13553],{"class":3469},"min",[2869,13555,3473],{"class":3132},[2869,13557,6236],{"class":3299},[2869,13559,2810],{"class":3132},[2869,13561,13562],{"class":3299},"600px",[2869,13564,6047],{"class":3132},[2869,13566,13567],{"class":2871,"line":2890},[2869,13568,3360],{"class":3132},[2869,13570,13571],{"class":2871,"line":2896},[2869,13572,4758],{"emptyLinePlaceholder":4757},[2869,13574,13575],{"class":2871,"line":2902},[2869,13576,13577],{"class":3762},"/* max(): не менше за 200px, але розширюється */\n",[2869,13579,13580,13583],{"class":2871,"line":2908},[2869,13581,13582],{"class":3258},".sidebar",[2869,13584,3262],{"class":3132},[2869,13586,13587,13589,13591,13594,13596,13598,13600,13603],{"class":2871,"line":2914},[2869,13588,6219],{"class":3128},[2869,13590,3270],{"class":3132},[2869,13592,13593],{"class":3469},"max",[2869,13595,3473],{"class":3132},[2869,13597,9428],{"class":3299},[2869,13599,2810],{"class":3132},[2869,13601,13602],{"class":3299},"20%",[2869,13604,6047],{"class":3132},[2869,13606,13607],{"class":2871,"line":2920},[2869,13608,3360],{"class":3132},[3107,13610,13611,13927],{},[2861,13612,13614],{"className":3111,"code":13613,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"minmax-demo\">\n  \u003Cdiv class=\"min-example\">\n    \u003Cp class=\"fn-label\">min(100%, 300px)\u003C/p>\n    \u003Cdiv class=\"min-box\">Не ширший 300px, але звужується на малих екранах\u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"max-example\">\n    \u003Cp class=\"fn-label\">max(80px, 20%)\u003C/p>\n    \u003Cdiv class=\"max-box\">Не вужчий 80px, навіть на малих екранах\u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"compare-row\">\n    \u003Cdiv class=\"item-pct\">width: 40%\u003Cbr>\u003Csmall>стискується до нуля!\u003C/small>\u003C/div>\n    \u003Cdiv class=\"item-min\">width: min(40%, 200px)\u003Cbr>\u003Csmall>обмежений зверху\u003C/small>\u003C/div>\n    \u003Cdiv class=\"item-max\">width: max(100px, 40%)\u003Cbr>\u003Csmall>обмежений знизу\u003C/small>\u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,13615,13616,13631,13646,13670,13694,13702,13717,13740,13764,13772,13787,13829,13870,13911,13919],{"__ignoreMap":2865},[2869,13617,13618,13620,13622,13624,13626,13629],{"class":2871,"line":2872},[2869,13619,3121],{"class":3120},[2869,13621,3125],{"class":3124},[2869,13623,3129],{"class":3128},[2869,13625,3133],{"class":3132},[2869,13627,13628],{"class":3136},"\"minmax-demo\"",[2869,13630,3140],{"class":3120},[2869,13632,13633,13635,13637,13639,13641,13644],{"class":2871,"line":2878},[2869,13634,3145],{"class":3120},[2869,13636,3125],{"class":3124},[2869,13638,3129],{"class":3128},[2869,13640,3133],{"class":3132},[2869,13642,13643],{"class":3136},"\"min-example\"",[2869,13645,3140],{"class":3120},[2869,13647,13648,13650,13652,13654,13656,13659,13661,13664,13666,13668],{"class":2871,"line":2884},[2869,13649,3971],{"class":3120},[2869,13651,2804],{"class":3124},[2869,13653,3129],{"class":3128},[2869,13655,3133],{"class":3132},[2869,13657,13658],{"class":3136},"\"fn-label\"",[2869,13660,3157],{"class":3120},[2869,13662,13663],{"class":3132},"min(100%, 300px)",[2869,13665,3162],{"class":3120},[2869,13667,2804],{"class":3124},[2869,13669,3140],{"class":3120},[2869,13671,13672,13674,13676,13678,13680,13683,13685,13688,13690,13692],{"class":2871,"line":2890},[2869,13673,3971],{"class":3120},[2869,13675,3125],{"class":3124},[2869,13677,3129],{"class":3128},[2869,13679,3133],{"class":3132},[2869,13681,13682],{"class":3136},"\"min-box\"",[2869,13684,3157],{"class":3120},[2869,13686,13687],{"class":3132},"Не ширший 300px, але звужується на малих екранах",[2869,13689,3162],{"class":3120},[2869,13691,3125],{"class":3124},[2869,13693,3140],{"class":3120},[2869,13695,13696,13698,13700],{"class":2871,"line":2896},[2869,13697,4073],{"class":3120},[2869,13699,3125],{"class":3124},[2869,13701,3140],{"class":3120},[2869,13703,13704,13706,13708,13710,13712,13715],{"class":2871,"line":2902},[2869,13705,3145],{"class":3120},[2869,13707,3125],{"class":3124},[2869,13709,3129],{"class":3128},[2869,13711,3133],{"class":3132},[2869,13713,13714],{"class":3136},"\"max-example\"",[2869,13716,3140],{"class":3120},[2869,13718,13719,13721,13723,13725,13727,13729,13731,13734,13736,13738],{"class":2871,"line":2908},[2869,13720,3971],{"class":3120},[2869,13722,2804],{"class":3124},[2869,13724,3129],{"class":3128},[2869,13726,3133],{"class":3132},[2869,13728,13658],{"class":3136},[2869,13730,3157],{"class":3120},[2869,13732,13733],{"class":3132},"max(80px, 20%)",[2869,13735,3162],{"class":3120},[2869,13737,2804],{"class":3124},[2869,13739,3140],{"class":3120},[2869,13741,13742,13744,13746,13748,13750,13753,13755,13758,13760,13762],{"class":2871,"line":2914},[2869,13743,3971],{"class":3120},[2869,13745,3125],{"class":3124},[2869,13747,3129],{"class":3128},[2869,13749,3133],{"class":3132},[2869,13751,13752],{"class":3136},"\"max-box\"",[2869,13754,3157],{"class":3120},[2869,13756,13757],{"class":3132},"Не вужчий 80px, навіть на малих екранах",[2869,13759,3162],{"class":3120},[2869,13761,3125],{"class":3124},[2869,13763,3140],{"class":3120},[2869,13765,13766,13768,13770],{"class":2871,"line":2920},[2869,13767,4073],{"class":3120},[2869,13769,3125],{"class":3124},[2869,13771,3140],{"class":3120},[2869,13773,13774,13776,13778,13780,13782,13785],{"class":2871,"line":2926},[2869,13775,3145],{"class":3120},[2869,13777,3125],{"class":3124},[2869,13779,3129],{"class":3128},[2869,13781,3133],{"class":3132},[2869,13783,13784],{"class":3136},"\"compare-row\"",[2869,13786,3140],{"class":3120},[2869,13788,13789,13791,13793,13795,13797,13800,13802,13805,13807,13809,13811,13814,13816,13819,13821,13823,13825,13827],{"class":2871,"line":2932},[2869,13790,3971],{"class":3120},[2869,13792,3125],{"class":3124},[2869,13794,3129],{"class":3128},[2869,13796,3133],{"class":3132},[2869,13798,13799],{"class":3136},"\"item-pct\"",[2869,13801,3157],{"class":3120},[2869,13803,13804],{"class":3132},"width: 40%",[2869,13806,3121],{"class":3120},[2869,13808,11827],{"class":3124},[2869,13810,9927],{"class":3120},[2869,13812,13813],{"class":3124},"small",[2869,13815,3157],{"class":3120},[2869,13817,13818],{"class":3132},"стискується до нуля!",[2869,13820,3162],{"class":3120},[2869,13822,13813],{"class":3124},[2869,13824,9941],{"class":3120},[2869,13826,3125],{"class":3124},[2869,13828,3140],{"class":3120},[2869,13830,13831,13833,13835,13837,13839,13842,13844,13847,13849,13851,13853,13855,13857,13860,13862,13864,13866,13868],{"class":2871,"line":2938},[2869,13832,3971],{"class":3120},[2869,13834,3125],{"class":3124},[2869,13836,3129],{"class":3128},[2869,13838,3133],{"class":3132},[2869,13840,13841],{"class":3136},"\"item-min\"",[2869,13843,3157],{"class":3120},[2869,13845,13846],{"class":3132},"width: min(40%, 200px)",[2869,13848,3121],{"class":3120},[2869,13850,11827],{"class":3124},[2869,13852,9927],{"class":3120},[2869,13854,13813],{"class":3124},[2869,13856,3157],{"class":3120},[2869,13858,13859],{"class":3132},"обмежений зверху",[2869,13861,3162],{"class":3120},[2869,13863,13813],{"class":3124},[2869,13865,9941],{"class":3120},[2869,13867,3125],{"class":3124},[2869,13869,3140],{"class":3120},[2869,13871,13872,13874,13876,13878,13880,13883,13885,13888,13890,13892,13894,13896,13898,13901,13903,13905,13907,13909],{"class":2871,"line":2944},[2869,13873,3971],{"class":3120},[2869,13875,3125],{"class":3124},[2869,13877,3129],{"class":3128},[2869,13879,3133],{"class":3132},[2869,13881,13882],{"class":3136},"\"item-max\"",[2869,13884,3157],{"class":3120},[2869,13886,13887],{"class":3132},"width: max(100px, 40%)",[2869,13889,3121],{"class":3120},[2869,13891,11827],{"class":3124},[2869,13893,9927],{"class":3120},[2869,13895,13813],{"class":3124},[2869,13897,3157],{"class":3120},[2869,13899,13900],{"class":3132},"обмежений знизу",[2869,13902,3162],{"class":3120},[2869,13904,13813],{"class":3124},[2869,13906,9941],{"class":3120},[2869,13908,3125],{"class":3124},[2869,13910,3140],{"class":3120},[2869,13912,13913,13915,13917],{"class":2871,"line":2950},[2869,13914,4073],{"class":3120},[2869,13916,3125],{"class":3124},[2869,13918,3140],{"class":3120},[2869,13920,13921,13923,13925],{"class":2871,"line":2956},[2869,13922,3162],{"class":3120},[2869,13924,3125],{"class":3124},[2869,13926,3140],{"class":3120},[2861,13928,13930],{"className":3249,"code":13929,"language":3251,"meta":2865,"style":2865},".minmax-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.8rem;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.75rem;\n}\n.fn-label { margin: 0 0 0.3rem; font-family: monospace; font-weight: 700; color: #6366f1; font-size: 0.82rem; }\n.min-box {\n  width: min(100%, 300px);\n  background: linear-gradient(90deg, #6366f1, #8b5cf6);\n  color: white;\n  padding: 0.5rem 0.75rem;\n  border-radius: 6px;\n  line-height: 1.3;\n}\n.max-box {\n  width: max(80px, 20%);\n  background: linear-gradient(90deg, #10b981, #059669);\n  color: white;\n  padding: 0.5rem 0.75rem;\n  border-radius: 6px;\n  line-height: 1.3;\n}\n.compare-row { display: flex; gap: 0.4rem; align-items: flex-start; flex-wrap: wrap; }\n.item-pct, .item-min, .item-max {\n  padding: 0.4rem 0.6rem;\n  border-radius: 6px;\n  line-height: 1.4;\n}\n.item-pct  { width: 40%; background: #fee2e2; border: 1px solid #fca5a5; }\n.item-min  { width: min(40%, 200px); background: #ede9fe; border: 1px solid #c4b5fd; }\n.item-max  { width: max(100px, 40%); background: #dcfce7; border: 1px solid #86efac; }\n.item-pct small, .item-min small, .item-max small { display: block; font-size: 0.72rem; opacity: 0.7; }\n",[2799,13931,13932,13939,13949,13959,13973,13983,13993,14003,14013,14023,14027,14079,14086,14104,14127,14137,14149,14159,14169,14173,14180,14198,14220,14230,14242,14252,14262,14266,14306,14323,14335,14345,14355,14359,14395,14438,14481],{"__ignoreMap":2865},[2869,13933,13934,13937],{"class":2871,"line":2872},[2869,13935,13936],{"class":3258},".minmax-demo",[2869,13938,3262],{"class":3132},[2869,13940,13941,13943,13945,13947],{"class":2871,"line":2878},[2869,13942,3307],{"class":3128},[2869,13944,3270],{"class":3132},[2869,13946,3300],{"class":3299},[2869,13948,3277],{"class":3132},[2869,13950,13951,13953,13955,13957],{"class":2871,"line":2884},[2869,13952,3319],{"class":3128},[2869,13954,3270],{"class":3132},[2869,13956,3324],{"class":3273},[2869,13958,3277],{"class":3132},[2869,13960,13961,13963,13965,13967,13969,13971],{"class":2871,"line":2890},[2869,13962,3331],{"class":3128},[2869,13964,3270],{"class":3132},[2869,13966,3336],{"class":3273},[2869,13968,2810],{"class":3132},[2869,13970,3341],{"class":3273},[2869,13972,3277],{"class":3132},[2869,13974,13975,13977,13979,13981],{"class":2871,"line":2896},[2869,13976,3348],{"class":3128},[2869,13978,3270],{"class":3132},[2869,13980,6305],{"class":3299},[2869,13982,3277],{"class":3132},[2869,13984,13985,13987,13989,13991],{"class":2871,"line":2902},[2869,13986,3397],{"class":3128},[2869,13988,3270],{"class":3132},[2869,13990,3402],{"class":3273},[2869,13992,3277],{"class":3132},[2869,13994,13995,13997,13999,14001],{"class":2871,"line":2908},[2869,13996,3267],{"class":3128},[2869,13998,3270],{"class":3132},[2869,14000,3274],{"class":3273},[2869,14002,3277],{"class":3132},[2869,14004,14005,14007,14009,14011],{"class":2871,"line":2914},[2869,14006,5222],{"class":3128},[2869,14008,3270],{"class":3132},[2869,14010,5227],{"class":3273},[2869,14012,3277],{"class":3132},[2869,14014,14015,14017,14019,14021],{"class":2871,"line":2920},[2869,14016,3294],{"class":3128},[2869,14018,3270],{"class":3132},[2869,14020,3376],{"class":3299},[2869,14022,3277],{"class":3132},[2869,14024,14025],{"class":2871,"line":2926},[2869,14026,3360],{"class":3132},[2869,14028,14029,14032,14034,14036,14038,14040,14042,14045,14047,14049,14051,14053,14055,14057,14059,14061,14063,14065,14067,14069,14071,14073,14075,14077],{"class":2871,"line":2932},[2869,14030,14031],{"class":3258},".fn-label",[2869,14033,3434],{"class":3132},[2869,14035,4328],{"class":3128},[2869,14037,3270],{"class":3132},[2869,14039,3460],{"class":3299},[2869,14041,4335],{"class":3299},[2869,14043,14044],{"class":3299}," 0.3rem",[2869,14046,3521],{"class":3132},[2869,14048,9317],{"class":3128},[2869,14050,3270],{"class":3132},[2869,14052,7086],{"class":3273},[2869,14054,3521],{"class":3132},[2869,14056,9334],{"class":3128},[2869,14058,3270],{"class":3132},[2869,14060,9339],{"class":3299},[2869,14062,3521],{"class":3132},[2869,14064,9147],{"class":3128},[2869,14066,3270],{"class":3132},[2869,14068,3538],{"class":3273},[2869,14070,3521],{"class":3132},[2869,14072,3584],{"class":3128},[2869,14074,3270],{"class":3132},[2869,14076,11966],{"class":3299},[2869,14078,3445],{"class":3132},[2869,14080,14081,14084],{"class":2871,"line":2938},[2869,14082,14083],{"class":3258},".min-box",[2869,14085,3262],{"class":3132},[2869,14087,14088,14090,14092,14094,14096,14098,14100,14102],{"class":2871,"line":2944},[2869,14089,6219],{"class":3128},[2869,14091,3270],{"class":3132},[2869,14093,13553],{"class":3469},[2869,14095,3473],{"class":3132},[2869,14097,6236],{"class":3299},[2869,14099,2810],{"class":3132},[2869,14101,8547],{"class":3299},[2869,14103,6047],{"class":3132},[2869,14105,14106,14108,14110,14112,14114,14117,14119,14121,14123,14125],{"class":2871,"line":2950},[2869,14107,3319],{"class":3128},[2869,14109,3270],{"class":3132},[2869,14111,6030],{"class":3469},[2869,14113,3473],{"class":3132},[2869,14115,14116],{"class":3299},"90deg",[2869,14118,2810],{"class":3132},[2869,14120,3538],{"class":3273},[2869,14122,2810],{"class":3132},[2869,14124,6044],{"class":3273},[2869,14126,6047],{"class":3132},[2869,14128,14129,14131,14133,14135],{"class":2871,"line":2956},[2869,14130,3397],{"class":3128},[2869,14132,3270],{"class":3132},[2869,14134,3390],{"class":3273},[2869,14136,3277],{"class":3132},[2869,14138,14139,14141,14143,14145,14147],{"class":2871,"line":2962},[2869,14140,3307],{"class":3128},[2869,14142,3270],{"class":3132},[2869,14144,6109],{"class":3299},[2869,14146,6293],{"class":3299},[2869,14148,3277],{"class":3132},[2869,14150,14151,14153,14155,14157],{"class":2871,"line":3448},[2869,14152,4741],{"class":3128},[2869,14154,3270],{"class":3132},[2869,14156,6278],{"class":3299},[2869,14158,3277],{"class":3132},[2869,14160,14161,14163,14165,14167],{"class":2871,"line":3505},[2869,14162,5640],{"class":3128},[2869,14164,3270],{"class":3132},[2869,14166,8235],{"class":3299},[2869,14168,3277],{"class":3132},[2869,14170,14171],{"class":2871,"line":3543},[2869,14172,3360],{"class":3132},[2869,14174,14175,14178],{"class":2871,"line":3573},[2869,14176,14177],{"class":3258},".max-box",[2869,14179,3262],{"class":3132},[2869,14181,14182,14184,14186,14188,14190,14192,14194,14196],{"class":2871,"line":3619},[2869,14183,6219],{"class":3128},[2869,14185,3270],{"class":3132},[2869,14187,13593],{"class":3469},[2869,14189,3473],{"class":3132},[2869,14191,13095],{"class":3299},[2869,14193,2810],{"class":3132},[2869,14195,13602],{"class":3299},[2869,14197,6047],{"class":3132},[2869,14199,14200,14202,14204,14206,14208,14210,14212,14214,14216,14218],{"class":2871,"line":4232},[2869,14201,3319],{"class":3128},[2869,14203,3270],{"class":3132},[2869,14205,6030],{"class":3469},[2869,14207,3473],{"class":3132},[2869,14209,14116],{"class":3299},[2869,14211,2810],{"class":3132},[2869,14213,5410],{"class":3273},[2869,14215,2810],{"class":3132},[2869,14217,7204],{"class":3273},[2869,14219,6047],{"class":3132},[2869,14221,14222,14224,14226,14228],{"class":2871,"line":4241},[2869,14223,3397],{"class":3128},[2869,14225,3270],{"class":3132},[2869,14227,3390],{"class":3273},[2869,14229,3277],{"class":3132},[2869,14231,14232,14234,14236,14238,14240],{"class":2871,"line":6174},[2869,14233,3307],{"class":3128},[2869,14235,3270],{"class":3132},[2869,14237,6109],{"class":3299},[2869,14239,6293],{"class":3299},[2869,14241,3277],{"class":3132},[2869,14243,14244,14246,14248,14250],{"class":2871,"line":6208},[2869,14245,4741],{"class":3128},[2869,14247,3270],{"class":3132},[2869,14249,6278],{"class":3299},[2869,14251,3277],{"class":3132},[2869,14253,14254,14256,14258,14260],{"class":2871,"line":6216},[2869,14255,5640],{"class":3128},[2869,14257,3270],{"class":3132},[2869,14259,8235],{"class":3299},[2869,14261,3277],{"class":3132},[2869,14263,14264],{"class":2871,"line":6229},[2869,14265,3360],{"class":3132},[2869,14267,14268,14271,14273,14275,14277,14279,14281,14283,14285,14287,14289,14291,14293,14296,14298,14300,14302,14304],{"class":2871,"line":6241},[2869,14269,14270],{"class":3258},".compare-row",[2869,14272,3434],{"class":3132},[2869,14274,9173],{"class":3128},[2869,14276,3270],{"class":3132},[2869,14278,3274],{"class":3273},[2869,14280,3521],{"class":3132},[2869,14282,9191],{"class":3128},[2869,14284,3270],{"class":3132},[2869,14286,6290],{"class":3299},[2869,14288,3521],{"class":3132},[2869,14290,3554],{"class":3128},[2869,14292,3270],{"class":3132},[2869,14294,14295],{"class":3273},"flex-start",[2869,14297,3521],{"class":3132},[2869,14299,12352],{"class":3128},[2869,14301,3270],{"class":3132},[2869,14303,3287],{"class":3273},[2869,14305,3445],{"class":3132},[2869,14307,14308,14311,14313,14316,14318,14321],{"class":2871,"line":6271},[2869,14309,14310],{"class":3258},".item-pct",[2869,14312,2810],{"class":3132},[2869,14314,14315],{"class":3258},".item-min",[2869,14317,2810],{"class":3132},[2869,14319,14320],{"class":3258},".item-max",[2869,14322,3262],{"class":3132},[2869,14324,14325,14327,14329,14331,14333],{"class":2871,"line":6283},[2869,14326,3307],{"class":3128},[2869,14328,3270],{"class":3132},[2869,14330,6290],{"class":3299},[2869,14332,9534],{"class":3299},[2869,14334,3277],{"class":3132},[2869,14336,14337,14339,14341,14343],{"class":2871,"line":6298},[2869,14338,4741],{"class":3128},[2869,14340,3270],{"class":3132},[2869,14342,6278],{"class":3299},[2869,14344,3277],{"class":3132},[2869,14346,14347,14349,14351,14353],{"class":2871,"line":6310},[2869,14348,5640],{"class":3128},[2869,14350,3270],{"class":3132},[2869,14352,7142],{"class":3299},[2869,14354,3277],{"class":3132},[2869,14356,14357],{"class":2871,"line":6321},[2869,14358,3360],{"class":3132},[2869,14360,14361,14363,14365,14367,14369,14372,14374,14376,14378,14380,14382,14384,14386,14388,14390,14393],{"class":2871,"line":6326},[2869,14362,14310],{"class":3258},[2869,14364,5369],{"class":3132},[2869,14366,3513],{"class":3128},[2869,14368,3270],{"class":3132},[2869,14370,14371],{"class":3299},"40%",[2869,14373,3521],{"class":3132},[2869,14375,3533],{"class":3128},[2869,14377,3270],{"class":3132},[2869,14379,10990],{"class":3273},[2869,14381,3521],{"class":3132},[2869,14383,3495],{"class":3128},[2869,14385,3270],{"class":3132},[2869,14387,3414],{"class":3299},[2869,14389,3417],{"class":3273},[2869,14391,14392],{"class":3273}," #fca5a5",[2869,14394,3445],{"class":3132},[2869,14396,14397,14399,14401,14403,14405,14407,14409,14411,14413,14415,14417,14419,14421,14423,14425,14427,14429,14431,14433,14436],{"class":2871,"line":6334},[2869,14398,14315],{"class":3258},[2869,14400,5369],{"class":3132},[2869,14402,3513],{"class":3128},[2869,14404,3270],{"class":3132},[2869,14406,13553],{"class":3469},[2869,14408,3473],{"class":3132},[2869,14410,14371],{"class":3299},[2869,14412,2810],{"class":3132},[2869,14414,9428],{"class":3299},[2869,14416,3492],{"class":3132},[2869,14418,3533],{"class":3128},[2869,14420,3270],{"class":3132},[2869,14422,10380],{"class":3273},[2869,14424,3521],{"class":3132},[2869,14426,3495],{"class":3128},[2869,14428,3270],{"class":3132},[2869,14430,3414],{"class":3299},[2869,14432,3417],{"class":3273},[2869,14434,14435],{"class":3273}," #c4b5fd",[2869,14437,3445],{"class":3132},[2869,14439,14440,14442,14444,14446,14448,14450,14452,14454,14456,14458,14460,14462,14464,14466,14468,14470,14472,14474,14476,14479],{"class":2871,"line":6345},[2869,14441,14320],{"class":3258},[2869,14443,5369],{"class":3132},[2869,14445,3513],{"class":3128},[2869,14447,3270],{"class":3132},[2869,14449,13593],{"class":3469},[2869,14451,3473],{"class":3132},[2869,14453,11149],{"class":3299},[2869,14455,2810],{"class":3132},[2869,14457,14371],{"class":3299},[2869,14459,3492],{"class":3132},[2869,14461,3533],{"class":3128},[2869,14463,3270],{"class":3132},[2869,14465,11114],{"class":3273},[2869,14467,3521],{"class":3132},[2869,14469,3495],{"class":3128},[2869,14471,3270],{"class":3132},[2869,14473,3414],{"class":3299},[2869,14475,3417],{"class":3273},[2869,14477,14478],{"class":3273}," #86efac",[2869,14480,3445],{"class":3132},[2869,14482,14483,14485,14488,14490,14492,14494,14496,14498,14500,14502,14504,14506,14508,14510,14512,14514,14516,14518,14520,14522,14524],{"class":2871,"line":6356},[2869,14484,14310],{"class":3258},[2869,14486,14487],{"class":3258}," small",[2869,14489,2810],{"class":3132},[2869,14491,14315],{"class":3258},[2869,14493,14487],{"class":3258},[2869,14495,2810],{"class":3132},[2869,14497,14320],{"class":3258},[2869,14499,14487],{"class":3258},[2869,14501,3434],{"class":3132},[2869,14503,9173],{"class":3128},[2869,14505,3270],{"class":3132},[2869,14507,8146],{"class":3273},[2869,14509,3521],{"class":3132},[2869,14511,3584],{"class":3128},[2869,14513,3270],{"class":3132},[2869,14515,9545],{"class":3299},[2869,14517,3521],{"class":3132},[2869,14519,5465],{"class":3128},[2869,14521,3270],{"class":3132},[2869,14523,12297],{"class":3299},[2869,14525,3445],{"class":3132},[2982,14527,14529,14531],{"id":14528},"clamp-fluid-scaling",[2799,14530,12659],{}," — fluid scaling",[2804,14533,14534,14537,14538,5726,14541,3905],{},[2799,14535,14536],{},"clamp(min, preferred, max)"," — найпотужніша з трьох. Вона обмежує значення знизу та зверху, але всередині діапазону використовує будь-який вираз — часто viewport-залежний. Це основа ",[2977,14539,14540],{},"fluid typography",[2977,14542,14543],{},"fluid spacing",[2861,14545,14547],{"className":3249,"code":14546,"language":3251,"meta":2865,"style":2865},"/* fluid font-size: мінімум 1rem, максимум 2rem, а між — масштабується з viewport */\nh1 {\n  font-size: clamp(1rem, 2.5vw + 0.5rem, 2rem);\n}\n\n/* fluid padding */\n.section {\n  padding: clamp(1.5rem, 5vw, 4rem);\n}\n",[2799,14548,14549,14554,14560,14588,14592,14596,14601,14607,14631],{"__ignoreMap":2865},[2869,14550,14551],{"class":2871,"line":2872},[2869,14552,14553],{"class":3762},"/* fluid font-size: мінімум 1rem, максимум 2rem, а між — масштабується з viewport */\n",[2869,14555,14556,14558],{"class":2871,"line":2878},[2869,14557,2790],{"class":3258},[2869,14559,3262],{"class":3132},[2869,14561,14562,14564,14566,14568,14570,14572,14574,14577,14580,14582,14584,14586],{"class":2871,"line":2884},[2869,14563,3348],{"class":3128},[2869,14565,3270],{"class":3132},[2869,14567,6414],{"class":3469},[2869,14569,3473],{"class":3132},[2869,14571,3300],{"class":3299},[2869,14573,2810],{"class":3132},[2869,14575,14576],{"class":3299},"2.5vw",[2869,14578,14579],{"class":3128}," +",[2869,14581,4338],{"class":3299},[2869,14583,2810],{"class":3132},[2869,14585,12178],{"class":3299},[2869,14587,6047],{"class":3132},[2869,14589,14590],{"class":2871,"line":2890},[2869,14591,3360],{"class":3132},[2869,14593,14594],{"class":2871,"line":2896},[2869,14595,4758],{"emptyLinePlaceholder":4757},[2869,14597,14598],{"class":2871,"line":2902},[2869,14599,14600],{"class":3762},"/* fluid padding */\n",[2869,14602,14603,14605],{"class":2871,"line":2908},[2869,14604,5687],{"class":3258},[2869,14606,3262],{"class":3132},[2869,14608,14609,14611,14613,14615,14617,14619,14621,14624,14626,14629],{"class":2871,"line":2914},[2869,14610,3307],{"class":3128},[2869,14612,3270],{"class":3132},[2869,14614,6414],{"class":3469},[2869,14616,3473],{"class":3132},[2869,14618,3312],{"class":3299},[2869,14620,2810],{"class":3132},[2869,14622,14623],{"class":3299},"5vw",[2869,14625,2810],{"class":3132},[2869,14627,14628],{"class":3299},"4rem",[2869,14630,6047],{"class":3132},[2869,14632,14633],{"class":2871,"line":2920},[2869,14634,3360],{"class":3132},[3107,14636,14637,14941],{},[2861,14638,14640],{"className":3111,"code":14639,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"clamp-demo\">\n  \u003Cp class=\"clamp-label\">Змініть ширину вікна, щоб побачити fluid scaling:\u003C/p>\n  \u003Ch2 class=\"fluid-h2\">Заголовок з clamp()\u003C/h2>\n  \u003Cp class=\"fluid-p\">Параграф з fluid font-size: \u003Cstrong>clamp(0.85rem, 1.5vw, 1.1rem)\u003C/strong>\u003C/p>\n  \u003Cdiv class=\"fluid-padding\">\n    \u003Ccode>padding: clamp(0.75rem, 3vw, 2.5rem)\u003C/code>\n    — відступ масштабується від 0.75rem до 2.5rem\n  \u003C/div>\n  \u003Cdiv class=\"clamp-explainer\">\n    \u003Cdiv class=\"clamp-part min\">min: 1rem\u003Cbr>\u003Csmall>(на малих екранах)\u003C/small>\u003C/div>\n    \u003Cdiv class=\"clamp-part pref\">preferred: 2.5vw+0.5rem\u003Cbr>\u003Csmall>(fluid зона)\u003C/small>\u003C/div>\n    \u003Cdiv class=\"clamp-part max\">max: 2rem\u003Cbr>\u003Csmall>(на великих екранах)\u003C/small>\u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,14641,14642,14657,14681,14705,14742,14757,14774,14779,14787,14802,14843,14884,14925,14933],{"__ignoreMap":2865},[2869,14643,14644,14646,14648,14650,14652,14655],{"class":2871,"line":2872},[2869,14645,3121],{"class":3120},[2869,14647,3125],{"class":3124},[2869,14649,3129],{"class":3128},[2869,14651,3133],{"class":3132},[2869,14653,14654],{"class":3136},"\"clamp-demo\"",[2869,14656,3140],{"class":3120},[2869,14658,14659,14661,14663,14665,14667,14670,14672,14675,14677,14679],{"class":2871,"line":2878},[2869,14660,3145],{"class":3120},[2869,14662,2804],{"class":3124},[2869,14664,3129],{"class":3128},[2869,14666,3133],{"class":3132},[2869,14668,14669],{"class":3136},"\"clamp-label\"",[2869,14671,3157],{"class":3120},[2869,14673,14674],{"class":3132},"Змініть ширину вікна, щоб побачити fluid scaling:",[2869,14676,3162],{"class":3120},[2869,14678,2804],{"class":3124},[2869,14680,3140],{"class":3120},[2869,14682,14683,14685,14687,14689,14691,14694,14696,14699,14701,14703],{"class":2871,"line":2884},[2869,14684,3145],{"class":3120},[2869,14686,2794],{"class":3124},[2869,14688,3129],{"class":3128},[2869,14690,3133],{"class":3132},[2869,14692,14693],{"class":3136},"\"fluid-h2\"",[2869,14695,3157],{"class":3120},[2869,14697,14698],{"class":3132},"Заголовок з clamp()",[2869,14700,3162],{"class":3120},[2869,14702,2794],{"class":3124},[2869,14704,3140],{"class":3120},[2869,14706,14707,14709,14711,14713,14715,14718,14720,14723,14725,14727,14729,14732,14734,14736,14738,14740],{"class":2871,"line":2890},[2869,14708,3145],{"class":3120},[2869,14710,2804],{"class":3124},[2869,14712,3129],{"class":3128},[2869,14714,3133],{"class":3132},[2869,14716,14717],{"class":3136},"\"fluid-p\"",[2869,14719,3157],{"class":3120},[2869,14721,14722],{"class":3132},"Параграф з fluid font-size: ",[2869,14724,3121],{"class":3120},[2869,14726,2977],{"class":3124},[2869,14728,3157],{"class":3120},[2869,14730,14731],{"class":3132},"clamp(0.85rem, 1.5vw, 1.1rem)",[2869,14733,3162],{"class":3120},[2869,14735,2977],{"class":3124},[2869,14737,9941],{"class":3120},[2869,14739,2804],{"class":3124},[2869,14741,3140],{"class":3120},[2869,14743,14744,14746,14748,14750,14752,14755],{"class":2871,"line":2896},[2869,14745,3145],{"class":3120},[2869,14747,3125],{"class":3124},[2869,14749,3129],{"class":3128},[2869,14751,3133],{"class":3132},[2869,14753,14754],{"class":3136},"\"fluid-padding\"",[2869,14756,3140],{"class":3120},[2869,14758,14759,14761,14763,14765,14768,14770,14772],{"class":2871,"line":2902},[2869,14760,3971],{"class":3120},[2869,14762,2799],{"class":3124},[2869,14764,3157],{"class":3120},[2869,14766,14767],{"class":3132},"padding: clamp(0.75rem, 3vw, 2.5rem)",[2869,14769,3162],{"class":3120},[2869,14771,2799],{"class":3124},[2869,14773,3140],{"class":3120},[2869,14775,14776],{"class":2871,"line":2908},[2869,14777,14778],{"class":3132},"    — відступ масштабується від 0.75rem до 2.5rem\n",[2869,14780,14781,14783,14785],{"class":2871,"line":2914},[2869,14782,4073],{"class":3120},[2869,14784,3125],{"class":3124},[2869,14786,3140],{"class":3120},[2869,14788,14789,14791,14793,14795,14797,14800],{"class":2871,"line":2920},[2869,14790,3145],{"class":3120},[2869,14792,3125],{"class":3124},[2869,14794,3129],{"class":3128},[2869,14796,3133],{"class":3132},[2869,14798,14799],{"class":3136},"\"clamp-explainer\"",[2869,14801,3140],{"class":3120},[2869,14803,14804,14806,14808,14810,14812,14815,14817,14820,14822,14824,14826,14828,14830,14833,14835,14837,14839,14841],{"class":2871,"line":2926},[2869,14805,3971],{"class":3120},[2869,14807,3125],{"class":3124},[2869,14809,3129],{"class":3128},[2869,14811,3133],{"class":3132},[2869,14813,14814],{"class":3136},"\"clamp-part min\"",[2869,14816,3157],{"class":3120},[2869,14818,14819],{"class":3132},"min: 1rem",[2869,14821,3121],{"class":3120},[2869,14823,11827],{"class":3124},[2869,14825,9927],{"class":3120},[2869,14827,13813],{"class":3124},[2869,14829,3157],{"class":3120},[2869,14831,14832],{"class":3132},"(на малих екранах)",[2869,14834,3162],{"class":3120},[2869,14836,13813],{"class":3124},[2869,14838,9941],{"class":3120},[2869,14840,3125],{"class":3124},[2869,14842,3140],{"class":3120},[2869,14844,14845,14847,14849,14851,14853,14856,14858,14861,14863,14865,14867,14869,14871,14874,14876,14878,14880,14882],{"class":2871,"line":2932},[2869,14846,3971],{"class":3120},[2869,14848,3125],{"class":3124},[2869,14850,3129],{"class":3128},[2869,14852,3133],{"class":3132},[2869,14854,14855],{"class":3136},"\"clamp-part pref\"",[2869,14857,3157],{"class":3120},[2869,14859,14860],{"class":3132},"preferred: 2.5vw+0.5rem",[2869,14862,3121],{"class":3120},[2869,14864,11827],{"class":3124},[2869,14866,9927],{"class":3120},[2869,14868,13813],{"class":3124},[2869,14870,3157],{"class":3120},[2869,14872,14873],{"class":3132},"(fluid зона)",[2869,14875,3162],{"class":3120},[2869,14877,13813],{"class":3124},[2869,14879,9941],{"class":3120},[2869,14881,3125],{"class":3124},[2869,14883,3140],{"class":3120},[2869,14885,14886,14888,14890,14892,14894,14897,14899,14902,14904,14906,14908,14910,14912,14915,14917,14919,14921,14923],{"class":2871,"line":2938},[2869,14887,3971],{"class":3120},[2869,14889,3125],{"class":3124},[2869,14891,3129],{"class":3128},[2869,14893,3133],{"class":3132},[2869,14895,14896],{"class":3136},"\"clamp-part max\"",[2869,14898,3157],{"class":3120},[2869,14900,14901],{"class":3132},"max: 2rem",[2869,14903,3121],{"class":3120},[2869,14905,11827],{"class":3124},[2869,14907,9927],{"class":3120},[2869,14909,13813],{"class":3124},[2869,14911,3157],{"class":3120},[2869,14913,14914],{"class":3132},"(на великих екранах)",[2869,14916,3162],{"class":3120},[2869,14918,13813],{"class":3124},[2869,14920,9941],{"class":3120},[2869,14922,3125],{"class":3124},[2869,14924,3140],{"class":3120},[2869,14926,14927,14929,14931],{"class":2871,"line":2944},[2869,14928,4073],{"class":3120},[2869,14930,3125],{"class":3124},[2869,14932,3140],{"class":3120},[2869,14934,14935,14937,14939],{"class":2871,"line":2950},[2869,14936,3162],{"class":3120},[2869,14938,3125],{"class":3124},[2869,14940,3140],{"class":3120},[2861,14942,14944],{"className":3249,"code":14943,"language":3251,"meta":2865,"style":2865},".clamp-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.75rem;\n}\n.clamp-label { margin: 0; font-size: 0.8rem; color: #64748b; font-style: italic; }\n.fluid-h2 {\n  margin: 0;\n  font-size: clamp(1rem, 2.5vw + 0.5rem, 2rem);\n  color: #6366f1;\n  line-height: 1.2;\n}\n.fluid-p {\n  margin: 0;\n  font-size: clamp(0.85rem, 1.5vw, 1.1rem);\n  line-height: 1.6;\n}\n.fluid-p strong { color: #6366f1; font-family: monospace; }\n.fluid-padding {\n  background: white;\n  border: 1px solid #e2e8f0;\n  border-radius: 8px;\n  padding: clamp(0.75rem, 3vw, 2.5rem);\n  font-size: 0.82rem;\n  line-height: 1.4;\n}\n.fluid-padding code { font-family: monospace; color: #6366f1; font-weight: 700; }\n.clamp-explainer { display: flex; gap: 2px; border-radius: 8px; overflow: hidden; font-size: 0.75rem; }\n.clamp-part { flex: 1; padding: 0.5rem; text-align: center; line-height: 1.3; }\n.clamp-part small { display: block; font-size: 0.68rem; opacity: 0.8; }\n.min  { background: #fee2e2; color: #991b1b; }\n.pref { background: #dcfce7; color: #166534; }\n.max  { background: #ede9fe; color: #5b21b6; }\n",[2799,14945,14946,14953,14963,14973,14987,14997,15007,15017,15027,15031,15070,15077,15087,15113,15123,15133,15137,15144,15154,15177,15187,15191,15215,15222,15232,15246,15256,15279,15289,15299,15303,15335,15383,15423,15456,15480,15504],{"__ignoreMap":2865},[2869,14947,14948,14951],{"class":2871,"line":2872},[2869,14949,14950],{"class":3258},".clamp-demo",[2869,14952,3262],{"class":3132},[2869,14954,14955,14957,14959,14961],{"class":2871,"line":2878},[2869,14956,3307],{"class":3128},[2869,14958,3270],{"class":3132},[2869,14960,3300],{"class":3299},[2869,14962,3277],{"class":3132},[2869,14964,14965,14967,14969,14971],{"class":2871,"line":2884},[2869,14966,3319],{"class":3128},[2869,14968,3270],{"class":3132},[2869,14970,3324],{"class":3273},[2869,14972,3277],{"class":3132},[2869,14974,14975,14977,14979,14981,14983,14985],{"class":2871,"line":2890},[2869,14976,3331],{"class":3128},[2869,14978,3270],{"class":3132},[2869,14980,3336],{"class":3273},[2869,14982,2810],{"class":3132},[2869,14984,3341],{"class":3273},[2869,14986,3277],{"class":3132},[2869,14988,14989,14991,14993,14995],{"class":2871,"line":2896},[2869,14990,3397],{"class":3128},[2869,14992,3270],{"class":3132},[2869,14994,3402],{"class":3273},[2869,14996,3277],{"class":3132},[2869,14998,14999,15001,15003,15005],{"class":2871,"line":2902},[2869,15000,3267],{"class":3128},[2869,15002,3270],{"class":3132},[2869,15004,3274],{"class":3273},[2869,15006,3277],{"class":3132},[2869,15008,15009,15011,15013,15015],{"class":2871,"line":2908},[2869,15010,5222],{"class":3128},[2869,15012,3270],{"class":3132},[2869,15014,5227],{"class":3273},[2869,15016,3277],{"class":3132},[2869,15018,15019,15021,15023,15025],{"class":2871,"line":2914},[2869,15020,3294],{"class":3128},[2869,15022,3270],{"class":3132},[2869,15024,3376],{"class":3299},[2869,15026,3277],{"class":3132},[2869,15028,15029],{"class":2871,"line":2920},[2869,15030,3360],{"class":3132},[2869,15032,15033,15036,15038,15040,15042,15044,15046,15048,15050,15052,15054,15056,15058,15060,15062,15064,15066,15068],{"class":2871,"line":2926},[2869,15034,15035],{"class":3258},".clamp-label",[2869,15037,3434],{"class":3132},[2869,15039,4328],{"class":3128},[2869,15041,3270],{"class":3132},[2869,15043,3460],{"class":3299},[2869,15045,3521],{"class":3132},[2869,15047,3584],{"class":3128},[2869,15049,3270],{"class":3132},[2869,15051,6305],{"class":3299},[2869,15053,3521],{"class":3132},[2869,15055,9147],{"class":3128},[2869,15057,3270],{"class":3132},[2869,15059,7822],{"class":3273},[2869,15061,3521],{"class":3132},[2869,15063,9156],{"class":3128},[2869,15065,3270],{"class":3132},[2869,15067,9161],{"class":3273},[2869,15069,3445],{"class":3132},[2869,15071,15072,15075],{"class":2871,"line":2932},[2869,15073,15074],{"class":3258},".fluid-h2",[2869,15076,3262],{"class":3132},[2869,15078,15079,15081,15083,15085],{"class":2871,"line":2938},[2869,15080,6398],{"class":3128},[2869,15082,3270],{"class":3132},[2869,15084,3460],{"class":3299},[2869,15086,3277],{"class":3132},[2869,15088,15089,15091,15093,15095,15097,15099,15101,15103,15105,15107,15109,15111],{"class":2871,"line":2944},[2869,15090,3348],{"class":3128},[2869,15092,3270],{"class":3132},[2869,15094,6414],{"class":3469},[2869,15096,3473],{"class":3132},[2869,15098,3300],{"class":3299},[2869,15100,2810],{"class":3132},[2869,15102,14576],{"class":3299},[2869,15104,14579],{"class":3128},[2869,15106,4338],{"class":3299},[2869,15108,2810],{"class":3132},[2869,15110,12178],{"class":3299},[2869,15112,6047],{"class":3132},[2869,15114,15115,15117,15119,15121],{"class":2871,"line":2950},[2869,15116,3397],{"class":3128},[2869,15118,3270],{"class":3132},[2869,15120,3538],{"class":3273},[2869,15122,3277],{"class":3132},[2869,15124,15125,15127,15129,15131],{"class":2871,"line":2956},[2869,15126,5640],{"class":3128},[2869,15128,3270],{"class":3132},[2869,15130,8170],{"class":3299},[2869,15132,3277],{"class":3132},[2869,15134,15135],{"class":2871,"line":2962},[2869,15136,3360],{"class":3132},[2869,15138,15139,15142],{"class":2871,"line":3448},[2869,15140,15141],{"class":3258},".fluid-p",[2869,15143,3262],{"class":3132},[2869,15145,15146,15148,15150,15152],{"class":2871,"line":3505},[2869,15147,6398],{"class":3128},[2869,15149,3270],{"class":3132},[2869,15151,3460],{"class":3299},[2869,15153,3277],{"class":3132},[2869,15155,15156,15158,15160,15162,15164,15166,15168,15171,15173,15175],{"class":2871,"line":3543},[2869,15157,3348],{"class":3128},[2869,15159,3270],{"class":3132},[2869,15161,6414],{"class":3469},[2869,15163,3473],{"class":3132},[2869,15165,3353],{"class":3299},[2869,15167,2810],{"class":3132},[2869,15169,15170],{"class":3299},"1.5vw",[2869,15172,2810],{"class":3132},[2869,15174,7064],{"class":3299},[2869,15176,6047],{"class":3132},[2869,15178,15179,15181,15183,15185],{"class":2871,"line":3573},[2869,15180,5640],{"class":3128},[2869,15182,3270],{"class":3132},[2869,15184,5494],{"class":3299},[2869,15186,3277],{"class":3132},[2869,15188,15189],{"class":2871,"line":3619},[2869,15190,3360],{"class":3132},[2869,15192,15193,15195,15197,15199,15201,15203,15205,15207,15209,15211,15213],{"class":2871,"line":4232},[2869,15194,15141],{"class":3258},[2869,15196,8134],{"class":3258},[2869,15198,3434],{"class":3132},[2869,15200,9147],{"class":3128},[2869,15202,3270],{"class":3132},[2869,15204,3538],{"class":3273},[2869,15206,3521],{"class":3132},[2869,15208,9317],{"class":3128},[2869,15210,3270],{"class":3132},[2869,15212,7086],{"class":3273},[2869,15214,3445],{"class":3132},[2869,15216,15217,15220],{"class":2871,"line":4241},[2869,15218,15219],{"class":3258},".fluid-padding",[2869,15221,3262],{"class":3132},[2869,15223,15224,15226,15228,15230],{"class":2871,"line":6174},[2869,15225,3319],{"class":3128},[2869,15227,3270],{"class":3132},[2869,15229,3390],{"class":3273},[2869,15231,3277],{"class":3132},[2869,15233,15234,15236,15238,15240,15242,15244],{"class":2871,"line":6208},[2869,15235,3409],{"class":3128},[2869,15237,3270],{"class":3132},[2869,15239,3414],{"class":3299},[2869,15241,3417],{"class":3273},[2869,15243,3420],{"class":3273},[2869,15245,3277],{"class":3132},[2869,15247,15248,15250,15252,15254],{"class":2871,"line":6216},[2869,15249,4741],{"class":3128},[2869,15251,3270],{"class":3132},[2869,15253,3442],{"class":3299},[2869,15255,3277],{"class":3132},[2869,15257,15258,15260,15262,15264,15266,15268,15270,15272,15274,15277],{"class":2871,"line":6229},[2869,15259,3307],{"class":3128},[2869,15261,3270],{"class":3132},[2869,15263,6414],{"class":3469},[2869,15265,3473],{"class":3132},[2869,15267,3376],{"class":3299},[2869,15269,2810],{"class":3132},[2869,15271,6424],{"class":3299},[2869,15273,2810],{"class":3132},[2869,15275,15276],{"class":3299},"2.5rem",[2869,15278,6047],{"class":3132},[2869,15280,15281,15283,15285,15287],{"class":2871,"line":6241},[2869,15282,3348],{"class":3128},[2869,15284,3270],{"class":3132},[2869,15286,11966],{"class":3299},[2869,15288,3277],{"class":3132},[2869,15290,15291,15293,15295,15297],{"class":2871,"line":6271},[2869,15292,5640],{"class":3128},[2869,15294,3270],{"class":3132},[2869,15296,7142],{"class":3299},[2869,15298,3277],{"class":3132},[2869,15300,15301],{"class":2871,"line":6283},[2869,15302,3360],{"class":3132},[2869,15304,15305,15307,15309,15311,15313,15315,15317,15319,15321,15323,15325,15327,15329,15331,15333],{"class":2871,"line":6298},[2869,15306,15219],{"class":3258},[2869,15308,10304],{"class":3258},[2869,15310,3434],{"class":3132},[2869,15312,9317],{"class":3128},[2869,15314,3270],{"class":3132},[2869,15316,7086],{"class":3273},[2869,15318,3521],{"class":3132},[2869,15320,9147],{"class":3128},[2869,15322,3270],{"class":3132},[2869,15324,3538],{"class":3273},[2869,15326,3521],{"class":3132},[2869,15328,9334],{"class":3128},[2869,15330,3270],{"class":3132},[2869,15332,9339],{"class":3299},[2869,15334,3445],{"class":3132},[2869,15336,15337,15340,15342,15344,15346,15348,15350,15352,15354,15356,15358,15360,15362,15364,15366,15369,15371,15373,15375,15377,15379,15381],{"class":2871,"line":6310},[2869,15338,15339],{"class":3258},".clamp-explainer",[2869,15341,3434],{"class":3132},[2869,15343,9173],{"class":3128},[2869,15345,3270],{"class":3132},[2869,15347,3274],{"class":3273},[2869,15349,3521],{"class":3132},[2869,15351,9191],{"class":3128},[2869,15353,3270],{"class":3132},[2869,15355,9479],{"class":3299},[2869,15357,3521],{"class":3132},[2869,15359,3437],{"class":3128},[2869,15361,3270],{"class":3132},[2869,15363,3442],{"class":3299},[2869,15365,3521],{"class":3132},[2869,15367,15368],{"class":3128},"overflow",[2869,15370,3270],{"class":3132},[2869,15372,9269],{"class":3273},[2869,15374,3521],{"class":3132},[2869,15376,3584],{"class":3128},[2869,15378,3270],{"class":3132},[2869,15380,3376],{"class":3299},[2869,15382,3445],{"class":3132},[2869,15384,15385,15388,15390,15392,15394,15396,15398,15400,15402,15404,15406,15409,15411,15413,15415,15417,15419,15421],{"class":2871,"line":6321},[2869,15386,15387],{"class":3258},".clamp-part",[2869,15389,3434],{"class":3132},[2869,15391,3274],{"class":3128},[2869,15393,3270],{"class":3132},[2869,15395,5645],{"class":3299},[2869,15397,3521],{"class":3132},[2869,15399,3593],{"class":3128},[2869,15401,3270],{"class":3132},[2869,15403,6109],{"class":3299},[2869,15405,3521],{"class":3132},[2869,15407,15408],{"class":3128},"text-align",[2869,15410,3270],{"class":3132},[2869,15412,3559],{"class":3273},[2869,15414,3521],{"class":3132},[2869,15416,5489],{"class":3128},[2869,15418,3270],{"class":3132},[2869,15420,8235],{"class":3299},[2869,15422,3445],{"class":3132},[2869,15424,15425,15427,15429,15431,15433,15435,15437,15439,15441,15443,15446,15448,15450,15452,15454],{"class":2871,"line":6326},[2869,15426,15387],{"class":3258},[2869,15428,14487],{"class":3258},[2869,15430,3434],{"class":3132},[2869,15432,9173],{"class":3128},[2869,15434,3270],{"class":3132},[2869,15436,8146],{"class":3273},[2869,15438,3521],{"class":3132},[2869,15440,3584],{"class":3128},[2869,15442,3270],{"class":3132},[2869,15444,15445],{"class":3299},"0.68rem",[2869,15447,3521],{"class":3132},[2869,15449,5465],{"class":3128},[2869,15451,3270],{"class":3132},[2869,15453,6203],{"class":3299},[2869,15455,3445],{"class":3132},[2869,15457,15458,15461,15463,15465,15467,15469,15471,15473,15475,15478],{"class":2871,"line":6334},[2869,15459,15460],{"class":3258},".min",[2869,15462,5369],{"class":3132},[2869,15464,3533],{"class":3128},[2869,15466,3270],{"class":3132},[2869,15468,10990],{"class":3273},[2869,15470,3521],{"class":3132},[2869,15472,9147],{"class":3128},[2869,15474,3270],{"class":3132},[2869,15476,15477],{"class":3273},"#991b1b",[2869,15479,3445],{"class":3132},[2869,15481,15482,15485,15487,15489,15491,15493,15495,15497,15499,15502],{"class":2871,"line":6345},[2869,15483,15484],{"class":3258},".pref",[2869,15486,3434],{"class":3132},[2869,15488,3533],{"class":3128},[2869,15490,3270],{"class":3132},[2869,15492,11114],{"class":3273},[2869,15494,3521],{"class":3132},[2869,15496,9147],{"class":3128},[2869,15498,3270],{"class":3132},[2869,15500,15501],{"class":3273},"#166534",[2869,15503,3445],{"class":3132},[2869,15505,15506,15509,15511,15513,15515,15517,15519,15521,15523,15526],{"class":2871,"line":6356},[2869,15507,15508],{"class":3258},".max",[2869,15510,5369],{"class":3132},[2869,15512,3533],{"class":3128},[2869,15514,3270],{"class":3132},[2869,15516,10380],{"class":3273},[2869,15518,3521],{"class":3132},[2869,15520,9147],{"class":3128},[2869,15522,3270],{"class":3132},[2869,15524,15525],{"class":3273},"#5b21b6",[2869,15527,3445],{"class":3132},[2967,15529],{},[2794,15531,15533,15536],{"id":15532},"aspect-ratio-фіксоване-співвідношення-сторін",[2799,15534,15535],{},"aspect-ratio"," — фіксоване співвідношення сторін",[2804,15538,15539,15540,15542],{},"До появи ",[2799,15541,15535],{}," підтримка фіксованого пропорційного розміру вимагала хаку з padding-top (так звана «padding-bottom trick»). Тепер це одна властивість.",[2861,15544,15546],{"className":3249,"code":15545,"language":3251,"meta":2865,"style":2865},"/* 16:9 для відео */\n.video-wrapper {\n  width: 100%;\n  aspect-ratio: 16 / 9;\n}\n\n/* Квадратна картка */\n.square-card {\n  aspect-ratio: 1;\n}\n\n/* Золотий перетин */\n.golden-ratio {\n  aspect-ratio: 1.618 / 1;\n}\n\n/* Природне співвідношення зображення */\nimg {\n  aspect-ratio: auto; /* використовує intrinsic ratio зображення */\n}\n",[2799,15547,15548,15553,15560,15570,15587,15591,15595,15600,15607,15617,15621,15625,15630,15637,15652,15656,15660,15665,15672,15685],{"__ignoreMap":2865},[2869,15549,15550],{"class":2871,"line":2872},[2869,15551,15552],{"class":3762},"/* 16:9 для відео */\n",[2869,15554,15555,15558],{"class":2871,"line":2878},[2869,15556,15557],{"class":3258},".video-wrapper",[2869,15559,3262],{"class":3132},[2869,15561,15562,15564,15566,15568],{"class":2871,"line":2884},[2869,15563,6219],{"class":3128},[2869,15565,3270],{"class":3132},[2869,15567,6236],{"class":3299},[2869,15569,3277],{"class":3132},[2869,15571,15572,15575,15577,15580,15582,15585],{"class":2871,"line":2890},[2869,15573,15574],{"class":3128},"  aspect-ratio",[2869,15576,3270],{"class":3132},[2869,15578,15579],{"class":3299},"16",[2869,15581,11408],{"class":3132},[2869,15583,15584],{"class":3299},"9",[2869,15586,3277],{"class":3132},[2869,15588,15589],{"class":2871,"line":2896},[2869,15590,3360],{"class":3132},[2869,15592,15593],{"class":2871,"line":2902},[2869,15594,4758],{"emptyLinePlaceholder":4757},[2869,15596,15597],{"class":2871,"line":2908},[2869,15598,15599],{"class":3762},"/* Квадратна картка */\n",[2869,15601,15602,15605],{"class":2871,"line":2914},[2869,15603,15604],{"class":3258},".square-card",[2869,15606,3262],{"class":3132},[2869,15608,15609,15611,15613,15615],{"class":2871,"line":2920},[2869,15610,15574],{"class":3128},[2869,15612,3270],{"class":3132},[2869,15614,5645],{"class":3299},[2869,15616,3277],{"class":3132},[2869,15618,15619],{"class":2871,"line":2926},[2869,15620,3360],{"class":3132},[2869,15622,15623],{"class":2871,"line":2932},[2869,15624,4758],{"emptyLinePlaceholder":4757},[2869,15626,15627],{"class":2871,"line":2938},[2869,15628,15629],{"class":3762},"/* Золотий перетин */\n",[2869,15631,15632,15635],{"class":2871,"line":2944},[2869,15633,15634],{"class":3258},".golden-ratio",[2869,15636,3262],{"class":3132},[2869,15638,15639,15641,15643,15646,15648,15650],{"class":2871,"line":2950},[2869,15640,15574],{"class":3128},[2869,15642,3270],{"class":3132},[2869,15644,15645],{"class":3299},"1.618",[2869,15647,11408],{"class":3132},[2869,15649,5645],{"class":3299},[2869,15651,3277],{"class":3132},[2869,15653,15654],{"class":2871,"line":2956},[2869,15655,3360],{"class":3132},[2869,15657,15658],{"class":2871,"line":2962},[2869,15659,4758],{"emptyLinePlaceholder":4757},[2869,15661,15662],{"class":2871,"line":3448},[2869,15663,15664],{"class":3762},"/* Природне співвідношення зображення */\n",[2869,15666,15667,15670],{"class":2871,"line":3505},[2869,15668,15669],{"class":3258},"img",[2869,15671,3262],{"class":3132},[2869,15673,15674,15676,15678,15680,15682],{"class":2871,"line":3543},[2869,15675,15574],{"class":3128},[2869,15677,3270],{"class":3132},[2869,15679,4988],{"class":3273},[2869,15681,3521],{"class":3132},[2869,15683,15684],{"class":3762},"/* використовує intrinsic ratio зображення */\n",[2869,15686,15687],{"class":2871,"line":3573},[2869,15688,3360],{"class":3132},[3107,15690,15691,16131],{},[2861,15692,15694],{"className":3111,"code":15693,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"ar-demo\">\n  \u003Cdiv class=\"ar-grid\">\n    \u003Cdiv class=\"ar-item ar-16-9\">\n      \u003Cspan>16:9\u003C/span>\n      \u003Csmall>відео, банери\u003C/small>\n    \u003C/div>\n    \u003Cdiv class=\"ar-item ar-4-3\">\n      \u003Cspan>4:3\u003C/span>\n      \u003Csmall>старі монітори, фото\u003C/small>\n    \u003C/div>\n    \u003Cdiv class=\"ar-item ar-1-1\">\n      \u003Cspan>1:1\u003C/span>\n      \u003Csmall>аватари, іконки\u003C/small>\n    \u003C/div>\n    \u003Cdiv class=\"ar-item ar-3-4\">\n      \u003Cspan>3:4\u003C/span>\n      \u003Csmall>Portrait, stories\u003C/small>\n    \u003C/div>\n    \u003Cdiv class=\"ar-item ar-golden\">\n      \u003Cspan>1.618:1\u003C/span>\n      \u003Csmall>Золотий перетин\u003C/small>\n    \u003C/div>\n  \u003C/div>\n  \u003Cdiv class=\"responsive-video\">\n    \u003Cdiv class=\"video-embed\">\n      \u003Cdiv class=\"play-icon\">▶\u003C/div>\n      \u003Cp>Responsive video container\u003Cbr>\u003Ccode>aspect-ratio: 16/9; width: 100%\u003C/code>\u003C/p>\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,15695,15696,15711,15726,15741,15758,15775,15783,15798,15815,15832,15840,15855,15872,15889,15897,15912,15929,15946,15954,15969,15986,16003,16011,16019,16034,16049,16073,16107,16115,16123],{"__ignoreMap":2865},[2869,15697,15698,15700,15702,15704,15706,15709],{"class":2871,"line":2872},[2869,15699,3121],{"class":3120},[2869,15701,3125],{"class":3124},[2869,15703,3129],{"class":3128},[2869,15705,3133],{"class":3132},[2869,15707,15708],{"class":3136},"\"ar-demo\"",[2869,15710,3140],{"class":3120},[2869,15712,15713,15715,15717,15719,15721,15724],{"class":2871,"line":2878},[2869,15714,3145],{"class":3120},[2869,15716,3125],{"class":3124},[2869,15718,3129],{"class":3128},[2869,15720,3133],{"class":3132},[2869,15722,15723],{"class":3136},"\"ar-grid\"",[2869,15725,3140],{"class":3120},[2869,15727,15728,15730,15732,15734,15736,15739],{"class":2871,"line":2884},[2869,15729,3971],{"class":3120},[2869,15731,3125],{"class":3124},[2869,15733,3129],{"class":3128},[2869,15735,3133],{"class":3132},[2869,15737,15738],{"class":3136},"\"ar-item ar-16-9\"",[2869,15740,3140],{"class":3120},[2869,15742,15743,15745,15747,15749,15752,15754,15756],{"class":2871,"line":2890},[2869,15744,4004],{"class":3120},[2869,15746,2869],{"class":3124},[2869,15748,3157],{"class":3120},[2869,15750,15751],{"class":3132},"16:9",[2869,15753,3162],{"class":3120},[2869,15755,2869],{"class":3124},[2869,15757,3140],{"class":3120},[2869,15759,15760,15762,15764,15766,15769,15771,15773],{"class":2871,"line":2896},[2869,15761,4004],{"class":3120},[2869,15763,13813],{"class":3124},[2869,15765,3157],{"class":3120},[2869,15767,15768],{"class":3132},"відео, банери",[2869,15770,3162],{"class":3120},[2869,15772,13813],{"class":3124},[2869,15774,3140],{"class":3120},[2869,15776,15777,15779,15781],{"class":2871,"line":2902},[2869,15778,4064],{"class":3120},[2869,15780,3125],{"class":3124},[2869,15782,3140],{"class":3120},[2869,15784,15785,15787,15789,15791,15793,15796],{"class":2871,"line":2908},[2869,15786,3971],{"class":3120},[2869,15788,3125],{"class":3124},[2869,15790,3129],{"class":3128},[2869,15792,3133],{"class":3132},[2869,15794,15795],{"class":3136},"\"ar-item ar-4-3\"",[2869,15797,3140],{"class":3120},[2869,15799,15800,15802,15804,15806,15809,15811,15813],{"class":2871,"line":2914},[2869,15801,4004],{"class":3120},[2869,15803,2869],{"class":3124},[2869,15805,3157],{"class":3120},[2869,15807,15808],{"class":3132},"4:3",[2869,15810,3162],{"class":3120},[2869,15812,2869],{"class":3124},[2869,15814,3140],{"class":3120},[2869,15816,15817,15819,15821,15823,15826,15828,15830],{"class":2871,"line":2920},[2869,15818,4004],{"class":3120},[2869,15820,13813],{"class":3124},[2869,15822,3157],{"class":3120},[2869,15824,15825],{"class":3132},"старі монітори, фото",[2869,15827,3162],{"class":3120},[2869,15829,13813],{"class":3124},[2869,15831,3140],{"class":3120},[2869,15833,15834,15836,15838],{"class":2871,"line":2926},[2869,15835,4064],{"class":3120},[2869,15837,3125],{"class":3124},[2869,15839,3140],{"class":3120},[2869,15841,15842,15844,15846,15848,15850,15853],{"class":2871,"line":2932},[2869,15843,3971],{"class":3120},[2869,15845,3125],{"class":3124},[2869,15847,3129],{"class":3128},[2869,15849,3133],{"class":3132},[2869,15851,15852],{"class":3136},"\"ar-item ar-1-1\"",[2869,15854,3140],{"class":3120},[2869,15856,15857,15859,15861,15863,15866,15868,15870],{"class":2871,"line":2938},[2869,15858,4004],{"class":3120},[2869,15860,2869],{"class":3124},[2869,15862,3157],{"class":3120},[2869,15864,15865],{"class":3132},"1:1",[2869,15867,3162],{"class":3120},[2869,15869,2869],{"class":3124},[2869,15871,3140],{"class":3120},[2869,15873,15874,15876,15878,15880,15883,15885,15887],{"class":2871,"line":2944},[2869,15875,4004],{"class":3120},[2869,15877,13813],{"class":3124},[2869,15879,3157],{"class":3120},[2869,15881,15882],{"class":3132},"аватари, іконки",[2869,15884,3162],{"class":3120},[2869,15886,13813],{"class":3124},[2869,15888,3140],{"class":3120},[2869,15890,15891,15893,15895],{"class":2871,"line":2950},[2869,15892,4064],{"class":3120},[2869,15894,3125],{"class":3124},[2869,15896,3140],{"class":3120},[2869,15898,15899,15901,15903,15905,15907,15910],{"class":2871,"line":2956},[2869,15900,3971],{"class":3120},[2869,15902,3125],{"class":3124},[2869,15904,3129],{"class":3128},[2869,15906,3133],{"class":3132},[2869,15908,15909],{"class":3136},"\"ar-item ar-3-4\"",[2869,15911,3140],{"class":3120},[2869,15913,15914,15916,15918,15920,15923,15925,15927],{"class":2871,"line":2962},[2869,15915,4004],{"class":3120},[2869,15917,2869],{"class":3124},[2869,15919,3157],{"class":3120},[2869,15921,15922],{"class":3132},"3:4",[2869,15924,3162],{"class":3120},[2869,15926,2869],{"class":3124},[2869,15928,3140],{"class":3120},[2869,15930,15931,15933,15935,15937,15940,15942,15944],{"class":2871,"line":3448},[2869,15932,4004],{"class":3120},[2869,15934,13813],{"class":3124},[2869,15936,3157],{"class":3120},[2869,15938,15939],{"class":3132},"Portrait, stories",[2869,15941,3162],{"class":3120},[2869,15943,13813],{"class":3124},[2869,15945,3140],{"class":3120},[2869,15947,15948,15950,15952],{"class":2871,"line":3505},[2869,15949,4064],{"class":3120},[2869,15951,3125],{"class":3124},[2869,15953,3140],{"class":3120},[2869,15955,15956,15958,15960,15962,15964,15967],{"class":2871,"line":3543},[2869,15957,3971],{"class":3120},[2869,15959,3125],{"class":3124},[2869,15961,3129],{"class":3128},[2869,15963,3133],{"class":3132},[2869,15965,15966],{"class":3136},"\"ar-item ar-golden\"",[2869,15968,3140],{"class":3120},[2869,15970,15971,15973,15975,15977,15980,15982,15984],{"class":2871,"line":3573},[2869,15972,4004],{"class":3120},[2869,15974,2869],{"class":3124},[2869,15976,3157],{"class":3120},[2869,15978,15979],{"class":3132},"1.618:1",[2869,15981,3162],{"class":3120},[2869,15983,2869],{"class":3124},[2869,15985,3140],{"class":3120},[2869,15987,15988,15990,15992,15994,15997,15999,16001],{"class":2871,"line":3619},[2869,15989,4004],{"class":3120},[2869,15991,13813],{"class":3124},[2869,15993,3157],{"class":3120},[2869,15995,15996],{"class":3132},"Золотий перетин",[2869,15998,3162],{"class":3120},[2869,16000,13813],{"class":3124},[2869,16002,3140],{"class":3120},[2869,16004,16005,16007,16009],{"class":2871,"line":4232},[2869,16006,4064],{"class":3120},[2869,16008,3125],{"class":3124},[2869,16010,3140],{"class":3120},[2869,16012,16013,16015,16017],{"class":2871,"line":4241},[2869,16014,4073],{"class":3120},[2869,16016,3125],{"class":3124},[2869,16018,3140],{"class":3120},[2869,16020,16021,16023,16025,16027,16029,16032],{"class":2871,"line":6174},[2869,16022,3145],{"class":3120},[2869,16024,3125],{"class":3124},[2869,16026,3129],{"class":3128},[2869,16028,3133],{"class":3132},[2869,16030,16031],{"class":3136},"\"responsive-video\"",[2869,16033,3140],{"class":3120},[2869,16035,16036,16038,16040,16042,16044,16047],{"class":2871,"line":6208},[2869,16037,3971],{"class":3120},[2869,16039,3125],{"class":3124},[2869,16041,3129],{"class":3128},[2869,16043,3133],{"class":3132},[2869,16045,16046],{"class":3136},"\"video-embed\"",[2869,16048,3140],{"class":3120},[2869,16050,16051,16053,16055,16057,16059,16062,16064,16067,16069,16071],{"class":2871,"line":6216},[2869,16052,4004],{"class":3120},[2869,16054,3125],{"class":3124},[2869,16056,3129],{"class":3128},[2869,16058,3133],{"class":3132},[2869,16060,16061],{"class":3136},"\"play-icon\"",[2869,16063,3157],{"class":3120},[2869,16065,16066],{"class":3132},"▶",[2869,16068,3162],{"class":3120},[2869,16070,3125],{"class":3124},[2869,16072,3140],{"class":3120},[2869,16074,16075,16077,16079,16081,16084,16086,16088,16090,16092,16094,16097,16099,16101,16103,16105],{"class":2871,"line":6229},[2869,16076,4004],{"class":3120},[2869,16078,2804],{"class":3124},[2869,16080,3157],{"class":3120},[2869,16082,16083],{"class":3132},"Responsive video container",[2869,16085,3121],{"class":3120},[2869,16087,11827],{"class":3124},[2869,16089,9927],{"class":3120},[2869,16091,2799],{"class":3124},[2869,16093,3157],{"class":3120},[2869,16095,16096],{"class":3132},"aspect-ratio: 16/9; width: 100%",[2869,16098,3162],{"class":3120},[2869,16100,2799],{"class":3124},[2869,16102,9941],{"class":3120},[2869,16104,2804],{"class":3124},[2869,16106,3140],{"class":3120},[2869,16108,16109,16111,16113],{"class":2871,"line":6241},[2869,16110,4064],{"class":3120},[2869,16112,3125],{"class":3124},[2869,16114,3140],{"class":3120},[2869,16116,16117,16119,16121],{"class":2871,"line":6271},[2869,16118,4073],{"class":3120},[2869,16120,3125],{"class":3124},[2869,16122,3140],{"class":3120},[2869,16124,16125,16127,16129],{"class":2871,"line":6283},[2869,16126,3162],{"class":3120},[2869,16128,3125],{"class":3124},[2869,16130,3140],{"class":3120},[2861,16132,16134],{"className":3249,"code":16133,"language":3251,"meta":2865,"style":2865},".ar-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 1rem;\n}\n.ar-grid {\n  display: flex;\n  gap: 0.5rem;\n  flex-wrap: wrap;\n  align-items: flex-start;\n}\n.ar-item {\n  width: 100px;\n  background: linear-gradient(135deg, #6366f1, #8b5cf6);\n  border-radius: 6px;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  color: white;\n  text-align: center;\n  padding: 0.25rem;\n  flex-shrink: 0;\n}\n.ar-item span { font-weight: 800; font-size: 0.9rem; }\n.ar-item small { font-size: 0.68rem; opacity: 0.8; margin-top: 0.2rem; }\n.ar-16-9 { aspect-ratio: 16/9; }\n.ar-4-3  { aspect-ratio: 4/3; }\n.ar-1-1  { aspect-ratio: 1; }\n.ar-3-4  { aspect-ratio: 3/4; }\n.ar-golden { aspect-ratio: 1.618/1; }\n.responsive-video {\n  width: 100%;\n}\n.video-embed {\n  width: 100%;\n  aspect-ratio: 16/9;\n  background: #1e293b;\n  border-radius: 10px;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  gap: 0.5rem;\n  color: white;\n}\n.play-icon { font-size: 2.5rem; opacity: 0.7; }\n.video-embed p { margin: 0; font-size: 0.78rem; text-align: center; opacity: 0.7; line-height: 1.4; }\n.video-embed code { font-family: monospace; font-size: 0.8rem; color: #93c5fd; }\n",[2799,16135,16136,16143,16153,16163,16177,16187,16197,16207,16217,16221,16228,16238,16248,16258,16268,16272,16279,16289,16311,16321,16331,16341,16351,16361,16371,16381,16391,16401,16405,16430,16462,16481,16501,16516,16535,16554,16561,16571,16575,16582,16592,16606,16616,16626,16636,16646,16656,16666,16676,16686,16690,16713,16761],{"__ignoreMap":2865},[2869,16137,16138,16141],{"class":2871,"line":2872},[2869,16139,16140],{"class":3258},".ar-demo",[2869,16142,3262],{"class":3132},[2869,16144,16145,16147,16149,16151],{"class":2871,"line":2878},[2869,16146,3307],{"class":3128},[2869,16148,3270],{"class":3132},[2869,16150,3300],{"class":3299},[2869,16152,3277],{"class":3132},[2869,16154,16155,16157,16159,16161],{"class":2871,"line":2884},[2869,16156,3319],{"class":3128},[2869,16158,3270],{"class":3132},[2869,16160,3324],{"class":3273},[2869,16162,3277],{"class":3132},[2869,16164,16165,16167,16169,16171,16173,16175],{"class":2871,"line":2890},[2869,16166,3331],{"class":3128},[2869,16168,3270],{"class":3132},[2869,16170,3336],{"class":3273},[2869,16172,2810],{"class":3132},[2869,16174,3341],{"class":3273},[2869,16176,3277],{"class":3132},[2869,16178,16179,16181,16183,16185],{"class":2871,"line":2896},[2869,16180,3397],{"class":3128},[2869,16182,3270],{"class":3132},[2869,16184,3402],{"class":3273},[2869,16186,3277],{"class":3132},[2869,16188,16189,16191,16193,16195],{"class":2871,"line":2902},[2869,16190,3267],{"class":3128},[2869,16192,3270],{"class":3132},[2869,16194,3274],{"class":3273},[2869,16196,3277],{"class":3132},[2869,16198,16199,16201,16203,16205],{"class":2871,"line":2908},[2869,16200,5222],{"class":3128},[2869,16202,3270],{"class":3132},[2869,16204,5227],{"class":3273},[2869,16206,3277],{"class":3132},[2869,16208,16209,16211,16213,16215],{"class":2871,"line":2914},[2869,16210,3294],{"class":3128},[2869,16212,3270],{"class":3132},[2869,16214,3300],{"class":3299},[2869,16216,3277],{"class":3132},[2869,16218,16219],{"class":2871,"line":2920},[2869,16220,3360],{"class":3132},[2869,16222,16223,16226],{"class":2871,"line":2926},[2869,16224,16225],{"class":3258},".ar-grid",[2869,16227,3262],{"class":3132},[2869,16229,16230,16232,16234,16236],{"class":2871,"line":2932},[2869,16231,3267],{"class":3128},[2869,16233,3270],{"class":3132},[2869,16235,3274],{"class":3273},[2869,16237,3277],{"class":3132},[2869,16239,16240,16242,16244,16246],{"class":2871,"line":2938},[2869,16241,3294],{"class":3128},[2869,16243,3270],{"class":3132},[2869,16245,6109],{"class":3299},[2869,16247,3277],{"class":3132},[2869,16249,16250,16252,16254,16256],{"class":2871,"line":2944},[2869,16251,3282],{"class":3128},[2869,16253,3270],{"class":3132},[2869,16255,3287],{"class":3273},[2869,16257,3277],{"class":3132},[2869,16259,16260,16262,16264,16266],{"class":2871,"line":2950},[2869,16261,6083],{"class":3128},[2869,16263,3270],{"class":3132},[2869,16265,14295],{"class":3273},[2869,16267,3277],{"class":3132},[2869,16269,16270],{"class":2871,"line":2956},[2869,16271,3360],{"class":3132},[2869,16273,16274,16277],{"class":2871,"line":2962},[2869,16275,16276],{"class":3258},".ar-item",[2869,16278,3262],{"class":3132},[2869,16280,16281,16283,16285,16287],{"class":2871,"line":3448},[2869,16282,6219],{"class":3128},[2869,16284,3270],{"class":3132},[2869,16286,11149],{"class":3299},[2869,16288,3277],{"class":3132},[2869,16290,16291,16293,16295,16297,16299,16301,16303,16305,16307,16309],{"class":2871,"line":3505},[2869,16292,3319],{"class":3128},[2869,16294,3270],{"class":3132},[2869,16296,6030],{"class":3469},[2869,16298,3473],{"class":3132},[2869,16300,6035],{"class":3299},[2869,16302,2810],{"class":3132},[2869,16304,3538],{"class":3273},[2869,16306,2810],{"class":3132},[2869,16308,6044],{"class":3273},[2869,16310,6047],{"class":3132},[2869,16312,16313,16315,16317,16319],{"class":2871,"line":3543},[2869,16314,4741],{"class":3128},[2869,16316,3270],{"class":3132},[2869,16318,6278],{"class":3299},[2869,16320,3277],{"class":3132},[2869,16322,16323,16325,16327,16329],{"class":2871,"line":3573},[2869,16324,3267],{"class":3128},[2869,16326,3270],{"class":3132},[2869,16328,3274],{"class":3273},[2869,16330,3277],{"class":3132},[2869,16332,16333,16335,16337,16339],{"class":2871,"line":3619},[2869,16334,5222],{"class":3128},[2869,16336,3270],{"class":3132},[2869,16338,5227],{"class":3273},[2869,16340,3277],{"class":3132},[2869,16342,16343,16345,16347,16349],{"class":2871,"line":4232},[2869,16344,6083],{"class":3128},[2869,16346,3270],{"class":3132},[2869,16348,3559],{"class":3273},[2869,16350,3277],{"class":3132},[2869,16352,16353,16355,16357,16359],{"class":2871,"line":4241},[2869,16354,6094],{"class":3128},[2869,16356,3270],{"class":3132},[2869,16358,3559],{"class":3273},[2869,16360,3277],{"class":3132},[2869,16362,16363,16365,16367,16369],{"class":2871,"line":6174},[2869,16364,3397],{"class":3128},[2869,16366,3270],{"class":3132},[2869,16368,3390],{"class":3273},[2869,16370,3277],{"class":3132},[2869,16372,16373,16375,16377,16379],{"class":2871,"line":6208},[2869,16374,6126],{"class":3128},[2869,16376,3270],{"class":3132},[2869,16378,3559],{"class":3273},[2869,16380,3277],{"class":3132},[2869,16382,16383,16385,16387,16389],{"class":2871,"line":6216},[2869,16384,3307],{"class":3128},[2869,16386,3270],{"class":3132},[2869,16388,4480],{"class":3299},[2869,16390,3277],{"class":3132},[2869,16392,16393,16395,16397,16399],{"class":2871,"line":6229},[2869,16394,8115],{"class":3128},[2869,16396,3270],{"class":3132},[2869,16398,3460],{"class":3299},[2869,16400,3277],{"class":3132},[2869,16402,16403],{"class":2871,"line":6241},[2869,16404,3360],{"class":3132},[2869,16406,16407,16409,16412,16414,16416,16418,16420,16422,16424,16426,16428],{"class":2871,"line":6271},[2869,16408,16276],{"class":3258},[2869,16410,16411],{"class":3258}," span",[2869,16413,3434],{"class":3132},[2869,16415,9334],{"class":3128},[2869,16417,3270],{"class":3132},[2869,16419,7075],{"class":3299},[2869,16421,3521],{"class":3132},[2869,16423,3584],{"class":3128},[2869,16425,3270],{"class":3132},[2869,16427,5282],{"class":3299},[2869,16429,3445],{"class":3132},[2869,16431,16432,16434,16436,16438,16440,16442,16444,16446,16448,16450,16452,16454,16456,16458,16460],{"class":2871,"line":6283},[2869,16433,16276],{"class":3258},[2869,16435,14487],{"class":3258},[2869,16437,3434],{"class":3132},[2869,16439,3584],{"class":3128},[2869,16441,3270],{"class":3132},[2869,16443,15445],{"class":3299},[2869,16445,3521],{"class":3132},[2869,16447,5465],{"class":3128},[2869,16449,3270],{"class":3132},[2869,16451,6203],{"class":3299},[2869,16453,3521],{"class":3132},[2869,16455,11548],{"class":3128},[2869,16457,3270],{"class":3132},[2869,16459,8196],{"class":3299},[2869,16461,3445],{"class":3132},[2869,16463,16464,16467,16469,16471,16473,16475,16477,16479],{"class":2871,"line":6298},[2869,16465,16466],{"class":3258},".ar-16-9",[2869,16468,3434],{"class":3132},[2869,16470,15535],{"class":3128},[2869,16472,3270],{"class":3132},[2869,16474,15579],{"class":3299},[2869,16476,4921],{"class":3132},[2869,16478,15584],{"class":3299},[2869,16480,3445],{"class":3132},[2869,16482,16483,16486,16488,16490,16492,16495,16497,16499],{"class":2871,"line":6310},[2869,16484,16485],{"class":3258},".ar-4-3",[2869,16487,5369],{"class":3132},[2869,16489,15535],{"class":3128},[2869,16491,3270],{"class":3132},[2869,16493,16494],{"class":3299},"4",[2869,16496,4921],{"class":3132},[2869,16498,5605],{"class":3299},[2869,16500,3445],{"class":3132},[2869,16502,16503,16506,16508,16510,16512,16514],{"class":2871,"line":6321},[2869,16504,16505],{"class":3258},".ar-1-1",[2869,16507,5369],{"class":3132},[2869,16509,15535],{"class":3128},[2869,16511,3270],{"class":3132},[2869,16513,5645],{"class":3299},[2869,16515,3445],{"class":3132},[2869,16517,16518,16521,16523,16525,16527,16529,16531,16533],{"class":2871,"line":6326},[2869,16519,16520],{"class":3258},".ar-3-4",[2869,16522,5369],{"class":3132},[2869,16524,15535],{"class":3128},[2869,16526,3270],{"class":3132},[2869,16528,5605],{"class":3299},[2869,16530,4921],{"class":3132},[2869,16532,16494],{"class":3299},[2869,16534,3445],{"class":3132},[2869,16536,16537,16540,16542,16544,16546,16548,16550,16552],{"class":2871,"line":6334},[2869,16538,16539],{"class":3258},".ar-golden",[2869,16541,3434],{"class":3132},[2869,16543,15535],{"class":3128},[2869,16545,3270],{"class":3132},[2869,16547,15645],{"class":3299},[2869,16549,4921],{"class":3132},[2869,16551,5645],{"class":3299},[2869,16553,3445],{"class":3132},[2869,16555,16556,16559],{"class":2871,"line":6345},[2869,16557,16558],{"class":3258},".responsive-video",[2869,16560,3262],{"class":3132},[2869,16562,16563,16565,16567,16569],{"class":2871,"line":6356},[2869,16564,6219],{"class":3128},[2869,16566,3270],{"class":3132},[2869,16568,6236],{"class":3299},[2869,16570,3277],{"class":3132},[2869,16572,16573],{"class":2871,"line":6367},[2869,16574,3360],{"class":3132},[2869,16576,16577,16580],{"class":2871,"line":6382},[2869,16578,16579],{"class":3258},".video-embed",[2869,16581,3262],{"class":3132},[2869,16583,16584,16586,16588,16590],{"class":2871,"line":6387},[2869,16585,6219],{"class":3128},[2869,16587,3270],{"class":3132},[2869,16589,6236],{"class":3299},[2869,16591,3277],{"class":3132},[2869,16593,16594,16596,16598,16600,16602,16604],{"class":2871,"line":6395},[2869,16595,15574],{"class":3128},[2869,16597,3270],{"class":3132},[2869,16599,15579],{"class":3299},[2869,16601,4921],{"class":3132},[2869,16603,15584],{"class":3299},[2869,16605,3277],{"class":3132},[2869,16607,16608,16610,16612,16614],{"class":2871,"line":6407},[2869,16609,3319],{"class":3128},[2869,16611,3270],{"class":3132},[2869,16613,3402],{"class":3273},[2869,16615,3277],{"class":3132},[2869,16617,16618,16620,16622,16624],{"class":2871,"line":6433},[2869,16619,4741],{"class":3128},[2869,16621,3270],{"class":3132},[2869,16623,6056],{"class":3299},[2869,16625,3277],{"class":3132},[2869,16627,16628,16630,16632,16634],{"class":2871,"line":6444},[2869,16629,3267],{"class":3128},[2869,16631,3270],{"class":3132},[2869,16633,3274],{"class":3273},[2869,16635,3277],{"class":3132},[2869,16637,16638,16640,16642,16644],{"class":2871,"line":6456},[2869,16639,5222],{"class":3128},[2869,16641,3270],{"class":3132},[2869,16643,5227],{"class":3273},[2869,16645,3277],{"class":3132},[2869,16647,16648,16650,16652,16654],{"class":2871,"line":8128},[2869,16649,6083],{"class":3128},[2869,16651,3270],{"class":3132},[2869,16653,3559],{"class":3273},[2869,16655,3277],{"class":3132},[2869,16657,16658,16660,16662,16664],{"class":2871,"line":8139},[2869,16659,6094],{"class":3128},[2869,16661,3270],{"class":3132},[2869,16663,3559],{"class":3273},[2869,16665,3277],{"class":3132},[2869,16667,16668,16670,16672,16674],{"class":2871,"line":8151},[2869,16669,3294],{"class":3128},[2869,16671,3270],{"class":3132},[2869,16673,6109],{"class":3299},[2869,16675,3277],{"class":3132},[2869,16677,16678,16680,16682,16684],{"class":2871,"line":8163},[2869,16679,3397],{"class":3128},[2869,16681,3270],{"class":3132},[2869,16683,3390],{"class":3273},[2869,16685,3277],{"class":3132},[2869,16687,16688],{"class":2871,"line":8175},[2869,16689,3360],{"class":3132},[2869,16691,16692,16695,16697,16699,16701,16703,16705,16707,16709,16711],{"class":2871,"line":8180},[2869,16693,16694],{"class":3258},".play-icon",[2869,16696,3434],{"class":3132},[2869,16698,3584],{"class":3128},[2869,16700,3270],{"class":3132},[2869,16702,15276],{"class":3299},[2869,16704,3521],{"class":3132},[2869,16706,5465],{"class":3128},[2869,16708,3270],{"class":3132},[2869,16710,12297],{"class":3299},[2869,16712,3445],{"class":3132},[2869,16714,16715,16717,16719,16721,16723,16725,16727,16729,16731,16733,16735,16737,16739,16741,16743,16745,16747,16749,16751,16753,16755,16757,16759],{"class":2871,"line":8189},[2869,16716,16579],{"class":3258},[2869,16718,4459],{"class":3258},[2869,16720,3434],{"class":3132},[2869,16722,4328],{"class":3128},[2869,16724,3270],{"class":3132},[2869,16726,3460],{"class":3299},[2869,16728,3521],{"class":3132},[2869,16730,3584],{"class":3128},[2869,16732,3270],{"class":3132},[2869,16734,7119],{"class":3299},[2869,16736,3521],{"class":3132},[2869,16738,15408],{"class":3128},[2869,16740,3270],{"class":3132},[2869,16742,3559],{"class":3273},[2869,16744,3521],{"class":3132},[2869,16746,5465],{"class":3128},[2869,16748,3270],{"class":3132},[2869,16750,12297],{"class":3299},[2869,16752,3521],{"class":3132},[2869,16754,5489],{"class":3128},[2869,16756,3270],{"class":3132},[2869,16758,7142],{"class":3299},[2869,16760,3445],{"class":3132},[2869,16762,16763,16765,16767,16769,16771,16773,16775,16777,16779,16781,16783,16785,16787,16789,16792],{"class":2871,"line":8205},[2869,16764,16579],{"class":3258},[2869,16766,10304],{"class":3258},[2869,16768,3434],{"class":3132},[2869,16770,9317],{"class":3128},[2869,16772,3270],{"class":3132},[2869,16774,7086],{"class":3273},[2869,16776,3521],{"class":3132},[2869,16778,3584],{"class":3128},[2869,16780,3270],{"class":3132},[2869,16782,6305],{"class":3299},[2869,16784,3521],{"class":3132},[2869,16786,9147],{"class":3128},[2869,16788,3270],{"class":3132},[2869,16790,16791],{"class":3273},"#93c5fd",[2869,16793,3445],{"class":3132},[2967,16795],{},[2794,16797,16799,16801],{"id":16798},"fr-дробова-одиниця-grid",[2799,16800,2831],{}," — дробова одиниця Grid",[2804,16803,16804,16806,16807,16810],{},[2799,16805,2831],{}," (fractional unit) — особлива одиниця, що існує ",[2977,16808,16809],{},"лише в CSS Grid",". Вона означає «частку вільного простору» після того, як всі фіксовані розміри розподілені.",[2861,16812,16814],{"className":3249,"code":16813,"language":3251,"meta":2865,"style":2865},".grid {\n  display: grid;\n  /* Три рівні колонки */\n  grid-template-columns: 1fr 1fr 1fr;\n\n  /* Або: перша фіксована, решта — рівні частки */\n  grid-template-columns: 200px 1fr 2fr;\n  /* 1fr отримає 1/3 вільного простору, 2fr — 2/3 */\n}\n",[2799,16815,16816,16823,16833,16838,16853,16857,16862,16877,16882],{"__ignoreMap":2865},[2869,16817,16818,16821],{"class":2871,"line":2872},[2869,16819,16820],{"class":3258},".grid",[2869,16822,3262],{"class":3132},[2869,16824,16825,16827,16829,16831],{"class":2871,"line":2878},[2869,16826,3267],{"class":3128},[2869,16828,3270],{"class":3132},[2869,16830,9446],{"class":3273},[2869,16832,3277],{"class":3132},[2869,16834,16835],{"class":2871,"line":2884},[2869,16836,16837],{"class":3762},"  /* Три рівні колонки */\n",[2869,16839,16840,16842,16844,16847,16849,16851],{"class":2871,"line":2890},[2869,16841,9453],{"class":3128},[2869,16843,3270],{"class":3132},[2869,16845,16846],{"class":3299},"1fr",[2869,16848,9676],{"class":3299},[2869,16850,9676],{"class":3299},[2869,16852,3277],{"class":3132},[2869,16854,16855],{"class":2871,"line":2896},[2869,16856,4758],{"emptyLinePlaceholder":4757},[2869,16858,16859],{"class":2871,"line":2902},[2869,16860,16861],{"class":3762},"  /* Або: перша фіксована, решта — рівні частки */\n",[2869,16863,16864,16866,16868,16870,16872,16875],{"class":2871,"line":2908},[2869,16865,9453],{"class":3128},[2869,16867,3270],{"class":3132},[2869,16869,9428],{"class":3299},[2869,16871,9676],{"class":3299},[2869,16873,16874],{"class":3299}," 2fr",[2869,16876,3277],{"class":3132},[2869,16878,16879],{"class":2871,"line":2914},[2869,16880,16881],{"class":3762},"  /* 1fr отримає 1/3 вільного простору, 2fr — 2/3 */\n",[2869,16883,16884],{"class":2871,"line":2920},[2869,16885,3360],{"class":3132},[3107,16887,16888,17307],{},[2861,16889,16891],{"className":3111,"code":16890,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"fr-demo\">\n  \u003Cp class=\"fr-label\">1fr 1fr 1fr — три рівні колонки:\u003C/p>\n  \u003Cdiv class=\"grid-equal\">\n    \u003Cdiv class=\"fr-cell\">1fr\u003C/div>\n    \u003Cdiv class=\"fr-cell\">1fr\u003C/div>\n    \u003Cdiv class=\"fr-cell\">1fr\u003C/div>\n  \u003C/div>\n  \u003Cp class=\"fr-label\">200px 1fr 2fr — фіксована + дробові:\u003C/p>\n  \u003Cdiv class=\"grid-mixed\">\n    \u003Cdiv class=\"fr-cell fixed\">200px\u003C/div>\n    \u003Cdiv class=\"fr-cell one\">1fr\u003C/div>\n    \u003Cdiv class=\"fr-cell two\">2fr\u003C/div>\n  \u003C/div>\n  \u003Cp class=\"fr-label\">repeat(auto-fill, minmax(120px, 1fr)) — автоадаптивна сітка:\u003C/p>\n  \u003Cdiv class=\"grid-auto\">\n    \u003Cdiv class=\"fr-cell\">A\u003C/div>\n    \u003Cdiv class=\"fr-cell\">B\u003C/div>\n    \u003Cdiv class=\"fr-cell\">C\u003C/div>\n    \u003Cdiv class=\"fr-cell\">D\u003C/div>\n    \u003Cdiv class=\"fr-cell\">E\u003C/div>\n  \u003C/div>\n\u003C/div>\n",[2799,16892,16893,16908,16932,16947,16970,16992,17014,17022,17045,17060,17083,17106,17130,17138,17161,17176,17199,17222,17245,17268,17291,17299],{"__ignoreMap":2865},[2869,16894,16895,16897,16899,16901,16903,16906],{"class":2871,"line":2872},[2869,16896,3121],{"class":3120},[2869,16898,3125],{"class":3124},[2869,16900,3129],{"class":3128},[2869,16902,3133],{"class":3132},[2869,16904,16905],{"class":3136},"\"fr-demo\"",[2869,16907,3140],{"class":3120},[2869,16909,16910,16912,16914,16916,16918,16921,16923,16926,16928,16930],{"class":2871,"line":2878},[2869,16911,3145],{"class":3120},[2869,16913,2804],{"class":3124},[2869,16915,3129],{"class":3128},[2869,16917,3133],{"class":3132},[2869,16919,16920],{"class":3136},"\"fr-label\"",[2869,16922,3157],{"class":3120},[2869,16924,16925],{"class":3132},"1fr 1fr 1fr — три рівні колонки:",[2869,16927,3162],{"class":3120},[2869,16929,2804],{"class":3124},[2869,16931,3140],{"class":3120},[2869,16933,16934,16936,16938,16940,16942,16945],{"class":2871,"line":2884},[2869,16935,3145],{"class":3120},[2869,16937,3125],{"class":3124},[2869,16939,3129],{"class":3128},[2869,16941,3133],{"class":3132},[2869,16943,16944],{"class":3136},"\"grid-equal\"",[2869,16946,3140],{"class":3120},[2869,16948,16949,16951,16953,16955,16957,16960,16962,16964,16966,16968],{"class":2871,"line":2890},[2869,16950,3971],{"class":3120},[2869,16952,3125],{"class":3124},[2869,16954,3129],{"class":3128},[2869,16956,3133],{"class":3132},[2869,16958,16959],{"class":3136},"\"fr-cell\"",[2869,16961,3157],{"class":3120},[2869,16963,16846],{"class":3132},[2869,16965,3162],{"class":3120},[2869,16967,3125],{"class":3124},[2869,16969,3140],{"class":3120},[2869,16971,16972,16974,16976,16978,16980,16982,16984,16986,16988,16990],{"class":2871,"line":2896},[2869,16973,3971],{"class":3120},[2869,16975,3125],{"class":3124},[2869,16977,3129],{"class":3128},[2869,16979,3133],{"class":3132},[2869,16981,16959],{"class":3136},[2869,16983,3157],{"class":3120},[2869,16985,16846],{"class":3132},[2869,16987,3162],{"class":3120},[2869,16989,3125],{"class":3124},[2869,16991,3140],{"class":3120},[2869,16993,16994,16996,16998,17000,17002,17004,17006,17008,17010,17012],{"class":2871,"line":2902},[2869,16995,3971],{"class":3120},[2869,16997,3125],{"class":3124},[2869,16999,3129],{"class":3128},[2869,17001,3133],{"class":3132},[2869,17003,16959],{"class":3136},[2869,17005,3157],{"class":3120},[2869,17007,16846],{"class":3132},[2869,17009,3162],{"class":3120},[2869,17011,3125],{"class":3124},[2869,17013,3140],{"class":3120},[2869,17015,17016,17018,17020],{"class":2871,"line":2908},[2869,17017,4073],{"class":3120},[2869,17019,3125],{"class":3124},[2869,17021,3140],{"class":3120},[2869,17023,17024,17026,17028,17030,17032,17034,17036,17039,17041,17043],{"class":2871,"line":2914},[2869,17025,3145],{"class":3120},[2869,17027,2804],{"class":3124},[2869,17029,3129],{"class":3128},[2869,17031,3133],{"class":3132},[2869,17033,16920],{"class":3136},[2869,17035,3157],{"class":3120},[2869,17037,17038],{"class":3132},"200px 1fr 2fr — фіксована + дробові:",[2869,17040,3162],{"class":3120},[2869,17042,2804],{"class":3124},[2869,17044,3140],{"class":3120},[2869,17046,17047,17049,17051,17053,17055,17058],{"class":2871,"line":2920},[2869,17048,3145],{"class":3120},[2869,17050,3125],{"class":3124},[2869,17052,3129],{"class":3128},[2869,17054,3133],{"class":3132},[2869,17056,17057],{"class":3136},"\"grid-mixed\"",[2869,17059,3140],{"class":3120},[2869,17061,17062,17064,17066,17068,17070,17073,17075,17077,17079,17081],{"class":2871,"line":2926},[2869,17063,3971],{"class":3120},[2869,17065,3125],{"class":3124},[2869,17067,3129],{"class":3128},[2869,17069,3133],{"class":3132},[2869,17071,17072],{"class":3136},"\"fr-cell fixed\"",[2869,17074,3157],{"class":3120},[2869,17076,9428],{"class":3132},[2869,17078,3162],{"class":3120},[2869,17080,3125],{"class":3124},[2869,17082,3140],{"class":3120},[2869,17084,17085,17087,17089,17091,17093,17096,17098,17100,17102,17104],{"class":2871,"line":2932},[2869,17086,3971],{"class":3120},[2869,17088,3125],{"class":3124},[2869,17090,3129],{"class":3128},[2869,17092,3133],{"class":3132},[2869,17094,17095],{"class":3136},"\"fr-cell one\"",[2869,17097,3157],{"class":3120},[2869,17099,16846],{"class":3132},[2869,17101,3162],{"class":3120},[2869,17103,3125],{"class":3124},[2869,17105,3140],{"class":3120},[2869,17107,17108,17110,17112,17114,17116,17119,17121,17124,17126,17128],{"class":2871,"line":2938},[2869,17109,3971],{"class":3120},[2869,17111,3125],{"class":3124},[2869,17113,3129],{"class":3128},[2869,17115,3133],{"class":3132},[2869,17117,17118],{"class":3136},"\"fr-cell two\"",[2869,17120,3157],{"class":3120},[2869,17122,17123],{"class":3132},"2fr",[2869,17125,3162],{"class":3120},[2869,17127,3125],{"class":3124},[2869,17129,3140],{"class":3120},[2869,17131,17132,17134,17136],{"class":2871,"line":2944},[2869,17133,4073],{"class":3120},[2869,17135,3125],{"class":3124},[2869,17137,3140],{"class":3120},[2869,17139,17140,17142,17144,17146,17148,17150,17152,17155,17157,17159],{"class":2871,"line":2950},[2869,17141,3145],{"class":3120},[2869,17143,2804],{"class":3124},[2869,17145,3129],{"class":3128},[2869,17147,3133],{"class":3132},[2869,17149,16920],{"class":3136},[2869,17151,3157],{"class":3120},[2869,17153,17154],{"class":3132},"repeat(auto-fill, minmax(120px, 1fr)) — автоадаптивна сітка:",[2869,17156,3162],{"class":3120},[2869,17158,2804],{"class":3124},[2869,17160,3140],{"class":3120},[2869,17162,17163,17165,17167,17169,17171,17174],{"class":2871,"line":2956},[2869,17164,3145],{"class":3120},[2869,17166,3125],{"class":3124},[2869,17168,3129],{"class":3128},[2869,17170,3133],{"class":3132},[2869,17172,17173],{"class":3136},"\"grid-auto\"",[2869,17175,3140],{"class":3120},[2869,17177,17178,17180,17182,17184,17186,17188,17190,17193,17195,17197],{"class":2871,"line":2962},[2869,17179,3971],{"class":3120},[2869,17181,3125],{"class":3124},[2869,17183,3129],{"class":3128},[2869,17185,3133],{"class":3132},[2869,17187,16959],{"class":3136},[2869,17189,3157],{"class":3120},[2869,17191,17192],{"class":3132},"A",[2869,17194,3162],{"class":3120},[2869,17196,3125],{"class":3124},[2869,17198,3140],{"class":3120},[2869,17200,17201,17203,17205,17207,17209,17211,17213,17216,17218,17220],{"class":2871,"line":3448},[2869,17202,3971],{"class":3120},[2869,17204,3125],{"class":3124},[2869,17206,3129],{"class":3128},[2869,17208,3133],{"class":3132},[2869,17210,16959],{"class":3136},[2869,17212,3157],{"class":3120},[2869,17214,17215],{"class":3132},"B",[2869,17217,3162],{"class":3120},[2869,17219,3125],{"class":3124},[2869,17221,3140],{"class":3120},[2869,17223,17224,17226,17228,17230,17232,17234,17236,17239,17241,17243],{"class":2871,"line":3505},[2869,17225,3971],{"class":3120},[2869,17227,3125],{"class":3124},[2869,17229,3129],{"class":3128},[2869,17231,3133],{"class":3132},[2869,17233,16959],{"class":3136},[2869,17235,3157],{"class":3120},[2869,17237,17238],{"class":3132},"C",[2869,17240,3162],{"class":3120},[2869,17242,3125],{"class":3124},[2869,17244,3140],{"class":3120},[2869,17246,17247,17249,17251,17253,17255,17257,17259,17262,17264,17266],{"class":2871,"line":3543},[2869,17248,3971],{"class":3120},[2869,17250,3125],{"class":3124},[2869,17252,3129],{"class":3128},[2869,17254,3133],{"class":3132},[2869,17256,16959],{"class":3136},[2869,17258,3157],{"class":3120},[2869,17260,17261],{"class":3132},"D",[2869,17263,3162],{"class":3120},[2869,17265,3125],{"class":3124},[2869,17267,3140],{"class":3120},[2869,17269,17270,17272,17274,17276,17278,17280,17282,17285,17287,17289],{"class":2871,"line":3573},[2869,17271,3971],{"class":3120},[2869,17273,3125],{"class":3124},[2869,17275,3129],{"class":3128},[2869,17277,3133],{"class":3132},[2869,17279,16959],{"class":3136},[2869,17281,3157],{"class":3120},[2869,17283,17284],{"class":3132},"E",[2869,17286,3162],{"class":3120},[2869,17288,3125],{"class":3124},[2869,17290,3140],{"class":3120},[2869,17292,17293,17295,17297],{"class":2871,"line":3619},[2869,17294,4073],{"class":3120},[2869,17296,3125],{"class":3124},[2869,17298,3140],{"class":3120},[2869,17300,17301,17303,17305],{"class":2871,"line":4232},[2869,17302,3162],{"class":3120},[2869,17304,3125],{"class":3124},[2869,17306,3140],{"class":3120},[2861,17308,17310],{"className":3249,"code":17309,"language":3251,"meta":2865,"style":2865},".fr-demo {\n  padding: 1rem;\n  background: #f8fafc;\n  font-family: system-ui, sans-serif;\n  font-size: 0.82rem;\n  color: #1e293b;\n  display: flex;\n  flex-direction: column;\n  gap: 0.5rem;\n}\n.fr-label { margin: 0.25rem 0 0.1rem; color: #64748b; font-style: italic; }\n.grid-equal {\n  display: grid;\n  grid-template-columns: 1fr 1fr 1fr;\n  gap: 4px;\n}\n.grid-mixed {\n  display: grid;\n  grid-template-columns: 120px 1fr 2fr;\n  gap: 4px;\n}\n.grid-auto {\n  display: grid;\n  grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));\n  gap: 4px;\n}\n.fr-cell {\n  background: #6366f1;\n  color: white;\n  padding: 0.5rem;\n  border-radius: 4px;\n  text-align: center;\n  font-weight: 700;\n  font-size: 0.8rem;\n}\n.fixed { background: #64748b; }\n.one   { background: #8b5cf6; }\n.two   { background: #6366f1; }\n",[2799,17311,17312,17319,17329,17339,17353,17363,17373,17383,17393,17403,17407,17443,17450,17460,17474,17484,17488,17495,17505,17520,17530,17534,17541,17551,17579,17589,17593,17600,17610,17620,17630,17640,17650,17660,17670,17674,17689,17705],{"__ignoreMap":2865},[2869,17313,17314,17317],{"class":2871,"line":2872},[2869,17315,17316],{"class":3258},".fr-demo",[2869,17318,3262],{"class":3132},[2869,17320,17321,17323,17325,17327],{"class":2871,"line":2878},[2869,17322,3307],{"class":3128},[2869,17324,3270],{"class":3132},[2869,17326,3300],{"class":3299},[2869,17328,3277],{"class":3132},[2869,17330,17331,17333,17335,17337],{"class":2871,"line":2884},[2869,17332,3319],{"class":3128},[2869,17334,3270],{"class":3132},[2869,17336,3324],{"class":3273},[2869,17338,3277],{"class":3132},[2869,17340,17341,17343,17345,17347,17349,17351],{"class":2871,"line":2890},[2869,17342,3331],{"class":3128},[2869,17344,3270],{"class":3132},[2869,17346,3336],{"class":3273},[2869,17348,2810],{"class":3132},[2869,17350,3341],{"class":3273},[2869,17352,3277],{"class":3132},[2869,17354,17355,17357,17359,17361],{"class":2871,"line":2896},[2869,17356,3348],{"class":3128},[2869,17358,3270],{"class":3132},[2869,17360,11966],{"class":3299},[2869,17362,3277],{"class":3132},[2869,17364,17365,17367,17369,17371],{"class":2871,"line":2902},[2869,17366,3397],{"class":3128},[2869,17368,3270],{"class":3132},[2869,17370,3402],{"class":3273},[2869,17372,3277],{"class":3132},[2869,17374,17375,17377,17379,17381],{"class":2871,"line":2908},[2869,17376,3267],{"class":3128},[2869,17378,3270],{"class":3132},[2869,17380,3274],{"class":3273},[2869,17382,3277],{"class":3132},[2869,17384,17385,17387,17389,17391],{"class":2871,"line":2914},[2869,17386,5222],{"class":3128},[2869,17388,3270],{"class":3132},[2869,17390,5227],{"class":3273},[2869,17392,3277],{"class":3132},[2869,17394,17395,17397,17399,17401],{"class":2871,"line":2920},[2869,17396,3294],{"class":3128},[2869,17398,3270],{"class":3132},[2869,17400,6109],{"class":3299},[2869,17402,3277],{"class":3132},[2869,17404,17405],{"class":2871,"line":2926},[2869,17406,3360],{"class":3132},[2869,17408,17409,17412,17414,17416,17418,17420,17422,17425,17427,17429,17431,17433,17435,17437,17439,17441],{"class":2871,"line":2932},[2869,17410,17411],{"class":3258},".fr-label",[2869,17413,3434],{"class":3132},[2869,17415,4328],{"class":3128},[2869,17417,3270],{"class":3132},[2869,17419,4480],{"class":3299},[2869,17421,4335],{"class":3299},[2869,17423,17424],{"class":3299}," 0.1rem",[2869,17426,3521],{"class":3132},[2869,17428,9147],{"class":3128},[2869,17430,3270],{"class":3132},[2869,17432,7822],{"class":3273},[2869,17434,3521],{"class":3132},[2869,17436,9156],{"class":3128},[2869,17438,3270],{"class":3132},[2869,17440,9161],{"class":3273},[2869,17442,3445],{"class":3132},[2869,17444,17445,17448],{"class":2871,"line":2938},[2869,17446,17447],{"class":3258},".grid-equal",[2869,17449,3262],{"class":3132},[2869,17451,17452,17454,17456,17458],{"class":2871,"line":2944},[2869,17453,3267],{"class":3128},[2869,17455,3270],{"class":3132},[2869,17457,9446],{"class":3273},[2869,17459,3277],{"class":3132},[2869,17461,17462,17464,17466,17468,17470,17472],{"class":2871,"line":2950},[2869,17463,9453],{"class":3128},[2869,17465,3270],{"class":3132},[2869,17467,16846],{"class":3299},[2869,17469,9676],{"class":3299},[2869,17471,9676],{"class":3299},[2869,17473,3277],{"class":3132},[2869,17475,17476,17478,17480,17482],{"class":2871,"line":2956},[2869,17477,3294],{"class":3128},[2869,17479,3270],{"class":3132},[2869,17481,3614],{"class":3299},[2869,17483,3277],{"class":3132},[2869,17485,17486],{"class":2871,"line":2962},[2869,17487,3360],{"class":3132},[2869,17489,17490,17493],{"class":2871,"line":3448},[2869,17491,17492],{"class":3258},".grid-mixed",[2869,17494,3262],{"class":3132},[2869,17496,17497,17499,17501,17503],{"class":2871,"line":3505},[2869,17498,3267],{"class":3128},[2869,17500,3270],{"class":3132},[2869,17502,9446],{"class":3273},[2869,17504,3277],{"class":3132},[2869,17506,17507,17509,17511,17514,17516,17518],{"class":2871,"line":3543},[2869,17508,9453],{"class":3128},[2869,17510,3270],{"class":3132},[2869,17512,17513],{"class":3299},"120px",[2869,17515,9676],{"class":3299},[2869,17517,16874],{"class":3299},[2869,17519,3277],{"class":3132},[2869,17521,17522,17524,17526,17528],{"class":2871,"line":3573},[2869,17523,3294],{"class":3128},[2869,17525,3270],{"class":3132},[2869,17527,3614],{"class":3299},[2869,17529,3277],{"class":3132},[2869,17531,17532],{"class":2871,"line":3619},[2869,17533,3360],{"class":3132},[2869,17535,17536,17539],{"class":2871,"line":4232},[2869,17537,17538],{"class":3258},".grid-auto",[2869,17540,3262],{"class":3132},[2869,17542,17543,17545,17547,17549],{"class":2871,"line":4241},[2869,17544,3267],{"class":3128},[2869,17546,3270],{"class":3132},[2869,17548,9446],{"class":3273},[2869,17550,3277],{"class":3132},[2869,17552,17553,17555,17557,17559,17561,17563,17565,17568,17570,17573,17575,17577],{"class":2871,"line":6174},[2869,17554,9453],{"class":3128},[2869,17556,3270],{"class":3132},[2869,17558,9717],{"class":3469},[2869,17560,3473],{"class":3132},[2869,17562,9722],{"class":3273},[2869,17564,2810],{"class":3132},[2869,17566,17567],{"class":3469},"minmax",[2869,17569,3473],{"class":3132},[2869,17571,17572],{"class":3299},"70px",[2869,17574,2810],{"class":3132},[2869,17576,16846],{"class":3299},[2869,17578,9733],{"class":3132},[2869,17580,17581,17583,17585,17587],{"class":2871,"line":6208},[2869,17582,3294],{"class":3128},[2869,17584,3270],{"class":3132},[2869,17586,3614],{"class":3299},[2869,17588,3277],{"class":3132},[2869,17590,17591],{"class":2871,"line":6216},[2869,17592,3360],{"class":3132},[2869,17594,17595,17598],{"class":2871,"line":6229},[2869,17596,17597],{"class":3258},".fr-cell",[2869,17599,3262],{"class":3132},[2869,17601,17602,17604,17606,17608],{"class":2871,"line":6241},[2869,17603,3319],{"class":3128},[2869,17605,3270],{"class":3132},[2869,17607,3538],{"class":3273},[2869,17609,3277],{"class":3132},[2869,17611,17612,17614,17616,17618],{"class":2871,"line":6271},[2869,17613,3397],{"class":3128},[2869,17615,3270],{"class":3132},[2869,17617,3390],{"class":3273},[2869,17619,3277],{"class":3132},[2869,17621,17622,17624,17626,17628],{"class":2871,"line":6283},[2869,17623,3307],{"class":3128},[2869,17625,3270],{"class":3132},[2869,17627,6109],{"class":3299},[2869,17629,3277],{"class":3132},[2869,17631,17632,17634,17636,17638],{"class":2871,"line":6298},[2869,17633,4741],{"class":3128},[2869,17635,3270],{"class":3132},[2869,17637,3614],{"class":3299},[2869,17639,3277],{"class":3132},[2869,17641,17642,17644,17646,17648],{"class":2871,"line":6310},[2869,17643,6126],{"class":3128},[2869,17645,3270],{"class":3132},[2869,17647,3559],{"class":3273},[2869,17649,3277],{"class":3132},[2869,17651,17652,17654,17656,17658],{"class":2871,"line":6321},[2869,17653,5652],{"class":3128},[2869,17655,3270],{"class":3132},[2869,17657,9339],{"class":3299},[2869,17659,3277],{"class":3132},[2869,17661,17662,17664,17666,17668],{"class":2871,"line":6326},[2869,17663,3348],{"class":3128},[2869,17665,3270],{"class":3132},[2869,17667,6305],{"class":3299},[2869,17669,3277],{"class":3132},[2869,17671,17672],{"class":2871,"line":6334},[2869,17673,3360],{"class":3132},[2869,17675,17676,17679,17681,17683,17685,17687],{"class":2871,"line":6345},[2869,17677,17678],{"class":3258},".fixed",[2869,17680,3434],{"class":3132},[2869,17682,3533],{"class":3128},[2869,17684,3270],{"class":3132},[2869,17686,7822],{"class":3273},[2869,17688,3445],{"class":3132},[2869,17690,17691,17694,17697,17699,17701,17703],{"class":2871,"line":6356},[2869,17692,17693],{"class":3258},".one",[2869,17695,17696],{"class":3132},"   { ",[2869,17698,3533],{"class":3128},[2869,17700,3270],{"class":3132},[2869,17702,6044],{"class":3273},[2869,17704,3445],{"class":3132},[2869,17706,17707,17710,17712,17714,17716,17718],{"class":2871,"line":6367},[2869,17708,17709],{"class":3258},".two",[2869,17711,17696],{"class":3132},[2869,17713,3533],{"class":3128},[2869,17715,3270],{"class":3132},[2869,17717,3538],{"class":3273},[2869,17719,3445],{"class":3132},[8451,17721,17722,17724,17725,17728,17729,17731,17732,11412,17735,17738,17739,17742,17743,17745,17746,5726,17749,17751],{},[2799,17723,2831],{}," вираховується ",[2977,17726,17727],{},"після"," розподілу фіксованих розмірів і ",[2799,17730,9191],{},". Тому ",[2799,17733,17734],{},"grid-template-columns: 200px 1fr",[2799,17736,17737],{},"gap: 1rem"," дасть ",[2799,17740,17741],{},"1fr = (100% - 200px - 1rem)",". Не можна використовувати ",[2799,17744,2831],{}," поза Grid — лише в ",[2799,17747,17748],{},"grid-template-*",[2799,17750,9446],{}," властивостях.",[2967,17753],{},[2794,17755,17757],{"id":17756},"зведена-таблиця-яку-одиницю-коли-використовувати","Зведена таблиця: яку одиницю коли використовувати",[3671,17759,17760,17773],{},[3674,17761,17762],{},[3677,17763,17764,17767,17770],{},[3680,17765,17766],{},"Задача",[3680,17768,17769],{},"Рекомендована одиниця",[3680,17771,17772],{},"Чому",[3690,17774,17775,17789,17808,17822,17836,17848,17865,17877,17889,17904,17918,17930,17944,17956],{},[3677,17776,17777,17782,17786],{},[3695,17778,17779,17781],{},[2799,17780,3584],{}," компонентів",[3695,17783,17784],{},[2799,17785,2816],{},[3695,17787,17788],{},"Пропорційно налаштуванням браузера",[3677,17790,17791,17798,17802],{},[3695,17792,17793,4921,17795,17797],{},[2799,17794,3593],{},[2799,17796,4328],{}," всередині компонента",[3695,17799,17800],{},[2799,17801,2813],{},[3695,17803,17804,17805,17807],{},"Масштабується з ",[2799,17806,3584],{}," компонента",[3677,17809,17810,17815,17819],{},[3695,17811,17812,17814],{},[2799,17813,4918],{}," між компонентами",[3695,17816,17817],{},[2799,17818,2816],{},[3695,17820,17821],{},"Стабільно, незалежно від вкладення",[3677,17823,17824,17827,17833],{},[3695,17825,17826],{},"Ширина контейнера (fluid)",[3695,17828,17829,5690,17831],{},[2799,17830,2834],{},[2799,17832,5372],{},[3695,17834,17835],{},"Адаптивно + обмежено",[3677,17837,17838,17841,17845],{},[3695,17839,17840],{},"Full-height сторінка",[3695,17842,17843],{},[2799,17844,6751],{},[3695,17846,17847],{},"Без проблем з mobile адрес-баром",[3677,17849,17850,17853,17862],{},[3695,17851,17852],{},"Responsive typography",[3695,17854,17855,4886,17857,17859,17860],{},[2799,17856,12659],{},[2799,17858,2819],{},"+",[2799,17861,2816],{},[3695,17863,17864],{},"Fluid масштабування",[3677,17866,17867,17870,17874],{},[3695,17868,17869],{},"Ширина тексту для читання",[3695,17871,17872],{},[2799,17873,2837],{},[3695,17875,17876],{},"Пропорційно символам",[3677,17878,17879,17882,17886],{},[3695,17880,17881],{},"Відступи, що ростуть з viewport",[3695,17883,17884],{},[2799,17885,12659],{},[3695,17887,17888],{},"Fluid spacing",[3677,17890,17891,17894,17901],{},[3695,17892,17893],{},"Grid-колонки",[3695,17895,17896,5690,17898],{},[2799,17897,2831],{},[2799,17899,17900],{},"minmax()",[3695,17902,17903],{},"Native grid units",[3677,17905,17906,17909,17915],{},[3695,17907,17908],{},"Компоненти в різних контейнерах",[3695,17910,17911,2810,17913],{},[2799,17912,8404],{},[2799,17914,2828],{},[3695,17916,17917],{},"Container-aware",[3677,17919,17920,17923,17927],{},[3695,17921,17922],{},"Тіні, border, декоративні деталі",[3695,17924,17925],{},[2799,17926,2809],{},[3695,17928,17929],{},"Фіксована чіткість",[3677,17931,17932,17935,17941],{},[3695,17933,17934],{},"Мінімальний/максимальний розмір",[3695,17936,17937,2810,17939],{},[2799,17938,12653],{},[2799,17940,12656],{},[3695,17942,17943],{},"Умовна логіка",[3677,17945,17946,17949,17953],{},[3695,17947,17948],{},"Aspect ratio",[3695,17950,17951],{},[2799,17952,15535],{},[3695,17954,17955],{},"Нативна підтримка",[3677,17957,17958,17961,17968],{},[3695,17959,17960],{},"Логічні відступи (i18n)",[3695,17962,17963,2810,17965],{},[2799,17964,11571],{},[2799,17966,17967],{},"padding-block",[3695,17969,17970],{},"RTL-сумісність",[2967,17972],{},[2794,17974,17976],{"id":17975},"практика","Практика",[17978,17979,17980,17984,17987,18095,18227,18232,18322,18328,18331,18370,18385,18389,18392,18412],"steps",{},[2982,17981,17983],{"id":17982},"рівень-1-базовий-виправте-розміри","Рівень 1 — Базовий: виправте розміри",[2804,17985,17986],{},"Дано зламаний CSS. Знайдіть і виправте помилки:",[2861,17988,17990],{"className":3111,"code":17989,"language":3113,"meta":2865,"style":2865},"\u003Cdiv class=\"parent\">\n  \u003Cdiv class=\"child\">Я маю займати всю висоту батька\u003C/div>\n\u003C/div>\n\n\u003Cp class=\"text\">Цей текст занадто широкий для читання на великих екранах\u003C/p>\n\n\u003Cdiv class=\"hero\">Hero секція на весь екран\u003C/div>\n",[2799,17991,17992,18007,18031,18039,18043,18067,18071],{"__ignoreMap":2865},[2869,17993,17994,17996,17998,18000,18002,18005],{"class":2871,"line":2872},[2869,17995,3121],{"class":3120},[2869,17997,3125],{"class":3124},[2869,17999,3129],{"class":3128},[2869,18001,3133],{"class":3132},[2869,18003,18004],{"class":3136},"\"parent\"",[2869,18006,3140],{"class":3120},[2869,18008,18009,18011,18013,18015,18017,18020,18022,18025,18027,18029],{"class":2871,"line":2878},[2869,18010,3145],{"class":3120},[2869,18012,3125],{"class":3124},[2869,18014,3129],{"class":3128},[2869,18016,3133],{"class":3132},[2869,18018,18019],{"class":3136},"\"child\"",[2869,18021,3157],{"class":3120},[2869,18023,18024],{"class":3132},"Я маю займати всю висоту батька",[2869,18026,3162],{"class":3120},[2869,18028,3125],{"class":3124},[2869,18030,3140],{"class":3120},[2869,18032,18033,18035,18037],{"class":2871,"line":2884},[2869,18034,3162],{"class":3120},[2869,18036,3125],{"class":3124},[2869,18038,3140],{"class":3120},[2869,18040,18041],{"class":2871,"line":2890},[2869,18042,4758],{"emptyLinePlaceholder":4757},[2869,18044,18045,18047,18049,18051,18053,18056,18058,18061,18063,18065],{"class":2871,"line":2896},[2869,18046,3121],{"class":3120},[2869,18048,2804],{"class":3124},[2869,18050,3129],{"class":3128},[2869,18052,3133],{"class":3132},[2869,18054,18055],{"class":3136},"\"text\"",[2869,18057,3157],{"class":3120},[2869,18059,18060],{"class":3132},"Цей текст занадто широкий для читання на великих екранах",[2869,18062,3162],{"class":3120},[2869,18064,2804],{"class":3124},[2869,18066,3140],{"class":3120},[2869,18068,18069],{"class":2871,"line":2902},[2869,18070,4758],{"emptyLinePlaceholder":4757},[2869,18072,18073,18075,18077,18079,18081,18084,18086,18089,18091,18093],{"class":2871,"line":2908},[2869,18074,3121],{"class":3120},[2869,18076,3125],{"class":3124},[2869,18078,3129],{"class":3128},[2869,18080,3133],{"class":3132},[2869,18082,18083],{"class":3136},"\"hero\"",[2869,18085,3157],{"class":3120},[2869,18087,18088],{"class":3132},"Hero секція на весь екран",[2869,18090,3162],{"class":3120},[2869,18092,3125],{"class":3124},[2869,18094,3140],{"class":3120},[2861,18096,18098],{"className":3249,"code":18097,"language":3251,"meta":2865,"style":2865},"/* ❌ Зламаний CSS — знайдіть і виправте 3 помилки */\n.parent {\n  border: 2px solid blue;\n  /* Немає висоти */\n}\n.child {\n  height: 100%;   /* не працює без висоти у батька */\n  background: lightblue;\n}\n\n.text {\n  width: 100%;    /* занадто широкий для читання */\n}\n\n.hero {\n  height: 100vh;  /* проблема на мобільних */\n}\n",[2799,18099,18100,18105,18112,18127,18132,18136,18143,18157,18168,18172,18176,18183,18196,18200,18204,18210,18223],{"__ignoreMap":2865},[2869,18101,18102],{"class":2871,"line":2872},[2869,18103,18104],{"class":3762},"/* ❌ Зламаний CSS — знайдіть і виправте 3 помилки */\n",[2869,18106,18107,18110],{"class":2871,"line":2878},[2869,18108,18109],{"class":3258},".parent",[2869,18111,3262],{"class":3132},[2869,18113,18114,18116,18118,18120,18122,18125],{"class":2871,"line":2884},[2869,18115,3409],{"class":3128},[2869,18117,3270],{"class":3132},[2869,18119,9479],{"class":3299},[2869,18121,3417],{"class":3273},[2869,18123,18124],{"class":3273}," blue",[2869,18126,3277],{"class":3132},[2869,18128,18129],{"class":2871,"line":2890},[2869,18130,18131],{"class":3762},"  /* Немає висоти */\n",[2869,18133,18134],{"class":2871,"line":2896},[2869,18135,3360],{"class":3132},[2869,18137,18138,18141],{"class":2871,"line":2902},[2869,18139,18140],{"class":3258},".child",[2869,18142,3262],{"class":3132},[2869,18144,18145,18147,18149,18151,18154],{"class":2871,"line":2908},[2869,18146,6014],{"class":3128},[2869,18148,3270],{"class":3132},[2869,18150,6236],{"class":3299},[2869,18152,18153],{"class":3132},";   ",[2869,18155,18156],{"class":3762},"/* не працює без висоти у батька */\n",[2869,18158,18159,18161,18163,18166],{"class":2871,"line":2914},[2869,18160,3319],{"class":3128},[2869,18162,3270],{"class":3132},[2869,18164,18165],{"class":3273},"lightblue",[2869,18167,3277],{"class":3132},[2869,18169,18170],{"class":2871,"line":2920},[2869,18171,3360],{"class":3132},[2869,18173,18174],{"class":2871,"line":2926},[2869,18175,4758],{"emptyLinePlaceholder":4757},[2869,18177,18178,18181],{"class":2871,"line":2932},[2869,18179,18180],{"class":3258},".text",[2869,18182,3262],{"class":3132},[2869,18184,18185,18187,18189,18191,18193],{"class":2871,"line":2938},[2869,18186,6219],{"class":3128},[2869,18188,3270],{"class":3132},[2869,18190,6236],{"class":3299},[2869,18192,9815],{"class":3132},[2869,18194,18195],{"class":3762},"/* занадто широкий для читання */\n",[2869,18197,18198],{"class":2871,"line":2944},[2869,18199,3360],{"class":3132},[2869,18201,18202],{"class":2871,"line":2950},[2869,18203,4758],{"emptyLinePlaceholder":4757},[2869,18205,18206,18208],{"class":2871,"line":2956},[2869,18207,7254],{"class":3258},[2869,18209,3262],{"class":3132},[2869,18211,18212,18214,18216,18218,18220],{"class":2871,"line":2962},[2869,18213,6014],{"class":3128},[2869,18215,3270],{"class":3132},[2869,18217,5752],{"class":3299},[2869,18219,4733],{"class":3132},[2869,18221,18222],{"class":3762},"/* проблема на мобільних */\n",[2869,18224,18225],{"class":2871,"line":3448},[2869,18226,3360],{"class":3132},[2804,18228,18229],{},[2977,18230,18231],{},"Очікуване рішення:",[2861,18233,18235],{"className":3249,"code":18234,"language":3251,"meta":2865,"style":2865},".parent { border: 2px solid blue; height: 200px; }\n.child  { height: 100%; background: lightblue; }\n.text   { max-width: 65ch; margin-inline: auto; }\n.hero   { min-height: 100dvh; }\n",[2799,18236,18237,18263,18285,18307],{"__ignoreMap":2865},[2869,18238,18239,18241,18243,18245,18247,18249,18251,18253,18255,18257,18259,18261],{"class":2871,"line":2872},[2869,18240,18109],{"class":3258},[2869,18242,3434],{"class":3132},[2869,18244,3495],{"class":3128},[2869,18246,3270],{"class":3132},[2869,18248,9479],{"class":3299},[2869,18250,3417],{"class":3273},[2869,18252,18124],{"class":3273},[2869,18254,3521],{"class":3132},[2869,18256,3524],{"class":3128},[2869,18258,3270],{"class":3132},[2869,18260,9428],{"class":3299},[2869,18262,3445],{"class":3132},[2869,18264,18265,18267,18269,18271,18273,18275,18277,18279,18281,18283],{"class":2871,"line":2878},[2869,18266,18140],{"class":3258},[2869,18268,5369],{"class":3132},[2869,18270,3524],{"class":3128},[2869,18272,3270],{"class":3132},[2869,18274,6236],{"class":3299},[2869,18276,3521],{"class":3132},[2869,18278,3533],{"class":3128},[2869,18280,3270],{"class":3132},[2869,18282,18165],{"class":3273},[2869,18284,3445],{"class":3132},[2869,18286,18287,18289,18291,18293,18295,18297,18299,18301,18303,18305],{"class":2871,"line":2884},[2869,18288,18180],{"class":3258},[2869,18290,17696],{"class":3132},[2869,18292,5372],{"class":3128},[2869,18294,3270],{"class":3132},[2869,18296,4973],{"class":3299},[2869,18298,3521],{"class":3132},[2869,18300,11571],{"class":3128},[2869,18302,3270],{"class":3132},[2869,18304,4988],{"class":3273},[2869,18306,3445],{"class":3132},[2869,18308,18309,18311,18313,18316,18318,18320],{"class":2871,"line":2890},[2869,18310,7254],{"class":3258},[2869,18312,17696],{"class":3132},[2869,18314,18315],{"class":3128},"min-height",[2869,18317,3270],{"class":3132},[2869,18319,6751],{"class":3299},[2869,18321,3445],{"class":3132},[2982,18323,18325,18326],{"id":18324},"рівень-2-fluid-typography-з-clamp","Рівень 2 — Fluid typography з ",[2799,18327,12659],{},[2804,18329,18330],{},"Реалізуйте адаптивну типографічну шкалу для статті, де заголовки та текст масштабуються між мінімальним та максимальним розміром залежно від ширини viewport. Вимоги:",[3072,18332,18333,18345,18353,18362],{},[3075,18334,18335,18337,18338,18341,18342],{},[2799,18336,2790],{},": від ",[2799,18339,18340],{},"1.75rem"," до ",[2799,18343,18344],{},"3.5rem",[3075,18346,18347,18337,18349,18341,18351],{},[2799,18348,2794],{},[2799,18350,4774],{},[2799,18352,12178],{},[3075,18354,18355,18337,18357,18341,18359],{},[2799,18356,2804],{},[2799,18358,5282],{},[2799,18360,18361],{},"1.125rem",[3075,18363,18364,18365,18341,18367],{},"Горизонтальний padding секцій: від ",[2799,18366,3300],{},[2799,18368,18369],{},"5rem",[18371,18372,18374,18375,18378,18379,18381,18382,3905],"collapsible",{"title":18373},"Підказка: формула для clamp()","Використовуйте формулу: ",[2799,18376,18377],{},"clamp(min, min + (max - min) * vw_factor, max)",".\nHarpoon правило: середнє значення має включати ",[2799,18380,2819],{}," компонент для fluid scaling.\nНаприклад: ",[2799,18383,18384],{},"clamp(1.75rem, 1.75rem + 1.75vw, 3.5rem)",[2982,18386,18388],{"id":18387},"рівень-3-компонент-картки-з-container-queries","Рівень 3 — Компонент картки з Container Queries",[2804,18390,18391],{},"Створіть компонент картки, що автоматично змінює layout:",[3072,18393,18394,18400,18406],{},[3075,18395,2847,18396,18399],{},[2977,18397,18398],{},"вузькому"," контейнері (\u003C 300px): вертикальний layout, дрібний текст",[3075,18401,2847,18402,18405],{},[2977,18403,18404],{},"середньому"," контейнері (300px–500px): горизонтальний layout, середній текст",[3075,18407,2847,18408,18411],{},[2977,18409,18410],{},"широкому"," контейнері (> 500px): горизонтальний layout з більшою картинкою, великий текст з описом",[2804,18413,18414,18415,2810,18418,18420,18421,18424],{},"Використовуйте ",[2799,18416,18417],{},"container-type",[2799,18419,8404],{}," для шрифту та ",[2799,18422,18423],{},"@container"," для layout.",[2967,18426],{},[2794,18428,18430],{"id":18429},"підсумок","Підсумок",[2804,18432,18433,18434,18437],{},"CSS-розміри — це не просто числа: це ",[2977,18435,18436],{},"система рішень",", де кожна одиниця відповідає на певне запитання. Ось головне, що варто запам'ятати:",[18439,18440,18441,18447,18460,18475,18486,18497],"card-group",{},[18442,18443,18446],"card",{"icon":18444,"title":18445},"i-lucide-ruler","📏 Абсолютні (px)","Для фіксованих деталей: border, shadow, border-radius, іконки. Не для font-size та layout spacing.",[18442,18448,18451,18453,18454,18456,18457,18459],{"icon":18449,"title":18450},"i-lucide-type","🔤 Шрифтові (rem/em)",[2799,18452,2816],{}," — для font-size та spacing компонентів. ",[2799,18455,2813],{}," — для padding/margin всередині компонента, що має масштабуватись з текстом. ",[2799,18458,2837],{}," — для ширини текстового блоку.",[18442,18461,18464,18466,18467,18469,18470,5690,18472,18474],{"icon":18462,"title":18463},"i-lucide-monitor-smartphone","📱 Viewport (dvh/vw)",[2799,18465,2825],{}," замість ",[2799,18468,2822],{}," для full-height layouts на мобільних. ",[2799,18471,2819],{},[2799,18473,12659],{}," для fluid typography.",[18442,18476,18478,4921,18480,18482,18483,18485],{"icon":62,"title":18477},"📦 Контейнерні (cqi)",[2799,18479,8404],{},[2799,18481,2828],{}," для компонентів, що розміщуються в різних контейнерах. Завжди потребують ",[2799,18484,18417],{}," на батькові.",[18442,18487,18490,2810,18492,2810,18494,18496],{"icon":18488,"title":18489},"i-lucide-brain","🧠 Intrinsic (min-content)",[2799,18491,2840],{},[2799,18493,8498],{},[2799,18495,8513],{}," — дозвольте вмісту самому вирішувати. Дуже корисні в Grid.",[18442,18498,18500,2810,18502,2810,18504,18506,18507,18509],{"icon":92,"title":18499},"⚡ Функції (clamp)",[2799,18501,12653],{},[2799,18503,12656],{},[2799,18505,12659],{}," — умовна логіка в CSS без медіа-запитів. ",[2799,18508,12659],{}," = fluid scaling між двома точками.",[18511,18512,18513],"style",{},"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 .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 pre.shiki code .sqdDX, html code.shiki .sqdDX{--shiki-light:#800000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sDUd3, html code.shiki .sDUd3{--shiki-light:#0451A5;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .sCDza, html code.shiki .sCDza{--shiki-light:#AF00DB;--shiki-default:#CE92A4;--shiki-dark:#CE92A4}",{"title":2865,"searchDepth":2878,"depth":2878,"links":18515},[18516,18518,18524,18534,18542,18546,18556,18562,18563,18572,18574,18576,18577,18583],{"id":2796,"depth":2878,"text":18517},"Чому width: 200px — це лише початок",{"id":2971,"depth":2878,"text":2972,"children":18519},[18520,18522],{"id":2984,"depth":2884,"text":18521},"px — піксель, якого не існує",{"id":3647,"depth":2884,"text":18523},"Друкарські одиниці: pt, cm, mm, in, pc",{"id":3872,"depth":2878,"text":3873,"children":18525},[18526,18528,18530,18532],{"id":3883,"depth":2884,"text":18527},"em — магія каскаду",{"id":4788,"depth":2884,"text":18529},"rem — надійна альтернатива",{"id":4934,"depth":2884,"text":18531},"ch — ширина символу «0»",{"id":5499,"depth":2884,"text":18533},"ex, lh, rlh, cap — спеціалізовані шрифтові одиниці",{"id":5716,"depth":2878,"text":5717,"children":18535},[18536,18538,18540],{"id":5723,"depth":2884,"text":18537},"vw та vh — базові viewport-одиниці",{"id":6461,"depth":2884,"text":18539},"Проблема vh на мобільних: адрес-бар",{"id":6511,"depth":2884,"text":18541},"svh, lvh, dvh — нові одиниці viewport (2022+)",{"id":7312,"depth":2878,"text":7313,"children":18543},[18544,18545],{"id":7326,"depth":2884,"text":7327},{"id":8245,"depth":2884,"text":8246},{"id":8469,"depth":2878,"text":8470,"children":18547},[18548,18550,18552,18554],{"id":8480,"depth":2884,"text":18549},"min-content — мінімум без втрат",{"id":8495,"depth":2884,"text":18551},"max-content — без переносів взагалі",{"id":8510,"depth":2884,"text":18553},"fit-content — компромісне рішення",{"id":8531,"depth":2884,"text":18555},"fit-content(value) — функція з обмеженням",{"id":9742,"depth":2878,"text":18557,"children":18558},"width, height та їх min-/max- варіанти",[18559,18560],{"id":9757,"depth":2884,"text":9758},{"id":10487,"depth":2884,"text":18561},"Чому height: 100% не завжди працює",{"id":11421,"depth":2878,"text":11422},{"id":12646,"depth":2878,"text":18564,"children":18565},"CSS-функції для розмірів: calc(), min(), max(), clamp()",[18566,18568,18570],{"id":12662,"depth":2884,"text":18567},"calc() — арифметика між будь-якими одиницями",{"id":13506,"depth":2884,"text":18569},"min() та max() — умовні розміри",{"id":14528,"depth":2884,"text":18571},"clamp() — fluid scaling",{"id":15532,"depth":2878,"text":18573},"aspect-ratio — фіксоване співвідношення сторін",{"id":16798,"depth":2878,"text":18575},"fr — дробова одиниця Grid",{"id":17756,"depth":2878,"text":17757},{"id":17975,"depth":2878,"text":17976,"children":18578},[18579,18580,18582],{"id":17982,"depth":2884,"text":17983},{"id":18324,"depth":2884,"text":18581},"Рівень 2 — Fluid typography з clamp()",{"id":18387,"depth":2884,"text":18388},{"id":18429,"depth":2878,"text":18430},"Глибокий огляд усіх одиниць вимірювання CSS: абсолютні (px), відносні (em, rem), viewport (vw, vh, dvh), контейнерні (cqw), intrinsic keywords (min-content, max-content, fit-content), функції min(), max(), clamp(), aspect-ratio, логічні властивості та fr.","md",null,{},{"title":2664,"description":18584},"tPpg4cKPRS9SCi-UpDj9etCcyfbk-g4g7JEJ8XMgBPw",[18591,18593],{"title":2660,"path":2661,"stem":2662,"description":18592,"children":-1},"Глибоке занурення у блокову модель CSS: content, padding, border, margin, box-sizing, margin collapse, display-типи (block, inline, inline-block), overflow та visibility.",{"title":2668,"path":2669,"stem":2670,"description":18594,"children":-1},"Глибоке занурення у CSS-типографіку: font-family, @font-face, Google Fonts, font-size (px/em/rem), line-height, text-align, text-decoration, text-overflow, одиниці виміру та CSS Custom Properties для системи типографіки.",1776866090862]