@import "https://fonts.googleapis.com/css2?family=Anton&family=Raleway:wght@200;300;400;600&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg:#eeebe4;--bg-card:#f7f4ef;--border:#c8bfa8;--navy:#2f4156;--blue:#4a78a8;--blue-light:#4a78a81f;--sky:#c8d9e6;--text:#2f4156;--text-2:#5a6275;--text-muted:#9a9888}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;background-image:linear-gradient(#2f41560f 1px,#0000 1px),linear-gradient(90deg,#2f41560f 1px,#0000 1px);background-size:26px 26px;font-family:Inter,sans-serif}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.shell{flex-direction:column;width:100vw;height:100vh;display:flex;overflow-y:auto}.topnav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:10;background:#eeebe4d9;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;height:52px;padding:0 40px;display:flex;position:relative}.nav-logo{letter-spacing:2px;color:var(--navy);flex-shrink:0;font-family:Anton,sans-serif;font-size:16px}.nav-links{gap:6px;display:flex}.nav-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:4px;padding:6px 18px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;transition:all .15s}@media (width<=600px){.topnav{gap:8px;padding:0 16px}.nav-btn{padding:5px 10px;font-size:10px}.nav-links{gap:4px}.nav-social{gap:6px}.nav-social a{width:26px;height:26px}.df-tools,.df-table th:last-child{display:none}.df-table td{padding:10px;font-size:12px}.df-table th{padding:8px 10px;font-size:10px}.df-project{font-size:12px}.df-cat-pill{padding:2px 7px;font-size:9px}.bento-thumb{min-height:0}.df-expanded{flex-direction:column;gap:12px}.df-expanded-thumb{width:100%;height:160px}.df-expanded-info{width:100%}.proj-modal-v2{width:95vw;max-height:92vh}.proj-modal-header{padding:18px 20px 16px}.proj-modal-h-title{font-size:20px}.proj-modal-v2-body{gap:14px;padding:18px 20px 20px}.proj-modal-v2-desc{font-size:13px;line-height:1.6}}.nav-btn:hover{color:var(--text);border-color:var(--border)}.nav-btn.active{background:var(--navy);color:#f7f4ef;border-color:var(--navy)}.nav-social{gap:10px;display:flex}.nav-social a{background:var(--navy);color:#f7f4ef;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:background .15s;display:flex}.nav-social a:hover{background:var(--blue)}.page{flex:1;position:relative;overflow:hidden}.scroll-page{height:100%;overflow-y:auto}.scroll-page section{position:relative}.scroll-page section+section{border-top:1.5px solid var(--border);margin-top:48px;padding-top:48px}@keyframes slideUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes drawLine{0%{stroke-dashoffset:1000px}to{stroke-dashoffset:0}}@keyframes nodePulse{0%,to{r:5;opacity:.12}50%{r:8;opacity:.22}}@keyframes hintBlink{0%,to{opacity:.5}50%{opacity:1}}.landing{flex-direction:column;justify-content:center;width:100%;min-height:calc(100vh - 52px);padding-bottom:48px;display:flex;position:relative}.landing-title{color:var(--navy);letter-spacing:.02em;text-align:center;z-index:2;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:0;font-family:Anton,sans-serif;font-size:clamp(72px,14vw,200px);line-height:.9;animation:.8s cubic-bezier(.22,1,.36,1) .2s forwards slideUp;position:relative}.landing-title .port{color:var(--navy)}.landing-title .folio{color:var(--blue)}.landing-meta{opacity:0;animation:.7s .9s forwards fadeIn}.landing-hint{animation:2.4s ease-in-out 2s infinite hintBlink}.landing-meta{z-index:2;pointer-events:none;justify-content:space-between;align-items:flex-end;margin-top:16px;padding:0 48px;display:flex;position:relative}.landing-year{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:12px}.landing-name{letter-spacing:.15em;text-transform:uppercase;color:var(--navy);font-family:Raleway,sans-serif;font-size:clamp(22px,3.6vw,42px);font-weight:600}.landing-label{color:var(--text-muted);text-align:right;letter-spacing:1.2px;font-family:JetBrains Mono,monospace;font-size:13px}.landing-viz{z-index:1;pointer-events:none;position:absolute;inset:0;overflow-y:auto}.landing-hint{color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;z-index:2;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.landing-hint:before,.landing-hint:after{content:"";background:var(--border);width:32px;height:1px;display:block}.profile-page{justify-content:center;align-items:center;width:100%;min-height:calc(100vh - 52px);padding:40px 0;display:flex;position:relative}.profile-content-grid{z-index:2;grid-template-columns:240px 1fr;align-items:start;gap:52px;width:100%;max-width:980px;padding:52px 56px 48px;display:grid;position:relative}.profile-text-block{margin-top:-28px}@media (width<=700px){.profile-content-grid{grid-template-columns:1fr;gap:28px;padding:32px 24px 40px}.profile-content-grid img{width:160px!important;height:192px!important}.profile-text-block{margin-top:16px}}.profile-hero{grid-template-columns:220px 1fr;align-items:flex-start;gap:32px;margin-bottom:36px;display:grid}.profile-photo{object-fit:cover;object-position:top center;border-radius:4px;width:200px;height:240px;display:block}.profile-intro{padding-top:4px}.profile-hello{letter-spacing:1px;color:#2f415640;margin-bottom:0;font-family:Anton,sans-serif;font-size:clamp(32px,4.5vw,58px);line-height:1}.profile-inam{letter-spacing:1px;color:var(--navy);margin-bottom:12px;font-family:Anton,sans-serif;font-size:clamp(32px,4.5vw,58px);line-height:1}.profile-inam span{color:var(--blue)}.profile-role{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;font-family:JetBrains Mono,monospace;font-size:10px}.profile-bio{color:var(--text-2);font-size:14.5px;line-height:1.75}.profile-tag{background:var(--blue-light);color:var(--blue);letter-spacing:.5px;border:1px solid #4a78a84d;border-radius:20px;margin:0 5px 6px 0;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:9px;display:inline-block}.profile-cols3{grid-template-columns:1fr 1fr 1fr;align-items:start;gap:32px;display:grid}.profile-section-title{letter-spacing:1px;color:var(--navy);border-bottom:2px solid var(--navy);margin-bottom:16px;padding-bottom:8px;font-family:Anton,sans-serif;font-size:20px}.exp-item{margin-bottom:18px}.exp-title{color:var(--navy);margin-bottom:1px;font-size:12.5px;font-weight:700;line-height:1.3}.exp-company{color:var(--blue);margin-bottom:2px;font-family:JetBrains Mono,monospace;font-size:10px}.exp-date{color:var(--text-muted);margin-bottom:5px;font-family:JetBrains Mono,monospace;font-size:9px}.exp-bullets{padding:0;list-style:none}.exp-bullets li{color:var(--text-2);margin-bottom:3px;padding-left:12px;font-size:11.5px;line-height:1.55;position:relative}.exp-bullets li:before{content:"–";color:var(--blue);position:absolute;left:0}.rec-item{align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.rec-dot{background:var(--blue);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}.rec-title{color:var(--navy);margin-bottom:1px;font-size:11.5px;font-weight:600;line-height:1.3}.rec-sub{color:var(--text-muted);font-size:10.5px;line-height:1.4}.skill-subhead{letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-top:14px;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:9px}.skill-subhead:first-child{margin-top:0}.skill-list{padding:0;list-style:none}.skill-list li{color:var(--text-2);padding-left:14px;font-size:12px;line-height:1.6;position:relative}.skill-list li:before{content:"·";color:var(--blue);font-size:14px;line-height:1.4;position:absolute;left:0}.projects-page{box-sizing:border-box;flex-direction:column;width:100%;padding:24px 32px 280px;display:flex}.projects-header{flex-shrink:0;align-items:baseline;gap:14px;margin-bottom:14px;display:flex}.projects-title{letter-spacing:2px;color:var(--navy);font-family:Anton,sans-serif;font-size:32px}.projects-count{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px}.projects-filter-wrap{flex-shrink:0;margin-bottom:14px;position:relative}.projects-filter{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:5px;display:flex;overflow-x:auto}.projects-filter::-webkit-scrollbar{display:none}.filter-scroll-hint{display:none}@media (width<=600px){.filter-scroll-hint{background:linear-gradient(to right, transparent, var(--bg) 60%);width:36px;color:var(--text-muted);pointer-events:none;justify-content:center;align-items:center;font-size:16px;animation:2s ease-in-out 1s 3 hintBlink;display:flex;position:absolute;top:0;bottom:0;right:0}}.filter-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:3px;flex-shrink:0;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;transition:all .15s}.filter-btn:hover{color:var(--text)}.filter-btn.active{background:var(--navy);color:#f7f4ef;border-color:var(--navy)}.projects-grid{flex:1;grid-template-columns:repeat(auto-fill,190px);place-content:start;gap:12px;padding-bottom:4px;display:grid;overflow-y:auto}.proj-card{background:var(--bg-card);border:1.5px solid var(--border);cursor:pointer;border-radius:6px;flex-direction:column;transition:all .2s;display:flex;position:relative;overflow:hidden}.proj-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:3px 4px #2f41561f}.proj-num{letter-spacing:1px;color:#2f41564d;z-index:2;font-family:Anton,sans-serif;font-size:10px;position:absolute;top:8px;left:10px}.proj-thumb{background:var(--bg);flex-shrink:0;width:100%;position:relative;overflow:hidden}.proj-thumb img{width:100%;height:auto;display:block}.proj-thumb svg{aspect-ratio:4/3;width:100%;display:block}.proj-title-bar{z-index:3;background:#2f4156d1;flex-shrink:0;padding:8px 12px;position:relative}.proj-title-bar-cat{color:var(--sky);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px;font-family:JetBrains Mono,monospace;font-size:8px}.proj-title-bar-name{letter-spacing:.5px;color:#f7f4ef;font-family:Anton,sans-serif;font-size:12px;line-height:1.2}.proj-info{opacity:0;z-index:4;background:#eeebe4f5;flex-direction:column;justify-content:flex-end;padding:12px 13px;transition:opacity .2s;display:flex;position:absolute;inset:0}.proj-card:hover .proj-info{opacity:1}.proj-category{color:var(--blue);text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px;font-family:JetBrains Mono,monospace;font-size:8px}.proj-title{color:var(--navy);margin-bottom:5px;font-size:12px;font-weight:700;line-height:1.25}.proj-desc{color:var(--text-2);margin-bottom:6px;font-size:10px;line-height:1.5;display:none}.proj-tags{flex-wrap:wrap;gap:3px;display:flex}.proj-tag{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);border-radius:3px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:8px}.proj-link{color:var(--blue);align-items:center;gap:4px;margin-top:6px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.proj-link:hover{text-decoration:underline}.projects-header{flex-wrap:wrap;flex-shrink:0;align-items:baseline;gap:14px;margin-bottom:20px;display:flex}.view-toggle{gap:4px;margin-left:auto;display:flex}.view-btn{border:1.5px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:5px;justify-content:center;align-items:center;transition:all .15s;display:flex}.view-btn:hover{border-color:var(--navy);color:var(--navy)}.view-btn.active{background:var(--navy);border-color:var(--navy);color:#f7f4ef}.bento-grid{align-items:flex-start;gap:12px;width:100%;display:flex}.bento-col{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.bento-card{border:1.5px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;width:100%;transition:border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.bento-card:hover{border-color:var(--blue);box-shadow:0 6px 20px #2f41561a}.bento-thumb{width:100%;display:block;position:relative;overflow:hidden}.bento-thumb img{width:100%;height:auto;display:block}.bento-thumb svg{aspect-ratio:4/3;width:100%;display:block}.bento-overlay{opacity:0;background:#2f4156d9;flex-direction:column;justify-content:flex-end;padding:16px 18px;transition:opacity .2s;display:flex;position:absolute;inset:0}.bento-card:hover .bento-overlay{opacity:1}.bento-num{letter-spacing:1px;color:#f5f1e866;margin-bottom:4px;font-family:Anton,sans-serif;font-size:11px}.bento-cat{color:var(--sky);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:9px}.bento-name{letter-spacing:.5px;color:#f7f4ef;margin-bottom:6px;font-family:Anton,sans-serif;font-size:16px;line-height:1.2}.bento-desc{color:#f5f1e8bf;margin-bottom:8px;font-size:11.5px;line-height:1.55}.bento-tags{flex-wrap:wrap;gap:5px;display:flex}.bento-title-bar{background:var(--navy);border-top:none;flex-shrink:0;padding:10px 12px}.bento-title-bar .bento-cat{color:var(--sky);text-transform:uppercase;letter-spacing:.8px;opacity:.75;margin-bottom:3px;font-family:JetBrains Mono,monospace;font-size:8px}.bento-title-bar .bento-name{color:#f7f4ef;font-family:Inter,sans-serif;font-size:12.5px;font-weight:500;line-height:1.3}.bento-card:hover .bento-title-bar{opacity:0;transition:opacity .2s}.df-wrap{flex-direction:column;flex:1;display:flex;overflow:hidden}.df-header{background:var(--navy);color:#f5f1e899;border-radius:6px 6px 0 0;flex-shrink:0;padding:6px 16px;font-family:JetBrains Mono,monospace;font-size:11px}.df-shape{color:var(--sky)}.df-table-wrap{border:1.5px solid var(--navy);border-top:none;border-radius:0 0 6px 6px;flex:1;overflow-y:auto}.df-table{border-collapse:collapse;width:100%}.df-table thead tr{background:var(--navy);z-index:2;position:sticky;top:0}.df-table th{color:#f5f1e8b3;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;letter-spacing:.5px;border-right:1px solid #f5f1e814;padding:10px 16px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.df-table th:hover{color:#f7f4ef}.df-sort{color:var(--sky);margin-left:2px}.df-row{cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s}.df-row-even{background:#2f415608}.df-row:hover{background:#4a78a814}.df-row-active{background:#4a78a81a!important}.df-table td{border-right:1px solid var(--border);vertical-align:middle;padding:10px 16px}.df-idx{color:var(--text-muted);width:52px;font-family:JetBrains Mono,monospace;font-size:11px}.df-num{color:var(--text-muted);margin-right:8px;font-family:JetBrains Mono,monospace;font-size:10px}.df-project{color:var(--navy);font-size:13px;font-weight:600}.df-cat-pill{background:var(--blue-light);color:var(--blue);white-space:nowrap;border:1px solid #4a78a840;border-radius:20px;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-block}.df-tools{color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:11px}.df-expanded-row{background:#4a78a80d}.df-expanded{gap:20px;padding:14px 16px;animation:.15s slideUp;display:flex}.df-expanded-thumb{border:1px solid var(--border);border-radius:4px;flex-shrink:0;width:160px;height:100px;position:relative;overflow:hidden}.df-expanded-thumb img{object-fit:cover!important;object-position:center!important;width:100%!important;height:100%!important;display:block!important;position:absolute!important;inset:0!important}.df-expanded-thumb svg{width:100%;height:100%;display:block;position:absolute;inset:0}.df-expanded-info{flex:1}.df-expanded-title{color:var(--navy);margin-bottom:6px;font-family:Anton,sans-serif;font-size:15px}.df-expanded-desc{color:var(--text-2);margin-bottom:8px;font-size:12.5px;line-height:1.6}.df-expanded-meta{color:var(--text-muted);flex-direction:column;gap:3px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.df-expanded-meta b{color:var(--navy)}.proj-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#2f415673;justify-content:center;align-items:center;padding:24px;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.proj-modal-v2{background:var(--bg-card);border-radius:10px;flex-direction:column;width:min(680px,90vw);max-height:88vh;animation:.2s cubic-bezier(.22,1,.36,1) slideUp;display:flex;overflow:hidden;box-shadow:0 24px 64px #2f415638}.proj-modal-header{background:var(--navy);flex-shrink:0;padding:28px 32px 26px;position:relative}.proj-modal-filepath{color:#c8d9e699;letter-spacing:.3px;margin-bottom:10px;font-family:JetBrains Mono,monospace;font-size:11px}.proj-modal-h-title{color:#f7f4ef;letter-spacing:.5px;font-family:Anton,sans-serif;font-size:clamp(22px,3.5vw,36px);line-height:1.1}.proj-modal-close{color:#f5f1e8b3;cursor:pointer;background:#ffffff1a;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:background .15s;display:flex;position:absolute;top:16px;right:18px}.proj-modal-close:hover{color:#fff;background:#fff3}.proj-modal-v2-body{flex-direction:column;gap:20px;padding:28px 32px 32px;display:flex;overflow-y:auto}.proj-modal-meta{flex-wrap:wrap;gap:32px;display:flex}.proj-modal-meta-item{flex-direction:column;gap:4px;display:flex}.proj-modal-meta-label{color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9px}.proj-modal-meta-value{color:var(--navy);font-size:13px;font-weight:600}.proj-modal-thumb-sm{border:1px solid var(--border);border-radius:4px;flex-shrink:0;width:160px;height:110px;margin-top:4px;line-height:0;position:relative;overflow:hidden}.proj-modal-thumb-sm img{object-fit:cover!important;object-position:center!important;width:100%!important;height:100%!important;display:block!important;position:absolute!important;inset:0!important}.proj-modal-thumb-sm svg{width:100%;height:100%;display:block;position:absolute;inset:0}.proj-modal-divider{background:var(--border);height:1px}.proj-modal-v2-desc{color:var(--text-2);font-family:Inter,sans-serif;font-size:14px;line-height:1.75}.proj-modal-btns{flex-wrap:wrap;gap:10px;display:flex}.proj-modal-pill{border:1.5px solid var(--navy);color:var(--navy);cursor:pointer;background:0 0;border-radius:999px;padding:9px 20px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;text-decoration:none;transition:all .15s}.proj-modal-pill:hover{background:var(--navy);color:#f7f4ef}.proj-modal-pill-disabled{opacity:.4;cursor:default}.proj-modal-pill-disabled:hover{color:var(--navy);background:0 0}.page-fade-overlay{z-index:500;background:var(--bg);pointer-events:none;animation:.28s forwards pageFade;position:fixed;inset:0}@keyframes pageFade{0%{opacity:0}40%{opacity:.85}to{opacity:0}}@keyframes cardIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.bento-card{animation:.4s both cardIn}.bento-col:first-child .bento-card{animation-delay:calc(var(--i,0) * 80ms)}.bento-col:nth-child(2) .bento-card{animation-delay:calc(80ms + var(--i,0) * 80ms)}.bento-col:nth-child(3) .bento-card{animation-delay:calc(.16s + var(--i,0) * 80ms)}.bento-col:nth-child(4) .bento-card{animation-delay:calc(.24s + var(--i,0) * 80ms)}@keyframes sectionIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.section-visible{animation:.6s cubic-bezier(.22,1,.36,1) both sectionIn}.bento-card{position:relative;overflow:hidden}.bento-card .ripple{pointer-events:none;background:#4a78a82e;border-radius:50%;animation:.55s ease-out forwards rippleOut;position:absolute;transform:scale(0)}@keyframes rippleOut{to{opacity:0;transform:scale(4)}}
