@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&display=swap";@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;--spacing:.25rem;--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)}}@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{.fixed{position:fixed}.resize{resize:both}.scroll-mt-28{scroll-margin-top:calc(var(--spacing) * 28)}.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{--color-bg:#fdfdfb;--color-surface:#fff;--color-surface-soft:#f1f5f9;--color-text:#18181b;--color-text-strong:#09090b;--color-muted:#71717a;--color-border:#18181b1f;--color-primary:#4f6df5;--color-primary-soft:#e8ecff;--color-accent:#b8f24b;--color-accent-soft:#f0ffd1;--container-max:1120px;--container-padding:clamp(28px, 8vw, 140px);--color-accent-yellow:var(--color-accent);--color-accent-blue:var(--color-primary-soft);--color-accent-brown:var(--color-primary);--shadow-soft:0 18px 50px #4f6df514;--shadow-card:0 20px 60px #4f6df51f;--bg:var(--color-bg);--ink:var(--color-text);--muted:var(--color-muted);--line:var(--color-border);--soft:var(--color-surface-soft);--blue:var(--color-accent-brown);--green:var(--color-accent-yellow);--lime:var(--color-accent-blue);--max:1420px;--resume:760px;color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;scroll-behavior:smooth;font-family:Outfit,Pretendard,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%}body{background:var(--bg);margin:0;overflow-x:hidden}.loading-screen{z-index:9999;color:#18181b;background:#fafaf7;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-inner{text-align:center;flex-direction:column;align-items:center;gap:14px;display:flex}.loading-label{color:#71717a;letter-spacing:.18em;text-transform:uppercase;margin:0;font-size:.85rem}.loading-title{letter-spacing:-.06em;margin:0;font-size:clamp(2.4rem,7vw,5.5rem);font-weight:600;line-height:.95}.loading-dots{gap:8px;margin-top:8px;display:flex}.loading-dots span{background:#4f6df5;border-radius:999px;width:8px;height:8px;animation:.9s ease-in-out infinite loading-bounce}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes loading-bounce{0%,80%,to{opacity:.45;transform:translateY(0)}40%{opacity:1;transform:translateY(-8px)}}@media (prefers-reduced-motion:reduce){.loading-dots span{animation:none}}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}button{font:inherit}h1,h2,h3,h4,p{margin:0}h1,h2,h3{letter-spacing:0}h1{font-size:clamp(3.1rem,6.2vw,5.85rem);font-weight:900;line-height:1.08}h2{font-size:clamp(2.45rem,4.6vw,4.65rem);font-weight:900;line-height:1}h3{font-size:clamp(1.45rem,2vw,2.15rem);font-weight:850;line-height:1.18}p,li,dd{color:var(--muted);font-size:1rem;line-height:1.72}main{overflow:visible}.top-face-video{background:#09090b;width:100%}.top-face-video__media{object-fit:cover;width:100%;max-height:min(72vh,760px);display:block}.focus-ring:focus-visible{outline-offset:4px;border-radius:10px;outline:3px solid #18181b52}.nav-shell{z-index:50;pointer-events:none;flex-direction:column;align-items:center;display:flex;position:fixed;bottom:34px;left:0;right:0}.nav-pill{pointer-events:auto;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#eeeeedeb;border-radius:999px;align-items:center;gap:34px;min-height:68px;padding:0 28px;display:flex;box-shadow:0 16px 40px #18181b14}.nav-dots{border-radius:999px;align-items:center;gap:10px;padding:10px 12px;transition:background .18s,transform .18s;display:inline-flex}.nav-dots:hover,.nav-dots.active{background:var(--color-primary-soft);transform:translateY(-1px)}.nav-dots span{border-radius:999px;width:14px;height:14px}.desktop-nav{align-items:center;gap:18px;display:flex}.nav-link{color:#6c6f76;border-radius:999px;justify-content:center;align-items:center;min-width:88px;min-height:44px;padding:0 16px;font-size:.95rem;font-weight:850;display:inline-flex;position:relative}.nav-link span:not(.nav-active){z-index:1;position:relative}.nav-active{z-index:-1;background:#fff;border-radius:999px;position:absolute;inset:4px;box-shadow:0 5px 18px #18181b0f}.mobile-menu-button,.mobile-nav{display:none}.floating-nav-wrap{z-index:100;pointer-events:none;justify-content:center;width:min(100% - 32px,1180px);margin:-64px auto 104px;display:flex;position:sticky;top:18px}.floating-nav{pointer-events:auto;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#f5f5f4e0;border:1px solid #18181b14;border-radius:999px;align-items:center;gap:14px;max-width:100%;min-height:58px;padding:10px 18px;display:flex;box-shadow:0 14px 40px #18181b14}.nav-scroll{align-items:center;gap:4px;display:flex}.hero-shell{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:0;width:min(980px,100% - 40px);min-height:100vh;margin:0 auto;padding:clamp(56px,7vh,88px) 0 72px;display:flex}.hero-mark{place-items:center;width:100%;min-height:230px;display:grid}.hero-symbol{object-fit:contain;place-items:center;width:clamp(140px,15vw,230px);height:clamp(140px,15vw,230px);max-height:230px;margin:0 auto 28px;display:grid}.hero-symbol-fallback{background:linear-gradient(135deg, #fff, var(--color-primary-soft));color:var(--color-primary);border:1px solid #18181b1f;border-radius:999px;font-size:clamp(2.4rem,5vw,4.5rem);font-weight:950;box-shadow:0 22px 54px #4f6df524}.hero-face-video{object-fit:cover;border-radius:999px;width:clamp(144px,15.6vw,240px);height:clamp(144px,15.6vw,240px);box-shadow:0 22px 54px #18181b1f}.hero-copy{justify-items:center;gap:0;display:grid}.hero-copy h1{letter-spacing:-.045em;font-size:clamp(3rem,5vw,5.2rem);line-height:1.14}.hero-copy h1 span{color:var(--blue)}.hero-kicker{color:#9ca0a8;margin-bottom:24px;font-size:clamp(.9rem,1vw,1rem);font-weight:800}.hero-summary{color:#9ca3af;max-width:640px;margin:28px auto 0;font-size:clamp(1rem,1.25vw,1.15rem);font-weight:600;line-height:1.7}.hero-actions,.contact-actions,.project-actions,.chip-row{flex-wrap:wrap;gap:10px;display:flex}.hero-actions{z-index:2;justify-content:center;gap:12px;margin-top:32px;margin-bottom:72px;position:relative}.text-link{color:#565b64;cursor:pointer;border:0;align-items:center;gap:8px;font-weight:850;transition:color .18s,transform .18s;display:inline-flex}.email-copy-button{appearance:none;font:inherit}.copy-status{min-height:1.2em;color:var(--color-primary);align-self:center;font-size:.86rem;font-weight:700}.text-link:hover{color:var(--blue);transform:translateY(-2px)}.section-shell{width:min(var(--max), calc(100% - 80px));margin:0 auto;padding:112px 0}.section-resume{width:min(var(--resume), calc(100% - 48px))}.section-heading{text-align:center;justify-items:center;gap:18px;margin:0 auto 66px;display:grid}.section-resume .section-heading{text-align:left;justify-items:start}.section-resume h2{font-size:clamp(1.95rem,3.5vw,2.75rem);line-height:1.25}.section-eyebrow{color:var(--blue);font-size:1.08rem;font-weight:900}.section-intro{color:#777c84;max-width:880px;font-size:clamp(1.05rem,2vw,1.55rem);font-weight:600}.resume-list{gap:56px;display:grid}.resume-divider{color:#a0a4aa;grid-template-columns:1fr auto 1fr;align-items:center;gap:22px;font-size:.95rem;font-weight:800;display:grid}.resume-divider:before,.resume-divider:after{content:"";background:var(--line);height:1px}.resume-item{grid-template-columns:210px minmax(0,1fr);gap:42px;display:grid}.resume-date{color:#8e939b;white-space:nowrap;align-items:flex-start;gap:14px;font-size:1.08rem;font-weight:700;display:flex}.resume-date svg{color:#bfc2c7;flex:none;margin-top:4px}.resume-content{gap:14px;display:grid}.resume-role,.project-english{color:#8c929b;font-size:1.08rem;font-weight:650}.resume-title-row{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.experience-kind{border:1px solid var(--color-border);background:var(--color-primary-soft);width:fit-content;color:var(--color-primary);border-radius:999px;align-items:center;margin-bottom:10px;padding:7px 10px;font-size:.78rem;font-weight:950;line-height:1;display:inline-flex}#experience .section-heading{text-align:center;justify-items:center}#experience .section-heading h2{letter-spacing:-.04em;max-width:1100px;margin-inline:auto;font-size:clamp(1.8rem,3vw,3.4rem);line-height:1.18}.award-badge{width:42px;height:42px;color:var(--blue);background:#f0f4ff;border-radius:999px;flex:none;justify-content:center;align-items:center;display:inline-flex}.education-keywords{gap:8px;margin:0;padding-left:20px;display:grid}.chip,.skill-chip,.status-pill{color:#777b83;background:#fff;border:1px solid #dedfdf;border-radius:999px;align-items:center;padding:9px 14px;font-size:.94rem;font-weight:750;line-height:1;display:inline-flex}.accent-chip,.status-pill{color:var(--blue);background:#f4f7ff;border-color:#18181b3d}.section-showcase{width:min(1320px,100% - clamp(48px,14vw,240px));padding-top:132px}.project-showcase-list{gap:0;display:grid}.project-showcase-item{background:linear-gradient(135deg,#ffffffeb,#f7f7f5db),#fff;border:1px solid #18181b14;border-radius:8px;grid-template-columns:minmax(0,1.08fr) minmax(360px,.78fr);align-items:center;gap:clamp(28px,5vw,72px);padding:clamp(18px,2.5vw,34px);display:grid;position:relative;box-shadow:0 28px 70px #18181b17}.project-showcase-item:nth-child(2n){transform:translateY(28px)}.project-showcase-item:nth-child(3n){transform:translateY(-12px)}.project-showcase-item.is-reversed .project-media-panel{order:2}.project-showcase-item.is-reversed .project-info-panel{order:1}.project-media-panel{min-width:0}.project-card-link{border-radius:8px;display:block}.project-summary-card{cursor:default}.project-info-panel{background:#ffffffb8;border-radius:8px;gap:18px;min-width:0;padding:clamp(20px,3vw,34px);display:grid}.project-info-panel .project-copy{color:#70757e;font-size:1.02rem;line-height:1.75;display:block}.compact-project-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.project-detail-link{width:fit-content}.project-video,.project-video-mockup{aspect-ratio:16/10;background:#ecece8;border:1px solid #18181b1a;border-radius:8px;width:100%;display:block;overflow:hidden;box-shadow:0 28px 58px #18181b24}.project-video{object-fit:cover}.local-video-preview,.youtube-player-preview{isolation:isolate;position:relative}.local-video-preview video,.youtube-player-preview iframe{z-index:0;border:0;width:100%;height:100%;display:block;position:absolute;inset:0}.local-video-preview video{object-fit:cover}.video-thumbnail-overlay{z-index:1;object-fit:cover;pointer-events:none;opacity:1;width:100%;height:100%;transition:opacity .22s;position:absolute;inset:0}.local-video-preview.is-playing .video-thumbnail-overlay,.youtube-player-preview.is-loaded .video-thumbnail-overlay{opacity:0}.youtube-preview{cursor:pointer;isolation:isolate;position:relative}.youtube-preview img{object-fit:cover;width:100%;height:100%;display:block}.youtube-preview:after{z-index:1;content:"";background:linear-gradient(#09090b0a,#09090b5c);position:absolute;inset:0}.youtube-preview__play{z-index:2;color:#09090b;background:#ffffffe6;border-radius:999px;justify-content:center;align-items:center;width:68px;height:68px;transition:background .18s,transform .18s;display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 18px 42px #09090b47}.youtube-preview:hover .youtube-preview__play,.youtube-preview:focus-visible .youtube-preview__play{background:#fff;transform:translate(-50%,-50%)scale(1.06)}.project-media-slider iframe,.project-video-mockup iframe,.project-media iframe,.project-visual iframe,.project-card iframe,.project-video:is(iframe){border:0;width:100%;height:100%;min-height:280px;display:block}.project-media-slider,.project-video-mockup,.project-media,.project-visual{position:relative;overflow:hidden}.project-video,.project-video-mockup video,.project-video-mockup img,.project-video-mockup iframe,.project-media video,.project-media img,.project-media iframe,.project-visual iframe,.project-visual img,.project-visual video,.project-card iframe,.project-media-slider video,.project-media-slider iframe,.project-media-slider img{object-fit:cover;width:100%;height:100%;display:block}.project-video-mockup iframe,.project-media iframe,.project-visual iframe,.project-media-slider iframe{border:0}.project-video-mockup{isolation:isolate;position:relative}.mockup-grid{z-index:-1;opacity:.72;background-color:#0000;background-image:linear-gradient(#ffffff2e 1px,#0000 1px),linear-gradient(90deg,#ffffff29 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:30px 30px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0}.mockup-copy{z-index:3;color:#fff;gap:8px;display:grid;position:absolute;inset:auto 34px 32px}.mockup-copy p,.mockup-copy strong,.mockup-copy span{color:inherit}.mockup-copy p{font-size:clamp(.9rem,1.2vw,1.08rem);font-weight:950;line-height:1.1}.mockup-copy strong{max-width:720px;font-size:clamp(2rem,4.8vw,4.8rem);font-weight:950;line-height:.98}.mockup-copy span{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff2e;border-radius:999px;width:fit-content;padding:8px 12px;font-size:.95rem;font-weight:850}.mockup-shapes,.mockup-shape{position:absolute}.mockup-shapes{inset:0;overflow:hidden}.mockup-shape{background:#ffffffdb;border-radius:8px;display:block;box-shadow:0 18px 42px #18181b2e}.mockup-rewind{background:linear-gradient(135deg, var(--color-text-strong), var(--color-muted) 58%, #dfe6ff)}.mockup-rewind .shape-a{background:repeating-linear-gradient(90deg, var(--color-text-strong) 0 36px, #fff 36px 46px, var(--color-text-strong) 46px 82px);border-radius:0;height:58px;top:52px;left:-44px;right:-44px;transform:rotate(-5deg)}.mockup-rewind .shape-b,.mockup-rewind .shape-c{background:linear-gradient(160deg, #fff7d8, var(--color-accent-yellow));width:118px;height:172px;bottom:96px}.mockup-rewind .shape-b{left:18%;transform:rotate(-8deg)}.mockup-rewind .shape-c{background:linear-gradient(160deg, #dfffb8, var(--color-accent-blue));right:18%;transform:rotate(7deg)}.mockup-rewind .shape-d{border-radius:999px;width:88px;height:42px;top:42%;left:13%}.mockup-robot{background:linear-gradient(135deg, var(--color-text-strong), var(--color-accent-yellow))}.mockup-robot .shape-a,.mockup-robot .shape-b{box-shadow:none;background:0 0;border:2px solid #6dffc8bd;border-radius:999px}.mockup-robot .shape-a{width:250px;height:250px;top:52px;left:14%}.mockup-robot .shape-b{width:154px;height:154px;top:100px;left:calc(14% + 48px)}.mockup-robot .shape-c{border:8px solid var(--color-text-strong);border-radius:22px;width:168px;height:118px;bottom:100px;right:20%}.mockup-robot .shape-d{background:repeating-linear-gradient(135deg, var(--color-text-strong) 0 20px, var(--color-accent-yellow) 20px 40px);border-radius:0;height:44px;bottom:26px;left:-10px;right:-10px}.mockup-seogaro{background:linear-gradient(135deg, #e8f5e9, var(--color-accent-blue))}.mockup-seogaro .shape-a,.mockup-seogaro .shape-b,.mockup-seogaro .shape-c{border-radius:8px 18px 18px 8px;width:90px;height:210px;bottom:76px}.mockup-seogaro .shape-a{background:var(--color-accent-brown);left:22%;transform:rotate(-8deg)}.mockup-seogaro .shape-b{background:var(--color-accent-blue);left:37%}.mockup-seogaro .shape-c{background:var(--color-accent-yellow);left:52%;transform:rotate(8deg)}.mockup-seogaro .shape-d{border:3px solid var(--color-text);background:#ffffffd1;border-radius:999px;width:108px;height:108px;top:76px;right:18%;transform:rotate(-12deg)}.mockup-rarepick{background:linear-gradient(135deg,#f3f1ff,#7ed6c7)}.mockup-rarepick .shape-a{border-radius:18px;width:150px;height:150px;top:70px;left:16%}.mockup-rarepick .shape-b{background:linear-gradient(90deg,#0000 47%,#18181b40 48% 52%,#0000 53%),linear-gradient(#0000 47%,#18181b40 48% 52%,#0000 53%),#fff;border-radius:18px;width:238px;height:168px;bottom:78px;right:16%}.mockup-rarepick .shape-c{background:var(--color-accent-yellow);border-radius:50% 50% 50% 0;width:36px;height:36px;bottom:160px;right:calc(16% + 94px);transform:rotate(-45deg)}.mockup-rarepick .shape-d{border-radius:999px;width:92px;height:42px;top:114px;right:24%}.mockup-dashboard{background:linear-gradient(135deg,#eef5ff,#cde6d7)}.mockup-dashboard .shape-a,.mockup-dashboard .shape-b,.mockup-dashboard .shape-c{border:1px solid #18181b14;border-radius:18px}.mockup-dashboard .shape-a{width:190px;height:132px;top:58px;left:16%}.mockup-dashboard .shape-b{width:250px;height:168px;bottom:66px;right:16%}.mockup-dashboard .shape-c{background:linear-gradient(135deg, #fff, var(--color-accent-brown));width:210px;height:110px;bottom:94px;left:30%}.mockup-dashboard .shape-d{background:var(--color-accent-yellow);border:8px solid #fff;border-radius:999px;width:34px;height:34px;bottom:150px;right:28%}.mockup-house{background:linear-gradient(135deg, #fff4e0, var(--color-accent-blue))}.mockup-house .shape-a,.mockup-house .shape-b,.mockup-house .shape-c{border-radius:16px}.mockup-house .shape-a{width:238px;height:156px;top:70px;left:16%}.mockup-house .shape-b{background:repeating-linear-gradient(0deg,#0000 0 30px,#18181b14 30px 32px),repeating-linear-gradient(90deg,#0000 0 30px,#18181b14 30px 32px),#fff;width:162px;height:162px;top:104px;right:16%}.mockup-house .shape-c{width:230px;height:110px;bottom:72px;right:26%}.mockup-house .shape-d{background:var(--color-text-strong);clip-path:polygon(50% 0,100% 60%,82% 60%,82% 100%,18% 100%,18% 60%,0 60%);border-radius:0;width:162px;height:108px;bottom:122px;left:24%}.project-detail-page{background:var(--bg);min-height:100vh;padding:clamp(28px,5vw,64px) 0 clamp(72px,9vw,128px)}.project-detail-shell{gap:clamp(30px,5vw,56px);width:min(1120px,100% - 48px);margin:0 auto;display:grid}.back-link{color:#565b64;background:#fff;border:1px solid #dedfdf;border-radius:999px;align-items:center;gap:8px;width:fit-content;padding:10px 16px;font-size:.95rem;font-weight:850;display:inline-flex}.project-detail-hero{grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:end;gap:clamp(28px,6vw,72px);display:grid}.project-detail-heading{gap:16px;display:grid}.project-detail-heading h1{font-size:clamp(3rem,7vw,6.4rem);line-height:1.02}.project-detail-heading>p:last-child{color:#777c84;max-width:760px;font-size:clamp(1.05rem,1.6vw,1.35rem);font-weight:650;line-height:1.65}.project-detail-meta{background:#ffffffb8;border:1px solid #18181b14;border-radius:8px;gap:12px;padding:22px;display:grid}.project-detail-meta div,.project-meta div{gap:5px;display:grid}.project-detail-meta dt,.project-meta dt{color:#9aa0ab;font-size:.78rem;font-weight:900}.project-detail-meta dd,.project-meta dd{color:#333840;font-size:.98rem;font-weight:850}.project-detail-visual .project-video,.project-detail-visual .project-video-mockup{aspect-ratio:16/8.5}.project-detail-section{border-top:1px solid var(--line);gap:18px;padding-top:clamp(26px,4vw,42px);display:grid}.project-detail-section h2{color:var(--color-text-strong);font-size:clamp(1.45rem,2.4vw,2.25rem);line-height:1.16}.project-overview p{color:#70757e;max-width:860px;font-size:1.05rem;font-weight:600;line-height:1.85}.detail-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 18px;margin:0;padding:0;list-style:none;display:grid}.detail-list li{color:#5f646d;background:#fff;border:1px solid #18181b14;border-radius:8px;padding:16px 18px 16px 34px;font-size:.98rem;font-weight:650;line-height:1.62;position:relative}.detail-list li:before{background:var(--blue);content:"";border-radius:999px;width:6px;height:6px;position:absolute;top:23px;left:18px}.project-detail-nav{border-top:1px solid var(--line);grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding-top:28px;display:grid}.detail-nav-card{background:#fff;border:1px solid #18181b14;border-radius:8px;align-content:center;gap:6px;min-height:96px;padding:18px;display:grid}.detail-nav-card span{color:#9aa0ab;font-size:.78rem;font-weight:900}.detail-nav-card strong{color:#333840;align-items:center;gap:8px;font-size:1rem;line-height:1.35;display:inline-flex}.detail-nav-home{text-align:center}.project-not-found{text-align:center;align-content:center;justify-items:center;gap:18px;width:min(760px,100% - 48px);margin:0 auto;display:grid}.projects-grid{opacity:1;visibility:visible;grid-template-columns:repeat(2,minmax(0,1fr));gap:56px 32px;width:100%;min-height:1px;display:grid}.project-card{opacity:1;visibility:visible;background:#fff;border:1px solid #dedfdf;border-radius:8px;grid-template-columns:1fr;align-items:start;gap:24px;min-height:420px;padding:18px;transition:border-color .18s,box-shadow .18s;display:grid;box-shadow:0 16px 34px #18181b0f}.project-card.featured{box-shadow:none;background:0 0;border:0;grid-column:1/-1;grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr);align-items:center;gap:64px;padding:0}.project-card:hover{border-color:#18181b66;box-shadow:0 24px 46px #18181b1a}.project-card.featured:hover{box-shadow:none}.project-visual-wrap{border-radius:8px;overflow:hidden}.project-visual{background:#dededa;border:1px solid #d7d7d4;border-radius:8px;min-height:360px;transition:border-color .18s,box-shadow .18s,transform .26s;position:relative;overflow:hidden;box-shadow:0 26px 54px #18181b1f}.project-card.featured .project-visual{min-height:520px}.project-card:not(.featured) .project-visual{min-height:360px}.project-card:hover .project-visual{border-color:#18181b75;box-shadow:0 34px 70px #18181b29}.visual-stage{position:absolute;inset:0;overflow:hidden}.visual-stage:before{content:"";background-color:#0000;background-image:linear-gradient(#18181b0a 1px,#0000 1px),linear-gradient(90deg,#18181b0a 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:28px 28px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0}.visual-overlay{z-index:5;color:#fff;text-align:center;background:#18181b57;place-content:center;display:grid;position:absolute;inset:0}.visual-overlay span{word-break:keep-all;max-width:760px;font-size:clamp(2.7rem,6vw,6.3rem);font-weight:950;line-height:.95}.visual-overlay small{margin-top:18px;font-size:clamp(1rem,2vw,1.65rem);font-weight:800}.film .visual-stage{background:linear-gradient(135deg, var(--color-text-strong)2c, var(--color-muted))}.film-strip{opacity:.9;background:repeating-linear-gradient(90deg,#0e0e12 0 42px,#fff 42px 54px,#0e0e12 54px 96px);height:74px;position:absolute;top:58px;left:-40px;right:-40px;transform:rotate(-4deg)}.poster{background:linear-gradient(160deg, #f7f2d5, var(--color-accent-yellow));border-radius:8px;width:170px;height:238px;position:absolute;box-shadow:0 18px 40px #18181b40}.poster-one{bottom:58px;left:25%;transform:rotate(-8deg)}.poster-two{background:linear-gradient(160deg, #dfffb8, var(--color-accent-blue));bottom:82px;right:25%;transform:rotate(7deg)}.ott-pill,.my-list,.decade{color:var(--color-text-strong);background:#ffffffeb;border-radius:999px;font-weight:900;position:absolute}.ott-pill{padding:14px 22px;top:170px;left:16%}.my-list{padding:14px 22px;bottom:62px;right:15%}.decade{padding:10px 18px;bottom:36px;left:50%;transform:translate(-50%)}.robot .visual-stage{background:linear-gradient(135deg, var(--color-text-strong), var(--color-accent-yellow))}.radar{border:2px solid #6dffc89e;border-radius:999px;position:absolute}.radar-one{width:260px;height:260px;top:72px;left:110px}.radar-two{width:164px;height:164px;top:120px;left:158px}.robot-body{border:8px solid var(--color-text-strong);background:#f4f4ef;border-radius:22px;width:180px;height:132px;position:absolute;bottom:82px;right:24%}.robot-head{background:var(--color-text-strong);border-radius:18px;width:84px;height:74px;position:absolute;bottom:210px;right:calc(24% + 48px)}.sensor{background:var(--blue);border-radius:999px;width:40px;height:40px;position:absolute;bottom:125px}.sensor-left{right:calc(24% + 118px)}.sensor-right{right:calc(24% + 36px)}.warning-line{background:repeating-linear-gradient(135deg, var(--color-text-strong) 0 22px, var(--color-accent-yellow) 22px 44px);height:54px;position:absolute;bottom:28px;left:-10px;right:-10px}.books .visual-stage{background:linear-gradient(135deg, #e8f5e9, var(--color-accent-blue))}.book{border-radius:8px 18px 18px 8px;width:120px;height:250px;position:absolute;bottom:78px;box-shadow:14px 18px 34px #18181b2e}.book-one{background:var(--color-accent-brown);left:24%;transform:rotate(-8deg)}.book-two{background:var(--color-accent-blue);left:39%}.book-three{background:var(--color-accent-yellow);left:54%;transform:rotate(8deg)}.stamp,.library-card{border:3px solid var(--color-text);background:#ffffffd1;position:absolute;right:18%}.stamp{color:var(--color-text);border-radius:999px;padding:18px;font-weight:900;top:96px;transform:rotate(-12deg)}.library-card{border-radius:12px;width:210px;height:136px;bottom:80px}.rare .visual-stage{background:linear-gradient(135deg,#f3f1ff,#7ed6c7)}.ai-panel,.map-card,.clinic-card{background:#ffffffe0;border-radius:18px;position:absolute;box-shadow:0 18px 40px #18181b24}.ai-panel{width:170px;height:170px;color:var(--blue);place-items:center;font-size:3rem;font-weight:950;display:grid;top:86px;left:18%}.map-card{background:linear-gradient(90deg,#0000 47%,#18181b40 48% 52%,#0000 53%),linear-gradient(#0000 47%,#18181b40 48% 52%,#0000 53%),#fff;width:260px;height:190px;bottom:80px;right:18%}.pin{background:var(--color-accent-yellow);border-radius:50% 50% 50% 0;width:40px;height:40px;position:absolute;bottom:178px;right:calc(18% + 104px);transform:rotate(-45deg)}.clinic-card{color:var(--color-text-strong);padding:18px 24px;font-weight:900;top:130px;right:24%}.dashboard .visual-stage{background:linear-gradient(135deg,#eef5ff,#cde6d7)}.widget{background:#ffffffe0;border:1px solid #18181b14;border-radius:18px;position:absolute;box-shadow:0 16px 32px #18181b1f}.weather-widget{width:210px;height:150px;top:72px;left:18%}.map-widget{width:270px;height:190px;bottom:68px;right:18%}.chart-widget{background:linear-gradient(135deg, #fff, var(--color-accent-brown));width:230px;height:120px;bottom:94px;left:28%}.location-dot{background:var(--color-accent-yellow);border:8px solid #fff;border-radius:999px;width:34px;height:34px;position:absolute;bottom:158px;right:30%}.house .visual-stage{background:linear-gradient(135deg, #fff4e0, var(--color-accent-blue))}.booking-card,.calendar-card,.room-card{background:#ffffffe6;border-radius:16px;position:absolute;box-shadow:0 18px 40px #18181b24}.booking-card{width:260px;height:180px;top:76px;left:18%}.calendar-card{background:repeating-linear-gradient(0deg,#0000 0 34px,#18181b14 34px 36px),repeating-linear-gradient(90deg,#0000 0 34px,#18181b14 34px 36px),#fff;width:180px;height:180px;top:120px;right:18%}.room-card{width:250px;height:130px;bottom:72px;right:27%}.house-roof{background:var(--color-text-strong);clip-path:polygon(50% 0,100% 60%,82% 60%,82% 100%,18% 100%,18% 60%,0 60%);width:180px;height:120px;position:absolute;bottom:132px;left:25%}.project-body{gap:18px;display:grid}.project-number,.project-kicker{color:#787d85;font-size:1.02rem;font-weight:850}.project-title-row{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.project-summary{color:#555a62;font-size:clamp(1.2rem,2vw,1.45rem);font-weight:800;line-height:1.5}.project-meta{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px 22px;margin:0;display:grid}.project-meta dt{color:var(--color-text-strong);font-weight:900}.project-meta dd{color:#858993;margin:4px 0 0;font-weight:650}.project-note{width:fit-content;color:var(--blue);background:#f4f7ff;border-radius:999px;padding:8px 12px;font-size:.92rem;font-weight:850}.project-copy{gap:8px;display:grid}.project-detail-grid{gap:16px;display:grid}.project-detail{gap:8px;display:grid}.project-detail h4{font-size:1rem;font-weight:900}.project-detail ul{gap:6px 18px;margin:0;padding-left:18px;display:grid}.featured .project-detail ul{grid-template-columns:repeat(2,minmax(0,1fr))}.outline-button{border:3px solid var(--color-text-strong);min-height:54px;color:var(--color-text-strong);background:#fff;border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:0 24px;font-size:1.05rem;font-weight:900;transition:transform .18s,background .18s,color .18s;display:inline-flex}.outline-button:hover{background:var(--color-text-strong);color:#fff;transform:translateY(-2px)}.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;display:grid}.skill-group{background:#fff;border:1px solid #e1e3e6;border-radius:8px;align-content:start;gap:24px;min-height:520px;padding:20px;transition:box-shadow .18s,transform .18s;display:grid;box-shadow:0 12px 34px #18181b0a}.skill-group:hover{transform:translateY(-3px);box-shadow:0 18px 48px #18181b17}.skill-heading{text-align:left;background:#f6f7f8;border-radius:8px;align-content:center;gap:12px;min-height:150px;padding:24px;display:grid}.skill-heading h3{color:var(--color-text-strong);font-size:clamp(1.8rem,2.4vw,2.65rem);font-weight:950;line-height:1}.skill-heading p{color:#858b94;max-width:280px;font-size:.95rem;font-weight:650;line-height:1.55}.skill-logo-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.skill-logo{color:#343941;text-align:center;background:#fff;border:1.5px dashed #cfd4dc;border-radius:8px;place-content:center;justify-items:center;gap:10px;min-height:112px;padding:14px 10px;display:grid}.skill-logo-featured{min-height:132px}.skill-logo-icon{width:42px;height:42px;color:var(--color-accent-brown)}.skill-logo span:last-child{color:#525861;word-break:keep-all;font-size:.84rem;font-weight:850;line-height:1.25}.skill-text-logo{min-width:56px;min-height:42px;color:var(--color-accent-brown);letter-spacing:0;background:#f0f4ff;border-radius:8px;align-items:center;padding:7px 9px;font-size:.76rem;font-weight:950;line-height:1.15;display:inline-grid}.contact-layout{gap:28px;width:min(1040px,100%);margin:0 auto;display:grid}.contact-lead{color:var(--color-text-strong);font-size:1.1rem;font-weight:850}.email-display{color:var(--color-text-strong);overflow-wrap:anywhere;font-size:clamp(2.4rem,6vw,6rem);font-weight:950;line-height:1.06}.contact-columns{grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);align-items:start;gap:48px;margin-top:22px;display:grid}.contact-actions{gap:14px;display:grid}.arrow-link{width:fit-content;color:var(--color-text-strong);align-items:center;gap:8px;font-weight:900;display:inline-flex}.arrow-link:hover{color:var(--blue)}.footer{border-top:1px solid var(--line);background:#fff;margin-top:80px}.footer-inner{grid-template-columns:1.4fr .7fr .7fr;gap:60px;width:min(1040px,100% - 80px);margin:0 auto;padding:54px 0 38px;display:grid}.footer h2{font-size:1.2rem;line-height:1.2}.footer-role{color:#777d86;margin-top:6px;font-size:.9rem}.footer h3{text-transform:uppercase;margin-bottom:14px;font-size:.82rem;font-weight:950}.footer a,.footer-link-button{color:#747983;cursor:pointer;background:0 0;border:0;width:fit-content;margin-top:9px;padding:0;font-size:.9rem;font-weight:650;display:block}.footer a:hover,.footer-link-button:hover{color:var(--blue)}.footer-copy-status{margin-top:9px;display:block}.copyright{border-top:1px solid var(--line);color:#8b8f97;width:min(1040px,100% - 80px);margin:0 auto;padding:20px 0 34px;font-size:.82rem}h1,h2,h3,h4,.project-title-row h3,.skill-heading h3,.email-display,.contact-lead,.project-detail-heading h1,.project-detail-section h2{color:var(--color-text-strong)}p,li,dd,.section-intro,.hero-summary,.resume-role,.project-english,.project-copy,.project-info-panel .project-copy,.project-overview p,.detail-list li,.footer-role{color:var(--color-muted)}.focus-ring:focus-visible{outline-color:#18181b47}.floating-nav,.nav-pill{background:#fffdf8d1;border-color:#18181b1f;box-shadow:0 14px 40px #18181b14}.nav-active{background:var(--color-accent-yellow);box-shadow:0 5px 18px #18181b14}.hero-copy h1 span{background:linear-gradient(180deg, transparent 58%, var(--color-accent-yellow) 58%);color:var(--color-text);border-radius:.18em;padding:0 .04em;display:inline-block}.hero-kicker,.section-eyebrow,.project-number,.project-kicker{color:var(--color-text)}.text-link,.arrow-link,.back-link{border-color:var(--color-border);color:var(--color-text)}.text-link:hover,.arrow-link:hover,.footer a:hover{color:var(--color-text-strong)}.hero-actions .text-link{border:1px solid var(--color-border);background:#fffdf89e;border-radius:999px;min-height:44px;padding:0 16px}.hero-actions .text-link:hover,.outline-button:hover,.back-link:hover,.detail-nav-card:hover{background:var(--color-accent-yellow);color:var(--color-text-strong);border-color:#18181b33}.chip,.skill-chip,.status-pill{border-color:var(--color-border);background:var(--color-surface-soft);color:var(--color-text)}.accent-chip,.status-pill,.project-note,.award-badge{background:var(--color-accent-yellow);color:var(--color-text);border-color:#18181b29}.resume-divider,.resume-date,.project-detail-meta dt,.project-meta dt,.detail-nav-card span{color:var(--color-muted)}.resume-divider:before,.resume-divider:after,.project-detail-section,.project-detail-nav,.footer,.copyright{border-color:var(--color-border)}.resume-date svg{color:#18181b57}.project-showcase-item,.project-card,.skill-group,.detail-list li,.detail-nav-card,.project-detail-meta,.back-link,.footer{border-color:var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-soft)}.project-showcase-item:first-child .status-pill,.project-showcase-item:first-child .chip:nth-child(odd){background:var(--color-accent-yellow)}.project-showcase-item:nth-child(2) .status-pill,.project-showcase-item:nth-child(2) .chip:nth-child(odd){background:var(--color-accent-blue)}.project-summary{color:var(--color-text-strong)}.project-detail-meta dd,.project-meta dd,.detail-nav-card strong{color:var(--color-text)}.project-video,.project-video-mockup,.project-visual{border-color:var(--color-border);background:var(--color-surface-soft);box-shadow:0 28px 58px #18181b1f}.mockup-copy,.visual-overlay{color:var(--color-surface)}.mockup-shape,.poster,.book,.ai-panel,.map-card,.clinic-card,.widget,.booking-card,.calendar-card,.room-card{background:#fffdf8e0;box-shadow:0 18px 42px #18181b24}.mockup-grid,.visual-stage:before{opacity:.48}.mockup-seogaro,.books .visual-stage{background:linear-gradient(135deg, var(--color-surface-soft), var(--color-primary-soft))}.mockup-rarepick,.rare .visual-stage{background:linear-gradient(135deg, var(--color-surface-soft), var(--color-accent) 48%, var(--color-primary-soft))}.mockup-dashboard,.dashboard .visual-stage{background:linear-gradient(135deg, var(--color-surface), var(--color-primary-soft))}.mockup-house,.house .visual-stage{background:linear-gradient(135deg, var(--color-surface), var(--color-accent) 54%, var(--color-surface-soft))}.mockup-rewind .shape-a,.film-strip{background:repeating-linear-gradient(90deg, var(--color-primary) 0 36px, var(--color-surface) 36px 46px, var(--color-primary) 46px 82px)}.mockup-rewind .shape-b,.poster,.poster-one{background:linear-gradient(160deg, var(--color-surface), var(--color-accent))}.mockup-rewind .shape-c,.poster-two,.chart-widget{background:linear-gradient(160deg, var(--color-surface), var(--color-primary-soft))}.mockup-robot .shape-a,.mockup-robot .shape-b,.radar{border-color:#dcecefc7}.mockup-robot .shape-c,.robot-body{border-color:var(--color-text-strong);background:var(--color-surface)}.mockup-robot .shape-d,.warning-line{background:repeating-linear-gradient(135deg, var(--color-primary) 0 20px, var(--color-accent) 20px 40px)}.mockup-seogaro .shape-a,.book-one{background:var(--color-accent-brown)}.mockup-seogaro .shape-b,.book-two{background:var(--color-accent-blue)}.mockup-seogaro .shape-c,.book-three{background:var(--color-accent-yellow)}.mockup-seogaro .shape-d,.stamp,.library-card{border-color:var(--color-text)}.mockup-rarepick .shape-b,.map-card{background:linear-gradient(90deg, transparent 47%, #18181b1f 48% 52%, transparent 53%), linear-gradient(0deg, transparent 47%, #18181b1f 48% 52%, transparent 53%), var(--color-surface)}.mockup-rarepick .shape-c,.pin,.location-dot,.sensor{background:var(--color-accent-yellow)}.mockup-dashboard .shape-a,.mockup-dashboard .shape-b,.mockup-dashboard .shape-c,.widget{border-color:var(--color-border)}.mockup-dashboard .shape-c{background:linear-gradient(135deg, var(--color-surface), var(--color-accent-blue))}.mockup-dashboard .shape-d,.location-dot{border-color:var(--color-surface)}.mockup-house .shape-b,.calendar-card{background:repeating-linear-gradient(0deg, transparent 0 30px, #18181b1a 30px 32px), repeating-linear-gradient(90deg, transparent 0 30px, #18181b1a 30px 32px), var(--color-surface)}.mockup-house .shape-d,.house-roof,.robot-head{background:var(--color-text-strong)}.visual-overlay{background:#18181b57}.skill-group{background:var(--color-surface)}.skill-group:hover,.project-showcase-item:hover{box-shadow:var(--shadow-card)}.skill-heading p,.skill-logo span:last-child{color:var(--color-muted)}.skill-logo{background:var(--color-surface);color:var(--color-text);border-color:#18181b33}.detail-list li:before{background:var(--color-accent-brown)}.contact-layout{background:var(--color-surface-soft);border-radius:8px;padding:clamp(28px,5vw,56px)}.contact-lead,.email-display,.arrow-link{color:var(--color-text-strong)}.footer{background:var(--color-surface);box-shadow:none}.footer a,.copyright{color:var(--color-muted)}body,.project-detail-page{background:var(--color-bg);color:var(--color-text)}.nav-link{color:var(--color-text)}.nav-active{background:var(--color-primary-soft)}.hero-actions .text-link,.detail-pill-button,.back-link,.detail-back-link{border-color:var(--color-border);color:var(--color-text);background:#ffffffbd}.hero-actions .text-link:hover,.detail-pill-button:hover,.outline-button:hover,.detail-bottom-card:hover,.back-link:hover{background:var(--color-primary-soft);color:var(--color-primary);border-color:#4f6df533}.chip,.skill-chip,.status-pill,.detail-tech-chip{border-color:var(--color-border);background:var(--color-surface-soft);color:var(--color-text)}.status-pill,.accent-chip,.project-note,.award-badge{background:var(--color-primary-soft);color:var(--color-primary)}.project-number,.project-kicker,.section-eyebrow,.detail-project-number,.detail-section-eyebrow{color:var(--color-primary)}.project-showcase-item,.project-card,.skill-group,.detail-list li,.detail-nav-card,.project-detail-meta,.detail-info-grid div,.detail-card-list li,.detail-bottom-card,.footer{border-color:var(--color-border);background:var(--color-surface);box-shadow:0 18px 48px #18181b0f}.project-showcase-item{background:var(--color-surface)}.project-info-panel{background:#ffffffc7}.project-video,.project-video-mockup,.project-visual,.detail-main-visual{border-color:var(--color-border);background:var(--color-surface-soft);box-shadow:0 24px 64px #4f6df51a}.mockup-rewind,.film .visual-stage{background:linear-gradient(135deg, #111827, var(--color-primary) 56%, var(--color-primary-soft))}.mockup-robot,.robot .visual-stage{background:linear-gradient(135deg, #18181b, var(--color-primary-soft) 62%, var(--color-accent-soft))}.mockup-seogaro,.books .visual-stage,.mockup-dashboard,.dashboard .visual-stage{background:linear-gradient(135deg, var(--color-surface), var(--color-primary-soft))}.mockup-rarepick,.rare .visual-stage,.mockup-house,.house .visual-stage{background:linear-gradient(135deg, var(--color-surface), var(--color-accent-soft) 54%, var(--color-primary-soft))}.mockup-copy span,.ott-pill,.my-list,.decade,.clinic-card,.stamp{color:var(--color-text-strong);background:#ffffffd6}.skill-heading{background:var(--color-surface-soft)}.skill-logo{background:var(--color-surface);border-color:#18181b29}.skill-logo:hover{background:var(--color-primary-soft)}.skill-logo-icon{color:var(--color-primary)}.skill-text-logo{background:var(--color-accent-soft);color:var(--color-text)}.contact-layout{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 18px 48px #18181b0d}.email-display{color:var(--color-primary)}.detail-highlight-list li.is-key-highlight{border-left-color:var(--color-primary);color:var(--color-text-strong);background:linear-gradient(90deg,#e8ecffe6,#0000 82%)}.detail-reference-layout{background:var(--color-bg);padding:54px 0 96px}.detail-article{width:min(980px,100% - 48px);margin:0 auto}.detail-topbar{margin-bottom:34px}.detail-back-link{color:var(--color-muted);align-items:center;gap:7px;font-size:.88rem;font-weight:800;display:inline-flex}.detail-back-link:hover{color:var(--color-text-strong)}.detail-hero-block{gap:14px;margin-bottom:28px;display:grid}.detail-project-number,.detail-section-eyebrow{color:var(--color-text);letter-spacing:.08em;font-size:.78rem;font-weight:950}.detail-hero-block h1{color:var(--color-text-strong);letter-spacing:-.045em;font-size:clamp(3.1rem,8vw,6.6rem);font-weight:950;line-height:.98}.detail-hero-block h1 span{color:var(--color-muted);letter-spacing:0;margin-top:8px;font-size:clamp(1.05rem,2.4vw,1.6rem);font-weight:850;line-height:1.2;display:block}.detail-hero-subtitle{max-width:780px;color:var(--color-text);font-size:clamp(1.08rem,1.8vw,1.38rem);font-weight:750;line-height:1.6}.detail-hero-meta{color:var(--color-muted);font-size:.98rem;font-weight:750}.detail-main-visual{border:1px solid var(--color-border);background:var(--color-surface);border-radius:10px;overflow:hidden;box-shadow:0 26px 70px #18181b1f}.detail-main-visual .project-video,.detail-main-visual .project-video-mockup{aspect-ratio:16/9;box-shadow:none;border:0;border-radius:0}.project-video-gallery{background:var(--color-surface);display:grid}.project-media-slider{aspect-ratio:16/9;background:var(--color-surface-soft);border-radius:10px;width:100%;position:relative;overflow:hidden}.project-media-slide{width:100%;height:100%}.project-slider-button{z-index:3;width:44px;height:44px;color:var(--color-text-strong);cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffc7;border:1px solid #18181b24;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 12px 32px #18181b24}.project-slider-button.prev{left:18px}.project-slider-button.next{right:18px}.project-slider-count,.project-slider-caption{z-index:3;color:var(--color-text-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd1;border-radius:999px;font-size:.85rem;font-weight:600;line-height:1;position:absolute}.project-slider-count{padding:8px 12px;bottom:18px;right:18px}.project-slider-caption{max-width:min(70%,520px);padding:8px 12px;bottom:18px;left:18px}.project-video-gallery .project-video{aspect-ratio:16/9;width:100%;box-shadow:none;object-fit:cover;border:0;border-radius:0}.project-video-gallery-controls{border-top:1px solid var(--color-border);background:#ffffffd6;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.project-video-link-controls{flex-wrap:wrap;justify-content:center}.gallery-nav-button{background:var(--color-primary-soft);color:var(--color-primary);cursor:pointer;font:inherit;border:0;border-radius:999px;align-items:center;gap:7px;padding:8px 14px;font-size:.86rem;font-weight:600;display:inline-flex}.gallery-nav-button:hover{background:var(--color-accent-soft);color:var(--color-text-strong)}.gallery-dots{align-items:center;gap:8px;display:inline-flex}.gallery-dot{cursor:pointer;background:#18181b2e;border:0;border-radius:999px;width:9px;height:9px;padding:0}.gallery-dot.active{background:var(--color-primary);width:24px}.detail-action-row{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:22px;margin:28px 0 14px;display:grid}.detail-title-summary{gap:8px;display:grid}.detail-title-summary strong{color:var(--color-text-strong);font-size:clamp(1.8rem,3.2vw,2.7rem);font-weight:950;line-height:1.05}.detail-title-summary p{max-width:760px;color:var(--color-muted);font-size:1rem;font-weight:650}.detail-link-buttons{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.detail-pill-button{border:1.5px solid var(--color-accent-brown);background:var(--color-surface);min-height:38px;color:var(--color-text);border-radius:999px;align-items:center;gap:7px;padding:0 14px;font-size:.86rem;font-weight:900;display:inline-flex}.detail-pill-button:hover{background:var(--color-accent-yellow)}.detail-tag-row{flex-wrap:wrap;gap:8px;margin:18px 0 42px;display:flex}.detail-tech-chip{background:var(--color-accent-blue);color:var(--color-text);border:1px solid #18181b1f;border-radius:999px;align-items:center;padding:7px 11px;font-size:.78rem;font-weight:850;line-height:1;display:inline-flex}.detail-info-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:0 0 58px;display:grid}.detail-info-grid div{border:1px solid var(--color-border);background:var(--color-surface);border-radius:10px;align-content:center;gap:8px;min-height:104px;padding:18px;display:grid}.detail-info-grid span{color:var(--color-muted);letter-spacing:.06em;text-transform:uppercase;font-size:.76rem;font-weight:950}.detail-info-grid strong{color:var(--color-text-strong);font-size:1rem;font-weight:900;line-height:1.45}.detail-article-section{border-top:1px solid var(--color-border);gap:18px;padding:52px 0;display:grid}.detail-article-section h2{color:var(--color-text-strong);letter-spacing:-.035em;font-size:clamp(2rem,4vw,3.2rem);font-weight:950;line-height:1.05}.detail-copy-block{gap:12px;max-width:820px;display:grid}.detail-copy-block p,.detail-learning-list p{color:#6f6259;font-size:1.02rem;font-weight:600;line-height:1.86}.detail-card-list{gap:14px;margin:0;padding:0;list-style:none;display:grid}.detail-card-list li{border:1px solid var(--color-border);background:var(--color-surface);border-radius:10px;grid-template-columns:54px minmax(0,1fr);align-items:start;gap:18px;padding:18px 20px;display:grid}.detail-card-list span{color:var(--color-text);font-size:1.05rem;font-weight:950}.detail-card-list p{color:#6f6259;font-size:.98rem;font-weight:650;line-height:1.68}.detail-card-list div{gap:8px;display:grid}.detail-card-list p strong{color:var(--color-text-strong);font-weight:900}.detail-highlight-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.detail-highlight-list li{border-left:4px solid var(--color-border);color:#6f6259;padding:10px 0 10px 18px;font-size:1rem;font-weight:650;line-height:1.72;position:relative}.detail-highlight-list li.is-key-highlight{border-left-color:var(--color-accent-brown);color:var(--color-text-strong);background:linear-gradient(90deg,#f4e6a675,#0000 78%);font-weight:850}.detail-learning-list{gap:12px;max-width:840px;display:grid}.detail-bottom-nav{border-top:1px solid var(--color-border);grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding-top:32px;display:grid}.detail-bottom-card{border:1px solid var(--color-border);background:var(--color-surface);border-radius:10px;align-content:center;gap:8px;min-height:94px;padding:18px;display:grid}.detail-bottom-card:hover{background:var(--color-surface-soft)}.detail-bottom-card span{color:var(--color-muted);text-transform:uppercase;font-size:.78rem;font-weight:950}.detail-bottom-card strong{color:var(--color-text-strong);align-items:center;gap:8px;font-size:1rem;line-height:1.35;display:inline-flex}.detail-bottom-home{background:var(--color-accent-yellow)}@media (width<=1180px){.hero-mark{min-height:220px}.hero-symbol{width:clamp(140px,22vw,220px);max-height:220px;margin-bottom:34px}.floating-nav-wrap{width:calc(100% - 28px)}.floating-nav{gap:12px}.nav-scroll{scrollbar-width:none;max-width:min(760px,100vw - 128px);overflow-x:auto}.nav-scroll::-webkit-scrollbar{display:none}.section-showcase{width:calc(100% - 48px)}.project-showcase-item,.project-showcase-item.is-reversed{grid-template-columns:1fr;gap:28px}.project-showcase-item.is-reversed .project-media-panel,.project-showcase-item.is-reversed .project-info-panel{order:initial}.project-showcase-item+.project-showcase-item{margin-top:34px}.project-showcase-item:nth-child(2n),.project-showcase-item:nth-child(3n){transform:none}.project-card,.project-card.featured{grid-template-columns:1fr;gap:30px}.project-visual,.project-card:not(.featured) .project-visual{min-height:460px}.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-detail-hero{grid-template-columns:1fr}.project-detail-meta{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=760px){h1{font-size:clamp(2.6rem,14vw,4rem)}h2{font-size:clamp(2.2rem,13vw,3.2rem)}.floating-nav-wrap{width:calc(100% - 32px);margin:-52px auto 72px;top:10px}.floating-nav{gap:6px;width:100%;max-width:calc(100vw - 32px);min-height:52px;padding:8px 10px;overflow-x:visible}.nav-dots{flex:none;gap:6px;padding:8px 9px}.nav-dots span{width:12px;height:12px}.nav-scroll{flex:auto;justify-content:space-between;gap:2px;max-width:none}.nav-link{white-space:nowrap;flex:auto;min-width:auto;min-height:36px;padding:8px 7px;font-size:.78rem}.nav-active{inset:3px}.hero-shell{gap:0;padding:64px 0 56px}.hero-mark{width:100%;min-height:180px}.hero-symbol{width:clamp(120px,38vw,180px);max-height:180px;margin-bottom:28px}.hero-copy h1{font-size:clamp(2.2rem,11vw,3.6rem);line-height:1.18}.hero-kicker{margin-bottom:20px}.hero-summary{margin-top:24px;font-size:.95rem}.hero-actions{margin-top:32px;margin-bottom:64px}.section-shell,.section-resume{width:calc(100% - 36px);padding:76px 0}.section-heading{margin-bottom:42px}.projects-grid{grid-template-columns:1fr}.project-showcase-list{gap:28px}.project-showcase-item{padding:14px}.project-showcase-item+.project-showcase-item{margin-top:0}.project-info-panel{gap:15px;padding:18px 4px 4px}.compact-project-meta{grid-template-columns:1fr}.project-video,.project-video-mockup{aspect-ratio:16/11}.project-detail-page{padding-top:24px}.project-detail-shell{gap:30px;width:calc(100% - 36px)}.project-detail-heading h1{font-size:clamp(2.4rem,13vw,4rem)}.project-detail-meta,.detail-list,.project-detail-nav{grid-template-columns:1fr}.project-detail-visual .project-video,.project-detail-visual .project-video-mockup{aspect-ratio:16/11}.detail-reference-layout{padding:28px 0 72px}.detail-article{width:calc(100% - 36px)}.detail-topbar{margin-bottom:28px}.detail-hero-block h1{font-size:clamp(2.6rem,14vw,4.3rem);line-height:1.04}.detail-hero-subtitle{font-size:1rem}.detail-main-visual .project-video,.detail-main-visual .project-video-mockup,.project-media-slider{aspect-ratio:16/11}.project-slider-button{width:38px;height:38px}.project-slider-button.prev{left:10px}.project-slider-button.next{right:10px}.project-slider-count{bottom:10px;right:10px}.project-slider-caption{max-width:none;bottom:10px;left:10px;right:68px}.detail-action-row,.detail-info-grid,.detail-bottom-nav{grid-template-columns:1fr}.detail-link-buttons{justify-content:flex-start}.detail-tag-row{margin-bottom:34px}.detail-info-grid{margin-bottom:42px}.detail-article-section{padding:40px 0}.detail-article-section h2{font-size:clamp(1.8rem,10vw,2.7rem)}.detail-card-list li{grid-template-columns:42px minmax(0,1fr);gap:12px;padding:16px}.mockup-copy{inset:auto 20px 20px}.mockup-copy strong{font-size:clamp(1.55rem,10vw,2.8rem)}.mockup-shape{transform-origin:50%;transform:scale(.82)}.project-card.featured{grid-column:auto}.resume-item{grid-template-columns:1fr;gap:16px}.resume-date{white-space:normal}.project-visual,.project-card:not(.featured) .project-visual{min-height:320px}.visual-overlay span{max-width:86%;font-size:clamp(2.2rem,15vw,4rem)}.project-meta{grid-template-columns:1fr}.project-title-row,.resume-title-row{display:grid}.featured .project-detail ul,.skills-grid,.contact-columns,.footer-inner,.skill-logo-grid{grid-template-columns:1fr}.contact-columns{gap:28px}.footer-inner,.copyright{width:calc(100% - 36px)}.footer{margin-top:36px}}@media (prefers-reduced-motion:reduce){:root{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.floating-nav,.nav-pill{border-color:var(--color-border);background:#ffffffc7;box-shadow:0 16px 48px #4f6df514}.nav-link.active{color:var(--color-primary)}.nav-active,.project-note,.award-badge,.status-pill{background:var(--color-primary-soft);color:var(--color-primary)}.nav-dots span:first-child{background:var(--color-primary)}.nav-dots span:nth-child(2){background:#22c55e}.nav-dots span:nth-child(3){background:#d9f99d}.hero-copy h1 span{background:linear-gradient(180deg, transparent 58%, var(--color-primary-soft) 58%);color:var(--color-primary)}.hero-actions .text-link:first-child,.outline-button{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.hero-actions .text-link:hover,.outline-button:hover,.detail-pill-button:hover,.detail-bottom-card:hover{background:var(--color-primary-soft);color:var(--color-primary);border-color:#4f6df538}.project-number,.project-kicker,.section-eyebrow,.detail-project-number,.detail-section-eyebrow,.email-display{color:var(--color-primary)}.project-showcase-item,.project-card,.skill-group,.detail-info-grid div,.detail-card-list li,.detail-bottom-card,.contact-layout,.footer{background:var(--color-surface);border-color:var(--color-border)}.project-showcase-item:hover,.skill-group:hover{box-shadow:0 20px 60px #4f6df51f}.skill-logo:hover,.detail-tech-chip{background:var(--color-primary-soft)}.detail-bottom-home,.skill-text-logo{background:var(--color-accent-soft)}h1,h2,h3,h4,.hero-copy h1,.section-heading h2,.project-title-row h3,.skill-heading h3,.detail-hero-block h1,.detail-article-section h2,.email-display,.contact-email-wave{font-family:Outfit,Pretendard,Inter,system-ui,sans-serif;font-weight:400}p,li,dd,.section-intro,.hero-summary,.project-summary,.resume-role,.project-english,.detail-copy-block p,.detail-learning-list p{font-weight:500}.nav-link,.text-link,.arrow-link,.outline-button,.chip,.skill-chip,.status-pill,.detail-tech-chip,.experience-kind,.project-number,.project-kicker,.section-eyebrow,.detail-project-number,.detail-section-eyebrow,.skill-logo span:last-child,.footer a,.footer h3{font-weight:600}#projects .project-preview-title{text-align:center;text-overflow:clip;white-space:normal;word-break:keep-all;overflow-wrap:normal;max-width:92%;max-height:2.05em;margin-inline:auto;display:block;overflow:hidden}#projects .project-media-overlay strong,#projects .project-preview-title{letter-spacing:-.052em;font-size:clamp(1.9rem,4vw,4.4rem);line-height:1.02}#projects .project-content-title{letter-spacing:-.045em;text-wrap:balance;word-break:keep-all;max-width:100%;font-size:clamp(1.45rem,2.6vw,2.6rem);line-height:1.08}@media (width<=760px){#projects .project-media-overlay strong,#projects .project-preview-title{font-size:clamp(1.8rem,8vw,3rem)}#projects .project-preview-title.is-long{font-size:clamp(1.45rem,6.8vw,2.4rem)}#projects .project-preview-title.is-extra-long{font-size:clamp(1.1rem,5vw,1.75rem)}#projects .project-content-title{font-size:clamp(1.35rem,7vw,2.3rem)}#projects .project-content-title.is-long{font-size:clamp(1.2rem,6vw,1.9rem)}#projects .project-content-title.is-extra-long{font-size:clamp(1rem,4.8vw,1.45rem)}}#projects .project-media-overlay{text-align:left;place-content:center start;justify-items:start;padding:clamp(32px,5vw,72px)}#projects .project-preview-title,#projects .project-preview-title.is-long,#projects .project-preview-title.is-extra-long{text-align:left;word-break:keep-all;overflow-wrap:normal;-webkit-box-orient:initial;-webkit-line-clamp:initial;max-width:min(58%,520px);max-height:none;text-overflow:clip!important;white-space:normal!important;display:block!important;overflow:visible!important}#projects .project-preview-title{letter-spacing:-.045em;font-size:clamp(1.55rem,3.1vw,3.3rem);line-height:1.04}#projects .project-preview-title.is-long{font-size:clamp(1.25rem,2.35vw,2.5rem);line-height:1.08}#projects .project-media-overlay>span{margin-left:2px}#projects .project-content-title{letter-spacing:-.035em;font-size:clamp(1.05rem,1.7vw,1.75rem);line-height:1.14}#projects .project-content-title.is-long{font-size:clamp(.98rem,1.45vw,1.45rem);line-height:1.18}#projects .project-content-title.is-extra-long{letter-spacing:-.015em;font-size:clamp(.9rem,1.2vw,1.2rem);line-height:1.25}@media (width<=768px){#projects .project-media-overlay{text-align:center;place-content:center;justify-items:center;padding:28px}#projects .project-preview-title,#projects .project-preview-title.is-long,#projects .project-preview-title.is-extra-long{text-align:center;max-width:86%}#projects .project-preview-title{font-size:clamp(1.55rem,7.5vw,2.6rem)}#projects .project-preview-title.is-long{font-size:clamp(1.25rem,6vw,2rem)}#projects .project-preview-title.is-extra-long{font-size:clamp(1rem,4.8vw,1.55rem)}#projects .project-content-title{font-size:clamp(1.15rem,5.4vw,1.85rem)}}#projects .project-content-title,#projects .project-content-title.is-long,#projects .project-content-title.is-extra-long{letter-spacing:-.045em;text-wrap:balance;word-break:keep-all;max-width:100%;font-size:clamp(2rem,2.8vw,3.4rem);line-height:1.12}#projects .project-content-title.is-extra-long{font-size:clamp(1.85rem,2.45vw,3rem);line-height:1.16}@media (width<=768px){#projects .project-content-title,#projects .project-content-title.is-long,#projects .project-content-title.is-extra-long{font-size:clamp(1.65rem,7.5vw,2.5rem);line-height:1.14}}#projects .project-comma-house .project-content-title{font-size:clamp(1.55rem,2.1vw,2.35rem)}#projects .project-comma-house .project-preview-title{font-size:clamp(1.25rem,2.4vw,2.7rem)}@media (width<=768px){#projects .project-comma-house .project-content-title{font-size:clamp(1.35rem,6vw,2rem)}#projects .project-comma-house .project-preview-title{font-size:clamp(1.2rem,5.8vw,2rem)}}.hero-copy h1{font-size:clamp(2.25rem,3.8vw,3.9rem)}.section-heading h2,#experience .section-heading h2{font-size:clamp(1.7rem,2.6vw,2.9rem)}.project-title-row h3,#projects .project-title-row h3{font-size:clamp(1.25rem,2.2vw,2.2rem)}p,li,dd,.section-intro,.hero-summary,.project-summary,.resume-content p,.detail-copy-block p,.detail-learning-list p{font-size:.9rem}.chip,.skill-chip,.status-pill,.detail-tech-chip{font-size:.78rem}@media (width<=760px){.hero-copy h1{font-size:clamp(2rem,9vw,3rem)}.section-heading h2,#experience .section-heading h2{font-size:clamp(1.55rem,8vw,2.35rem)}.project-title-row h3,#projects .project-title-row h3{font-size:clamp(1.2rem,6.5vw,2rem)}}.mockup-copy strong,.detail-title-summary strong,.detail-info-grid strong,.detail-card-list span,.detail-bottom-card strong{font-weight:600}body{font-size:15px}p,li,dd,.section-intro,.project-description,.project-summary,.hero-summary,.project-overview p,.detail-copy-block p,.detail-learning-list p{font-size:.95rem;line-height:1.7}h1{font-size:clamp(2.6rem,4.4vw,4.6rem);line-height:1.15}h2,.section-heading h2{font-size:clamp(2rem,3vw,3.2rem);line-height:1.15}h3,.card-title,.project-title,.project-title-row h3{font-size:clamp(1.4rem,2vw,2rem)}.section-shell,.section-showcase,.section-resume{width:min(100% - var(--container-padding), var(--container-max));padding-block:clamp(72px,10vw,120px)}.section-heading{margin-bottom:clamp(32px,5vw,56px)}.hero-shell{min-height:92vh;width:min(100% - var(--container-padding), 960px);padding:clamp(88px,11vh,144px) 0 clamp(48px,7vh,88px)}.hero-symbol{width:clamp(288px,31.2vw,480px);max-height:480px;margin-bottom:8px}.hero-copy h1{font-size:clamp(2.6rem,4.4vw,4.6rem);line-height:1.16}.hero-summary{max-width:560px;margin-top:24px;font-size:.98rem;line-height:1.75}.hero-actions{margin-top:28px;margin-bottom:52px}.floating-nav-wrap{width:fit-content;max-width:calc(100% - 40px)}.floating-nav{gap:10px;min-height:48px;padding:8px 14px}.floating-nav a,.nav-link{min-height:38px;padding:8px 14px;font-size:.9rem}.nav-dots{gap:10px;padding:8px 12px}.nav-dots span{width:12px;height:12px}.chip,.skill-chip,.status-pill,.detail-tech-chip,.experience-kind,.detail-pill-button,.text-link{padding:8px 12px;font-size:.82rem}.outline-button{min-height:44px;padding:0 18px;font-size:.9rem}.resume-list{gap:42px}.resume-item{grid-template-columns:180px minmax(0,1fr);gap:32px}.resume-date,.resume-role,.project-english{font-size:.95rem}.project-showcase-list{gap:clamp(64px,8vw,110px)}.project-showcase-item{gap:clamp(28px,4vw,56px);padding:clamp(16px,2vw,26px);box-shadow:0 16px 44px #18181b0f}.project-showcase-item+.project-showcase-item{margin-top:0}.project-info-panel{gap:14px;max-width:460px;padding:clamp(18px,2.4vw,28px)}.project-video,.project-video-mockup{aspect-ratio:16/10;max-height:420px}.mockup-copy strong{font-size:clamp(1.6rem,3.6vw,3.4rem)}.mockup-copy p,.mockup-copy span{font-size:.82rem}.skills-grid{gap:24px}.skill-group{min-height:430px;padding:18px}.skill-heading{min-height:118px;padding:18px}.skill-heading h3{font-size:1.4rem}.skill-heading p{font-size:.86rem}.skill-logo-grid{gap:12px}.skill-logo,.skill-logo-featured{min-height:78px;padding:12px}.skill-logo-icon{width:34px;height:34px}.skill-logo span:last-child{font-size:.78rem}.contact-layout{padding:clamp(24px,4vw,44px)}.email-display{font-size:clamp(2rem,5vw,4.8rem)}.detail-reference-layout{padding-inline:var(--container-padding)}.detail-article{width:min(100%,1080px)}.detail-hero-block h1{font-size:clamp(2.4rem,5vw,4.8rem)}.detail-main-visual .project-video,.detail-main-visual .project-video-mockup{max-height:520px}.detail-article-section{padding-block:56px}.detail-article-section h2{font-size:clamp(1.8rem,3vw,2.7rem)}@media (width<=760px){:root{--container-padding:40px}body{font-size:15px}.section-shell,.section-showcase,.section-resume,.hero-shell{width:min(100% - 40px,100%)}.section-shell,.section-showcase,.section-resume{padding-block:72px}.hero-shell{min-height:88vh;padding:84px 0 48px}.hero-mark{min-height:324px}.hero-symbol{width:clamp(264px,82vw,384px);max-height:384px;margin-bottom:6px}.hero-copy h1{font-size:clamp(2.2rem,10vw,3.4rem)}.floating-nav-wrap{max-width:calc(100% - 20px)}.floating-nav{padding:7px 8px}.floating-nav a,.nav-link{padding:7px 6px;font-size:.76rem}.nav-dots{gap:5px;padding:7px 8px}.nav-dots span{width:10px;height:10px}.resume-item{grid-template-columns:1fr}.project-info-panel{max-width:none}.skill-group{min-height:auto}.skill-logo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-reference-layout{padding-inline:20px}.detail-hero-block h1{font-size:clamp(2.2rem,11vw,3.6rem)}.detail-article-section{padding-block:42px}}#projects.section-showcase{width:min(100% - clamp(120px,24vw,420px),1040px);padding-top:clamp(180px,20vw,260px)}#projects .project-showcase-list{gap:clamp(24px,3.5vw,44px);display:grid}#projects .project-showcase-item,#projects .project-showcase-item.is-reversed{border:1px solid var(--color-border);background:var(--color-surface);border-radius:0;grid-template-columns:minmax(360px,.65fr) minmax(0,1.35fr);align-items:stretch;gap:0;padding:0;display:grid;overflow:hidden;transform:none;box-shadow:0 20px 60px #4f6df514}#projects .project-showcase-item.is-reversed{grid-template-columns:minmax(0,1.35fr) minmax(360px,.65fr)}#projects .project-showcase-item+.project-showcase-item{margin-top:0}#projects .project-showcase-item .project-info-panel{order:1}#projects .project-showcase-item .project-media-panel{order:2}#projects .project-showcase-item.is-reversed .project-media-panel{order:1}#projects .project-showcase-item.is-reversed .project-info-panel{order:2}#projects .project-media-panel,#projects .project-card-link{border-radius:0;align-self:stretch;min-width:0;height:100%;display:block;position:relative}#projects .project-info-panel{background:var(--color-surface);border-radius:0;align-content:center;max-width:none;min-height:560px;padding:clamp(38px,4.4vw,68px);display:grid}#projects .project-video,#projects .project-video-mockup{aspect-ratio:auto;width:100%;height:100%;min-height:560px;max-height:none;box-shadow:none;border:0;border-radius:0}#projects .project-info-panel{border-radius:0}#projects .project-video{object-fit:cover;display:block}#projects .project-card-link>.project-video,#projects .project-card-link>.project-video-mockup{height:100%}#projects .mockup-copy{display:none}#projects .project-media-overlay{z-index:5;color:#fff;text-align:center;pointer-events:none;background:#09090b6b;place-content:center;gap:18px;display:grid;position:absolute;inset:0}#projects .project-media-overlay strong{color:inherit;letter-spacing:-.06em;word-break:keep-all;font-size:clamp(2.2rem,4.8vw,5.2rem);font-weight:700;line-height:.95}#projects .project-preview-title{text-align:center;text-overflow:ellipsis;text-wrap:balance;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:90%;margin-inline:auto;display:-webkit-box;overflow:hidden}#projects .project-preview-title.is-long{letter-spacing:-.055em;font-size:clamp(1.8rem,3.6vw,4rem)}#projects .project-preview-title.is-extra-long{letter-spacing:-.04em;font-size:clamp(1.35rem,2.5vw,2.8rem);line-height:1.08}#projects .project-media-overlay span{color:inherit;font-size:clamp(1rem,1.5vw,1.35rem);font-weight:500;display:inline-block;position:relative}#projects .project-media-overlay span:after{content:"";background:currentColor;width:74px;height:2px;position:absolute;bottom:.35em;right:-92px}#projects .project-title-row{align-items:center}#projects .project-number{display:none}#projects .project-kicker{color:var(--color-muted);margin-bottom:8px;font-size:1.02rem}#projects .project-title-row h3{letter-spacing:-.06em;font-size:clamp(2.4rem,4.2vw,4.5rem);line-height:.95}#projects .status-pill{background:var(--color-accent);color:var(--color-text-strong)}#projects .project-summary{color:var(--color-muted);font-size:clamp(1rem,1.35vw,1.2rem);font-weight:500;line-height:1.55}#projects .project-meta{gap:8px 24px}#projects .project-meta dt{color:var(--color-text-strong);font-size:.95rem}#projects .project-meta dd{color:var(--color-muted);font-size:.95rem}#projects .chip{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-muted)}#projects .project-actions{margin-top:12px}@media (width<=768px){#projects.section-showcase{width:min(100% - 40px,100%);padding-top:clamp(110px,24vw,150px)}#projects .project-showcase-list{gap:clamp(32px,8vw,48px)}#projects .project-showcase-item,#projects .project-showcase-item.is-reversed{grid-template-columns:1fr}#projects .project-showcase-item .project-media-panel,#projects .project-showcase-item.is-reversed .project-media-panel{order:1}#projects .project-showcase-item .project-info-panel,#projects .project-showcase-item.is-reversed .project-info-panel{order:initial}#projects .project-video,#projects .project-video-mockup{min-height:clamp(260px,72vw,420px)}#projects .project-info-panel{order:2;min-height:auto;padding:28px}#projects .project-media-overlay strong{font-size:clamp(2rem,10vw,3.4rem)}#projects .project-preview-title.is-long{font-size:clamp(1.55rem,8vw,2.7rem)}#projects .project-preview-title.is-extra-long{font-size:clamp(1.25rem,6vw,2rem)}#projects .project-media-overlay span:after{width:48px;right:-62px}#projects .project-title-row h3{font-size:clamp(2rem,10vw,3.2rem)}}#projects .projects-grid,#projects .projects-showcase,#projects .project-showcase-list{gap:0}#projects .project-showcase-item,#projects .project-card,#projects .project-item{margin-top:0;margin-bottom:0}#projects .project-showcase-item+.project-showcase-item,#projects .project-card+.project-card,#projects .project-item+.project-item{margin-top:0}#projects .project-showcase-item,#projects .project-video,#projects .project-video-mockup,.skill-group,.skill-logo,.contact-layout{border:0}.contact-email-wave{color:var(--color-text-strong);letter-spacing:-.035em;overflow-wrap:anywhere;flex-wrap:wrap;align-items:baseline;font-family:Outfit,Inter,system-ui,sans-serif;font-size:clamp(2.4rem,7vw,7rem);font-weight:600;line-height:.95;text-decoration:none;display:inline-flex}.contact-email-wave:hover{color:var(--color-primary)}.contact-email-char{will-change:transform;display:inline-block}@media (width<=640px){.contact-email-wave{letter-spacing:-.03em;font-size:clamp(2rem,12vw,3.6rem);line-height:1}}.contact-email-wave{font-weight:400}.hero-mark{min-height:clamp(176px,18vw,260px)}.hero-symbol.hero-face-video{width:clamp(144px,15.6vw,240px);height:clamp(144px,15.6vw,240px);max-height:240px;margin-bottom:8px}@media (width<=640px){.hero-mark{min-height:220px}.hero-symbol.hero-face-video{width:clamp(132px,41vw,192px);height:clamp(132px,41vw,192px)}}body{font-family:Outfit,Pretendard,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:500}h1,h2,h3,h4,.hero-copy h1,.section-heading h2,.project-title-row h3,.skill-heading h3,.detail-hero-block h1,.detail-article-section h2{font-weight:600}p,li,dd,.section-intro,.hero-summary,.project-summary,.resume-role,.project-english{font-weight:500}.nav-link,.text-link,.arrow-link,.outline-button,.chip,.skill-chip,.status-pill,.detail-tech-chip,.experience-kind,.project-number,.project-kicker,.section-eyebrow,.skill-logo span:last-child,.footer a,.footer h3{font-weight:600}
