*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafaf8;--bg-card:#fff;--text:#1a1a18;--text-muted:#6b6b68;--text-faint:#9a9a96;--border:#00000017;--border-strong:#00000024;--tag-bg:#f0efeb;--tag-text:#4a4a47;--green-bg:#eaf3de;--green-text:#3b6d11;--blue-bg:#e6f1fb;--blue-text:#185fa5;--amber-bg:#faeeda;--amber-text:#854f0b;--coral-bg:#faece7;--coral-text:#993c1d;--teal-bg:#e1f5ee;--teal-text:#0f6e56;--purple-bg:#eeedfe;--purple-text:#534ab7}html{height:-webkit-fill-available}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:-webkit-fill-available;font-family:DM Sans,system-ui,sans-serif;font-size:15px;line-height:1.6}.hero-outer{min-height:100vh;height:100vh;min-height:100dvh;background:var(--bg);transform-origin:top;flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.hero-card-up{animation:.75s cubic-bezier(.4,0,.2,1) forwards heroCardUp}.hero-card-down{animation:.75s cubic-bezier(.4,0,.2,1) forwards heroCardDown}@keyframes heroCardUp{0%{transform:translateY(0)scale(1);box-shadow:0 0 #0000}18%{transform:translateY(-18px)scale(1.015);box-shadow:0 32px 64px #0000001f}to{transform:translateY(-105%)scale(.97);box-shadow:0 48px 96px #0000002e}}@keyframes heroCardDown{0%{transform:translateY(-105%)scale(.97)}75%{transform:translateY(14px)scale(1.01)}to{transform:translateY(0)scale(1)}}.hero-inner{flex-direction:column;flex:1;justify-content:center;gap:52px;width:100%;max-width:1060px;margin:0 auto;padding:80px 32px 40px;display:flex}.hero-skills{border-top:.5px solid var(--border);margin-top:48px;padding-top:32px}.hero-skills .section-label{margin-bottom:16px}.hero-skills-row{flex-flow:wrap;gap:12px;display:flex}.hero-skills-row .skill-group{flex:1;min-width:160px}.hero-scroll-hint{text-align:center;width:100%;color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:24px 0 32px;font-size:18px;transition:color .15s;display:block}.hero-scroll-hint:hover{color:var(--text-muted)}.hero-scroll-hint span:last-child{transition:transform .3s;animation:1.8s ease-in-out infinite bobDown;display:block}.hero-scroll-label{letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:500;transition:transform .3s;display:block}.hero-scroll-hint span:last-child{transition:transform .3s;display:block}.hero-scroll-hint:hover .hero-scroll-label{transform:translateY(-4px)}.hero-scroll-hint:hover span:last-child{transform:translateY(4px)}@keyframes bobDown{0%,to{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(6px)}}.layout{grid-template-columns:280px 1fr;grid-template-areas:"sidebar main";align-items:start;gap:48px;max-width:80vw;margin:0 auto;padding:60px 32px 80px;transition:grid-template-columns .3s,gap .3s;display:grid}.layout-sidebar-hidden{grid-template-columns:0 1fr;gap:0}.work-sidebar{grid-area:sidebar;position:sticky;top:48px;overflow:hidden}.work-sidebar-clip{width:280px;min-width:280px}.sidebar-toggle-btn{cursor:pointer;color:var(--text-faint);letter-spacing:.3px;background:0 0;border:none;margin-bottom:12px;padding:0;font-family:inherit;font-size:12px;display:block}.sidebar-toggle-btn:hover{color:var(--text-muted)}.work-sidebar-inner{flex-direction:column;gap:20px;display:flex}.sidebar-profile-row{align-items:center;gap:12px;display:flex}.sidebar-pic-container{border-radius:50%;flex-shrink:0;width:72px;height:72px;position:relative;overflow:hidden}.work-sidebar-name{letter-spacing:-.3px;color:var(--text);font-size:18px;font-weight:500}.work-main{grid-area:main;justify-self:center;width:min(100%,880px);min-width:0;position:relative}.work-main .sidebar-toggle{position:absolute;top:0;left:-44px}.sidebar-clip{overflow:hidden}.sidebar-panel-inner{width:220px}.sidebar-toggle{border:.5px solid var(--border-strong);background:var(--bg-card);width:28px;height:28px;color:var(--text-muted);cursor:pointer;z-index:10;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:color .15s,border-color .15s;display:flex}.sidebar-toggle:hover{color:var(--text);border-color:var(--text)}.sidebar-toggle[data-tooltip]{position:relative}.sidebar-toggle[data-tooltip]:after{content:attr(data-tooltip);background:var(--bg-card);border:.5px solid var(--border-strong);color:var(--text-muted);white-space:nowrap;pointer-events:none;opacity:0;border-radius:5px;padding:4px 8px;font-family:inherit;font-size:11px;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%)}.sidebar-toggle[data-tooltip]:hover:after{opacity:1}.sidebar-skills{flex-direction:column;gap:12px;display:flex}header{margin-bottom:0}.header-links{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:20px;display:flex}.header-links a{color:var(--blue-text);font-size:13px;text-decoration:none;transition:color .15s}.header-links a:hover{color:var(--text)}.header-links span{color:var(--border-strong);font-size:12px}.header-contact{flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px;margin-bottom:0;display:flex}.header-contact a{color:var(--blue-text);font-size:13px;text-decoration:none;transition:color .15s}.header-contact a:hover{color:var(--text)}.header-contact span{color:var(--border-strong);font-size:12px}.header-body{align-items:stretch;gap:28px;display:flex}.profile-pic-container{border-radius:50%;flex-shrink:0;align-self:center;width:180px;height:180px;position:relative;overflow:hidden}.profile-pic{object-fit:cover}.header-text{flex-direction:column;justify-content:center;display:flex}.name{letter-spacing:-.5px;font-size:32px;font-weight:500;line-height:1.15}.role{color:var(--text-muted);margin-top:4px;font-size:16px;font-weight:300}.bio{color:var(--text-muted);margin-top:14px;font-size:15.5px;font-weight:300;line-height:1.75}.bio strong{color:var(--text);font-weight:400}section{margin-bottom:64px}.section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px;font-size:10.5px;font-weight:500}.project-card{background:var(--bg-card);border:.5px solid var(--border-strong);border-radius:12px;margin-bottom:16px;overflow:clip;box-shadow:0 4px 24px #00000012,0 1px 4px #0000000d}.project-card-collapsible{margin-bottom:0}.project-card-toggle{cursor:pointer;text-align:left;width:100%;color:inherit;font-family:inherit;font-size:inherit;background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.project-collapsed-info{flex-direction:column;gap:3px;min-width:0;display:flex}.project-collapsed-title{letter-spacing:-.2px;font-size:15px;font-weight:500;line-height:1.3}.project-collapsed-meta{color:var(--text-faint);align-items:center;gap:6px;font-size:12px;display:flex}.project-collapsed-company-link{color:var(--blue-text);text-decoration:none}.project-collapsed-company-link:hover{color:var(--text)}.project-collapsed-date{color:var(--text-faint);font-size:12px}.project-toggle-icon{color:var(--text-faint);flex-shrink:0;font-size:20px;font-weight:300;line-height:1}.project-card-expanded-body .project-main{padding-top:0}.mobile-project-list{flex-direction:column;gap:8px;display:flex}.project-main{padding:28px 32px}.project-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:6px;display:flex}.project-title{letter-spacing:-.2px;flex:1;font-size:17px;font-weight:500}.project-index{color:var(--text-faint);letter-spacing:.05em;flex-shrink:0;align-self:flex-start;padding-top:3px;font-family:DM Mono,monospace;font-size:11px;font-weight:400}.project-meta{align-items:center;gap:10px;margin-bottom:12px;display:flex}.project-company{color:var(--text-muted);background:var(--tag-bg);white-space:nowrap;border-radius:100px;padding:3px 10px;font-size:12px;font-weight:500;text-decoration:none}.project-company-link{color:var(--blue-text)}.project-company-link:hover{color:var(--text);background:var(--border-strong)}.project-date{color:var(--text-muted);white-space:nowrap;font-size:11.5px}.project-desc{color:var(--text-muted);margin-bottom:20px;font-size:14.5px;font-weight:300;line-height:1.75}.project-desc strong{color:var(--text);font-weight:400}.project-bullets{color:var(--text-muted);flex-direction:column;gap:8px;margin-bottom:20px;padding-left:18px;font-size:14.5px;font-weight:300;line-height:1.75;display:flex}.project-bullets li{padding-left:4px}.project-bullets strong{color:var(--text);font-weight:400}.callout{border-left:2px solid var(--amber-text);color:var(--amber-text);background:var(--amber-bg);border-radius:0 6px 6px 0;margin:0 0 20px;padding:10px 14px;font-size:13.5px;line-height:1.6}.callout.blue{border-left-color:var(--blue-text);color:var(--blue-text);background:var(--blue-bg)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlayFadeOut{0%{opacity:1}to{opacity:0}}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetSlideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.card-overlay{z-index:200;background:#00000073;align-items:flex-end;animation:.25s overlayFadeIn;display:flex;position:fixed;inset:0}.card-overlay-closing{animation:.25s forwards overlayFadeOut}.card-overlay-sheet{background:var(--bg);width:100%;max-height:92dvh;color:var(--text);border-radius:16px 16px 0 0;flex-direction:column;font-family:DM Sans,system-ui,sans-serif;animation:.3s cubic-bezier(.4,0,.2,1) sheetSlideUp;display:flex;overflow:hidden}.card-overlay-sheet-closing{animation:.3s cubic-bezier(.4,0,.2,1) forwards sheetSlideDown}.card-overlay-header{border-bottom:.5px solid var(--border-strong);background:var(--bg);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 16px 12px;display:flex}.card-overlay-header-info{flex-direction:column;gap:4px;min-width:0;display:flex}.card-overlay-close{cursor:pointer;color:var(--text-faint);background:0 0;border:none;padding:4px 8px;font-size:16px;line-height:1}.card-overlay-scroll{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;padding-bottom:32px;overflow-y:auto}.card-overlay-scroll .project-card{box-shadow:none;background:0 0;border:none;border-radius:0;margin-bottom:0}.lightbox{z-index:200;cursor:zoom-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000059;justify-content:center;align-items:center;animation:.2s forwards lightbox-in;display:flex;position:fixed;inset:0}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.lightbox-img{object-fit:contain;border-radius:10px;max-width:70vw;max-height:70dvh;animation:.25s cubic-bezier(.34,1.56,.64,1) forwards lightbox-img-in}@keyframes lightbox-img-in{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.project-images{gap:12px;margin:12px 0 20px;display:flex;overflow-x:auto}@media (max-width:600px){.project-images{flex-wrap:wrap;overflow-x:visible}.project-image-wrap{width:100%}}.project-image-wrap{border:.5px solid var(--border-strong);cursor:zoom-in;background:#fff;border-radius:8px;flex-shrink:0;width:min(280px,72vw);height:160px;padding:0;position:relative;overflow:hidden}.project-image-wrap:hover{border-color:var(--text-muted)}.project-image{object-fit:contain;padding:8px}.project-details{border-top:.5px solid var(--border);grid-template-columns:1fr 1fr;gap:12px 24px;margin-bottom:20px;padding-top:20px;display:grid}.detail-label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px;font-size:11px;font-weight:500}.detail-value{color:var(--text);font-size:13.5px;line-height:1.5}.tags-section{margin-top:4px}.tags-section .detail-label{margin-bottom:8px}.tags{flex-wrap:wrap;gap:6px;display:flex}.tag{background:var(--tag-bg);color:var(--tag-text);border-radius:5px;padding:4px 10px;font-family:DM Mono,monospace;font-size:12px;text-decoration:none}.tag-link{color:var(--blue-text)}.tag-link:hover{background:var(--blue-bg);color:var(--blue-text)}.arch-diagram{border-top:.5px solid var(--border);background:var(--bg);padding:20px 32px}.arch-label{color:var(--text-faint);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;font-size:10.5px;font-weight:500}.arch-flow{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.arch-node{white-space:nowrap;border-radius:6px;padding:5px 11px;font-family:DM Mono,monospace;font-size:12px}.node-green{background:var(--green-bg);color:var(--green-text)}.node-blue{background:var(--blue-bg);color:var(--blue-text)}.node-amber{background:var(--amber-bg);color:var(--amber-text)}.node-coral{background:var(--coral-bg);color:var(--coral-text)}.node-teal{background:var(--teal-bg);color:var(--teal-text)}.node-purple{background:var(--purple-bg);color:var(--purple-text)}.node-neutral{background:var(--tag-bg);color:var(--tag-text)}.arch-arrow{color:var(--text-faint);margin:0 1px;font-size:12px}.link-strip{background:var(--bg);border-top:.5px solid var(--border);flex-wrap:wrap;gap:20px;padding:14px 32px;display:flex}.link-strip-item{color:var(--blue-text);font-size:12.5px;text-decoration:none;transition:color .15s}.link-strip-item:hover{color:var(--text)}.skill-group{background:var(--bg-card);border:.5px solid var(--border-strong);border-radius:10px;padding:18px 20px}.skill-group-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:500}.skill-list{flex-wrap:wrap;gap:5px;display:flex}.skill-tag{background:var(--tag-bg);color:var(--tag-text);border-radius:4px;padding:3px 8px;font-family:DM Mono,monospace;font-size:12px;text-decoration:none}.skill-tag-link{color:var(--blue-text)}.skill-tag-link:hover{background:var(--blue-bg);color:var(--blue-text)}.avail-bar{background:var(--green-bg);border:.5px solid #396d1133;border-radius:8px;align-items:center;gap:10px;padding:14px 18px;display:flex}.avail-dot{background:var(--green-text);border-radius:50%;flex-shrink:0;width:7px;height:7px}.avail-text{color:var(--green-text);font-size:13.5px}.carousel{flex-direction:column;gap:16px;display:flex}.carousel-header{flex-direction:column;align-items:center;gap:16px;margin-bottom:20px;display:flex}.carousel-header .section-label{letter-spacing:.08em;color:var(--text);margin:0;font-size:14px}.carousel-viewport{touch-action:pan-y;position:relative;overflow:hidden}.carousel-nav{flex-direction:row;align-items:center;gap:10px;display:flex}.carousel-dots{flex-direction:row;align-items:center;gap:8px;display:flex}.carousel-dot{background:var(--border-strong);cursor:pointer;border:none;border-radius:50%;width:7px;height:7px;padding:0;transition:background .2s,transform .2s}.carousel-dot.active{background:var(--text);transform:scale(1.3)}.carousel-arrow{border:.5px solid var(--border-strong);width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:13px;line-height:1;transition:color .15s,border-color .15s;display:flex}.carousel-arrow:hover:not(:disabled){color:var(--text);border-color:var(--text)}.carousel-arrow:disabled{opacity:.3;cursor:default}.carousel-slide{width:100%;padding-bottom:20px;position:absolute;top:0;left:0}.slide-hidden{opacity:0;pointer-events:none;visibility:hidden}.slide-active{opacity:1;transform:none}.site-footer{border-top:.5px solid var(--border);max-width:80vw;margin:0 auto;padding:32px 32px 48px}.site-footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.footer-name{color:var(--text-muted);font-size:13px;font-weight:300}.footer-links{gap:16px;display:flex}.footer-links a{color:var(--blue-text);font-size:13px;text-decoration:none;transition:color .15s}.footer-links a:hover{color:var(--text)}.mobile-skills-section{display:none}@media (max-width:860px){.layout{grid-template-columns:1fr;grid-template-areas:"main";gap:0;padding-bottom:24px}section{margin-bottom:24px}.work-sidebar,.work-main .sidebar-toggle{display:none}.mobile-skills-section{padding:0 0 40px;display:block}.mobile-skills-section .sidebar-profile-row{display:none}.sidebar-skills{flex-direction:column;gap:12px;display:flex}.carousel-mobile{gap:12px;margin-left:-32px;margin-right:-32px;padding-left:32px;padding-right:32px}.carousel-mobile-header{margin-bottom:4px}.mobile-project-list{padding-bottom:16px}.hero-skills-row{flex-direction:column;gap:10px}.hero-skills-row .skill-group{flex:unset;min-width:unset}}@media (max-width:700px){.hero-inner{justify-content:center;gap:0;padding:40px 24px 0;overflow-y:auto}.hero-skills{display:none}.header-body{flex-direction:column;align-items:center;gap:14px}.profile-pic-container{width:50vw;height:50vw}.header-text{text-align:center;width:100%}.header-contact{justify-content:center}.bio{text-align:center}.header-contact a{word-break:break-all}.bio{margin-top:10px;font-size:14px;line-height:1.65}}@media (max-width:540px){.layout{max-width:100%;padding:40px 20px 24px}section{margin-bottom:24px}.site-footer{border-top:none;max-width:100%;padding:24px 20px 40px}.site-footer:before{content:"";background:var(--border);height:.5px;margin:0 20px 24px;display:block}.site-footer-inner{text-align:center;flex-direction:column;align-items:center;gap:8px}.project-main{padding:20px}.link-strip,.arch-diagram{padding-left:20px;padding-right:20px}.name{font-size:24px}.carousel-mobile{margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px}}
