@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5901b7c6-module__ec5Qua__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_5901b7c6-module__ec5Qua__variable{--font-inter:"Inter", "Inter Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.0s19wthhh_6~m.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.0dza.stei.9v7.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.03nf~dfjdkf~..woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.0gfhww.tctz1o.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.09q3q1i5159bl.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.1409xf.ylxg8g.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_707233f-module__9hS9bG__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_707233f-module__9hS9bG__variable{--font-jetbrains-mono:"JetBrains Mono", "JetBrains Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-sky-400:#00bcfe;--color-sky-500:#00a5ef;--color-sky-600:#0084cc;--color-slate-200:#e2e8f0;--spacing:.25rem;--font-weight-bold:700;--radius-md:.375rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-sky-400:lab(70.687% -23.6078 -45.9483);--color-sky-500:lab(63.3038% -18.433 -51.0407);--color-sky-600:lab(51.7754% -11.4712 -49.8349);--color-slate-200:lab(91.7353% -.998765 -4.76968)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.z-10{z-index:10}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.flex{display:flex}.hidden{display:none}.h-\[40px\]{height:40px}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-\[2px\]{width:2px}.w-\[6px\]{width:6px}.w-full{width:100%}.origin-top{transform-origin:top}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-\[var\(--bg-primary\)\]{background-color:var(--bg-primary)}.bg-sky-400{background-color:var(--color-sky-400)}.bg-sky-500{background-color:var(--color-sky-500)}.bg-slate-200{background-color:var(--color-slate-200)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.text-\[var\(--text-main\)\]{color:var(--text-main)}.text-sky-600{color:var(--color-sky-600)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-20{opacity:.2}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--text-main:#1e293b;--text-muted:#64748b;--accent:#0ea5e9;--accent-light:#0ea5e91a;--border-color:#e2e8f0;--shadow-sm:0 4px 6px -1px #0000000d;--shadow-lg:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--font-main:"Pretendard", "Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-main);position:relative;overflow-x:hidden}.bg-grid,.bg-circuit{pointer-events:none;z-index:0;position:fixed;inset:0}.bg-grid{background-color:#0000;background-image:linear-gradient(#0ea5e90a 1px,#0000 1px),linear-gradient(90deg,#0ea5e90a 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:70px 70px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box}.bg-circuit{opacity:.8;background:radial-gradient(circle at 18% 26%,#0ea5e908 0 3px,#0000 4px),radial-gradient(circle at 74% 62%,#0ea5e908 0 3px,#0000 4px),linear-gradient(120deg,#0000 0 48%,#0ea5e905 50%,#0000 52%),linear-gradient(35deg,#0000 0 65%,#0ea5e905 66%,#0000 67%)}.ambient-orb{filter:blur(80px);z-index:-1;pointer-events:none;opacity:.5;will-change:transform;border-radius:50%;animation:20s ease-in-out infinite alternate float-orb;position:fixed}.orb-1{background:#0ea5e926;width:400px;height:400px;bottom:-100px;left:-100px}.orb-2{background:#38bdf81f;width:500px;height:500px;animation-duration:25s;top:10%;right:-150px}.orb-3{background:#bae6fd33;width:300px;height:300px;animation-duration:18s;animation-delay:-5s;top:40%;left:30%}@keyframes float-orb{0%{transform:translate(0)scale(1)}50%{transform:translate(50px,-30px)scale(1.1)}to{transform:translate(-30px,50px)scale(.9)}}.page{z-index:2;max-width:1160px;margin:0 auto;padding:0 20px 120px;position:relative}.intro{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:80px 20px;display:flex}.intro-glass{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;text-align:center;background:0 0;border:none;flex-direction:column;align-items:center;display:flex}.eyebrow{color:var(--text-main);background:#fff;border:1px solid #0000000d;border-radius:100px;align-items:center;gap:10px;margin-bottom:24px;padding:8px 20px;font-size:.95rem;font-weight:600;display:inline-flex;box-shadow:0 4px 12px #0000000d}.status-dot-blink{background-color:#22c55e;border-radius:50%;width:10px;height:10px;animation:1.5s ease-in-out infinite bg-blink;box-shadow:0 0 10px #22c55e99}@keyframes bg-blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.85)}}.intro h1{color:#111;letter-spacing:-.02em;margin:0;font-weight:900;font-size:clamp(3rem,10vw,5.5rem)!important}.intro-copy{color:var(--text-muted);max-width:600px;margin:20px 0 0;font-size:clamp(1.1rem,2vw,1.4rem)}.module-field{align-items:center;gap:24px;padding-left:4px;display:flex}.module-cube{width:64px;height:64px;transform-style:preserve-3d;background:linear-gradient(135deg,#ffffffe6,#0ea5e914);border:1px solid #0ea5e94d;animation:12s linear infinite rotate-cube;box-shadow:0 0 24px #0ea5e91a,inset 0 0 24px #0ea5e90d}.module-cube.m2{width:46px;height:46px;animation-duration:9s;animation-direction:reverse}.module-node{background:radial-gradient(circle at 30% 30%, #7dd3fc, var(--accent) 70%, #0284c7);border-radius:999px;animation:4.8s ease-in-out infinite pulse-node;box-shadow:0 0 20px #0ea5e933}.module-node.n1{width:18px;height:18px}.module-node.n2{width:26px;height:26px;animation-delay:.7s}.projects{padding-top:18px;position:relative}.section-head h2{letter-spacing:.04em;text-transform:uppercase;color:var(--text-main);margin:0;font-size:clamp(1.2rem,2.2vw,1.9rem)}.section-head p{color:var(--text-muted);margin:10px 0 0;font-size:.9rem}.tab-group{border-bottom:1px solid var(--border-color);gap:32px;margin-bottom:48px;padding-bottom:2px;display:flex}.tab-btn{letter-spacing:.1em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:12px 4px;font-size:.9rem;font-weight:700;transition:color .3s;position:relative}.tab-btn:hover,.tab-btn.active{color:var(--text-main)}.tab-underline{background:var(--text-main);z-index:1;height:2px;position:absolute;bottom:-2px;left:0;right:0}.prototype-placeholder{border:1px dashed var(--border-color);background:#00000005;border-radius:32px;justify-content:center;align-items:center;min-height:400px;display:flex}.placeholder-content{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.placeholder-content .status-dot-blink{margin-bottom:8px}.placeholder-content h3{color:var(--text-main);margin:0;font-size:1.5rem;font-weight:800}.placeholder-content p{color:var(--text-muted);max-width:300px;line-height:1.6}.project-rail{gap:34px;margin-top:26px;display:grid}.project-card{border:1px solid var(--border-color);background:var(--bg-secondary);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-sm);opacity:0;cursor:pointer;border-radius:32px;padding:clamp(30px,5vw,48px);transition:transform .8s cubic-bezier(.2,.8,.2,1),opacity .8s,border-color .4s,box-shadow .4s;position:relative;overflow:visible;transform:translateY(60px)scale(.92)}.project-header{z-index:5;align-items:center;gap:32px;margin-bottom:4px;display:flex;position:relative}.project-info-stack{flex-direction:column;gap:8px;padding-top:14px;display:flex}.card-bg-number{color:#00000014;pointer-events:none;letter-spacing:-.05em;font-size:8rem;font-weight:900;line-height:1}.project-status-pill{color:#fff;background:#111;border-radius:100px;align-items:center;gap:8px;width:fit-content;padding:6px 14px;font-size:.78rem;font-weight:700;display:inline-flex}.project-kind{color:var(--accent);letter-spacing:.1rem;text-transform:uppercase;opacity:.8;font-size:.75rem;font-weight:700}.project-top-spacing{height:12px}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.in-progress{background:#22c55e;box-shadow:0 0 8px #22c55ecc}.status-dot.completed{background:#94a3b8}.project-card:before{content:"";background:radial-gradient(800px circle at var(--mouse-x,50%) var(--mouse-y,50%), #0ea5e91a, transparent 40%);z-index:0;pointer-events:none;opacity:0;transition:opacity .5s;position:absolute;inset:0}.project-card:hover:before{opacity:1}.project-card>*{z-index:1;position:relative}.project-card:hover{box-shadow:var(--shadow-lg);border-color:#0ea5e966;transform:translateY(-5px)}.project-card.in-view{opacity:1;transform:translateY(0)scale(1)}.project-card h3{letter-spacing:.01em;color:var(--text-main);z-index:2;margin:12px 0 0;font-size:clamp(1.1rem,2.3vw,1.8rem);position:relative}.project-summary{color:var(--text-muted);margin:14px 0 0;font-size:.9rem;line-height:1.75}.stack-wrap{flex-wrap:wrap;gap:9px;margin-top:18px;display:flex}.stack-chip{background:var(--accent-light);color:#0284c7;letter-spacing:.03em;border:1px solid #0ea5e933;border-radius:999px;padding:7px 12px;font-size:.75rem;font-weight:600}.project-points{color:var(--text-muted);margin:16px 0 0;padding-left:18px;font-size:.86rem;line-height:1.65}.project-links{gap:10px;margin-top:16px;display:flex}.project-link{color:var(--text-main);border:1px solid var(--border-color);border-radius:10px;padding:8px 12px;font-size:.78rem;font-weight:600;text-decoration:none;transition:all .2s}.project-link:hover{color:#fff;background:var(--accent);border-color:var(--accent)}.scroll-timeline{z-index:1;background:#0ea5e91a;border-radius:6px;width:6px;height:min(400px,60vh);position:fixed;top:50%;left:24px;overflow:hidden;transform:translateY(-50%);box-shadow:inset 0 2px 4px #0000000d}.timeline-fill{background:var(--accent);transform-origin:top;will-change:transform;border-radius:6px;width:100%;height:100%;position:absolute;top:0;left:0;box-shadow:0 0 10px #0ea5e966}.glass-shape{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:-1;width:250px;height:250px;margin-top:calc((var(--scroll-shift,0px) * -.15) + (var(--detail-scroll-global,0) * -.15px));background:linear-gradient(135deg,#fff6,#ffffff0d);border:1px solid #0ea5e926;border-radius:40px;justify-content:center;align-items:center;animation:25s linear infinite float-shape;display:flex;position:fixed;box-shadow:0 20px 40px #0000000d,inset 0 0 20px #fff3}.glass-shape span{color:#0ea5e91a;font-family:JetBrains Mono,monospace;font-size:5rem;font-weight:800}.shape-1{animation-duration:35s;top:15%;right:8%;transform:rotate(15deg)}.shape-2{width:180px;height:180px;animation-duration:45s;animation-direction:reverse;bottom:10%;left:-2%}.shape-2 span{font-size:3.5rem}.shape-3{width:120px;height:120px;animation-duration:25s;top:55%;right:25%}.shape-3 span{font-size:2.5rem}@keyframes float-shape{0%{transform:translateY(0)rotate(0)}33%{transform:translateY(-40px)rotate(120deg)}66%{transform:translateY(40px)rotate(240deg)}to{transform:translateY(0)rotate(360deg)}}.page-element{transition:transform .8s cubic-bezier(.2,.8,.2,1),opacity .6s}.scatter-out{pointer-events:none;opacity:0!important}.detail-view{z-index:50;background:var(--bg-primary);visibility:hidden;opacity:0;pointer-events:none;scroll-behavior:smooth;padding:0 40px;transition:opacity .5s .2s,visibility .5s .2s;display:block;position:fixed;inset:0;overflow-y:auto}.detail-view.active{visibility:visible;opacity:1;pointer-events:auto;transition:opacity .5s,visibility .5s}.detail-header{opacity:0;z-index:60;background:var(--bg-primary);margin-bottom:20px;padding:40px 0 20px;transition:transform .6s cubic-bezier(.2,.8,.2,1) .3s,opacity .6s .3s;position:sticky;top:0;transform:translateY(-50px)}.detail-content{width:100%;max-width:1400px;margin:0 auto}.detail-desc-area{text-align:center;will-change:transform, opacity;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:900px;min-height:90vh;margin:0 auto;padding:80px 0;display:flex}.detail-desc-area>*{opacity:0;transition:transform .6s cubic-bezier(.2,.8,.2,1),opacity .6s;transform:translateY(40px)}.detail-view.active .detail-header{opacity:1;transform:translateY(0)}.detail-view.active .detail-desc-area h2{transition-delay:.3s}.detail-view.active .detail-desc-area p{transition-delay:.45s}.detail-view.active .detail-desc-area .action-btn{transition-delay:.6s}.detail-view.active .detail-desc-area>*{opacity:1;transform:translateY(0)}.detail-desc-area h2{letter-spacing:-.02em;color:var(--text-main);max-width:25ch;margin:20px 0 30px;font-size:clamp(2.5rem,6vw,3.5rem);font-weight:800;line-height:1.15}.detail-desc-area p{color:var(--text-muted);word-break:keep-all;overflow-wrap:break-word;max-width:65ch;margin:0 auto 40px;font-size:clamp(1.05rem,1.5vw,1.5rem);line-height:1.8}.detail-eyebrow{color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin:0;font-size:.9rem;font-weight:700}.project-points-list{text-align:left;flex-direction:column;gap:10px;margin-top:20px;display:flex}.point-item{color:var(--text-muted);align-items:flex-start;gap:10px;font-size:.95rem;line-height:1.6;display:flex}.point-icon{color:var(--accent);flex-shrink:0;font-size:.9rem;font-weight:700}.action-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:12px;padding:14px 28px;font-size:1.05rem;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 10px 20px #0ea5e933}.action-btn:after{content:"↓";font-family:monospace;font-size:1.2rem;animation:2s infinite bounce-y}.action-btn:hover{background:#0284c7;transform:translateY(-2px);box-shadow:0 15px 25px #0ea5e94d}@keyframes bounce-y{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.detail-mindmap-area{align-items:center;width:100%;min-height:100vh;padding-bottom:80px;display:flex}.mind-map{contain:layout style;align-items:center;gap:0;padding:40px;display:flex}.mm-branch-area{flex-shrink:0;align-items:center;display:flex;position:relative}.mm-stem{background:#0ea5e933;border-radius:2px;flex-shrink:0;width:40px;height:3px;position:relative;overflow:hidden}.mm-node-col.with-spine{flex-direction:column;flex-shrink:0;gap:16px;padding-left:40px;display:flex;position:relative}.mm-spine{background:#0ea5e933;border-radius:2px;width:3px;position:absolute;top:24px;bottom:24px;left:0}.mm-branch-row{align-items:center;display:flex;position:relative}.mm-rib-line{z-index:1;background:#0ea5e933;border-radius:2px;width:40px;height:3px;position:absolute;left:-40px;overflow:hidden}.mm-dataflow-particle{filter:blur(2px);will-change:left;background:#38bdf8cc;border-radius:2px;width:16px;height:100%;position:absolute;top:0}.mm-node-main{text-align:center;min-width:140px;color:var(--text-main);box-shadow:0 8px 25px #0ea5e91f, inset 0 0 0 2px var(--accent-light);z-index:2;background:#fff;border-radius:50px;flex-shrink:0;padding:18px 28px;font-size:1.15rem;font-weight:800;transition:box-shadow .3s;position:relative}.mm-node-main.mm-main-glow{box-shadow:0 12px 35px #0ea5e940, inset 0 0 0 2px var(--accent)}.mm-node-cat{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-align:center;min-width:200px;color:var(--text-muted);cursor:pointer;z-index:2;background:#ffffffb3;border:1px solid #0ea5e933;border-radius:30px;padding:13px 20px;font-size:.92rem;font-weight:600;transition:all .25s cubic-bezier(.2,.8,.2,1);position:relative}.mm-node-cat:hover{color:var(--text-main);background:#fff;border-color:#0ea5e980}.mm-node-cat.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 6px 18px #0ea5e94d}.mm-node-cat.mm-cat-highlighted{background:var(--accent);color:#fff;box-shadow:0 6px 22px #0ea5e959}.mm-node-cat.mm-cat-dimmed{opacity:.3;filter:blur(1px)}.mm-node-detail{border-left:4px solid var(--accent);z-index:2;opacity:0;transform-origin:0;background:#fff;border-radius:0 14px 14px 0;flex-direction:column;width:340px;padding:18px 22px;transition:box-shadow .25s,transform .25s,opacity .25s;animation:.4s cubic-bezier(.175,.885,.32,1.1) forwards popInDetail;display:flex;position:relative;box-shadow:0 6px 20px #0000000f}.mm-node-detail h4{color:var(--text-main);font-size:.95rem;font-family:var(--font-main);letter-spacing:-.02em;margin:0 0 8px}.mm-node-detail p{color:var(--text-muted);flex-grow:1;margin:0 0 6px;font-size:.85rem;line-height:1.6}.mm-detail-highlighted{border-left-color:#0ea5e9;transform:scale(1.02);box-shadow:0 12px 35px #0ea5e926}.mm-detail-dimmed{opacity:.3;filter:grayscale(.3)}.mm-impact-badge{color:var(--accent);white-space:nowrap;background:#0ea5e914;border:1px solid #0ea5e91f;border-radius:20px;flex-shrink:0;margin-left:8px;padding:2px 9px;font-size:10px;font-weight:700}.mm-node-link{color:#fff;background:#12b886;border-radius:8px;align-items:center;gap:8px;width:fit-content;margin-top:6px;padding:9px 18px;font-size:.82rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 3px 12px #12b88633}.mm-node-link:hover{color:#fff;background:#0ca678;transform:translateY(-1px);box-shadow:0 5px 18px #12b8864d}.mm-node-link svg{flex-shrink:0;transition:transform .25s}.mm-node-link:hover svg{transform:scale(1.15)rotate(-8deg)}@keyframes connector-pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes popInDetail{0%{opacity:0;filter:blur(4px);transform:scale(.9)translate(-15px)}to{opacity:1;filter:blur();transform:scale(1)translate(0)}}@keyframes rotate-cube{0%{transform:rotateX(0)rotateY(0)rotate(0)}to{transform:rotateX(360deg)rotateY(180deg)rotate(360deg)}}@keyframes pulse-node{0%,to{opacity:.9;transform:scale(1)}50%{opacity:.5;transform:scale(1.35)}}@media (max-width:1024px){.intro-glass{border-radius:24px;width:100%;min-height:auto;padding:40px 30px}.intro-glass h1{font-size:clamp(2.2rem,7vw,3.5rem)}.detail-desc-area{min-height:auto;padding-top:80px}}@media (max-width:768px){.mind-map{flex-direction:column;align-items:stretch;gap:30px;padding:0}.mm-col{gap:16px}.mm-col.branch{border-left:3px solid var(--accent-light);border-top:none;margin-left:30px;padding-left:20px}.mm-row{flex-direction:column;align-items:stretch;margin-left:30px}.has-children:after,.mm-node-cat.active:after,.mm-row.branch .mm-node-detail:not(:first-child):before{display:none}.mm-node-detail{width:100%}.detail-view{padding:0 20px}.project-rail{flex-direction:column;padding:20px}.project-card{min-width:100%}.scroll-timeline{z-index:0;opacity:.4;height:30vh;left:8px}}.metrics-banner{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:16px;gap:1rem;margin:2rem 0;padding:1.5rem;display:flex}.metric-item{background:#ffffff08;border-radius:12px;flex-direction:column;flex:1;gap:.4rem;padding:1rem;display:flex}.metric-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-sub,#89a);font-size:.65rem}.metric-values{font-family:var(--font-jetbrains-mono), monospace;align-items:center;gap:.5rem;display:flex}.metric-before{color:var(--text-sub,#89a);opacity:.6;font-size:.85rem;text-decoration:line-through}.metric-arrow{color:var(--text-sub,#89a);font-size:.8rem}.metric-after{color:#38bdf8;font-size:1.4rem;font-weight:700;font-family:var(--font-jetbrains-mono), monospace}.metric-badge{color:#38bdf8;letter-spacing:.05em;background:#38bdf81f;border:1px solid #38bdf840;border-radius:999px;width:fit-content;padding:.2rem .6rem;font-size:.65rem;font-weight:600;display:inline-block}.opt-card-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin:1.5rem 0;display:grid}.opt-card{background:#ffffff0a;border:1px solid #ffffff14;border-radius:14px;flex-direction:column;gap:.6rem;padding:1.25rem;transition:border-color .2s,box-shadow .2s;display:flex}.opt-card:hover{border-color:#38bdf84d;box-shadow:0 0 20px #38bdf80f}.opt-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.opt-title{color:var(--text-main,#e2e8f0);font-size:.9rem;font-weight:600;line-height:1.3}.opt-badge{color:#38bdf8;letter-spacing:.04em;white-space:nowrap;background:#38bdf81a;border:1px solid #38bdf833;border-radius:999px;flex-shrink:0;padding:.15rem .5rem;font-size:.6rem;font-weight:700}.opt-perf{font-family:var(--font-jetbrains-mono), monospace;align-items:center;gap:.4rem;font-size:.8rem;display:flex}.opt-perf span:first-child{color:var(--text-sub,#89a);opacity:.6;text-decoration:line-through}.opt-after{color:#38bdf8;font-weight:700}.opt-desc{color:var(--text-sub,#89a);flex:1;font-size:.78rem;line-height:1.55}.opt-velog-link{color:var(--text-sub,#89a);background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:.35rem;width:fit-content;margin-top:auto;padding:.4rem .75rem;font-size:.72rem;text-decoration:none;transition:color .2s,border-color .2s;display:inline-flex}.opt-velog-link:hover{color:#38bdf8;border-color:#38bdf84d}.mindmap-trigger-area{justify-content:center;padding:1rem 0 .5rem;display:flex}@media (max-width:640px){.metrics-banner{flex-direction:column}.opt-card-grid{grid-template-columns:1fr}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
