@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400;600&family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap";:root{--bg: #fbf1c7;--surface: #ebdbb2;--card: #d5c4a1;--text: #3c3836;--dim: #665c54;--red: #9d0006;--orange: #af3a03;--yellow: #b57614;--green: #79740e;--aqua: #427b58;--purple: #8f3f71;--line: #bdae93}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg)}a{text-decoration:none;color:inherit}::selection{background:#b5761459;color:#fbf1c7}.portfolio{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,system-ui,sans-serif;-webkit-font-smoothing:antialiased}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2.5rem;position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--line)}.nav-links{display:flex;gap:2rem}.nav-link{background:none;border:none;font-family:JetBrains Mono,monospace;font-size:.9rem;color:var(--dim);cursor:pointer;transition:color .2s ease;padding:.25rem 0;position:relative}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--yellow);transition:width .25s ease}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-link:hover,.nav-link.active{color:var(--yellow)}.nav-email{font-family:JetBrains Mono,monospace;font-size:.78rem;color:var(--dim);text-decoration:underline;text-underline-offset:3px;transition:color .2s ease}.nav-email:hover{color:var(--yellow)}.page{max-width:960px;margin:0 auto;padding:4.5rem 2.5rem;flex:1;width:100%}.hero-top{margin-bottom:1.25rem}.hero-name{font-family:JetBrains Mono,monospace;font-size:3.5rem;font-weight:700;line-height:1.1;letter-spacing:-.03em;margin-bottom:.75rem}.hero-bar{display:block;width:80px;height:3px;background:var(--orange)}.hero-line{font-family:JetBrains Mono,monospace;font-size:1.15rem;line-height:1.6;color:var(--text);margin-bottom:1rem}.hero-details{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.hero-detail{font-family:JetBrains Mono,monospace;font-size:.88rem;color:var(--dim)}.hero-dot{color:var(--dim);font-size:.85rem}.hero-building{font-family:JetBrains Mono,monospace;font-size:.92rem;color:var(--dim);margin-bottom:1.25rem;line-height:1.5}.hero-building strong{font-weight:600;color:var(--orange)}.hero-status{display:inline-flex;align-items:center;gap:.4rem;font-family:JetBrains Mono,monospace;font-size:.78rem;color:var(--yellow);padding:.3rem .75rem;border:1px solid var(--yellow);border-radius:100px;margin-bottom:1.75rem}.hero-status:before{content:"";width:6px;height:6px;background:var(--yellow);border-radius:50%;animation:blink 2.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}.hero-skills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.75rem}.skill-tag{font-family:JetBrains Mono,monospace;font-size:.75rem;padding:.25rem .65rem;border:1px solid var(--line);border-radius:4px;color:var(--dim);transition:border-color .2s ease,color .2s ease}.skill-tag:hover{border-color:var(--yellow);color:var(--text)}.hero-socials{display:flex;align-items:center;gap:.5rem;font-family:JetBrains Mono,monospace;font-size:.9rem}.hero-socials a{color:var(--dim);transition:color .2s ease}.hero-socials a:hover{color:var(--yellow)}.dot{color:var(--dim)}.exp-row{display:flex;align-items:flex-start;gap:1.25rem;padding:1.25rem 0;border-bottom:1px solid var(--line)}.exp-row:last-child{border-bottom:none}.logo-box{width:44px;height:44px;background:var(--card);display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:700;color:var(--dim);flex-shrink:0;border-radius:4px}.exp-info{flex:1;display:flex;flex-direction:column;gap:.2rem}.exp-role{font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:600}.exp-company{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--dim)}.exp-company a{transition:color .2s ease}.exp-company a:hover{color:var(--yellow)}.exp-desc{font-family:JetBrains Mono,monospace;font-size:.82rem;color:var(--dim);line-height:1.6;margin-top:.35rem}.exp-date{font-family:JetBrains Mono,monospace;font-size:.78rem;color:var(--dim);text-align:right;flex-shrink:0;align-self:flex-start;margin-top:.15rem;white-space:nowrap}.builds-sub{font-family:JetBrains Mono,monospace;font-size:.92rem;font-style:italic;color:var(--dim);margin-bottom:.75rem}.works-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.works-label{font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600;color:var(--yellow);letter-spacing:.15em;white-space:nowrap}.works-line{flex:1;height:1px;background:var(--line)}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;min-width:0;text-align:left;cursor:pointer;width:100%}.card:hover{transform:translateY(-3px);border-color:var(--orange);box-shadow:0 8px 24px #3c38361f}.card-body{padding:1.25rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:.65rem;flex:1;min-width:0}.card-header-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.card-name{font-family:JetBrains Mono,monospace;font-size:1.05rem;font-weight:600;color:var(--text);overflow-wrap:break-word}.card-desc{font-size:.85rem;color:var(--dim);line-height:1.65;flex:1;overflow-wrap:break-word}.card-tech{display:flex;flex-wrap:wrap;gap:.4rem}.card-tech-tag{font-family:JetBrains Mono,monospace;font-size:.65rem;padding:.2rem .55rem;border:1px solid var(--line);border-radius:3px;color:var(--dim)}.card-links{display:flex;gap:.6rem;flex-shrink:0}.card-links a{font-family:JetBrains Mono,monospace;font-size:.72rem;color:var(--orange);transition:color .2s ease}.card-links a:hover{color:var(--yellow)}.footer{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2.5rem;border-top:1px solid var(--line)}.foot-item{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--dim)}.game-btn{display:inline-flex;align-items:center;gap:.35rem;background:none;border:none;font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--dim);cursor:pointer;padding:0;transition:color .2s ease}.game-btn svg{width:12px;height:12px}.game-btn:hover{color:var(--yellow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#3c383680;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--surface);border:1px solid var(--line);border-radius:0;padding:1.25rem;width:100%;max-width:680px;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.modal-title{display:flex;align-items:center;gap:.4rem;font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600}.modal-icon{width:15px;height:15px;color:var(--yellow)}.modal-right{display:flex;align-items:center;gap:.6rem}.modal-score{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--yellow)}.modal-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--card);border:1px solid var(--line);border-radius:0;color:var(--dim);cursor:pointer;transition:all .2s ease}.modal-close:hover{color:var(--yellow);border-color:var(--yellow)}.modal-close svg{width:14px;height:14px}.geodash-canvas{width:100%;height:auto;background:var(--bg);border:1px solid var(--line);border-radius:0;cursor:pointer;display:block}.modal-hint{font-family:JetBrains Mono,monospace;font-size:.72rem;color:var(--dim);text-align:center;margin:.6rem 0 0}.blog-list{display:flex;flex-direction:column;gap:1rem}.blog-card{display:block;padding:1.25rem 1.5rem;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--orange);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.blog-card:hover{transform:translateY(-2px);border-color:var(--yellow);border-left-color:var(--yellow);box-shadow:0 8px 24px #3c38361a}.blog-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.blog-card-title{font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:600;color:var(--text);line-height:1.3}.blog-card-date{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--dim);flex-shrink:0;white-space:nowrap}.blog-card-desc{font-family:Inter,sans-serif;font-size:.85rem;color:var(--dim);line-height:1.6;margin-bottom:.75rem}.blog-card-tags{display:flex;flex-wrap:wrap;gap:.4rem}.blog-tag{font-family:JetBrains Mono,monospace;font-size:.65rem;padding:.15rem .5rem;border:1px solid var(--line);border-radius:3px;color:var(--yellow)}.blog-card{background:none;border:none;text-align:left;cursor:pointer;width:100%}.blog-back{background:none;border:none;font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--dim);cursor:pointer;padding:0;margin-bottom:2rem;transition:color .2s ease}.blog-back:hover{color:var(--yellow)}.blog-post{max-width:720px}.blog-post-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--line)}.blog-post-title{font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;line-height:1.2;color:var(--text);margin-bottom:.75rem}.blog-post-date{font-family:JetBrains Mono,monospace;font-size:.82rem;color:var(--dim);display:block;margin-bottom:.75rem}.blog-post-body{display:flex;flex-direction:column;gap:2rem}.blog-section-title{font-family:JetBrains Mono,monospace;font-size:1.15rem;font-weight:600;color:var(--text);margin-bottom:.75rem}.blog-section-body{font-family:Inter,sans-serif;font-size:.95rem;color:var(--dim);line-height:1.75}.blog-post-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line)}.blog-post-source{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--orange);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#af3a034d;transition:color .2s ease,text-decoration-color .2s ease}.blog-post-source:hover{color:var(--yellow);text-decoration-color:var(--yellow)}.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.video-card{display:block;background:var(--card);border:1px solid var(--line);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;overflow:hidden}.video-card:hover{transform:translateY(-3px);border-color:var(--orange);box-shadow:0 8px 24px #3c38361f}.video-thumb{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:var(--surface)}.video-thumb img{width:100%;height:100%;object-fit:cover;display:block}.video-play{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#3c38364d;color:var(--bg);opacity:0;transition:opacity .25s ease}.video-card:hover .video-play{opacity:1}.video-title{font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:500;color:var(--text);line-height:1.4;padding:.85rem 1rem}.video-channel{margin-top:2rem;text-align:center}.video-channel-link{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--orange);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#af3a034d;transition:color .2s ease,text-decoration-color .2s ease}.video-channel-link:hover{color:var(--yellow);text-decoration-color:var(--yellow)}.project-detail{max-width:800px}.project-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--line)}.project-detail-title{font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;line-height:1.2;color:var(--text)}.project-detail-links{display:flex;gap:.75rem;flex-shrink:0}.project-detail-link{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--orange);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#af3a034d;transition:color .2s ease,text-decoration-color .2s ease}.project-detail-link:hover{color:var(--yellow);text-decoration-color:var(--yellow)}.project-detail-video{width:100%;margin-bottom:2rem;background:var(--surface);border:1px solid var(--line)}.project-detail-video video{width:100%;height:auto;display:block}.project-detail-body{display:flex;flex-direction:column;gap:1.5rem}.project-detail-desc{font-family:Inter,sans-serif;font-size:.95rem;color:var(--dim);line-height:1.75}.project-detail-tech{display:flex;flex-direction:column;gap:.75rem}.project-detail-tech-label{font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:600;color:var(--text)}.project-detail-tech-list{display:flex;flex-wrap:wrap;gap:.5rem}.project-detail-tech-tag{font-family:JetBrains Mono,monospace;font-size:.75rem;padding:.3rem .7rem;border:1px solid var(--line);border-radius:3px;color:var(--dim)}@media(max-width:1024px){.page{padding:3.5rem 2rem}.hero-name{font-size:2.8rem}.hero-line{font-size:1.05rem}.navbar,.footer{padding:1.15rem 2rem}}@media(max-width:768px){.navbar{padding:1rem 1.5rem}.nav-email{display:none}.nav-links{gap:1.25rem}.nav-link{font-size:.82rem}.page{padding:2.5rem 1.5rem}.hero-name{font-size:2.2rem}.hero-bar{width:60px}.hero-line{font-size:.95rem}.hero-detail{font-size:.82rem}.hero-building{font-size:.85rem}.hero-status{font-size:.72rem}.hero-socials{font-size:.82rem}.card-grid,.video-grid{gap:1rem}.exp-row{gap:1rem;padding:1rem 0}.exp-role{font-size:.92rem}.exp-company{font-size:.8rem}.exp-desc{font-size:.78rem}.exp-date{font-size:.72rem}.logo-box{width:38px;height:38px;font-size:.88rem}.blog-card{padding:1rem 1.25rem}.blog-card-title{font-size:.92rem}.blog-card-desc{font-size:.8rem}.blog-post-title{font-size:1.6rem}.blog-section-title{font-size:1.05rem}.blog-section-body{font-size:.88rem}.footer{padding:1rem 1.5rem}}@media(max-width:640px){.card-grid,.video-grid{grid-template-columns:1fr;gap:1rem}.hero-name{font-size:1.8rem}.hero-bar{width:50px}.hero-line{font-size:.88rem}.hero-detail{font-size:.78rem}.hero-building{font-size:.8rem}.hero-skills{gap:.4rem}.skill-tag{font-size:.7rem;padding:.2rem .55rem}.page{padding:2rem 1.25rem}.exp-row{flex-direction:column;gap:.5rem;padding:1rem 0}.exp-date{align-self:flex-start;text-align:left}.exp-info{gap:.15rem}.card-body{padding:1rem 1.1rem 1.1rem}.card-name{font-size:.95rem}.card-desc{font-size:.82rem}.card-header-row{flex-direction:column;align-items:flex-start;gap:.35rem}.blog-card{padding:.9rem 1rem}.blog-card-header{flex-direction:column;gap:.25rem}.blog-card-title{font-size:.88rem}.blog-card-desc{font-size:.78rem}.blog-post-title{font-size:1.4rem}.blog-post-header{margin-bottom:2rem;padding-bottom:1.25rem}.blog-post-body{gap:1.5rem}.blog-section-title{font-size:.95rem}.blog-section-body{font-size:.85rem}}@media(max-width:480px){.navbar{padding:.85rem 1rem}.nav-links{gap:1rem}.nav-link{font-size:.78rem}.page{padding:1.75rem 1rem}.hero-name{font-size:1.5rem}.hero-line{font-size:.82rem}.hero-detail{font-size:.72rem}.hero-building{font-size:.75rem}.hero-status{font-size:.68rem;padding:.25rem .6rem}.hero-socials{font-size:.78rem;gap:.4rem}.skill-tag{font-size:.65rem;padding:.15rem .45rem}.hero-skills{gap:.3rem}.card-body{padding:.85rem 1rem 1rem}.card-name{font-size:.88rem}.card-desc{font-size:.78rem}.card-tech-tag{font-size:.6rem}.card-header-row{flex-direction:column;align-items:flex-start;gap:.3rem}.logo-box{width:34px;height:34px;font-size:.78rem}.blog-back{font-size:.78rem;margin-bottom:1.5rem}.blog-post-title{font-size:1.2rem}.blog-post-header{margin-bottom:1.5rem;padding-bottom:1rem}.blog-post-body{gap:1.25rem}.blog-section-title{font-size:.88rem;margin-bottom:.5rem}.blog-section-body{font-size:.82rem;line-height:1.65}.blog-post-footer{margin-top:2rem;padding-top:1.25rem}.blog-post-source{font-size:.78rem}.footer{padding:.85rem 1rem}}
