html{scroll-behavior:smooth}body{color:#f3f6fb;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#030303;min-width:320px;margin:0;font-family:IBM Plex Sans KR,Segoe UI,sans-serif}body:before{content:none}#root{min-height:100svh}h1,h2,h3{font-family:IBM Plex Sans KR,Segoe UI,sans-serif;font-weight:650}code,pre{font-family:JetBrains Mono,SFMono-Regular,monospace}img{max-width:100%;display:block}:root{--bg:#020202;--surface:#0a0b0ff0;--surface-soft:#0e1015f0;--surface-card:#101319f0;--line:#adb5bd3d;--line-strong:#adb5bd66;--text:#f5f7fa;--text-soft:#d0d4da;--text-muted:#9da5ae;--accent:#adb5bd;--radius-xl:30px;--radius-lg:24px;--radius-md:18px;--radius-sm:14px;--shadow:0 20px 70px #00000073}*,:before,:after{box-sizing:border-box}a{color:inherit;text-decoration:none}button{font:inherit}.app-shell{width:min(1760px,100% - 24px);margin:0 auto;padding:18px 0 56px}.site-header{z-index:30;border:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#07080be6;border-radius:999px;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;margin-bottom:20px;padding:16px 22px;display:grid;position:sticky;top:14px;box-shadow:0 16px 36px #0000003d}.brand{align-items:center;gap:10px;display:inline-flex}.brand__dot{background:#f8f9fa;border-radius:999px;width:9px;height:9px;box-shadow:0 0 0 3px #f8f9fa33}.brand__name{color:var(--text);letter-spacing:-.015em;font-family:IBM Plex Sans KR,Segoe UI,sans-serif;font-size:1.12rem;font-weight:640}.site-nav{justify-content:center;gap:8px;min-width:0;display:flex}.site-nav__tab{color:var(--text-soft);cursor:pointer;letter-spacing:-.01em;background:0 0;border:0;border-radius:999px;padding:.66rem 1.02rem;font-family:IBM Plex Sans KR,Segoe UI,sans-serif;font-size:.98rem;font-weight:560;transition:color .18s,background-color .18s,transform .18s}.site-nav__tab:hover,.site-nav__tab:focus-visible{color:var(--text);background:#ffffff0f;transform:translateY(-1px)}.site-nav__tab.is-active{color:var(--text);background:#adb5bd33}.header-actions{align-items:center;gap:12px;display:flex}.language-toggle{border:1px solid var(--line);background:#ffffff0a;border-radius:999px;gap:4px;padding:4px;display:inline-flex}.language-toggle button{color:var(--text-muted);cursor:pointer;letter-spacing:-.01em;background:0 0;border:0;border-radius:999px;padding:.56rem .88rem;font-family:IBM Plex Sans KR,Segoe UI,sans-serif;font-size:.95rem;font-weight:540;transition:color .18s,background-color .18s}.language-toggle .is-active{color:var(--text);background:#adb5bd33}.site-main{gap:20px;display:grid}.section-anchor{scroll-margin-top:106px}.section-card{border:1px solid var(--line);border-radius:var(--radius-xl);background:radial-gradient(circle at 82% -8%, #adb5bd2e, transparent 40%), linear-gradient(180deg, var(--surface), var(--surface-soft));box-shadow:var(--shadow);padding:26px;position:relative;overflow:hidden}.section-card:before{content:"";background:linear-gradient(90deg,#adb5bd80,#0000 60%);width:100%;height:1px;position:absolute;inset:0 auto auto 0}.section-label{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.88rem;font-weight:620}.hero-layout{--hero-media-height:clamp(370px, 38vw, 540px);grid-template-columns:minmax(310px,390px) minmax(0,1fr);align-items:start;gap:24px;display:grid}.profile-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:#ffffff05;padding:14px}.profile-photo-frame{border-radius:var(--radius-md);height:var(--hero-media-height);background:#ffffff05;border:1px solid #ffffff14;overflow:hidden}.profile-photo-frame img{object-fit:cover;object-position:center 12%;width:100%;height:100%}.profile-list{gap:9px;display:grid}.profile-list--hero{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:24px}.profile-item{border:1px solid var(--line);border-radius:var(--radius-sm);background:#ffffff08;gap:6px;padding:12px 14px;transition:border-color .18s,transform .18s,background-color .18s;display:grid}.profile-item:hover,.profile-item:focus-visible{border-color:var(--line-strong);background:#ffffff0d;transform:translateY(-1px)}.profile-item--static{cursor:default}.profile-item--static:hover{border-color:var(--line);background:#ffffff08;transform:none}.profile-item__label{color:var(--text-muted);font-size:.86rem;font-weight:520}.profile-item strong{color:var(--text);overflow-wrap:anywhere;gap:2px;font-size:.97rem;font-weight:590;line-height:1.5;display:grid}.profile-item__line{white-space:nowrap}.hero-copy{grid-template-columns:minmax(0,1fr) minmax(300px,390px);align-content:start;gap:20px;display:grid}.hero-copy__main{align-content:start;gap:20px;display:grid}.hero-title{max-width:19ch;color:var(--text);letter-spacing:-.03em;text-wrap:pretty;word-break:keep-all;margin:0;font-family:Fraunces,IBM Plex Sans KR,Segoe UI,sans-serif;font-size:clamp(1.72rem,2.35vw,2.78rem);font-weight:620;line-height:1.1}.hero-summary{max-width:64ch;color:var(--text-soft);margin:6px 0 0;font-size:.98rem;line-height:1.72}.hero-actions{flex-wrap:wrap;gap:10px;display:flex}.action-pill{border:1px solid var(--line);letter-spacing:.02em;border-radius:999px;justify-content:center;align-items:center;min-height:46px;padding:.74rem 1.18rem;font-size:.95rem;font-weight:620;transition:transform .18s,border-color .18s,filter .18s;display:inline-flex}.action-pill:hover,.action-pill:focus-visible{border-color:var(--line-strong);transform:translateY(-1px)}.action-pill--light{color:#090a0d;background:#f2f4f6}.action-pill--muted{color:var(--text);background:#adb5bd38}.action-pill--dark{color:var(--text);background:#ffffff0a}.hero-resume-card{border:1px solid var(--line);border-radius:var(--radius-md);max-width:none;height:var(--hero-media-height);background:#ffffff08;grid-template-rows:auto minmax(0,1fr);gap:8px;margin-top:0;padding:12px;display:grid}.resume-link{min-height:36px;color:var(--text);letter-spacing:-.005em;background:linear-gradient(135deg,#adb5bd33,#adb5bd14);border:1px solid #adb5bd70;border-radius:12px;justify-content:center;align-items:center;padding:.5rem .78rem;font-size:.84rem;font-weight:620;transition:transform .18s,border-color .18s,filter .18s;display:inline-flex}.resume-link:hover,.resume-link:focus-visible{filter:brightness(1.06);border-color:#adb5bd9e;transform:translateY(-1px)}.resume-preview-frame{border-radius:var(--radius-sm);border:1px solid var(--line);height:100%;min-height:calc(var(--hero-media-height) - 58px);background:#ffffff08;overflow:hidden}.resume-preview-frame iframe{pointer-events:none;background:#fff;border:0;width:100%;height:100%;display:block}.overview-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px;display:grid}.info-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:#ffffff08;padding:20px}.info-card__body{margin-top:14px}.info-card__body h2{color:var(--text);letter-spacing:-.02em;margin:0;font-size:clamp(1.5rem,2.2vw,2rem);line-height:1.18}.info-card__body p{color:var(--text-soft);margin:9px 0 0;font-size:1.02rem;line-height:1.7}.info-card__row{align-items:baseline;gap:8px;margin-top:12px;display:flex}.info-card__row span{color:var(--text-muted);font-size:.97rem}.info-card__row strong{color:var(--text);font-size:1.24rem;line-height:1.45}.section-head{gap:0;margin-bottom:18px;display:grid}.section-head h2{color:var(--text);letter-spacing:-.03em;margin:0;font-size:clamp(2.1rem,3vw,3.4rem);font-weight:700;line-height:1.12}.nowrap{white-space:nowrap}.section-head p{color:var(--text-soft);margin:0;font-size:1rem;line-height:1.75}.timeline-list{gap:30px;display:grid}.timeline-project{grid-template-columns:98px minmax(0,1fr);align-items:start;gap:18px;display:grid}.timeline-project__rail{flex-direction:column;align-items:center;gap:12px;min-height:100%;display:flex;position:relative}.timeline-project__rail:after{content:"";background:var(--line);width:1px;position:absolute;top:98px;bottom:-30px}.timeline-project:last-child .timeline-project__rail:after{display:none}.timeline-project__logo-slot{width:82px;height:82px;color:var(--text);letter-spacing:.04em;text-align:center;background:#ffffff0a;border:1px dashed #adb5bd66;border-radius:20px;place-items:center;padding:8px;font-size:.82rem;font-weight:650;display:grid}.timeline-project__dot{background:#adb5bd;border-radius:50%;width:13px;height:13px;box-shadow:0 0 0 5px #020202}.timeline-project__body{border:1px solid var(--line);border-radius:var(--radius-lg);background:#ffffff08;padding:20px}.timeline-project__meta{grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:14px;display:grid}.timeline-project__org{color:var(--accent);letter-spacing:-.01em;word-break:keep-all;margin:0 0 8px;font-size:1rem;font-weight:600;line-height:1.5}.timeline-project__meta h3{color:var(--text);letter-spacing:-.03em;word-break:keep-all;margin:0;font-size:clamp(1.42rem,2vw,1.98rem);line-height:1.28}.timeline-project__period{border:1px solid var(--line);color:var(--text-muted);white-space:nowrap;background:#ffffff08;border-radius:999px;margin:0;padding:.56rem .8rem;font-size:.83rem;font-weight:560}.timeline-project__description{max-width:72ch;color:var(--text-soft);word-break:keep-all;margin:14px 0 0;font-size:1rem;line-height:1.75}.timeline-project__sections{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.timeline-project__section{border-radius:var(--radius-md);border:1px solid var(--line);background:#ffffff05;padding:16px}.timeline-project__section h4{color:var(--text);letter-spacing:-.02em;margin:0 0 10px;font-size:1rem}.timeline-project__section ul{margin:0;padding:0;list-style:none}.timeline-project__section li{color:var(--text-soft);word-break:keep-all;padding-left:16px;line-height:1.72;position:relative}.timeline-project__section li+li{margin-top:8px}.timeline-project__section li:before{content:"";background:#adb5bd;border-radius:50%;width:7px;height:7px;position:absolute;top:.78em;left:0}.stack-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.stack-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:#ffffff08;padding:18px}.stack-card__header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.stack-card__header h3{color:var(--text);letter-spacing:-.01em;margin:0;font-size:1.04rem;line-height:1.4}.stack-card__count{color:var(--text-muted);white-space:nowrap;margin:0;font-size:.78rem}.stack-card__items{flex-wrap:wrap;gap:8px;margin:14px 0 0;padding:0;list-style:none;display:flex}.stack-card__items li{border:1px solid var(--line);color:#e0e4e8;word-break:keep-all;overflow-wrap:anywhere;background:#ffffff0a;border-radius:10px;max-width:100%;padding:.46rem .72rem;font-size:.88rem;line-height:1.45}@media (width<=1220px){.site-header{border-radius:26px;grid-template-columns:1fr;justify-items:center;gap:12px}.site-nav{flex-wrap:wrap}.hero-layout{grid-template-columns:minmax(260px,320px) minmax(0,1fr)}.hero-copy{grid-template-columns:1fr}.hero-resume-card{min-height:0}.resume-preview-frame{min-height:230px}.stack-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=920px){.app-shell{width:min(100% - 16px,1760px);padding-top:12px}.site-header{padding:14px 16px;top:10px}.header-actions{justify-content:center;width:100%}.language-toggle{width:min(320px,100%)}.language-toggle button{flex:1 1 0}.section-card{padding:18px}.hero-layout{grid-template-columns:1fr;gap:16px}.profile-photo-frame{height:min(62vw,430px)}.hero-title{max-width:none;font-size:clamp(1.62rem,7.4vw,2.42rem)}.hero-summary{font-size:1.02rem}.profile-list--hero{grid-template-columns:repeat(2,minmax(0,1fr))}.overview-meta,.timeline-project{grid-template-columns:1fr}.timeline-project__rail{flex-direction:row;justify-content:flex-start}.timeline-project__rail:after{display:none}.timeline-project__sections,.stack-grid{grid-template-columns:1fr}}@media (width<=640px){.profile-photo-frame{height:min(70vw,360px)}.profile-list--hero{grid-template-columns:1fr}.action-pill{width:100%}.resume-preview-frame iframe{height:100%}.resume-preview-frame{min-height:190px}.timeline-project__period{white-space:normal}.info-card__row{flex-direction:column;align-items:flex-start;gap:2px}.profile-item__line{white-space:normal}}
