@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700;800&display=swap";:root{--zap-black: #201515;--cream: #fffefb;--off-white: #fffdf9;--orange: #ff4f00;--charcoal: #36342e;--warm-gray: #939084;--sand: #c5c0b1;--light-sand: #eceae3;--mid-warm: #b5b2aa;--overlay-dark: rgba(45, 45, 46, .5);--bg: var(--cream);--bg-alt: var(--off-white);--bg-inverse: var(--zap-black);--bg-muted: var(--light-sand);--fg: var(--zap-black);--fg-body: var(--charcoal);--fg-muted: var(--warm-gray);--fg-inverse: var(--cream);--border: var(--sand);--border-strong: var(--charcoal);--border-muted: var(--mid-warm);--accent: var(--orange);--accent-fg: var(--cream);--link: var(--zap-black);--focus-ring: var(--orange);--font-display: "Bricolage Grotesque", "Degular Display", system-ui, sans-serif;--font-sans: "Inter", Helvetica, Arial, sans-serif;--font-serif: "Cormorant Garamond", "GT Alpina", Georgia, serif;--font-mono: ui-monospace, "SF Mono", Menlo, monospace;--s-1: 1px;--s-4: 4px;--s-6: 6px;--s-8: 8px;--s-10: 10px;--s-12: 12px;--s-16: 16px;--s-20: 20px;--s-24: 24px;--s-32: 32px;--s-40: 40px;--s-48: 48px;--s-56: 56px;--s-64: 64px;--s-72: 72px;--s-80: 80px;--r-tight: 3px;--r-sm: 4px;--r-md: 5px;--r-lg: 8px;--r-xl: 14px;--r-pill: 20px;--elev-0: none;--elev-1: 0 0 0 1px var(--sand) inset;--elev-1b: 0 0 0 1px var(--charcoal) inset;--tab-active: rgb(255, 79, 0) 0px -4px 0px 0px inset;--tab-hover: rgb(197, 192, 177) 0px -4px 0px 0px inset;--max-content: 1200px;--section-py: 80px}html,body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.t-display-xl{font-family:var(--font-display);font-size:80px;font-weight:500;line-height:.9;letter-spacing:0;color:var(--fg)}.t-display{font-family:var(--font-display);font-size:56px;font-weight:500;line-height:.95;letter-spacing:0;color:var(--fg)}.t-display-sm{font-family:var(--font-display);font-size:40px;font-weight:500;line-height:.9;color:var(--fg)}.t-display-btn{font-family:var(--font-display);font-size:24px;font-weight:600;line-height:1;letter-spacing:1px}.t-h1{font-family:var(--font-sans);font-size:48px;font-weight:500;line-height:1.04;color:var(--fg)}.t-h2{font-family:var(--font-sans);font-size:36px;font-weight:500;line-height:1.1;letter-spacing:-1px;color:var(--fg)}.t-h3{font-family:var(--font-sans);font-size:32px;font-weight:400;line-height:1.25;color:var(--fg)}.t-h4{font-family:var(--font-sans);font-size:28px;font-weight:500;line-height:1.2;color:var(--fg)}.t-card-title{font-family:var(--font-sans);font-size:24px;font-weight:600;line-height:1.2;letter-spacing:-.48px;color:var(--fg)}.t-editorial{font-family:var(--font-serif);font-size:48px;font-weight:300;line-height:1;letter-spacing:-1.92px;color:var(--fg)}.t-editorial-sub{font-family:var(--font-serif);font-size:40px;font-weight:300;line-height:1.08;letter-spacing:-1.6px;color:var(--fg)}.t-body-lg{font-family:var(--font-sans);font-size:20px;font-weight:400;line-height:1.2;letter-spacing:-.2px;color:var(--fg-body)}.t-body-emphasis{font-family:var(--font-sans);font-size:18px;font-weight:600;line-height:1;color:var(--fg)}.t-body{font-family:var(--font-sans);font-size:16px;font-weight:400;line-height:1.5;letter-spacing:-.16px;color:var(--fg-body)}.t-body-semibold{font-family:var(--font-sans);font-size:16px;font-weight:600;line-height:1.16;color:var(--fg)}.t-button{font-family:var(--font-sans);font-size:16px;font-weight:600;line-height:1}.t-button-sm{font-family:var(--font-sans);font-size:14px;font-weight:600;line-height:1}.t-caption{font-family:var(--font-sans);font-size:14px;font-weight:500;line-height:1.4;color:var(--fg-body)}.t-caption-upper{font-family:var(--font-sans);font-size:14px;font-weight:600;line-height:1;letter-spacing:.5px;text-transform:uppercase;color:var(--fg-body)}.t-micro{font-family:var(--font-sans);font-size:12px;font-weight:600;line-height:1;letter-spacing:.5px;text-transform:uppercase;color:var(--fg-muted)}.t-micro-sm{font-family:var(--font-sans);font-size:13px;font-weight:500;line-height:1.5;color:var(--fg-muted)}h1{font-family:var(--font-display);font-size:56px;font-weight:500;line-height:.95;color:var(--fg);margin:0 0 24px}h2{font-family:var(--font-sans);font-size:36px;font-weight:500;line-height:1.1;letter-spacing:-1px;color:var(--fg);margin:0 0 20px}h3{font-family:var(--font-sans);font-size:24px;font-weight:600;line-height:1.2;letter-spacing:-.48px;color:var(--fg);margin:0 0 12px}h4{font-family:var(--font-sans);font-size:18px;font-weight:600;color:var(--fg);margin:0 0 8px}p{font-family:var(--font-sans);font-size:16px;font-weight:400;line-height:1.5;letter-spacing:-.16px;color:var(--fg-body);margin:0 0 16px}a{color:var(--link);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}a:hover{text-decoration:none}small{font-size:13px;color:var(--fg-muted)}hr{border:0;border-top:1px solid var(--border);margin:32px 0}code,pre{font-family:var(--font-mono);font-size:14px}::selection{background:var(--orange);color:var(--cream)}:focus-visible{outline:1px solid var(--focus-ring);outline-offset:2px}:root{--font-korean: "Inter", "Noto Sans KR", "Apple SD Gothic Neo", "Pretendard", "Malgun Gothic", sans-serif;--font-korean-heading: "Noto Sans KR", "Apple SD Gothic Neo", "Pretendard", "Inter", sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:72px}body{margin:0;min-width:320px;color:var(--fg);font-family:var(--font-korean);line-height:1.65;word-break:keep-all;overflow-wrap:break-word;background:linear-gradient(90deg,rgba(197,192,177,.18) 1px,transparent 1px) 0 0 / 80px 80px,var(--cream)}button,a{font:inherit}img{display:block;max-width:100%}.site-header{position:sticky;top:0;z-index:50;height:72px;display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:24px;padding:0 32px;background:#fffefbeb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand img{width:92px;height:auto}.site-header nav{display:flex;justify-content:center;gap:8px}.site-header nav a,.header-cta{min-height:40px;display:inline-flex;align-items:center;gap:8px;padding:0 12px;color:var(--fg);text-decoration:none;border-radius:var(--r-md);font-size:14px;font-weight:600;transition:background .22s cubic-bezier(.2,0,0,1),box-shadow .22s cubic-bezier(.2,0,0,1),color .22s cubic-bezier(.2,0,0,1)}.site-header nav a:hover,.site-header nav a[aria-current=page]{box-shadow:var(--tab-hover)}.site-header nav a[aria-current=page]{color:var(--zap-black);box-shadow:var(--tab-active)}.header-cta{border:1px solid var(--border);background:var(--bg-muted);color:var(--zap-black)}.header-cta:hover,.header-cta[aria-current=page]{border-color:var(--zap-black);background:var(--zap-black);color:var(--cream);box-shadow:inset 0 -4px 0 var(--accent)}.hero{position:relative;min-height:calc(100svh - 72px);display:grid;grid-template-columns:minmax(0,.95fr) minmax(340px,.58fr);column-gap:clamp(36px,5.4vw,80px);row-gap:clamp(16px,2.6vh,28px);align-items:center;max-width:1280px;margin:0 auto;padding:clamp(32px,5vh,56px) 40px clamp(20px,3.5vh,36px)}.hero-copy{min-width:0}.eyebrow{width:fit-content;display:inline-flex;align-items:center;gap:8px;margin:0 0 24px;padding:7px 12px;border:1px solid var(--border);border-radius:var(--r-pill);background:var(--cream);color:var(--fg-body);font-size:12px;font-weight:700;letter-spacing:.5px;line-height:1;text-transform:uppercase}.eyebrow span{width:7px;height:7px;border-radius:999px;background:var(--accent)}.hero h1,.section-intro h2,.closing h2{margin:0;color:var(--fg);font-family:var(--font-korean-heading);font-weight:800;letter-spacing:0;text-wrap:balance}.hero h1{max-width:760px;font-size:clamp(42px,3.55vw,54px);line-height:1.16}.hero h1 span{display:block;white-space:nowrap}.hero-lede{max-width:660px;margin:22px 0 0;color:var(--fg-body);font-size:clamp(16px,1.35vw,18px);line-height:1.7}.hero-proof{max-width:560px;margin:18px 0 0;padding-left:16px;border-left:2px solid var(--accent);color:var(--fg-muted);font-size:14px;font-weight:600;line-height:1.72}.hero-actions,.closing-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.btn{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 22px;border:1px solid var(--zap-black);border-radius:var(--r-sm);text-decoration:none;font-weight:700;transition:background .22s cubic-bezier(.2,0,0,1),border-color .22s cubic-bezier(.2,0,0,1),color .22s cubic-bezier(.2,0,0,1)}.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}.btn-secondary{background:var(--zap-black);color:var(--cream)}.btn-primary:hover,.btn-secondary:hover{background:var(--border);border-color:var(--border);color:var(--zap-black)}.btn:active,.header-cta:active{background:var(--charcoal);color:var(--cream)}.btn-inverse{border-color:#fffefb85;color:var(--cream)}.btn-inverse:hover{background:var(--cream);color:var(--zap-black)}.profile-pass{position:relative;align-self:stretch;display:flex;flex-direction:column;min-height:580px;padding:18px;background:var(--off-white);border:1px solid var(--border-strong);border-radius:var(--r-lg);transition:border-color .26s cubic-bezier(.2,0,0,1),transform .26s cubic-bezier(.2,0,0,1)}.profile-pass:before{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;z-index:-1;border:1px solid var(--orange);border-radius:var(--r-lg);transform:rotate(-2deg)}.pass-topline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;color:var(--fg-body);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pass-topline img{width:42px;border-radius:var(--r-md)}.profile-pass figure{flex:1;min-height:0;margin:0;overflow:hidden;border:1px solid var(--border);border-radius:var(--r-md);background:var(--orange)}.profile-pass figure img{width:100%;height:100%;object-fit:cover;object-position:50% 23%;transition:transform .42s cubic-bezier(.2,0,0,1)}.profile-pass:hover{border-color:var(--accent);transform:translateY(-2px)}.profile-pass:hover figure img{transform:scale(1.025)}.pass-grid{display:grid;grid-template-columns:92px 1fr;gap:0;margin-top:18px;border:1px solid var(--border);border-bottom:0}.pass-grid span,.pass-grid strong{min-height:42px;display:flex;align-items:center;padding:8px 10px;border-bottom:1px solid var(--border);color:var(--fg);font-size:13px;line-height:1.2}.pass-grid span{background:var(--light-sand);color:var(--fg-muted);font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pass-grid strong{font-weight:700}.keyword-strip{grid-column:1 / -1;width:100%;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));align-items:center;gap:8px;padding:8px;border:1px solid var(--border);border-radius:var(--r-lg);background:#fffefbc7}.keyword-strip span{display:inline-flex;align-items:center;justify-content:space-between;min-height:38px;gap:10px;padding:0 10px;color:var(--zap-black);font-family:var(--font-display);font-size:clamp(15px,1.15vw,18px);font-weight:700;line-height:1;border-radius:var(--r-md);transition:background .22s cubic-bezier(.2,0,0,1),color .22s cubic-bezier(.2,0,0,1)}.keyword-strip span:hover{background:var(--light-sand)}.keyword-strip i{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border-radius:var(--r-tight);background:var(--accent);color:var(--accent);font-family:var(--font-sans);font-style:normal;font-size:0}.keyword-strip i:before{content:"→";color:var(--cream);font-size:14px;line-height:1}.section{min-height:calc(100svh - 72px);display:flex;align-items:center;padding:clamp(64px,7vw,84px) 0;border-top:1px solid var(--border);scroll-margin-top:72px}.section-inner{width:min(1200px,calc(100% - 80px));margin:0 auto}.overview-section .section-inner{min-height:min(760px,calc(100svh - 200px));display:flex;flex-direction:column;justify-content:center}.section-intro{display:grid;grid-template-columns:minmax(0,.95fr) minmax(320px,.72fr);gap:56px;align-items:start}.section-intro .eyebrow{grid-column:1 / -1;margin-bottom:0}.section-intro h2{max-width:760px;font-size:clamp(34px,4.2vw,56px);line-height:1.22}.section-intro>p:last-child{max-width:620px;margin:0;padding-top:6px;color:var(--fg-body);font-size:17px;line-height:1.82}.problem .section-intro,.approach-section .section-intro,.portfolio .section-intro,.case .section-intro{grid-template-columns:minmax(0,.95fr) minmax(360px,.78fr);gap:clamp(48px,5.5vw,72px);align-items:start}.problem .section-intro>p:last-child,.approach-section .section-intro>p:last-child,.portfolio .section-intro>p:last-child,.case .section-intro>p:last-child{max-width:640px;padding-top:12px;color:var(--fg-body);font-size:clamp(18px,1.35vw,20px);font-weight:500;line-height:1.86}.featured-title-line{display:block;white-space:nowrap}.problem-lines,.approach-lines,.project-lines,.featured-lines{display:grid;gap:8px}.problem-lines span,.approach-lines span,.project-lines span,.featured-lines span{display:block}.experience-lines{display:grid;gap:18px}.experience-lines span{display:block}.experience-group{display:grid;gap:0}.problem,.portfolio,.case{background:var(--off-white)}.problem-grid,.approach-grid,.case-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:48px}.overview-section .problem-grid,.overview-section .approach-grid{gap:22px;margin-top:clamp(56px,7vh,92px)}.problem-card,.approach-card,.case-card,.project-card{background:var(--cream);border:1px solid var(--border);border-radius:var(--r-lg);transition:background .26s cubic-bezier(.2,0,0,1),border-color .26s cubic-bezier(.2,0,0,1)}.problem-card,.approach-card,.case-card{padding:26px}.overview-section .problem-card,.overview-section .approach-card{min-height:clamp(260px,27vh,330px);padding:clamp(28px,2.4vw,36px)}.problem-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:42px}.problem-card span{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:var(--accent);color:var(--cream);font-family:var(--font-display);font-size:13px;font-weight:700;transition:background .24s cubic-bezier(.2,0,0,1),color .24s cubic-bezier(.2,0,0,1)}.problem-card small{color:var(--fg-muted);font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.problem-card:hover,.approach-card:hover,.case-card:hover,.project-card:hover{border-color:var(--border-strong)}.problem-card:hover span{background:var(--zap-black)}.problem-card h3,.approach-card h3,.case-card h3{margin:0 0 12px;color:var(--fg);font-size:22px;line-height:1.36}.problem-card p,.approach-card p,.case-card p{margin:0;color:var(--fg-body);font-size:15px;line-height:1.76}.approach-card{min-height:clamp(280px,30vh,350px);display:flex;flex-direction:column}.approach-card:nth-child(1){background:#fbf4e6}.approach-card:nth-child(2){background:#f7ded9}.approach-card:nth-child(3){background:#e5eee0}.icon-wrap{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:auto;border:1px solid var(--border);border-radius:var(--r-md);background:var(--cream);color:var(--fg);transition:background .24s cubic-bezier(.2,0,0,1),border-color .24s cubic-bezier(.2,0,0,1),color .24s cubic-bezier(.2,0,0,1)}.approach-card:hover .icon-wrap{border-color:var(--border-strong);background:var(--zap-black);color:var(--cream)}.approach-card small{margin-top:36px;margin-bottom:10px;color:var(--fg-body);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.project-flow{display:grid;gap:32px;margin-top:56px}.project-card{display:grid;grid-template-columns:minmax(300px,.62fr) minmax(0,1fr);gap:0;overflow:hidden}.project-card:nth-child(2n){grid-template-columns:minmax(0,1fr) minmax(300px,.62fr)}.project-card:nth-child(2n) .project-visual{order:2}.project-visual{min-height:420px;display:flex;align-items:center;justify-content:center;padding:clamp(28px,4vw,48px);border-right:1px solid var(--border);background:linear-gradient(90deg,rgba(197,192,177,.18) 1px,transparent 1px) 0 0 / 48px 48px,#f7f1e7;transition:background .32s cubic-bezier(.2,0,0,1)}.project-card:nth-child(2n) .project-visual{border-right:0;border-left:1px solid var(--border)}.project-visual.meal{background:linear-gradient(90deg,rgba(197,192,177,.16) 1px,transparent 1px) 0 0 / 48px 48px,#f5eee6}.project-visual.ops{background:linear-gradient(90deg,rgba(197,192,177,.16) 1px,transparent 1px) 0 0 / 48px 48px,#f3eadf}.project-body{display:grid;align-content:center;padding:clamp(32px,4.5vw,56px)}.project-kicker{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:22px;color:var(--fg-muted);font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.project-kicker span{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:28px;padding:0 8px;background:var(--zap-black);color:var(--cream);border-radius:var(--r-tight);transition:background .22s cubic-bezier(.2,0,0,1),color .22s cubic-bezier(.2,0,0,1)}.project-card:hover .project-kicker span{background:var(--accent)}.project-body h3{margin:0;color:var(--fg);font-family:var(--font-korean-heading);font-size:clamp(40px,4.6vw,68px);font-style:normal;font-weight:800;letter-spacing:0;line-height:1.12}.project-title{margin:24px 0 12px;color:var(--fg);font-size:17px;font-weight:700;line-height:1.68}.project-body p:not(.project-title){margin:0 0 14px;color:var(--fg-body);line-height:1.78}.project-role{padding-top:12px;border-top:1px dashed var(--border)}.project-board{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));margin:24px 0 0;border-top:1px solid var(--border-strong);border-bottom:1px solid var(--border)}.project-board div{padding:16px 16px 18px 0}.project-board div+div{padding-left:16px;border-left:1px solid var(--border)}.project-board dt{margin:0 0 8px;color:var(--accent);font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.project-board dd{margin:0;color:var(--fg);font-size:14px;font-weight:650;line-height:1.5}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}.tag-row span{display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-pill);background:var(--light-sand);color:var(--fg-body);font-size:13px;font-weight:600;line-height:1.35}.project-link{width:fit-content;display:inline-flex;align-items:center;margin-top:20px;color:var(--zap-black);font-weight:800;text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px}.project-link:hover{color:var(--accent);text-decoration:none}.artifact-stack{width:min(100%,360px);display:grid;gap:12px}.screenshot-stack{justify-items:start}.screenshot-stack.mobile-shot{width:min(100%,230px)}.screenshot-stack.desktop-shot{width:min(100%,460px)}.artifact-label{width:fit-content;padding:6px 10px;border:1px solid rgba(32,21,21,.2);border-radius:var(--r-tight);background:var(--cream);color:var(--fg);font-family:var(--font-display);font-size:13px;font-weight:800;transition:background .22s cubic-bezier(.2,0,0,1),border-color .22s cubic-bezier(.2,0,0,1),color .22s cubic-bezier(.2,0,0,1)}.mock{width:100%;padding:18px;border:1px solid rgba(32,21,21,.22);border-radius:var(--r-lg);background:var(--cream);color:var(--fg);transition:border-color .26s cubic-bezier(.2,0,0,1)}.project-card:hover .artifact-label{border-color:var(--accent);background:var(--accent);color:var(--cream)}.project-card:hover .mock{border-color:var(--border-strong)}.screenshot-frame{position:relative;width:100%;overflow:hidden;border:1px solid rgba(32,21,21,.22);border-radius:var(--r-lg);background:var(--cream);cursor:zoom-in;padding:0;transition:border-color .26s cubic-bezier(.2,0,0,1)}.project-card:hover .screenshot-frame{border-color:var(--border-strong)}.screenshot-frame img{width:100%;height:100%;display:block;object-fit:cover;object-position:top center}.screenshot-zoom{position:absolute;right:10px;bottom:10px;padding:6px 9px;border:1px solid rgba(255,254,251,.28);border-radius:var(--r-tight);background:#201515d1;color:var(--cream);font-size:11px;font-weight:800;opacity:0;transition:opacity .2s cubic-bezier(.2,0,0,1)}.screenshot-frame:hover .screenshot-zoom,.screenshot-frame:focus-visible .screenshot-zoom{opacity:1}.screenshot-frame-mobile{aspect-ratio:354 / 770}.screenshot-frame-desktop{aspect-ratio:16 / 9;background:#080808}.screenshot-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:28px;background:#201515b8}.screenshot-modal-panel{width:min(1120px,100%);max-height:min(860px,calc(100svh - 56px));display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--cream)}.screenshot-modal-panel.mobile-modal{width:min(460px,100%)}.screenshot-modal-top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--border)}.screenshot-modal-top span{color:var(--fg-muted);font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.screenshot-modal-top h3{margin:4px 0 0;color:var(--fg);font-family:var(--font-display);font-size:24px;line-height:1}.screenshot-modal-top button{min-height:36px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--light-sand);color:var(--fg);cursor:pointer;font-weight:800}.screenshot-modal-image{min-height:0;overflow:auto;background:var(--off-white)}.screenshot-modal-image img{width:100%;display:block}.desktop-modal .screenshot-modal-image{background:#080808}.modal-link{margin:0;padding:14px 18px;border-top:1px solid var(--border)}.mock-spec{display:grid;gap:14px;transform:rotate(-3deg)}.mock-spec strong,.mock-meal strong,.mock-ops strong{font-family:var(--font-korean-heading);font-size:22px;line-height:1.25}.mock-spec section{display:grid;gap:7px;padding:10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--off-white)}.mock-spec section p{margin:0;color:var(--fg);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.mock-spec section span{height:8px;border-radius:999px;background:var(--light-sand)}.mock-spec section span:nth-child(2){width:72%}.mock-spec section span:nth-child(3){width:54%}.mock-spec div{display:flex;flex-wrap:wrap;gap:6px}.mock-spec i{padding:6px 8px;border-radius:var(--r-tight);background:#fbf4e6;color:#6c4b00;font-size:10px;font-style:normal;font-weight:800;letter-spacing:.5px}.mock-meal{aspect-ratio:9 / 15;display:flex;flex-direction:column;gap:12px;transform:rotate(2deg)}.meal-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:8px}.meal-grid span{border-radius:var(--r-md);background:linear-gradient(135deg,#f0d4a8,#d08a53)}.meal-grid span:nth-child(2){background:linear-gradient(135deg,#f4d4ce,#d8463a)}.meal-grid span:nth-child(3){background:linear-gradient(135deg,#e8e0c8,#92753c)}.meal-grid span:nth-child(4){background:linear-gradient(135deg,#dfe8d9,#7b9c73)}.mock-meal p{margin:0;color:var(--fg-body);font-size:13px;font-weight:600}.mock-ops{display:grid;gap:12px;transform:rotate(-2deg)}.ops-row{display:grid;grid-template-columns:88px 1fr;gap:12px;align-items:center}.ops-row span{color:var(--fg-body);font-size:12px;font-weight:700}.ops-row i{height:8px;border-radius:999px;background:var(--light-sand)}.case-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.case-card{min-height:250px}.case-card span{display:inline-flex;margin-bottom:42px;padding:6px 9px;border-radius:var(--r-tight);background:var(--zap-black);color:var(--cream);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;transition:background .22s cubic-bezier(.2,0,0,1)}.case-card:nth-child(1) span{background:var(--accent)}.case-card:nth-child(2) span{background:#f4c44e;color:var(--fg)}.case-card:nth-child(3) span{background:#a8c8d8;color:var(--fg)}.case-card:nth-child(4) span{background:#c8d8c2;color:var(--fg)}.featured-note{margin:32px 0 0;padding:22px 24px;border:1px solid var(--border-strong);border-radius:var(--r-lg);background:var(--zap-black);color:var(--cream);font-family:var(--font-korean-heading);font-size:clamp(19px,2vw,28px);font-weight:800;line-height:1.45}.featured-note span{display:block}.skills-section{background:var(--cream)}.skills-section .section-inner{display:grid;grid-template-columns:minmax(500px,.92fr) minmax(0,1fr);gap:clamp(40px,4vw,56px);align-items:center}.skills-section .section-intro{display:block}.skills-section .section-intro .eyebrow{margin-bottom:28px}.skills-section .section-intro h2{max-width:560px;font-size:clamp(34px,3.6vw,52px)}.intro-title-line{display:block}.skills-section .section-intro>p:last-child{max-width:560px;margin-top:22px;padding-top:0}.skills-table{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--border-strong)}.skill-row{position:relative;display:grid;grid-template-columns:minmax(104px,.2fr) minmax(0,1fr);gap:18px;align-items:start;padding:20px 0 20px 18px;border-bottom:1px solid var(--border);transition:background .22s cubic-bezier(.2,0,0,1)}.skill-row:before{content:"";position:absolute;left:0;top:20px;bottom:20px;width:4px;border-radius:var(--r-tight);background:var(--light-sand);transition:bottom .22s cubic-bezier(.2,0,0,1),top .22s cubic-bezier(.2,0,0,1),width .22s cubic-bezier(.2,0,0,1)}.skill-row:hover{background:#eceae357}.skill-row:hover:before{top:14px;bottom:14px;width:6px}.skill-row:nth-child(1):before,.skill-row:nth-child(4):before{background:var(--accent)}.skill-row:nth-child(2):before,.skill-row:nth-child(5):before{background:#f4c44e}.skill-row:nth-child(3):before,.skill-row:nth-child(6):before{background:#a8c8d8}.skill-head{display:grid;gap:8px}.skill-head span{color:var(--fg-muted);font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.5px}.skill-row strong{color:var(--fg);font-family:var(--font-display);font-size:clamp(16px,1.15vw,18px);line-height:1.08;text-transform:uppercase}.skill-copy{display:grid;gap:8px}.skill-copy h3{margin:0;color:var(--fg);font-family:var(--font-korean-heading);font-size:clamp(18px,1.35vw,22px);line-height:1.42}.skill-copy p{margin:0;color:var(--fg-body);font-size:15px;line-height:1.72}.skill-detail-lines{display:grid;gap:0}.skill-detail-lines span{display:block}.closing{padding:112px 0 64px;background:var(--zap-black);color:var(--cream)}.closing .section-inner{width:min(1200px,calc(100% - 80px));display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.42fr);column-gap:clamp(40px,6vw,80px);row-gap:clamp(32px,4vw,48px);align-items:start}.closing-heading{grid-column:1 / -1;max-width:920px}.eyebrow.inverse{border-color:#fffefb4d;background:transparent;color:var(--cream)}.closing h2{color:var(--cream);font-size:clamp(34px,4.4vw,60px);line-height:1.22}.closing-title-line,.closing-lines span{display:block}.closing-title-line{white-space:nowrap}.closing p:not(.eyebrow){max-width:760px;margin:26px 0 0;color:#fffefbc7;font-size:18px;line-height:1.82}.closing-copy .closing-lines:first-child{margin-top:0}.contact-card{display:grid;gap:0;border:1px solid rgba(255,254,251,.3);border-radius:var(--r-lg);background:#fffefb0a}.contact-card div{display:grid;gap:10px;padding:22px}.contact-card div+div{border-top:1px solid rgba(255,254,251,.2)}.contact-card span{color:#fffefb8f;font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.contact-card strong,.contact-card a{color:var(--cream);font-size:16px;font-weight:700;line-height:1.35}.contact-card a{width:fit-content;text-decoration:underline;text-underline-offset:4px}.contact-card a:hover{text-decoration:none}@media (min-width: 981px){.hero{height:calc(100svh - 72px);min-height:640px;padding-top:clamp(28px,4.5vh,48px);padding-bottom:clamp(18px,3vh,32px)}.profile-pass{min-height:min(500px,calc(100svh - 214px))}}@media (max-width: 980px){.site-header{grid-template-columns:1fr auto}.site-header nav{display:none}.hero{grid-template-columns:1fr;padding-bottom:48px}.profile-pass{min-height:520px}.section-intro,.project-card,.project-card:nth-child(2n){grid-template-columns:1fr}.problem .section-intro,.approach-section .section-intro,.portfolio .section-intro,.case .section-intro{grid-template-columns:1fr}.project-card:nth-child(2n) .project-visual{order:0;border-left:0}.project-visual,.project-card:nth-child(2n) .project-visual{min-height:340px;border-right:0;border-bottom:1px solid var(--border)}.project-board{grid-template-columns:1fr}.project-board div{padding:14px 0}.project-board div+div{padding-left:0;border-top:1px solid var(--border);border-left:0}.problem-grid,.approach-grid,.case-grid{grid-template-columns:1fr}.skills-section .section-inner{grid-template-columns:1fr;gap:36px}.closing .section-inner{grid-template-columns:1fr;align-items:start}.skills-section .section-intro h2,.skills-section .section-intro>p:last-child{max-width:none}}@media (max-width: 680px){.site-header{height:64px;padding:0 18px}html{scroll-padding-top:64px}.brand img{width:82px}.header-cta{padding:0 10px}.hero{min-height:auto;padding:48px 20px 150px}.hero h1{font-size:clamp(30px,9vw,38px);line-height:1.2}.hero-actions,.closing-actions{flex-direction:column}.btn{width:100%}.profile-pass{min-height:470px;padding:12px}.pass-grid{grid-template-columns:78px 1fr}.keyword-strip{grid-template-columns:repeat(5,minmax(136px,1fr));overflow-x:auto}.keyword-strip span{white-space:nowrap}.section{padding:72px 0}.section-inner{width:min(100% - 40px,1200px)}.overview-section .section-inner{min-height:auto;display:block}.overview-section .problem-grid,.overview-section .approach-grid{margin-top:36px}.overview-section .problem-card,.overview-section .approach-card{min-height:auto}.section-intro h2{font-size:32px;line-height:1.28}.closing-title-line{white-space:normal}.skills-table{grid-template-columns:1fr}.skill-row{min-height:auto;grid-template-columns:1fr;gap:10px;padding:18px 0 18px 16px}}@media (prefers-reduced-motion: no-preference){.reveal-item{opacity:0;transform:translateY(12px);transition:opacity .52s cubic-bezier(.2,0,0,1) var(--reveal-delay, 0ms),transform .52s cubic-bezier(.2,0,0,1) var(--reveal-delay, 0ms)}.reveal-item.is-visible{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto;scroll-snap-type:none}*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
