@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0b0d10;--bg-card:#13161b;--bg-card-hover:#161a20;--border-color:#1f2933;--text-primary:#fff;--text-secondary:#d1d5db;--text-muted:#9ca3af;--text-dim:#a1a1aa;--text-faint:#6b7280;--accent-bg:#3a2a1a;--accent-text:#e7c38a;--section-gap:96px;--title-gap:64px;--card-padding:16px;--content-max-width:1100px;--left-col:240px}html{background-color:#0b0d10}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:initial;color:#fff;color:var(--text-primary);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}body:before{background-image:linear-gradient(#ffffff08 1px,#0000 0),linear-gradient(90deg,#ffffff08 1px,#0000 0);background-size:40px 40px;content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.portfolio{margin:0 auto;max-width:var(--content-max-width);padding:60px 40px 40px}.header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:80px}.header-left{align-items:center;display:flex;gap:12px}.header-left span,.menu-trigger{color:var(--text-muted);font-size:13px}.menu-trigger{background:#0000;border:none;cursor:pointer;font-family:inherit;transition:color .2s ease}.menu-trigger:hover{color:var(--text-primary)}.menu-overlay{background:#0b0d10f5;height:auto;left:0;opacity:0;pointer-events:none;position:fixed;top:0;transform:translateY(-12px);transition:opacity .18s cubic-bezier(.4,0,.2,1),transform .18s cubic-bezier(.4,0,.2,1);width:100%;z-index:1000}.menu-overlay.menu-open{opacity:1;pointer-events:auto;transform:translateY(0)}.menu-content{align-items:flex-start;display:flex;justify-content:space-between;margin:0 auto;max-width:var(--content-max-width);padding:40px 40px 32px}.menu-left{flex-shrink:0}.menu-label{color:var(--text-faint);font-size:13px}.menu-right{gap:24px}.menu-item-wrapper,.menu-nav,.menu-right{align-items:flex-end;display:flex;flex-direction:column}.menu-item-wrapper{width:100%}.menu-item{color:var(--text-dim);font-size:16px;font-weight:400;padding:12px 0;text-decoration:none;transition:color .18s ease}.menu-item:hover{color:var(--text-primary)}.menu-divider{background:#ffffff0f;height:1px;min-width:200px;width:100%}.menu-button{background:#0000;border:1px solid var(--border-color);border-radius:10px;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:13px;font-weight:400;padding:8px 16px;transition:all .18s ease}.menu-button-active{border-color:#60a5fa;color:#60a5fa}.menu-button:hover{border-color:var(--text-muted);color:var(--text-primary)}.section{grid-gap:var(--title-gap);display:grid;gap:var(--title-gap);grid-template-columns:var(--left-col) 1fr;min-height:50vh;padding-bottom:var(--section-gap);position:relative}.section-heading{-webkit-backface-visibility:hidden;backface-visibility:hidden;color:var(--text-primary);font-size:22px;font-weight:500;height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:120px;transform:translateZ(0);will-change:transform}.section-content{align-self:start;border-left:2px solid var(--accent-text);display:flex;flex-direction:column;gap:32px;padding-left:16px}.hero{grid-gap:var(--title-gap);display:grid;gap:var(--title-gap);grid-template-columns:var(--left-col) 1fr;margin-bottom:var(--section-gap)}.shader-fullscreen-bg{background:var(--bg-primary);height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:-2}.shader-fullscreen-bg:after{background:#0006;content:"";height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.shader-animation-container{background:#000;height:100%;opacity:1;transition:opacity 1.5s ease-out;width:100%}.shader-animation-container.fade-out{opacity:0;pointer-events:none}.hero-name{color:var(--text-primary);font-size:48px;font-weight:600;letter-spacing:-.02em;line-height:1.1}.hero-right{display:flex;gap:24px}.profile-image{border-radius:12px;box-shadow:0 4px 20px #0006;height:56px;object-fit:cover;width:56px}.hero-about{flex:1 1}.hero-role{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:4px}.hero-status{color:var(--text-muted);font-size:13px;margin-bottom:16px}.hero-status span{display:block}.hero-bio{color:var(--text-dim);font-size:13px;line-height:1.6}.experience-highlight{border-left:2px solid var(--accent-text);padding-left:16px}.proficiency-group{margin-bottom:24px}.proficiency-title{color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:.05em;margin-bottom:12px;text-transform:uppercase}.proficiency-items{display:flex;flex-direction:column;gap:6px}.proficiency-items span{color:var(--text-secondary);font-size:13px}.entry{margin-bottom:32px}.entry-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.entry-title{color:var(--text-secondary);font-size:14px;font-weight:500}.badge{background:var(--accent-bg);border-radius:999px;color:var(--accent-text);font-size:11px;font-weight:500;padding:2px 8px}.entry-meta{align-items:center;color:var(--text-muted);display:flex;font-size:12px;gap:8px;margin-bottom:8px}.entry-meta svg{color:var(--text-faint);height:12px;width:12px}.entry-description{color:var(--text-dim);font-size:13px;line-height:1.6}.thesis-text{border-left:2px solid var(--accent-text);color:var(--text-dim);font-size:14px;line-height:1.7;margin-left:-16px;max-width:560px;padding-left:16px}.experience-bullets{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}.experience-bullets li{color:var(--text-dim);font-size:13px;line-height:1.6;padding-left:14px;position:relative}.experience-bullets li:before{color:var(--accent-text);content:"→";font-size:12px;left:0;position:absolute}.project-section-highlight{background:#e7c38a0a;border-left:2px solid var(--accent-text);border-radius:0 6px 6px 0;padding:12px 14px}.failure-fix-text{color:var(--text-dim);font-size:12.5px;line-height:1.55}.sd-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.sd-card-header{align-items:center;display:flex;justify-content:space-between;padding:20px 20px 0}.sd-card-name{color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:2px}.sd-card-tagline{color:var(--text-muted);font-size:12.5px}.sd-card-body{gap:24px;padding:20px}.sd-card-body,.sd-section{display:flex;flex-direction:column}.sd-section{gap:10px}.sd-section-label{color:var(--text-faint);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.sd-section-label--warn{color:#fb923ccc}.sd-pipeline{align-items:stretch;display:flex;gap:0;overflow-x:auto;padding:4px 0}.sd-pipe-arrow{align-items:center;color:#e7c38a40;display:flex;flex-shrink:0;font-size:16px;padding:0 4px}.sd-pipe-node{background:#ffffff08;border:1px solid #ffffff12;border-radius:8px;flex:1 1;min-width:100px;padding:10px 12px;text-align:center;transition:all .2s ease}.sd-pipe-node:hover{background:#ffffff0f;border-color:#e7c38a33;transform:translateY(-1px)}.sd-pipe-node--highlight{background:#e7c38a0a;border-color:#e7c38a33}.sd-pipe-label{color:var(--text-secondary);font-size:12px;font-weight:500;margin-bottom:3px}.sd-pipe-sub{color:var(--text-faint);font-size:10px}.sd-failure-path{background:#fb923c08;border:1px dashed #fb923c40;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:14px}.sd-failure-path-header{align-items:center;display:flex;gap:8px}.sd-failure-path-icon{align-items:center;background:#fb923c26;border-radius:50%;color:#fbbf24e6;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:16px;justify-content:center;width:16px}.sd-failure-path-trigger{color:#fbbf24e6;font-size:12px;font-weight:500}.sd-failure-flow{align-items:center;display:flex;flex-wrap:wrap;gap:2px}.sd-failure-step{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:4px;color:var(--text-dim);font-size:11px;padding:3px 8px}.sd-failure-arrow{color:#fb923c4d;font-size:12px;padding:0 2px}.sd-failure-outcome{border-top:1px solid #fb923c1a;color:var(--text-faint);font-size:11.5px;font-style:italic;line-height:1.5;padding-top:8px}.sd-decision-logic-title{color:var(--text-muted);font-size:12px;font-weight:500;margin-bottom:4px}.sd-decision-steps{display:flex;flex-direction:column;gap:8px}.sd-decision-step{align-items:flex-start;display:flex;gap:10px}.sd-decision-step-num{align-items:center;background:#e7c38a1a;border-radius:50%;color:var(--accent-text);display:flex;font-size:10px;font-weight:600;height:20px;justify-content:center;margin-top:1px;min-width:20px;width:20px}.sd-decision-step-label{color:var(--text-secondary);font-size:12px;font-weight:500}.sd-decision-step-detail{color:var(--text-faint);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:11px;margin-top:1px}.sd-support{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.sd-support-group{display:flex;flex-direction:column;gap:6px}.sd-support-label{color:var(--text-faint);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.sd-support-label--security{color:#60a5fab3}.sd-support-label--reliability{color:#34d399b3}.sd-support-label--data{color:#a78bfab3}.sd-support-label--observability{color:#fbbf24b3}.sd-support-items{display:flex;flex-wrap:wrap;gap:4px}.sd-support-tag{background:#ffffff08;border:1px solid #ffffff0f;border-radius:4px;color:var(--text-dim);font-size:10px;padding:2px 7px}.sd-why{display:flex;flex-direction:column;gap:10px}.sd-why-item{border-left:2px solid #e7c38a26;padding-left:12px}.sd-why-point{color:var(--text-secondary);font-size:12px;font-weight:500;margin-bottom:3px}.sd-why-tradeoff{color:var(--text-faint);font-size:11.5px;line-height:1.5}.sd-metrics-grid{grid-gap:10px;border-top:1px solid #ffffff0a;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);padding-top:4px}.sd-metric{background:#ffffff05;border:1px solid #ffffff0d;border-radius:8px;padding:14px 10px;text-align:center;transition:all .2s ease}.sd-metric:hover{background:#e7c38a08;border-color:#e7c38a33}.sd-metric-value{color:var(--accent-text);font-size:20px;font-weight:600;margin-bottom:3px}.sd-metric-label{color:var(--text-secondary);font-size:11px;font-weight:500;margin-bottom:1px}.sd-metric-detail{color:var(--text-faint);font-size:10px}.project-detail-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:border-color .2s ease}.project-detail-card:hover{border-color:#e7c38a33}.project-detail-card.expanded{border-color:#e7c38a26}.project-detail-header{align-items:flex-start;background:#0000;border:none;color:inherit;cursor:pointer;display:flex;font-family:inherit;gap:14px;padding:18px;text-align:left;width:100%}.project-detail-header:hover{background:var(--bg-card-hover)}.project-icon{align-items:center;background:#e7c38a0d;border:1px solid #e7c38a1f;border-radius:12px;color:var(--accent-text);display:flex;flex-shrink:0;height:44px;justify-content:center;margin-top:2px;min-width:44px;width:44px}.project-header-text{flex:1 1;min-width:0}.project-name{color:var(--text-secondary);font-size:15px;font-weight:500;margin-bottom:6px}.project-problem{color:var(--text-muted);font-size:12.5px;line-height:1.55}.project-chevron{color:var(--text-faint);flex-shrink:0;margin-top:4px;transition:transform .25s ease}.project-chevron.rotated{transform:rotate(180deg)}.project-detail-body{animation:fadeSlideIn .25s ease;display:flex;flex-direction:column;gap:18px;padding:0 18px 18px 72px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.project-section-title{color:var(--text-faint);font-size:11px;font-weight:500;letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}.project-section-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.project-section-list li{color:var(--text-dim);font-size:12.5px;line-height:1.55;padding-left:12px;position:relative}.project-section-list li:before{color:var(--accent-text);content:"·";font-weight:600;left:0;position:absolute}.project-tech{color:var(--text-muted);font-size:12.5px;letter-spacing:.01em}.project-links{display:flex;gap:12px;padding-top:4px}.project-link{align-items:center;border:1px solid #e7c38a33;border-radius:6px;color:var(--accent-text);display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:5px 12px;text-decoration:none;transition:all .2s ease}.project-link:hover{background:#e7c38a14;border-color:#e7c38a59}.contact-link{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:8px;padding:8px 0;text-decoration:none;transition:all .2s ease}.contact-link:hover{color:var(--text-primary);transform:translateX(2px)}.contact-link svg{height:14px;width:14px}.footer{border-top:1px solid var(--border-color);margin-top:40px;padding-top:24px;text-align:center}.footer-text{color:var(--text-faint);font-size:11px}.footer-links{display:flex;gap:16px;justify-content:center;margin-top:8px}.footer-links a{color:var(--text-muted);font-size:11px;text-decoration:none}.footer-links a:hover{color:var(--text-primary)}@media (max-width:768px){.portfolio{padding:40px 20px}.hero,.section{gap:24px;grid-template-columns:1fr}.section-heading{position:relative;top:0}.hero-name{font-size:36px}.project-detail-body{padding-left:18px}.project-detail-header{padding:14px}.sd-pipeline{flex-wrap:wrap;gap:6px}.sd-pipe-arrow{display:none}.sd-pipe-node{flex:initial;min-width:calc(50% - 4px)}.sd-support{grid-template-columns:1fr}.sd-metrics-grid{grid-template-columns:repeat(2,1fr)}.sd-card-header{align-items:flex-start;flex-direction:column;gap:10px}}
/*# sourceMappingURL=main.c4838e0a.css.map*/