*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Noto Sans KR,Apple SD Gothic Neo,Malgun Gothic,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:IBM Plex Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{color-scheme:light;--color-page: 243 243 243;--color-surface: 250 250 250;--color-soft: 240 240 240;--color-elevated: 255 255 255;--color-line: 223 223 223;--color-foreground: 42 42 42;--shadow-soft: 0 0 0 / .06;--shadow-card: 0 0 0 / .07}.dark{color-scheme:dark;--color-page: 24 25 28;--color-surface: 31 32 36;--color-soft: 39 40 45;--color-elevated: 35 36 40;--color-line: 71 73 81;--color-foreground: 232 233 236;--shadow-soft: 0 0 0 / .18;--shadow-card: 0 0 0 / .24}*{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;background:rgb(var(--color-page))}body{margin:0;min-height:100vh;font-family:Noto Sans KR,Apple SD Gothic Neo,Malgun Gothic,sans-serif;color:rgb(var(--color-foreground));background:rgb(var(--color-page));line-height:1.6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6,p,figure,ul,ol,dl,blockquote{margin:0}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.container-shell{margin-left:auto;margin-right:auto;width:100%;max-width:1200px;padding-left:1rem;padding-right:1rem}@media (min-width: 768px){.container-shell{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.container-shell{padding-left:1.75rem;padding-right:1.75rem}}.main-shell{padding-bottom:3.5rem;padding-top:80px}@media (min-width: 768px){.main-shell{padding-bottom:72px;padding-top:86px}}.page-card{border-radius:12px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(var(--color-line) / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(var(--color-surface) / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 14px rgb(var(--shadow-soft));--tw-shadow-colored: 0 4px 14px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-shadow-color: rgb(var(--color-soft) / 1);--tw-shadow: var(--tw-shadow-colored)}.btn-pill-dark{display:inline-flex;height:2.5rem;align-items:center;justify-content:center;white-space:nowrap;border-radius:9999px;border-width:1px;padding-left:1.25rem;padding-right:1.25rem;font-size:13px;font-weight:500;line-height:1;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;--tw-border-opacity: 1;border-color:rgb(24 24 27 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(24 24 27 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.dark button.btn-pill-dark{border-color:#d8dade;background-color:#d8dade;color:#18191c}.dark button.btn-pill-dark .text-zinc-200{color:#52525b}.btn-pill-dark:hover{--tw-bg-opacity: 1;background-color:rgb(39 39 42 / var(--tw-bg-opacity, 1))}.btn-pill-soft{display:inline-flex;height:2.5rem;align-items:center;justify-content:center;white-space:nowrap;border-radius:9999px;border-width:1px;padding-left:1.25rem;padding-right:1.25rem;font-size:13px;font-weight:500;line-height:1;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;--tw-border-opacity: 1;border-color:rgb(var(--color-line) / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(var(--color-soft) / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(24 24 27 / var(--tw-text-opacity, 1))}.dark .btn-pill-soft{color:#e8e9ec}.dark .btn-pill-soft:hover{background-color:#303238}.btn-pill-soft:hover{--tw-bg-opacity: 1;background-color:rgb(228 228 231 / var(--tw-bg-opacity, 1))}.kicker{font-size:.75rem;line-height:1rem;text-transform:uppercase;letter-spacing:.08em;--tw-text-opacity: 1;color:rgb(113 113 122 / var(--tw-text-opacity, 1))}.dark .kicker{color:#a6a9b0}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.\!visible{visibility:visible!important}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.right-4{right:1rem}.top-24{top:6rem}.z-50{z-index:50}.z-\[70\]{z-index:70}.order-1{order:1}.order-2{order:2}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-5{margin-top:1.25rem;margin-bottom:1.25rem}.my-7{margin-top:1.75rem;margin-bottom:1.75rem}.my-8{margin-top:2rem;margin-bottom:2rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-2\.5{margin-bottom:.625rem}.mb-3{margin-bottom:.75rem}.mb-3\.5{margin-bottom:.875rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-\[18px\]{margin-bottom:18px}.mb-\[34px\]{margin-bottom:34px}.mr-1\.5{margin-right:.375rem}.mr-5{margin-right:1.25rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-10{margin-top:2.5rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-24{margin-top:6rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:1.75rem}.mt-8{margin-top:2rem}.mt-\[18px\]{margin-top:18px}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-24{height:6rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[120px\]{height:120px}.h-\[22px\]{height:22px}.h-\[26px\]{height:26px}.h-\[300px\]{height:300px}.h-full{height:100%}.min-h-\[104px\]{min-height:104px}.min-h-\[112px\]{min-height:112px}.min-h-\[320px\]{min-height:320px}.min-h-\[70px\]{min-height:70px}.min-h-\[calc\(100vh-240px\)\]{min-height:calc(100vh - 240px)}.w-2\.5{width:.625rem}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-44{width:11rem}.w-8{width:2rem}.w-\[153px\]{width:153px}.w-\[26px\]{width:26px}.w-\[min\(92vw\,360px\)\]{width:min(92vw,360px)}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.min-w-0{min-width:0px}.max-w-\[1080px\]{max-width:1080px}.max-w-\[22ch\]{max-width:22ch}.max-w-\[280px\]{max-width:280px}.max-w-\[30ch\]{max-width:30ch}.max-w-\[420px\]{max-width:420px}.max-w-\[44ch\]{max-width:44ch}.max-w-\[56ch\]{max-width:56ch}.max-w-\[58ch\]{max-width:58ch}.max-w-\[60ch\]{max-width:60ch}.max-w-\[620px\]{max-width:620px}.max-w-\[62ch\]{max-width:62ch}.max-w-\[720px\]{max-width:720px}.max-w-\[900px\]{max-width:900px}.max-w-\[904px\]{max-width:904px}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes panel-reveal{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-panel-reveal{animation:panel-reveal .42s ease both}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes result-pop{0%{opacity:0;transform:translateY(8px) scale(.985)}55%{opacity:1;transform:translateY(-1px) scale(1.004)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-result-pop{animation:result-pop .46s cubic-bezier(.22,.9,.26,1) both}@keyframes step-enter{0%{opacity:0;transform:translateY(6px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-step-enter{animation:step-enter .36s cubic-bezier(.18,.9,.32,1) both}@keyframes toast-slide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.animate-toast-slide{animation:toast-slide .26s ease both}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize-y{resize:vertical}.resize{resize:both}.scroll-mt-\[96px\]{scroll-margin-top:96px}.list-none{list-style-type:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-\[auto_1fr\]{grid-template-columns:auto 1fr}.grid-cols-\[repeat\(auto-fill\,minmax\(220px\,1fr\)\)\]{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.content-center{align-content:center}.content-start{align-content:flex-start}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-items-center{justify-items:center}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-7{gap:1.75rem}.gap-\[18px\]{gap:18px}.gap-x-8{-moz-column-gap:2rem;column-gap:2rem}.gap-y-\[clamp\(28px\,3\.5vw\,52px\)\]{row-gap:clamp(28px,3.5vw,52px)}.self-center{align-self:center}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-\[14px\]{border-radius:14px}.rounded-\[18px\]{border-radius:18px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[var\(--border\)\]{border-color:var(--border)}.border-\[var\(--border-strong\)\]{border-color:var(--border-strong)}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-cyan-200{--tw-border-opacity: 1;border-color:rgb(165 243 252 / var(--tw-border-opacity, 1))}.border-emerald-200{--tw-border-opacity: 1;border-color:rgb(167 243 208 / var(--tw-border-opacity, 1))}.border-line{--tw-border-opacity: 1;border-color:rgb(var(--color-line) / var(--tw-border-opacity, 1))}.border-red-300{--tw-border-opacity: 1;border-color:rgb(252 165 165 / var(--tw-border-opacity, 1))}.border-rose-200{--tw-border-opacity: 1;border-color:rgb(254 205 211 / var(--tw-border-opacity, 1))}.border-violet-200{--tw-border-opacity: 1;border-color:rgb(221 214 254 / var(--tw-border-opacity, 1))}.border-zinc-950{--tw-border-opacity: 1;border-color:rgb(9 9 11 / var(--tw-border-opacity, 1))}.bg-\[var\(--accent\)\]{background-color:var(--accent)}.bg-\[var\(--bg\)\]{background-color:var(--bg)}.bg-\[var\(--surface\)\]{background-color:var(--surface)}.bg-\[var\(--surface-2\)\]{background-color:var(--surface-2)}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-cyan-50{--tw-bg-opacity: 1;background-color:rgb(236 254 255 / var(--tw-bg-opacity, 1))}.bg-emerald-50{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-rose-50{--tw-bg-opacity: 1;background-color:rgb(255 241 242 / var(--tw-bg-opacity, 1))}.bg-soft{--tw-bg-opacity: 1;background-color:rgb(var(--color-soft) / var(--tw-bg-opacity, 1))}.bg-violet-50{--tw-bg-opacity: 1;background-color:rgb(245 243 255 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-zinc-950{--tw-bg-opacity: 1;background-color:rgb(9 9 11 / var(--tw-bg-opacity, 1))}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-3{padding:.75rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-\[clamp\(26px\,3vw\,42px\)\]{padding:clamp(26px,3vw,42px)}.\!py-\[26px\]{padding-top:26px!important;padding-bottom:26px!important}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-\[18px\]{padding-left:18px;padding-right:18px}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-11{padding-top:2.75rem;padding-bottom:2.75rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-7{padding-top:1.75rem;padding-bottom:1.75rem}.py-9{padding-top:2.25rem;padding-bottom:2.25rem}.py-\[26px\]{padding-top:26px;padding-bottom:26px}.pb-1{padding-bottom:.25rem}.pb-14{padding-bottom:3.5rem}.pb-9{padding-bottom:2.25rem}.pb-\[clamp\(28px\,4vw\,48px\)\]{padding-bottom:clamp(28px,4vw,48px)}.pl-5{padding-left:1.25rem}.pr-5{padding-right:1.25rem}.pr-6{padding-right:1.5rem}.pr-\[18px\]{padding-right:18px}.pt-1{padding-top:.25rem}.pt-10{padding-top:2.5rem}.pt-2{padding-top:.5rem}.pt-5{padding-top:1.25rem}.pt-7{padding-top:1.75rem}.pt-8{padding-top:2rem}.pt-\[84px\]{padding-top:84px}.pt-\[clamp\(44px\,7vw\,84px\)\]{padding-top:clamp(44px,7vw,84px)}.pt-px{padding-top:1px}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-serif{font-family:ui-serif,Georgia,Cambria,Times New Roman,Times,serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[0\.62rem\]{font-size:.62rem}.text-\[0\.64rem\]{font-size:.64rem}.text-\[0\.66rem\]{font-size:.66rem}.text-\[0\.68rem\]{font-size:.68rem}.text-\[0\.78rem\]{font-size:.78rem}.text-\[0\.7rem\]{font-size:.7rem}.text-\[0\.82rem\]{font-size:.82rem}.text-\[0\.88rem\]{font-size:.88rem}.text-\[0\.92rem\]{font-size:.92rem}.text-\[0\.95rem\]{font-size:.95rem}.text-\[0\.96rem\]{font-size:.96rem}.text-\[0\.9rem\]{font-size:.9rem}.text-\[1\.02rem\]{font-size:1.02rem}.text-\[1\.05rem\]{font-size:1.05rem}.text-\[1\.12rem\]{font-size:1.12rem}.text-\[1\.15rem\]{font-size:1.15rem}.text-\[1\.18rem\]{font-size:1.18rem}.text-\[1\.25rem\]{font-size:1.25rem}.text-\[1\.2rem\]{font-size:1.2rem}.text-\[1\.35rem\]{font-size:1.35rem}.text-\[1\.7rem\]{font-size:1.7rem}.text-\[1\.85rem\]{font-size:1.85rem}.text-\[11px\]{font-size:11px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[18px\]{font-size:18px}.text-\[2\.1rem\]{font-size:2.1rem}.text-\[22px\]{font-size:22px}.text-\[25px\]{font-size:25px}.text-\[26px\]{font-size:26px}.text-\[30px\]{font-size:30px}.text-\[46px\]{font-size:46px}.text-\[86px\]{font-size:86px}.text-\[clamp\(1\.5rem\,2\.6vw\,2\.1rem\)\]{font-size:clamp(1.5rem,2.6vw,2.1rem)}.text-\[clamp\(1\.6rem\,3\.4vw\,2\.3rem\)\]{font-size:clamp(1.6rem,3.4vw,2.3rem)}.text-\[clamp\(1\.9rem\,4\.4vw\,2\.7rem\)\]{font-size:clamp(1.9rem,4.4vw,2.7rem)}.text-\[clamp\(2\.1rem\,5vw\,3\.2rem\)\]{font-size:clamp(2.1rem,5vw,3.2rem)}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.not-italic{font-style:normal}.leading-\[1\.12\]{line-height:1.12}.leading-\[1\.22\]{line-height:1.22}.leading-\[1\.25\]{line-height:1.25}.leading-\[1\.28\]{line-height:1.28}.leading-\[1\.2\]{line-height:1.2}.leading-\[1\.32\]{line-height:1.32}.leading-\[1\.35\]{line-height:1.35}.leading-\[1\.3\]{line-height:1.3}.leading-\[1\.42\]{line-height:1.42}.leading-\[1\.4\]{line-height:1.4}.leading-\[1\.55\]{line-height:1.55}.leading-\[1\.5\]{line-height:1.5}.leading-\[1\.62\]{line-height:1.62}.leading-\[1\.65\]{line-height:1.65}.leading-\[1\.6\]{line-height:1.6}.leading-\[1\.75\]{line-height:1.75}.leading-\[1\.7\]{line-height:1.7}.leading-\[1\.8\]{line-height:1.8}.leading-none{line-height:1}.leading-normal{line-height:1.5}.leading-tight{line-height:1.25}.tracking-\[-0\.01em\]{letter-spacing:-.01em}.tracking-\[-0\.025em\]{letter-spacing:-.025em}.tracking-\[-0\.02em\]{letter-spacing:-.02em}.tracking-\[-0\.035em\]{letter-spacing:-.035em}.tracking-\[-0\.03em\]{letter-spacing:-.03em}.tracking-\[-0\.04em\]{letter-spacing:-.04em}.tracking-\[-0\.05em\]{letter-spacing:-.05em}.tracking-\[0\.08em\]{letter-spacing:.08em}.text-\[var\(--text\)\]{color:var(--text)}.text-\[var\(--text-dim\)\]{color:var(--text-dim)}.text-\[var\(--text-faint\)\]{color:var(--text-faint)}.text-amber-800{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-cyan-800{--tw-text-opacity: 1;color:rgb(21 94 117 / var(--tw-text-opacity, 1))}.text-emerald-800{--tw-text-opacity: 1;color:rgb(6 95 70 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-rose-800{--tw-text-opacity: 1;color:rgb(159 18 57 / var(--tw-text-opacity, 1))}.text-violet-800{--tw-text-opacity: 1;color:rgb(91 33 182 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-zinc-500{--tw-text-opacity: 1;color:rgb(113 113 122 / var(--tw-text-opacity, 1))}.text-zinc-600{--tw-text-opacity: 1;color:rgb(82 82 91 / var(--tw-text-opacity, 1))}.text-zinc-700{--tw-text-opacity: 1;color:rgb(63 63 70 / var(--tw-text-opacity, 1))}.text-zinc-900{--tw-text-opacity: 1;color:rgb(24 24 27 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.underline-offset-2{text-underline-offset:2px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-soft{--tw-shadow: 0 4px 14px rgb(var(--shadow-soft));--tw-shadow-colored: 0 4px 14px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-shadow-color: rgb(var(--color-soft) / 1);--tw-shadow: var(--tw-shadow-colored)}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[padding-left\]{transition-property:padding-left;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-500{transition-duration:.5s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.will-change-transform{will-change:transform}.\[_https\:\/\/dev\.to\/tassiofront\/barrel-files-and-why-you-should-stop-using-them-now-bc4_\]{_https://dev.to/tassiofront/barrel-files-and-why-you-should-stop-using-them-now-bc4}.\[_https\:\/\/developer\.mozilla\.org\/ko\/docs\/Web\/API\/Window\/requestIdleCallback_\]{_https://developer.mozilla.org/ko/docs/Web/API/Window/requestIdleCallback}.\[_https\:\/\/github\.com\/diegomura\/react-pdf\/issues\/1252_\]{_https://github.com/diegomura/react-pdf/issues/1252}.\[_https\:\/\/github\.com\/diegomura\/react-pdf\/issues\/1884_\]{_https://github.com/diegomura/react-pdf/issues/1884}.\[_https\:\/\/github\.com\/diegomura\/react-pdf\/issues\/2340_\]{_https://github.com/diegomura/react-pdf/issues/2340}.\[_https\:\/\/github\.com\/diegomura\/react-pdf\/issues\/929_\]{_https://github.com/diegomura/react-pdf/issues/929}.\[_https\:\/\/rollupjs\.org\/configuration-options\/\#output-manualchunks_\]{_https://rollupjs.org/configuration-options/#output-manualchunks}.\[_https\:\/\/toss\.tech\/article\/smart-web-service-cache_\]{_https://toss.tech/article/smart-web-service-cache}.\[animation-delay\:140ms\]{animation-delay:.14s}.\[animation-delay\:80ms\]{animation-delay:80ms}.dark .btn-pill-dark{border-color:#d8dade;background:#d8dade;color:#18191c}.dark .btn-pill-dark:hover{background:#e4e6ea}.dark .btn-pill-soft,.dark .text-zinc-950,.dark .text-zinc-900,.dark .text-zinc-800{color:#e8e9ec}.dark .text-zinc-700{color:#d4d6dc}.dark .text-zinc-600,.dark .text-zinc-500{color:#a6a9b0}.dark .text-zinc-400{color:#c2c5cc}.dark .bg-white,.dark .bg-zinc-50,.dark .bg-zinc-100{background-color:rgb(var(--color-elevated))}.dark .bg-zinc-200{background-color:#303238}.dark .border-zinc-200,.dark .border-zinc-300,.dark .border-zinc-400{border-color:rgb(var(--color-line))}.dark .hover\:bg-zinc-50:hover,.dark .hover\:bg-zinc-100:hover,.dark .hover\:bg-zinc-200:hover{background-color:#303238}.dark .hover\:border-zinc-400:hover{border-color:#71717a}.dark .hover\:text-zinc-900:hover,.dark .hover\:text-zinc-950:hover{color:#eeeff2}.dark input,.dark textarea,.dark select{background-color:rgb(var(--color-elevated));color:rgb(var(--color-foreground))}.dark input::-moz-placeholder,.dark textarea::-moz-placeholder{color:#878787}.dark input::placeholder,.dark textarea::placeholder{color:#878787}.dark input:disabled,.dark textarea:disabled,.dark select:disabled{background-color:rgb(var(--color-soft));color:#878787}.dark .tag-rail__button.is-active{border-color:#d8dade;background-color:#d8dade;color:#18191c}.dark .tag-rail__button.is-active span:last-child{color:#3f3f46}.dark button.bg-zinc-900{border-color:#d8dade;background-color:#d8dade;color:#18191c}.dark button.bg-zinc-900 .text-zinc-200{color:#52525b}.dark .theme-inverse{border-color:#d8dade;background-color:#fff;color:#18191c}.dark .theme-inverse:hover{background-color:#f5f5f5}:root{--maxw: 100%;--gutter: clamp(20px, 5.7vw, 104px);--font-sans-ref: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono-ref: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--bg: oklch(.165 .003 255);--surface: oklch(.205 .004 255);--surface-2: oklch(.245 .005 255);--border: oklch(1 0 0 / .1);--border-strong: oklch(1 0 0 / .2);--text: oklch(.965 .003 255);--text-dim: oklch(.74 .005 255);--text-faint: oklch(.56 .006 255);--accent: var(--text);--on-accent: var(--bg);--shadow: 0 1px 2px oklch(0 0 0 / .4), 0 12px 32px oklch(0 0 0 / .32);--placeholder-a: oklch(.26 .005 255);--placeholder-b: oklch(.3 .006 255)}:root,[data-theme=dark]{color-scheme:dark}[data-theme=light]{--bg: oklch(.985 .0015 255);--surface: oklch(1 0 0);--surface-2: oklch(.965 .002 255);--border: oklch(0 0 0 / .1);--border-strong: oklch(0 0 0 / .22);--text: oklch(.205 .004 255);--text-dim: oklch(.42 .005 255);--text-faint: oklch(.58 .006 255);--accent: var(--text);--on-accent: oklch(1 0 0);--shadow: 0 1px 2px oklch(0 0 0 / .05), 0 14px 30px oklch(0 0 0 / .08);--placeholder-a: oklch(.93 .003 255);--placeholder-b: oklch(.89 .004 255);color-scheme:light}html{background:var(--bg)}body{background-color:var(--bg);color:var(--text);font-family:var(--font-sans-ref);letter-spacing:-.01em;word-break:keep-all}::-moz-selection{background:var(--accent);color:var(--on-accent)}::selection{background:var(--accent);color:var(--on-accent)}.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}.mono{font-family:var(--font-mono-ref);font-size:.72rem;letter-spacing:.04em;font-variant-numeric:tabular-nums;color:var(--text-faint)}.eyebrow{font-family:var(--font-mono-ref);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);white-space:nowrap}.pill{display:inline-flex;align-items:center;gap:.4em;min-height:26px;padding:0 11px;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text-dim);font-family:var(--font-mono-ref);font-size:.7rem;letter-spacing:.02em;line-height:1;white-space:nowrap;cursor:pointer;transition:border-color .2s,color .2s,background .2s}.pill:hover{border-color:var(--border-strong);color:var(--text)}.pill[data-active=true]{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.rule{height:1px;margin:0;border:0;background:var(--border)}.ph{position:relative;display:grid;place-items:center;overflow:hidden;border:1px solid var(--border);background:repeating-linear-gradient(135deg,var(--placeholder-a) 0 10px,var(--placeholder-b) 10px 20px)}.ph:after{content:attr(data-label);padding:3px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text-faint);font-family:var(--font-mono-ref);font-size:.68rem;letter-spacing:.04em}.ph--silent:after{display:none}.site-header{position:sticky;top:0;z-index:50;border-bottom:1px solid var(--border);background:color-mix(in oklab,var(--bg) 82%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.site-header__inner{height:64px;display:flex;align-items:center;gap:24px}.site-header__brand{display:flex;align-items:baseline;gap:9px;flex-shrink:0;font-weight:700;letter-spacing:-.02em;white-space:nowrap}.site-header__nav{margin-left:auto;display:flex;align-items:center;gap:4px;flex-shrink:0}.site-header__link{position:relative;padding:8px 12px;color:var(--text-dim);font-size:.92rem;font-weight:500;white-space:nowrap;transition:color .2s}.site-header__link:hover,.site-header__link[data-active=true]{color:var(--text)}.site-header__link[data-active=true]:after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:2px;border-radius:2px;background:var(--accent)}.icon-button{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text-dim);transition:border-color .2s,color .2s}.icon-button:hover{border-color:var(--border-strong);color:var(--text)}.site-main{min-height:calc(100vh - 64px)}.section-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:8px}.section-title{margin:0;color:var(--text);font-size:1.35rem;font-weight:700;letter-spacing:-.025em;line-height:1.25}.focus-row{display:flex;flex-wrap:wrap;gap:8px}.focus-chip{padding:5px 10px;border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-family:var(--font-mono-ref);font-size:.7rem;letter-spacing:.04em;white-space:nowrap}.feat-card{display:grid;grid-template-columns:1.15fr 1fr;gap:0;overflow:hidden;border:1px solid var(--border);border-radius:20px;background:var(--surface);transition:border-color .25s,transform .25s}.feat-card:hover{border-color:var(--border-strong)}.featured-image,.post-card-image,.project-image,.post-cover,.project-cover{display:block;width:100%;border:1px solid var(--border);background:var(--surface);-o-object-fit:cover;object-fit:cover}.featured-image{height:100%;min-height:clamp(420px,38vw,560px);border-width:0 1px 0 0;border-color:var(--border)}.feat-card>.ph{min-height:clamp(420px,38vw,560px)}.post-card-image{aspect-ratio:16 / 10}.project-image{aspect-ratio:4 / 3}.post-cover{aspect-ratio:16 / 8}.project-cover{aspect-ratio:16 / 7}.post-row{display:grid;grid-template-columns:92px 1fr auto;gap:0 24px;align-items:baseline;padding:22px 8px;border-radius:12px;transition:background .2s}.post-row:hover{background:var(--surface)}.post-card{display:flex;flex-direction:column;gap:16px}.post-title{color:var(--text)}.project-card{display:grid;grid-template-columns:minmax(0,1fr) 200px;gap:28px;align-items:center;padding:28px 4px;border-top:1px solid var(--border);transition:padding-left .25s ease}.project-card:hover{padding-left:16px}.project-card:hover .pj-arrow{transform:translate(4px)}.tag-card:hover,.tag-card[data-active=true]{padding-left:10px}.pj-arrow{color:var(--text-faint);transition:transform .25s ease}.saju-card{border:1px solid var(--border);border-radius:20px;background:var(--surface);box-shadow:var(--shadow)}.saju-card--active{border-color:var(--border-strong)}.saju-choice{display:block;width:100%;border:1px solid var(--border);border-radius:12px;background:transparent;color:var(--text-dim);transition:border-color .2s,background .2s,color .2s,transform .2s}.saju-choice:hover{border-color:var(--border-strong);background:var(--surface-2);color:var(--text)}.saju-choice[data-active=true]{border-color:var(--accent);background:var(--accent);color:var(--on-accent)}.saju-choice:disabled{cursor:not-allowed;opacity:.6}.saju-input{width:100%;min-width:0;height:44px;border:1px solid var(--border);border-radius:8px;background:var(--bg);padding:0 12px;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s,background .2s}.saju-input:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 14%,transparent)}.saju-input::-moz-placeholder{color:var(--text-faint)}.saju-input::placeholder{color:var(--text-faint)}.saju-input:disabled{cursor:not-allowed;background:var(--surface-2);color:var(--text-faint)}.saju-segment{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);padding:4px}.saju-segment__button{min-width:0;border-radius:8px;padding:9px 12px;color:var(--text-dim);font-size:.875rem;font-weight:600;transition:background .2s,color .2s}.saju-segment__button:hover{color:var(--text)}.saju-segment__button[data-active=true]{background:var(--accent);color:var(--on-accent)}.saju-segment__button:disabled{cursor:not-allowed;opacity:.6}.saju-status{flex-shrink:0;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);padding:4px 10px;color:var(--text-faint);font-size:.75rem;font-weight:600;white-space:nowrap}.saju-status--done{border-color:var(--accent);background:var(--accent);color:var(--on-accent)}.saju-summary-row{display:grid;gap:4px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);padding:10px 12px}.saju-summary-row dt{color:var(--text-faint);font-size:.75rem;font-weight:600}.saju-summary-row dd{color:var(--text);font-size:.9rem;font-weight:600}.page-head{padding:clamp(48px,7vw,88px) 0 clamp(28px,3vw,40px)}.page-head h1{margin:0;color:var(--text);font-size:clamp(2rem,4.4vw,3rem);font-weight:700;letter-spacing:-.04em;line-height:1.15}.page-head p{max-width:56ch;margin:20px 0 0;color:var(--text-dim);font-size:1.05rem;line-height:1.7}.flow-row{display:grid;grid-template-columns:minmax(0,160px) minmax(0,1fr);gap:clamp(16px,4vw,56px);padding:44px 0;border-top:1px solid var(--border)}.metric-3{display:grid;grid-template-columns:repeat(3,1fr);gap:0}.result-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,2fr) minmax(0,1.2fr);align-items:center;gap:16px;padding:16px 20px}.article-body{color:var(--text);font-size:1rem;line-height:1.82}.article-body h1,.article-body h2,.article-body h3{margin:2.1em 0 .65em;color:var(--text);font-weight:700;letter-spacing:-.035em;line-height:1.25}.article-body h2{font-size:1.65rem}.article-body h3{font-size:1.3rem}.article-body p,.article-body ul,.article-body ol,.article-body blockquote,.article-body pre{margin:0 0 1.2em}.article-body a{border-bottom:1px solid var(--border-strong);color:var(--text)}.article-body blockquote{border-left:2px solid var(--border-strong);padding-left:16px;color:var(--text-dim)}.article-body code{font-family:var(--font-mono-ref)}.article-body :not(pre)>code{border:1px solid var(--border);border-radius:5px;background:var(--surface);padding:2px 5px;color:var(--text-dim);font-size:.9em}.article-body pre{overflow-x:auto;border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:18px}.article-body table{display:block;width:-moz-max-content;width:max-content;max-width:100%;margin:0 0 1.2em;overflow-x:auto;border-collapse:collapse;font-size:.9rem;line-height:1.55}.article-body thead{background:var(--surface)}.article-body th,.article-body td{border:1px solid var(--border);padding:10px 12px;text-align:left;vertical-align:top}.article-body img{margin:28px auto;border-radius:16px}@media (prefers-reduced-motion: no-preference){.rise{animation:rise .6s cubic-bezier(.22,1,.36,1) both}@keyframes rise{0%{transform:translateY(12px)}to{transform:none}}}@media (max-width: 880px){.hero-editorial>div{grid-template-columns:1fr!important;gap:40px!important}.grid-2,.feat-card{grid-template-columns:1fr!important}.feat-card>.ph,.feat-card>.featured-image{min-height:clamp(300px,70vw,420px)!important;border-right:0!important;border-bottom:1px solid var(--border)!important}.project-card{grid-template-columns:1fr!important}.project-card>.ph{display:none!important}.flow-row{grid-template-columns:1fr!important;gap:8px!important}.flow-row>div:first-child h2{font-size:1.15rem!important}}@media (max-width: 560px){:root{--gutter: 18px}.metric-3{grid-template-columns:1fr 1fr!important}.result-row{grid-template-columns:1fr!important;gap:4px!important;padding:14px 16px!important}.result-row>:last-child{text-align:left!important}.hd-sub,.hd-github{display:none!important}.site-header__nav{gap:0!important}.site-header__link{padding:8px 9px!important;font-size:.85rem!important}.post-row{grid-template-columns:70px 1fr!important}.post-row>.mono:last-child{display:none!important}}.dark .theme-inverse .theme-inverse-text{color:#18191c}.dark .theme-inverse .theme-inverse-muted{color:#52525b}.home-principle-card{background-color:#fcfbf8}.dark .home-principle-card{border-color:#ffffffeb;background-color:#fff;box-shadow:0 8px 24px #00000038}.dark .home-principle-card h3{color:#18181b}.dark .home-principle-card p{color:#52525b}.dark .article-body{color:#d4d6dc}.dark .article-body h1,.dark .article-body h2,.dark .article-body h3,.dark .article-body h4,.dark .article-body h5,.dark .article-body h6{color:#e8e9ec}.dark .article-body h2,.dark .article-body hr{border-color:rgb(var(--color-line))}.dark .article-body a{color:#e8e9ec;border-color:#878787}.dark .article-body a:hover{border-color:#d8dade}.dark .article-body blockquote{border-color:#71717a;background-color:rgb(var(--color-soft));color:#c2c5cc}.dark .article-body :not(pre)>code{border-color:rgb(var(--color-line));background-color:rgb(var(--color-soft));color:#e8e9ec}.dark .article-body thead{background-color:rgb(var(--color-soft))}.dark .article-body th,.dark .article-body td{border-color:rgb(var(--color-line))}.dark .article-body .table-scroll,.dark .article-body .article-video,.dark .article-body .article-link-card,.dark .article-body .article-mermaid{border-color:rgb(var(--color-line));background-color:rgb(var(--color-elevated))}.dark .article-body .article-link-card{color:#e8e9ec}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-\[var\(--border-strong\)\]:hover{border-color:var(--border-strong)}.hover\:border-zinc-400:hover{--tw-border-opacity: 1;border-color:rgb(161 161 170 / var(--tw-border-opacity, 1))}.hover\:bg-zinc-200:hover{--tw-bg-opacity: 1;background-color:rgb(228 228 231 / var(--tw-bg-opacity, 1))}.hover\:\!text-\[var\(--text\)\]:hover{color:var(--text)!important}.hover\:text-\[var\(--text\)\]:hover{color:var(--text)}.hover\:text-zinc-900:hover{--tw-text-opacity: 1;color:rgb(24 24 27 / var(--tw-text-opacity, 1))}.hover\:opacity-60:hover{opacity:.6}.focus\:ring-zinc-900\/20:focus{--tw-ring-color: rgb(24 24 27 / .2)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-60:disabled{opacity:.6}.dark\:border-red-300\/40:is(.dark *){border-color:#fca5a566}.dark\:bg-red-950\/30:is(.dark *){background-color:#450a0a4d}.dark\:text-red-200:is(.dark *){--tw-text-opacity: 1;color:rgb(254 202 202 / var(--tw-text-opacity, 1))}.dark\:text-red-300:is(.dark *){--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.sm\:h-\[340px\]{height:340px}.sm\:w-auto{width:auto}.sm\:w-fit{width:-moz-fit-content;width:fit-content}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-center{justify-content:center}.sm\:gap-3{gap:.75rem}}@media (min-width: 768px){.md\:order-1{order:1}.md\:order-2{order:2}.md\:h-\[460px\]{height:460px}.md\:min-h-\[calc\(100vh-280px\)\]{min-height:calc(100vh - 280px)}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-\[1fr_auto\]{grid-template-columns:1fr auto}.md\:grid-cols-\[220px_1fr\]{grid-template-columns:220px 1fr}.md\:grid-cols-\[minmax\(260px\,320px\)_1fr\]{grid-template-columns:minmax(260px,320px) 1fr}.md\:flex-row{flex-direction:row}.md\:items-start{align-items:flex-start}.md\:items-end{align-items:flex-end}.md\:justify-between{justify-content:space-between}.md\:gap-4{gap:1rem}.md\:gap-5{gap:1.25rem}.md\:p-4{padding:1rem}.md\:p-7{padding:1.75rem}.md\:px-7{padding-left:1.75rem;padding-right:1.75rem}.md\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.md\:py-7{padding-top:1.75rem;padding-bottom:1.75rem}.md\:text-\[13px\]{font-size:13px}.md\:text-\[15px\]{font-size:15px}.md\:text-\[164px\]{font-size:164px}.md\:text-\[16px\]{font-size:16px}.md\:text-\[20px\]{font-size:20px}.md\:text-\[22px\]{font-size:22px}.md\:text-\[30px\]{font-size:30px}.md\:text-\[44px\]{font-size:44px}.md\:text-base{font-size:1rem;line-height:1.5rem}}
