# ๐ŸŽจ ITAM ์‹œ์Šคํ…œ ๋””์ž์ธ ๊ฐ€์ด๋“œ (Design Guide) ๋ณธ ๋ฌธ์„œ๋Š” ITAM(IT Asset Management System)์˜ ์‹œ๊ฐ์  ์ผ๊ด€์„ฑ๊ณผ ์‚ฌ์šฉ์ž ๊ฒฝํ—˜์„ ์œ ์ง€ํ•˜๊ธฐ ์œ„ํ•œ ํ•ต์‹ฌ ๋””์ž์ธ ์›์น™์„ ์ •์˜ํ•ฉ๋‹ˆ๋‹ค. --- ### 1. ๋””์ž์ธ ์ฒ ํ•™ (Design Philosophy) * **Minimalist & Stark**: Vercel ์Šคํƒ€์ผ์˜ ๊ทน๋„๋กœ ๊ฐ„๊ฒฐํ•˜๊ณ  ํ˜„๋Œ€์ ์ธ ๋””์ž์ธ์„ ์ง€ํ–ฅํ•ฉ๋‹ˆ๋‹ค. * **Achromatic Base**: ๋ธ”๋ž™(#171717)๊ณผ ํ™”์ดํŠธ๋ฅผ ๊ธฐ๋ณธ์œผ๋กœ ํ•˜๋ฉฐ, ์ •๋ณด์˜ ๊ตฌ๋ถ„์€ ์–‡์€ ํ—ค์–ด๋ผ์ธ(#ebebeb)์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. * **Fluid & Responsive**: ๊ณ ์ •๋œ ํ”ฝ์…€ ๋Œ€์‹  ํ™”๋ฉด ํฌ๊ธฐ์— ๋น„๋ก€ํ•˜์—ฌ UI ๋ฐ€๋„๊ฐ€ ๋ณ€ํ•˜๋Š” ์œ ๋™์  ์Šค์ผ€์ผ๋ง ์‹œ์Šคํ…œ์„ ์ ์šฉํ•ฉ๋‹ˆ๋‹ค. ### 2. ๋ฐ˜์‘ํ˜• ์Šค์ผ€์ผ๋ง (Fluid Scaling System) * **Core Principle**: ๋ชจ๋“  UI ์š”์†Œ๋Š” `vmin`๊ณผ `vw` ๋‹จ์œ„๋ฅผ ์กฐํ•ฉํ•œ `clamp()` ํ•จ์ˆ˜๋ฅผ ํ†ตํ•ด ํ™”๋ฉด ํฌ๊ธฐ์— ๋งž์ถฐ ๋™์ ์œผ๋กœ ๋ณ€ํ™”ํ•ฉ๋‹ˆ๋‹ค. * **Typography Scale**: * **XS**: `clamp(10px, 1.2vmin + 0.2vw, 15px)` - ๋ณด์กฐ ํ…์ŠคํŠธ * **SM**: `clamp(12px, 1.4vmin + 0.3vw, 18px)` - ํ•„ํ„ฐ, ์ผ๋ฐ˜ ๋ผ๋ฒจ * **Base**: `clamp(14px, 1.6vmin + 0.4vw, 22px)` - ๋ณธ๋ฌธ, ํ…Œ์ด๋ธ” ๋ฐ์ดํ„ฐ * **MD**: `clamp(18px, 2.5vmin + 0.5vw, 30px)` - ์„น์…˜ ์†Œ์ œ๋ชฉ * **LG**: `clamp(24px, 4vmin + 0.6vw, 48px)` - ํŽ˜์ด์ง€ ๋Œ€์ œ๋ชฉ * **XL**: `clamp(32px, 6vmin + 0.8vw, 72px)` - ํ•ต์‹ฌ ํ†ต๊ณ„ ์ง€ํ‘œ * **Layout Units**: * **Header Height**: `clamp(50px, 8vmin, 90px)` * **Base Spacing**: `clamp(0.75rem, 3vmin, 3rem)` * **Radius**: `clamp(6px, 1.5vmin, 16px)` ### 3. ์ปฌ๋Ÿฌ ํŒ”๋ ˆํŠธ (Vercel Stark Palette) * **Primary**: `#171717` (Stark Black) - ํ…์ŠคํŠธ, ์ฃผ์š” ๋ฒ„ํŠผ, ๊ฐ•์กฐ ์š”์†Œ. * **Secondary**: `#888888` (Mute) - ๋ณด์กฐ ํ…์ŠคํŠธ, ๋น„ํ™œ์„ฑ ์•„์ด์ฝ˜. * **Border**: `#ebebeb` (Hairline) - ์ •๋ณด ๊ตฌ๋ถ„์„ . * **Background**: `#ffffff` (Canvas), `#fafafa` (Soft), `#f5f5f5` (Soft 2). * **Accents**: Blue(`#0070f3`), Orange(`#f5a623`), Danger(`#ee0000`). ### 4. ์ปดํฌ๋„ŒํŠธ ๋ฐ ๋ ˆ์ด์•„์›ƒ ๊ทœ์น™ (Component Rules) * **Header & Navigation**: * ์ƒ๋‹จ 1์—ด ํ†ตํ•ฉ ๋ฐ” ํ˜•ํƒœ๋ฅผ ์œ ์ง€ํ•˜๋ฉฐ, GNB์™€ LNB๋ฅผ ๋™์ผ ๋ผ์ธ์— ๋ฐฐ์น˜ํ•˜์—ฌ ๊ณต๊ฐ„์„ ํšจ์œจ์ ์œผ๋กœ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. * **Unified Filter Bar**: * ๊ฒ€์ƒ‰์ฐฝ๊ณผ ํ•„ํ„ฐ๋Š” ์ƒ๋‹จ ํƒ€์ดํ‹€ ๋ฐ”๋กœ ์•„๋ž˜(๊ธฐ์กด ์•ก์…˜ ๋ฒ„ํŠผ ๋ผ์ธ)๊นŒ์ง€ ์˜ฌ๋ ค์„œ ๋ฐฐ์น˜ํ•ฉ๋‹ˆ๋‹ค. * **Action Group**: '์ž์‚ฐ ์ถ”๊ฐ€', '๋ถ€ํ’ˆ ๋งˆ์Šคํ„ฐ' ๋“ฑ์˜ ์ฃผ์š” ์•ก์…˜ ๋ฒ„ํŠผ์€ ๊ฒ€์ƒ‰์ฐฝ๊ณผ ๊ฐ™์€ ๋ผ์ธ์˜ ์ตœ์šฐ์ธก์— ์ •๋ ฌํ•ฉ๋‹ˆ๋‹ค. * **Dashboard**: * **Single-Screen View**: 1920*1080(๋˜๋Š” 1920*919) ํ•ด์ƒ๋„์—์„œ ์Šคํฌ๋กค ์—†์ด ํ•œ ํ™”๋ฉด์— ํ•ต์‹ฌ ์ •๋ณด๊ฐ€ ๋ชจ๋‘ ๋ณด์ด๋„๋ก ์ตœ์ ํ™”ํ•ฉ๋‹ˆ๋‹ค. * **Fixed Charts**: ์ฐจํŠธ ๋‚ด๋ถ€ ์ˆซ์ž๋‚˜ ์š”์†Œ์— ์• ๋‹ˆ๋ฉ”์ด์…˜(`animation: false`) ๋ฐ ํ”Œ๋กœํŒ… ๋ ˆ์ด๋ธ”์„ ๋ฐฐ์ œํ•˜์—ฌ ์ •์ ์ธ ์•ˆ์ •์„ฑ์„ ํ™•๋ณดํ•ฉ๋‹ˆ๋‹ค. * **Footer**: * ํ™”๋ฉด ์ตœํ•˜๋‹จ์— ์œ„์น˜ํ•˜๋ฉฐ, ํ…์ŠคํŠธ๋Š” **์šฐ์ธก ์ •๋ ฌ(Right-aligned)**ํ•ฉ๋‹ˆ๋‹ค. * ์ƒ๋‹จ์— 1px ํ—ค์–ด๋ผ์ธ ๊ตฌ๋ถ„์„ ์„ ๊ฐ€์ง‘๋‹ˆ๋‹ค. * **Security & UX**: * **Text Selection**: ์‚ฌ์šฉ์ž์˜ ์‹ค์ˆ˜์— ์˜ํ•œ UI ๋“œ๋ž˜๊ทธ ๋ฐฉ์ง€๋ฅผ ์œ„ํ•ด ์ž…๋ ฅ์ฐฝ(`input`, `textarea`)์„ ์ œ์™ธํ•œ ์ „์ฒด ์˜์—ญ์˜ ํ…์ŠคํŠธ ์„ ํƒ์„ ์ฐจ๋‹จํ•ฉ๋‹ˆ๋‹ค. * **View Toggle**: '์„œ๋ฒ„' ํƒญ ๋“ฑ ํŠน์ • ํƒญ์—์„œ๋งŒ '๋ชฉ๋ก๋ณด๊ธฐ' ์ฒดํฌ๋ฐ•์Šค๋ฅผ ํ†ตํ•ด ๋ทฐ๋ฅผ ์ „ํ™˜ํ•˜๋ฉฐ, ๊ทธ ์™ธ ํ™”๋ฉด์€ ๋ฆฌ์ŠคํŠธ ์ค‘์‹ฌ์˜ UI๋ฅผ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.