@font-face{font-family:Nunito Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/f813d0b748b050e0-s.0bue79j92ry8p.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:Nunito Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/dcd150d580a10316-s.00vt6ovfanaoz.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Nunito Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/d261779aa92de579-s.08vb0en80h4ak.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:Nunito Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/24ce79ed121239f3-s.0e7.nfwufgbbc.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:Nunito Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/f141b5b7abe57afc-s.p.0-k1k9nod8chc.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:Nunito Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/f813d0b748b050e0-s.0bue79j92ry8p.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:Nunito Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/dcd150d580a10316-s.00vt6ovfanaoz.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Nunito Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/d261779aa92de579-s.08vb0en80h4ak.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:Nunito Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/24ce79ed121239f3-s.0e7.nfwufgbbc.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:Nunito Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/f141b5b7abe57afc-s.p.0-k1k9nod8chc.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:Nunito Sans;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/f813d0b748b050e0-s.0bue79j92ry8p.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:Nunito Sans;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/dcd150d580a10316-s.00vt6ovfanaoz.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Nunito Sans;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/d261779aa92de579-s.08vb0en80h4ak.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:Nunito Sans;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/24ce79ed121239f3-s.0e7.nfwufgbbc.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:Nunito Sans;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/f141b5b7abe57afc-s.p.0-k1k9nod8chc.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:Nunito Sans Fallback;src:local(Arial);ascent-override:99.71%;descent-override:34.82%;line-gap-override:0.0%;size-adjust:101.39%}.nunito_sans_e8bca852-module__9mV_PG__className{font-family:Nunito Sans,Nunito Sans Fallback;font-style:normal}.nunito_sans_e8bca852-module__9mV_PG__variable{--font-nunito-sans:"Nunito Sans", "Nunito Sans Fallback"}
:root{--ink:#17191d;--muted:#5e6670;--line:#e5e8eb;--panel:#fff;--soft:#f7f8f9;--shadow:0 12px 30px #14181e14}[data-theme=dark]{--ink:#e4e6ea;--muted:#9ca3af;--line:#2a2d33;--panel:#1a1d23;--soft:#12141a;--shadow:0 12px 30px #0000004d}*{box-sizing:border-box}html{scroll-behavior:smooth}body{max-width:1400px;color:var(--ink);background:var(--panel);font-family:var(--font-noto-sans-kr), var(--font-nunito-sans), sans-serif;margin:0 auto;font-size:16px;line-height:1.6;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:1.15em;height:1.15em}.site-header{z-index:20;color:#fff;justify-content:space-between;align-items:center;width:100%;max-width:1400px;height:86px;padding:0 clamp(28px,6.8vw,72px);display:flex;position:fixed;top:0;left:50%;transform:translate(-50%)}.brand{color:inherit;font-family:var(--font-nunito-sans), sans-serif;letter-spacing:0;font-size:22px;font-weight:800}.nav{font-family:var(--font-nunito-sans), sans-serif;align-items:center;gap:clamp(18px,2.2vw,34px);font-size:15px;font-weight:800;display:flex}.nav a{color:inherit;position:relative}.nav a.active:after{content:"";background:currentColor;height:2px;position:absolute;bottom:-10px;left:0;right:0}.theme-button,.social-row a,.footer-social a{border:0;border-radius:50%;place-items:center;display:grid}.lang-button{min-width:58px;height:32px;color:inherit;font:inherit;cursor:pointer;background:#80808029;border:0;border-radius:999px;padding:0 13px;font-size:13px;font-weight:800}.theme-button{width:32px;height:32px;color:inherit;background:#ffffff29}.hero{background:linear-gradient(90deg,#fffffff5 0%,#ffffffd1 25%,#ffffff14 49%,#13100e6b 100%),url(/assets/2.png) 50% 22%/cover;align-items:center;min-height:670px;padding:92px clamp(32px,7.6vw,96px) 58px;display:grid;position:relative;overflow:hidden}.hero:after{content:"";background:#ffffff8c;height:1px;position:absolute;inset:auto 0 0}.hero-copy{z-index:2;width:min(420px,100%);padding-top:36px;position:relative}.hero h1{letter-spacing:0;margin:0;font-size:clamp(56px,6vw,72px);font-weight:500;line-height:1.23}.hero-copy p{color:var(--muted);margin:34px 0 28px;font-size:19px;font-weight:500}.primary-button,.dark-button,.light-button{border-radius:14px;justify-content:center;align-items:center;gap:9px;font-weight:800;display:inline-flex}.primary-button{color:#fff;background:#050505;min-width:176px;height:58px;box-shadow:0 10px 28px #0003}.social-row{gap:18px;margin-top:36px;display:flex}.social-row a{color:#111;background:#ffffffc7;width:34px;height:34px;box-shadow:0 8px 18px #0f141914}.hero-quote{color:#ffffffe0;text-align:right;text-shadow:0 1px 16px #00000057;margin:0;font-size:24px;font-weight:400;line-height:1.45;position:absolute;bottom:70px;right:clamp(32px,6.2vw,86px)}.hero-quote span{margin-top:16px;font-size:14px;display:block}.section{width:min(1080px,100% - 64px);margin:0 auto}.about-section{grid-template-columns:.8fr 1.45fr;gap:clamp(38px,8vw,112px);padding:58px 0 40px;display:grid}h2{margin:0 0 24px;font-size:26px;font-weight:800;line-height:1.2}.about-copy p{color:var(--muted);margin:0 0 28px;font-size:17px;font-weight:500}.dark-button{color:#fff;background:#1d2228;border-radius:10px;height:40px;padding:0 18px;font-size:13px}.info-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-self:center;gap:16px;display:grid}.info-card{border:1px solid var(--line);background:var(--panel);min-height:108px;box-shadow:var(--shadow);border-radius:14px;align-items:center;gap:30px;padding:28px 34px;display:flex}.info-card svg{width:28px;height:28px;color:var(--ink)}.info-card strong,.info-card span{display:block}.info-card strong{margin-bottom:4px;font-size:15px}.info-card span{color:var(--muted);font-size:16px;font-weight:500}.skills-section{border-top:1px solid var(--line);padding:30px 0 34px}.skills-grid{grid-template-columns:repeat(8,minmax(0,1fr));gap:18px;display:grid}.skill-card{border:1px solid var(--line);background:var(--panel);min-height:104px;box-shadow:var(--shadow);color:var(--ink);border-radius:12px;place-items:center;gap:10px;font-size:14px;font-weight:600;display:grid}.skill-mark{color:#fff;width:36px;height:36px;font-family:var(--font-nunito-sans), sans-serif;place-items:center;font-size:20px;font-weight:900;line-height:1;display:grid}.skill-mark.html{clip-path:polygon(12% 0,88% 0,80% 84%,50% 100%,20% 84%);background:#e84c27}.skill-mark.css{clip-path:polygon(12% 0,88% 0,80% 84%,50% 100%,20% 84%);background:#2668d9}.skill-mark.js{color:#202124;background:#f6d23b;border-radius:2px;font-size:17px}.skill-mark.ts{background:#3078c6;border-radius:2px;font-size:17px}.skill-mark.react{color:#42c7ee;font-size:34px}.skill-mark.node{color:#65bd53;border:3px solid #65bd53;border-radius:9px}.skill-mark.git{color:#f04d35;font-size:35px}.skill-mark.python{color:#3775a8;font-size:18px}.projects-section{padding:8px 0 70px}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:50px;display:grid}.project-card{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:10px;overflow:hidden}.project-image{background-position:50%;background-size:cover;height:170px}.project-image.portfolio{background:radial-gradient(circle at 20% 25%,#26384c 0 9%,#0000 10%),linear-gradient(135deg,#111922,#070a10 60%,#1d2633)}.project-image.task{background:linear-gradient(90deg,#fffc,#fff0),repeating-linear-gradient(0deg,#fff 0 25px,#f5f7fa 26px 27px),linear-gradient(135deg,#edf4ff,#fff)}.project-image.travel{background-image:linear-gradient(#00000014,#0003),url(https://images.unsplash.com/photo-1500530855697-b586d89ba3ee?auto=format&fit=crop&w=900&q=80)}.project-body{padding:18px 20px 20px}.project-body h3{margin:0 0 4px;font-size:17px;line-height:1.25}.project-body p{color:#4e5965;margin:0 0 16px;font-size:14px;font-weight:600}.tag-row{flex-wrap:wrap;gap:8px;display:flex}.tag-row span{color:#4d5660;background:#eef1f4;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:700}.more-link{color:#303841;justify-content:center;align-items:center;gap:10px;margin-top:28px;font-weight:700;display:flex}.footer{color:#fff;background:radial-gradient(circle at 85% 15%,#ffffff14,#0000 32%),linear-gradient(120deg,#20272d,#151a1e);grid-template-columns:1fr 1fr 1fr;gap:40px;padding:30px clamp(32px,7.6vw,96px) 54px;display:grid;position:relative}.footer h2{margin-bottom:18px}.footer p{margin:0 0 18px}.light-button{height:42px;color:var(--ink);background:var(--panel);border-radius:10px;padding:0 18px;font-size:14px}address{align-content:center;gap:13px;font-style:normal;display:grid}address a,address span{align-items:center;gap:13px;display:flex}address svg{fill:#ffffff26;background:#ffffff14;border-radius:50%;width:30px;height:30px;padding:8px}.footer-social{justify-content:flex-end;align-items:center;gap:34px;display:flex}.footer-social a{background:#ffffff1a;width:54px;height:54px}.footer-social svg{width:24px;height:24px}.copyright{color:#ffffffc7;white-space:nowrap;font-size:14px;position:absolute;bottom:22px;left:50%;transform:translate(-50%)}@media (max-width:900px){.site-header{align-items:flex-start;height:auto;padding-top:22px}.nav{gap:14px;font-size:13px}.hero{background:linear-gradient(90deg,#fffffff0 0%,#ffffffb8 32%,#ffffff14 62%,#13100e6b 100%),url(/assets/1.png) 50% 20%/cover;min-height:720px}.about-section,.project-grid,.footer{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.footer-social{justify-content:flex-start}}@media (max-width:640px){.site-header{color:#fff;position:absolute}.brand{color:#fff}.nav a:not(.active){display:none}.nav{gap:12px}.lang-button{min-width:54px;padding:0 10px}.section{width:min(100% - 36px,1080px)}.hero{background:linear-gradient(90deg,#ffffffe6 0%,#ffffff9e 42%,#ffffff05 72%,#13100e61 100%),url(/assets/1.png) 56% 18%/cover;min-height:680px;padding:96px 24px 38px}.hero h1{font-size:32px}.hero-copy p{font-size:15px}.hero-quote{font-size:18px;bottom:30px;right:24px}.about-section{padding-top:44px}.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.info-grid{grid-template-columns:1fr}.info-card{gap:16px;min-height:96px;padding:20px}.project-grid{gap:24px}.footer{padding-bottom:78px}.copyright{text-align:center;width:100%}}
