--- id: wiki-2026-0508-컨테이너-쿼리-container-queries title: 컨테이너 쿼리 (Container Queries) category: 10_Wiki/Topics status: verified canonical_id: self aliases: [Container Queries, CSS Container Query, "@container"] duplicate_of: none source_trust_level: A confidence_score: 0.95 verification_status: applied tags: [frontend, css, responsive-design, container-queries] raw_sources: [] last_reinforced: 2026-05-10 github_commit: pending tech_stack: language: css framework: none --- # 컨테이너 쿼리 (Container Queries) ## 매 한 줄 > **"매 element 가 매 viewport 가 아니라 매 자기 부모 container 의 크기 에 반응"**. 매 2023 Baseline 진입 후 매 2026 production-ready — Chrome / Safari / Firefox 모두 stable. 매 반응형 CSS 의 매 패러다임 전환 — component 가 매 자기 context 에 매 self-aware. ## 매 핵심 ### 매 Media Query 와 의 차이 - **Media query**: viewport (window) 기준. 매 component 위치 모름. - **Container query**: 부모 element 기준. 매 sidebar 안에서도, main 안에서도 매 적절히 동작. ### 매 Container 종류 - **size container** (`container-type: size` / `inline-size`): 매 width / height 기준. - **style container** (`container-type: style`): 매 부모 의 custom property 값 기준 (실험적). - **scroll-state container**: 매 scroll position 기준 (Chrome 124+). ### 매 단위 - `cqw`, `cqh`, `cqi` (inline), `cqb` (block), `cqmin`, `cqmax` — 매 container 기준 단위. ### 매 응용 1. Card component — sidebar / grid / hero 어디서나. 2. Design system component (Button, Modal). 3. Email-style nested layout. ## 💻 패턴 ### 기본 container query ```css .card-container { container-type: inline-size; container-name: card; } .card { display: grid; grid-template-columns: 1fr; gap: 1rem; } @container card (min-width: 30rem) { .card { grid-template-columns: 200px 1fr; } } @container card (min-width: 50rem) { .card { grid-template-columns: 200px 1fr 1fr; } } ``` ### Container query units (cqi) ```css .card-container { container-type: inline-size; } .card__title { font-size: clamp(1rem, 4cqi, 2rem); /* 매 container width 기반 fluid type */ } ``` ### Tailwind 4 (built-in) ```html