{data.title}
{data.description}
--- id: wiki-2026-0508-container-queries title: CSS Container Queries category: 10_Wiki/Topics status: verified canonical_id: self aliases: [container queries, @container, cqi, cqw, component-centric responsive, design system] duplicate_of: none source_trust_level: A confidence_score: 0.95 verification_status: applied tags: [css, container-queries, responsive-design, component-driven, design-system, baseline-2025] raw_sources: [] last_reinforced: 2026-05-10 github_commit: pending tech_stack: language: CSS framework: any (vanilla CSS, Tailwind, CSS-in-JS) --- # CSS Container Queries ## 매 한 줄 > **"매 viewport X — 매 parent container 의 size 의 반응"**. 매 component 의 어디 에 의 placed 의 robust. 매 2025 baseline. 매 design system / modular UI 의 game-changer. 매 page-centric → 매 component-centric paradigm shift. ## 매 핵심 ### 매 vs Media Queries - **Media query**: 매 viewport size. - **Container query**: 매 parent size. - 매 component 의 self-decide layout regardless of page placement. ### 매 syntax (basic) ```css .parent { container-type: inline-size; container-name: card; /* 매 optional */ } @container card (min-width: 600px) { .card { display: grid; grid-template-columns: 1fr 1fr; } } ``` ### 매 container-type - **`inline-size`**: 매 width-based (most common). - **`size`**: 매 width + height (rarer, more performance). - **`normal`**: 매 default (no query support). ### 매 unit - **`cqw`**: 매 1% of container width. - **`cqh`**: 매 1% of container height. - **`cqi`**: 매 inline size (LTR/RTL aware). - **`cqb`**: 매 block size. - **`cqmin`** / **`cqmax`**: 매 min / max of inline / block. ### 매 use case 1. **Card component**: 매 sidebar (narrow) vs main (wide) 의 다른 layout. 2. **Dashboard tile**: 매 chart → 매 number 의 narrow. 3. **Table → card** (narrow). 4. **Article**: 매 typography 의 cqi 기반 fluid. 5. **Sidebar item**: 매 collapsed vs expanded. ### 매 modern browser support - 매 Chrome 105+ (2022 Aug). - 매 Firefox 110+ (2023 Feb). - 매 Safari 16+ (2022 Sep). - 매 Baseline widely available 2025. ### 매 design system 의 perfect fit - 매 component 의 reusable 어디 에서. - 매 Storybook 의 isolation testing. - 매 modular UI library. - 매 truly self-contained component. ### 매 vs media query (when 의 use) - **Media query**: 매 page layout, 매 dark mode, 매 print. - **Container query**: 매 component size adaptation. - 매 둘 다 의 combine. ### 매 fluid typography (cqi) ```css .title { font-size: clamp(1rem, 4cqi, 2rem); } ``` → 매 container 의 size 의 따라 fluid scale. ## 💻 패턴 ### Card layout (sidebar vs main) ```css .card-container { container-type: inline-size; } .card { display: flex; flex-direction: column; } @container (min-width: 400px) { .card { flex-direction: row; } .card__image { width: 40%; } .card__content { flex: 1; } } @container (min-width: 700px) { .card { grid-template-columns: 1fr 2fr 1fr; } .card__action { display: block; } } ``` ### Dashboard tile (chart ↔ number) ```css .tile { container-type: inline-size; } .chart { display: block; } .summary-number { display: none; } @container (max-width: 200px) { .chart { display: none; } .summary-number { display: block; font-size: 2rem; } } ``` ### Fluid typography ```css .article { container-type: inline-size; } .article h1 { font-size: clamp(1.5rem, 5cqi, 3rem); } .article p { font-size: clamp(0.9rem, 2cqi, 1.1rem); } ``` ### Table → Card stack (narrow) ```css .table-container { container-type: inline-size; } table { display: table; width: 100%; } @container (max-width: 600px) { table, thead, tbody, tr, td { display: block; } thead { display: none; } tr { border: 1px solid #ddd; margin-bottom: 1rem; padding: 1rem; } td::before { content: attr(data-label) ': '; font-weight: bold; } } ``` ### Named container ```css .article-context { container-type: inline-size; container-name: article; } .aside-context { container-type: inline-size; container-name: aside; } @container article (min-width: 600px) { .my-component { /* ... */ } } @container aside (min-width: 200px) { .my-component { /* ... */ } } ``` ### React + container queries ```tsx function Card({ data }) { return (
{data.description}