:root{--font-sans: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, "Apple SD Gothic Neo", "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;--bg: #fbfbf9;--surface: #ffffff;--ink: #1a1a1c;--ink-soft: #3d3d42;--muted: #76767d;--line: #e8e6e1;--accent: #1f3a5f;--accent-soft: #eef1f6;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--sp-16: 4rem;--sp-20: 5rem;--sp-24: 6rem;--sp-32: 8rem;--maxw: 60rem;--maxw-text: 40rem;--radius: 6px;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);line-height:1.7;letter-spacing:-.011em;word-break:keep-all}h1,h2,h3,h4{line-height:1.25;letter-spacing:-.025em;font-weight:700}h1{font-size:clamp(2rem,5vw,2.9rem)}h2{font-size:clamp(1.4rem,3vw,1.85rem)}h3{font-size:1.2rem}p{color:var(--ink-soft)}a{color:inherit;text-decoration:none}ul{list-style:none}.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--sp-6)}.section{padding-block:var(--sp-20);border-top:1px solid var(--line)}.section:first-of-type{border-top:0}.section>h2{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--sp-8)}.hero{padding-block:var(--sp-32) var(--sp-24);border-top:0}.eyebrow{font-family:var(--font-mono);font-size:.85rem;color:var(--muted);margin-bottom:var(--sp-5)}.hero h1{max-width:22ch}.lede{max-width:56rem;margin-top:var(--sp-6);font-size:1.1rem;color:var(--ink-soft)}.about{max-width:56rem;font-size:1.05rem;line-height:1.75;color:var(--ink-soft)}.projects{display:grid;gap:var(--sp-3)}.project-card{display:block;padding:var(--sp-6);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:border-color .18s ease,transform .18s ease}.project-card:hover{border-color:var(--accent);transform:translateY(-2px)}.project-card h3{margin-bottom:var(--sp-2)}.project-card p{color:var(--muted);font-size:.96rem}.stack{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-4)}.stack span{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-soft);padding:2px var(--sp-2);background:var(--accent-soft);border-radius:4px}.project-tags{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.project-type{font-size:.72rem;font-weight:600;color:var(--accent)}.project-team{font-size:.72rem;color:var(--muted)}.project-team:before{content:"·";margin-right:var(--sp-2);color:var(--muted)}.footer{padding-block:var(--sp-16);border-top:1px solid var(--line);color:var(--muted);font-size:.9rem}.sidenav{position:fixed;right:var(--sp-6);top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column;gap:var(--sp-4)}.sidenav a{position:relative;display:flex;align-items:center;justify-content:flex-end;height:14px}.sidenav-line{width:28px;height:2px;border-radius:1px;background:var(--muted);opacity:.4;transition:opacity .2s ease,background .2s ease,width .2s ease}.sidenav-text{position:absolute;right:calc(100% + var(--sp-3));top:50%;font-size:.8rem;color:var(--ink);white-space:nowrap;opacity:0;transform:translateY(-50%) translate(4px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.sidenav a:hover .sidenav-line{opacity:1;background:var(--accent)}.sidenav a.active .sidenav-line{opacity:1;background:var(--accent);width:40px}.sidenav a:hover .sidenav-text{opacity:1;transform:translateY(-50%) translate(0)}@media(max-width:760px){.sidenav{display:none}}.navmobile-toggle,.navmobile-backdrop,.navmobile-panel{display:none}@media(max-width:760px){.navmobile-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;position:fixed;top:var(--sp-4);right:var(--sp-4);z-index:60;width:44px;height:44px;padding:0 11px;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:10px;cursor:pointer}.navmobile-toggle span{display:block;width:100%;height:2px;background:var(--ink);border-radius:1px;transition:transform .25s ease,opacity .2s ease}.navmobile-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navmobile-toggle.open span:nth-child(2){opacity:0}.navmobile-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navmobile-backdrop{display:block;position:fixed;inset:0;z-index:55;background:#00000040;opacity:0;pointer-events:none;transition:opacity .2s ease}.navmobile-backdrop.open{opacity:1;pointer-events:auto}.navmobile-panel{display:flex;flex-direction:column;gap:2px;position:fixed;top:calc(var(--sp-4) + 52px);right:var(--sp-4);z-index:60;min-width:190px;max-width:calc(100vw - var(--sp-8));padding:var(--sp-2);background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:0 10px 34px #00000021;opacity:0;transform:translateY(-8px) scale(.98);transform-origin:top right;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.navmobile-panel.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.navmobile-panel a{padding:var(--sp-3) var(--sp-4);border-radius:9px;font-size:.95rem;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navmobile-panel a:active,.navmobile-panel a:hover{background:var(--accent-soft);color:var(--accent)}}.section{scroll-margin-top:32px}.back{display:inline-block;font-family:var(--font-mono);font-size:.85rem;color:var(--muted);margin-top:var(--sp-12);margin-bottom:var(--sp-8)}.back:hover{color:var(--accent)}.case-header{padding-bottom:var(--sp-10);border-bottom:1px solid var(--line);margin-bottom:var(--sp-10)}.case-one{margin-top:var(--sp-4);font-size:1.15rem;color:var(--ink-soft);max-width:var(--maxw-text)}.meta{display:flex;flex-wrap:wrap;gap:var(--sp-8);margin-top:var(--sp-8)}.meta dt{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}.meta dd{font-size:.95rem;color:var(--ink);max-width:38ch}.metrics{display:flex;flex-wrap:wrap;gap:var(--sp-8);margin-top:var(--sp-8);padding:var(--sp-5) 0}.metrics li{display:flex;flex-direction:column}.metrics strong{font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.metrics span{font-size:.78rem;color:var(--muted);margin-top:2px}.case-header .stack{margin-top:var(--sp-8)}.case-header .links{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-8)}.case-header .links a{font-family:var(--font-mono);font-size:.82rem;color:var(--accent);padding:var(--sp-2) var(--sp-4);border:1px solid var(--accent);border-radius:6px;text-decoration:none;transition:background .15s ease,color .15s ease}.case-header .links a:before{content:"↗ ";opacity:.6}.case-header .links a:hover{background:var(--accent);color:#fff}.prose{max-width:var(--maxw-text);padding-bottom:var(--sp-24)}.prose h2{font-size:1.3rem;margin-top:var(--sp-12);margin-bottom:var(--sp-4);scroll-margin-top:32px}.prose h3{font-size:1.05rem;margin-top:var(--sp-8);margin-bottom:var(--sp-3)}.prose p{margin-top:var(--sp-4)}.prose ul{list-style:disc;padding-left:1.2rem;margin-top:var(--sp-4)}.prose li{margin-top:var(--sp-2);color:var(--ink-soft)}.prose blockquote{border-left:3px solid var(--accent);padding-left:var(--sp-4);margin-top:var(--sp-6);color:var(--muted);font-size:.95rem}.prose strong{color:var(--ink)}.prose code{font-family:var(--font-mono);font-size:.85em;background:var(--accent-soft);padding:1px 5px;border-radius:4px}.prose .lead-list{margin-top:var(--sp-6)}.prose details{margin-top:var(--sp-6);border:1px solid var(--line);border-radius:var(--radius);padding:var(--sp-4) var(--sp-6);background:var(--surface)}.prose summary{cursor:pointer;font-weight:600;color:var(--accent);font-size:.92rem;list-style:none}.prose summary::-webkit-details-marker{display:none}.prose summary:before{content:"▸ ";color:var(--muted)}.prose details[open] summary:before{content:"▾ "}.prose details[open] summary{margin-bottom:var(--sp-4)}.prose details strong{display:block;margin-top:var(--sp-5);margin-bottom:var(--sp-1);font-size:.9rem}.prose details ul{margin-top:var(--sp-1)}.prose .shots{display:flex;gap:var(--sp-3);overflow-x:auto;margin:var(--sp-8) 0 var(--sp-2);padding-bottom:var(--sp-3);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.prose .shots img{height:340px;width:auto;flex:0 0 auto;border:1px solid var(--line);border-radius:14px;scroll-snap-align:start;background:var(--surface)}.prose .shots-cap{font-size:.8rem;color:var(--muted);margin:0 0 var(--sp-12)}.prose .shots-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3);margin:var(--sp-8) 0 var(--sp-2)}.prose .shots-grid img{width:100%;height:auto;border:1px solid var(--line);border-radius:10px;background:var(--surface);display:block}@media(max-width:560px){.prose .shots-grid{grid-template-columns:1fr}}.prose .shot-portrait{margin:var(--sp-6) 0 var(--sp-8)}.prose .shot-portrait img{width:auto;max-width:100%;max-height:560px;border:1px solid var(--line);border-radius:12px;background:var(--surface);display:block}.prose .shot-portrait figcaption{font-size:.8rem;color:var(--muted);margin-top:var(--sp-2);max-width:32rem}.prose .shot-figure{margin:var(--sp-6) 0 var(--sp-8)}.prose .shot-figure img{width:100%;height:auto;border:1px solid var(--line);border-radius:10px;background:var(--surface);display:block}.prose .shot-figure figcaption{font-size:.8rem;color:var(--muted);margin-top:var(--sp-2)}.prose table{width:100%;border-collapse:collapse;margin:var(--sp-6) 0 var(--sp-4);font-size:.88rem}.prose th,.prose td{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line);text-align:left}.prose th{color:var(--ink);font-weight:600}.prose td{color:var(--ink-soft)}.prose th:not(:first-child),.prose td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}.prose tbody tr:last-child td{border-bottom:none}.prose tr.is-best td{color:var(--accent);font-weight:600}.prose table+.table-cap{font-size:.8rem;color:var(--muted);margin:calc(-1 * var(--sp-2)) 0 var(--sp-8)}.creds{display:grid;gap:var(--sp-8)}.cred-label{font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--sp-3)}.cred-prog{margin-left:var(--sp-4)}.cred-prog+.cred-prog{margin-top:var(--sp-4)}.cred-prog-name{font-size:.85rem;font-weight:600;color:var(--ink-soft);margin-bottom:var(--sp-2)}.cred-col>.cred-item{margin-left:var(--sp-4)}.cred-prog .cred-item{margin-left:var(--sp-4)}.cred-item{padding:var(--sp-1) 0;font-size:.96rem}.cred-name{color:var(--ink)}.cred-name em{font-style:normal;color:var(--muted);font-size:.85em}.cred-meta{color:var(--muted);font-size:.88rem}.cred-meta:before{content:"·";margin:0 .45em;color:var(--muted)}.edu{margin-bottom:var(--sp-8)}.cred-gpa{margin-left:var(--sp-4);margin-top:var(--sp-1);font-size:.96rem;color:var(--ink)}.cred-gpa-max{color:var(--muted);font-size:.85em}.skills{display:grid;gap:var(--sp-6)}.skill-label{font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--sp-3)}.skill-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.skill-chips span{font-family:var(--font-mono);font-size:.75rem;color:var(--ink-soft);padding:3px var(--sp-3);background:var(--accent-soft);border-radius:4px}
