.company-mark{border-radius:6px;background:oklch(.16 .05 var(--hue));color:oklch(.82 .13 var(--hue));letter-spacing:-.02em;border:1px solid oklch(.28 .06 var(--hue)/.7)}.company-mark,.tech-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-mono);font-weight:600}.tech-icon{border-radius:4px;background:var(--bg-2);color:currentColor;letter-spacing:-.04em;border:1px solid var(--line-2)}.tech-chip__logo{object-fit:contain;border-radius:4px;flex-shrink:0}.tech-chip{display:inline-flex;align-items:center;font-family:var(--font-mono);border-radius:999px}.tech-chip--md{padding:5px 10px 5px 5px}.tech-chip--md,.tech-chip--sm{gap:6px;background:var(--bg-3);border:1px solid var(--line-2);font-size:12px;color:var(--fg-2)}.tech-chip--sm{padding:4px 9px 4px 4px}.tech-chip--xs{gap:0;padding:3px 8px;background:rgba(0,0,0,0);border:1px solid var(--line-2);font-size:11px;color:var(--fg-3)}.exp__logo{width:44px;height:44px;object-fit:contain;border-radius:6px;border:1px solid var(--line-2);background:var(--bg-3);padding:4px}.hero{display:grid;grid-template-columns:minmax(0,1fr) clamp(220px,24vw,300px);grid-gap:clamp(28px,4vw,64px);gap:clamp(28px,4vw,64px);padding:72px 0 56px;position:relative;z-index:1}.hero__name{font-family:var(--font-mono);font-size:clamp(48px,6.4vw,76px);font-weight:500;line-height:1;letter-spacing:-.035em;margin:0 0 28px;white-space:nowrap}.hero__role{font-size:15px;color:var(--fg);margin-bottom:10px}.hero__location,.hero__role{font-family:var(--font-mono);line-height:1.5}.hero__location{font-size:13px;color:var(--fg-3);margin-bottom:24px}.hero__flag{font-size:16px;line-height:1;margin-right:6px}.hero__bio{max-width:540px;color:var(--fg-2);font-size:16px;line-height:1.7;margin:0 0 32px;padding-left:18px;border-left:2px solid var(--accent)}.hero__actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.hero__cta{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;background:var(--accent-gradient);color:var(--bg);border-radius:999px;font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:-.005em;white-space:nowrap;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 1px 0 hsla(0,0%,100%,.15) inset,0 8px 24px -10px var(--accent)}.hero__cta:hover{transform:translateY(-1px);box-shadow:0 1px 0 hsla(0,0%,100%,.18) inset,0 14px 32px -10px var(--accent)}.hero__socials{display:inline-flex;gap:2px;padding:2px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:6px}.hero__socials a{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;color:var(--fg-3);border-radius:4px;transition:background .2s,color .2s}.hero__socials a:hover{background:var(--accent-soft);color:var(--accent)}.hero__photo-frame{position:relative;align-self:start;border:1px solid var(--line-2);padding:10px;background:var(--bg-3);border-radius:4px}.hero__photo-frame:before{content:"~/me.jpg";position:absolute;top:-10px;left:14px;background:var(--bg);padding:0 8px;font-size:10px;color:var(--fg-4);font-family:var(--font-mono)}.hero__photo{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;border-radius:2px}@media(max-width:680px){.hero{grid-template-columns:1fr;gap:32px}.hero__photo-frame{max-width:240px;order:-1}.hero__name{white-space:normal}}.tech-stack-section__grid{display:flex;flex-wrap:wrap;gap:8px}.tech-stack-section__grid .tech-chip .tech-icon,.tech-stack-section__grid .tech-chip svg{color:var(--accent)}.exp-list{display:flex;flex-direction:column}.exp{display:grid;grid-template-columns:48px minmax(120px,150px) minmax(0,1fr);grid-gap:20px;gap:20px;padding:28px 0;border-top:1px solid var(--line);align-items:start}.exp:first-child{border-top:none;padding-top:0}.exp__mark{grid-column:1}.exp__when{font-family:var(--font-mono);font-size:12px;color:var(--fg-4);line-height:1.5;padding-top:8px;white-space:nowrap;grid-column:2}.exp__content{grid-column:3}.exp__title{font-family:var(--font-mono);font-size:17px;font-weight:500;color:var(--fg);margin:0;letter-spacing:-.01em;line-height:1.45;display:flex;align-items:baseline;flex-wrap:wrap;gap:0;position:relative}.exp__role{color:var(--accent)}.exp__at{color:var(--fg-5);margin:0 6px;font-weight:400}.exp__company{color:var(--fg)}.exp__summary{font-size:14px;color:var(--fg-2);margin:12px 0 0;line-height:1.6}.exp__tech{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:16px}.exp__overflow{display:inline-flex;align-items:center;gap:0;padding:1px 8px 1px 2px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:999px;cursor:pointer;transition:border-color .2s}.exp__overflow:hover{border-color:var(--accent)}.exp__overflow-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;border-radius:50%;background:var(--bg-2);color:var(--fg-3);border:1.5px solid var(--bg-3);position:relative;flex-shrink:0;overflow:hidden}.exp__overflow-icon+.exp__overflow-icon{margin-left:-6px}.exp__overflow-icon--logo{padding:2px}.exp__overflow-count{font-family:var(--font-mono);font-size:11px;color:var(--fg-3);margin-left:6px}.exp__bullets{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}.exp__bullets li{font-size:13px;color:var(--fg-3);padding-left:24px;position:relative}.exp__bullets li:before{content:"–";position:absolute;left:0;color:var(--accent);opacity:.8}.exp-divider{padding:24px 0 16px;display:flex;justify-content:center;border-top:1px dashed var(--line-2);margin-top:4px}.exp-divider button{background:rgba(0,0,0,0);border:1px solid var(--accent);padding:7px 18px;border-radius:999px;color:var(--accent);cursor:pointer;font-family:var(--font-mono);font-size:12px;transition:background .2s}.exp-divider button:hover{background:var(--accent-soft)}@media(max-width:720px){.exp{display:flex;flex-direction:column;gap:6px}.exp__mark{margin-bottom:4px}.exp__when{padding-top:0}}.projects{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:16px;gap:16px}.proj{background:var(--bg-3);border:1px solid var(--line-2);padding:24px;border-radius:6px;position:relative;overflow:hidden;transition:border-color .2s,background .2s}.proj:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}.proj:hover{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-mist) 0,var(--bg-3) 60%)}.proj:hover:before{opacity:1}.proj--placeholder{border-style:dashed;opacity:.6}.proj--placeholder:hover{opacity:.85}.proj__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;font-family:var(--font-mono);font-size:11px;color:var(--fg-4)}.proj__tag{padding:2px 8px;border:1px solid var(--line-2);border-radius:999px;font-size:10px;letter-spacing:.08em;text-transform:uppercase}.proj__tag--work{color:var(--accent);border-color:var(--accent-dim)}.proj__tag--personal{color:var(--fg-3);border-color:var(--line-2)}.proj__name{font-size:20px;font-weight:500;color:var(--fg);margin:0 0 6px;letter-spacing:-.02em}.proj__for,.proj__name{font-family:var(--font-mono)}.proj__for{font-size:12px;color:var(--fg-4);margin-bottom:14px}.proj__for strong{color:var(--accent);font-weight:500}.proj__passion{color:var(--fg-3)}.proj__sep{margin:0 6px;color:var(--fg-5)}.proj__link{color:var(--accent)}.proj__link:hover{text-decoration:underline}.proj__desc{font-size:14px;color:var(--fg-2);line-height:1.6;margin:0 0 18px}.proj__tech{display:flex;flex-wrap:wrap;gap:6px}@media(max-width:720px){.projects{grid-template-columns:1fr}}.contact{margin:0 0 24px;padding:40px;border:1px solid var(--line-2);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 3%,transparent),var(--bg-3));border-radius:6px;position:relative}.contact__ask{font-family:var(--font-mono);font-size:13px;color:var(--fg-3);margin-bottom:10px}.contact__ask:before{content:"$ ";color:var(--accent)}.contact__answer{font-family:var(--font-mono);font-size:36px;font-weight:500;color:var(--accent);margin:0 0 16px;display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}.contact__answer:hover{text-decoration:underline}.contact__blurb{font-size:14px;color:var(--fg-2);max-width:560px;line-height:1.6;margin:0 0 20px}.contact__also{display:flex;gap:10px;align-items:center;font-family:var(--font-mono);font-size:12px;color:var(--fg-4)}.contact__also a{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line-2);border-radius:4px;color:var(--fg-3);transition:color .2s,border-color .2s}.contact__also a:hover{color:var(--accent);border-color:var(--accent)}@media(max-width:720px){.contact{padding:28px}.contact__answer{font-size:22px}}.site-footer{padding:32px 0;text-align:center;font-family:var(--font-mono);font-size:11px;color:var(--fg-4);border-top:1px solid var(--line);margin-top:32px;display:flex;justify-content:space-between;align-items:center}@media(max-width:480px){.site-footer{flex-direction:column;gap:8px}}.site-footer__built{display:inline-flex;align-items:center;gap:6px}.site-footer__icon{display:inline-flex;align-items:center;color:var(--fg-4);transition:color .2s}.site-footer__icon:hover{color:var(--fg)}.site-wrap{max-width:1200px;margin:0 auto;padding:0 32px;position:relative}.site-content{position:relative;z-index:1}@media(max-width:720px){.site-wrap{padding:0 20px}}.logo{font-family:var(--font-mono);line-height:1;display:inline-flex;align-items:baseline;letter-spacing:-.02em}.logo__accent{color:var(--accent)}.logo__dim{color:var(--accent-dim);opacity:.85}.logo__slash{color:var(--accent);font-weight:300;margin:0 .04em}.top-bar{position:-webkit-sticky;position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 85%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.top-bar__inner{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;max-width:1200px;margin:0 auto}.top-bar__brand{display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:16px;font-weight:500;letter-spacing:-.01em}.top-bar__wordmark{display:inline-flex;align-items:baseline;opacity:0;transform:translateX(-6px);transition:opacity .3s ease,transform .3s ease;pointer-events:none}.top-bar__wordmark--shown{opacity:1;transform:none;pointer-events:auto}.top-bar__wordmark-tilde{color:var(--fg-5);margin-right:1px}.top-bar__wordmark-name{color:var(--fg)}.top-bar__wordmark-karl{color:var(--accent)}.top-bar__nav{display:flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:13px}.top-bar__nav a{padding:8px 14px;color:var(--fg-3);border-radius:4px;transition:color .2s,background .2s;display:inline-flex;align-items:center;gap:6px}.top-bar__nav a:hover{color:var(--accent);background:var(--accent-soft)}.top-bar__burger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.top-bar__burger span{display:block;width:20px;height:1.5px;background:var(--fg-3);transition:background .2s}.top-bar__burger:hover span{background:var(--accent)}.top-bar__drawer{position:absolute;top:100%;left:0;right:0;flex-direction:column;padding:8px 20px 16px;background:color-mix(in srgb,var(--bg) 95%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line)}.top-bar__drawer,.top-bar__drawer a{display:flex;border-bottom:1px solid var(--line)}.top-bar__drawer a{font-family:var(--font-mono);font-size:14px;color:var(--fg-3);padding:12px 4px;align-items:center;gap:6px;transition:color .2s}.top-bar__drawer a:last-child{border-bottom:none}.top-bar__drawer a:hover{color:var(--accent)}@media(max-width:720px){.top-bar__inner{padding:16px 20px}.top-bar__nav{gap:0}.top-bar__nav a{padding:8px;font-size:12px}}@media(max-width:540px){.top-bar__nav{display:none}.top-bar__burger{display:flex}}