@font-face{font-family:Minecraft;src:url(/assets/Minecraft-DepcjwOz.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--white:#fff;--gray:#8f8f8f;--sage:#c3c9b7;--pale-green:#e7ffcd;--leaf:#a2d577;--moss:#507d2a;--deep-grass:#558113;--acid:#a6ff00;--panel:#1e211f;--sky-top:#c0d9ff;--sky-mid:#71baff;--sky-bottom:#6fc2ff;color:var(--white);background:var(--panel);font-synthesis:none;text-rendering:geometricprecision;-webkit-font-smoothing:none;-moz-osx-font-smoothing:grayscale;font-family:JetBrains Mono,Cascadia Mono,Consolas,monospace}*{box-sizing:border-box}html{background:var(--panel);scrollbar-width:none;-ms-overflow-style:none;min-width:320px;min-height:100%;scroll-behavior:smooth!important}html::-webkit-scrollbar{display:none}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}#root{min-height:100vh}.about-section{color:#fff;background:#111413;border-top:1px solid #c3c9b785;min-height:100vh;padding:clamp(78px,9vw,120px) clamp(34px,8vw,102px) 78px;font-family:JetBrains Mono,monospace}.about-intro{grid-template-columns:1fr 1.5fr;justify-content:center;align-items:center;gap:clamp(54px,8vw,92px);width:min(848px,100%);margin:0 auto clamp(64px,8vw,82px);display:grid}.about-image-frame{aspect-ratio:1;background:#8f8f8f;border:4px solid #fff;border-radius:50%;width:clamp(220px,24vw,320px);overflow:hidden}.about-image-frame img{object-fit:cover;object-position:55% 40%;width:100%;height:100%}.about-copy{gap:30px;display:grid}.about-copy p{color:#fff;margin:0;font-size:clamp(16px,1.65vw,21px);font-weight:400;line-height:1.22}.skills-block{width:min(848px,100%);margin:0 auto}.skills-block h2{color:#fff;letter-spacing:0;margin:0;font-size:clamp(36px,4.3vw,43px);font-weight:800;line-height:1.08}.skills-block>p{color:#8f8f8f;margin:10px 0 20px;font-size:12px;font-weight:700;line-height:1.4}.skill-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.skill-card{background:#ffffff03;border:2px solid #8f8f8f40;min-height:164px;padding:20px 16px}.skill-card h3{color:#a6ff00;margin:0 0 16px;font-size:15px;font-weight:800;line-height:1}.skill-card ul{gap:8px;margin:0;padding:0;list-style:none;display:grid}.skill-card li{color:#fff;margin-bottom:5px;padding-left:12px;font-size:13px;font-weight:800;line-height:1;position:relative}.skill-card li:before{content:"";background:#558113;width:4px;height:4px;position:absolute;top:.35em;left:0}@media (width<=900px){.about-section{min-height:auto;padding:64px 24px}.about-intro{grid-template-columns:1fr;justify-items:center;gap:34px;margin-bottom:54px}.about-copy{width:min(560px,100%)}.about-copy p{font-size:16px}.skill-grid{grid-template-columns:1fr 1fr 1fr}}@media (width<=560px){.about-section{padding:48px 18px}.about-image-frame{width:min(220px,72vw)}.about-copy p{font-size:14px;line-height:1.3}.skills-block h2{font-size:30px}.skill-grid{grid-template-columns:1fr}}.contact-section{color:#fff;background:#111413;border-top:1px solid #c3c9b785;padding:clamp(92px,11vw,110px) clamp(34px,8vw,100px);font-family:JetBrains Mono,monospace}.contact-inner{flex-direction:column;justify-content:space-between;width:min(846px,100%);margin:0 auto;display:flex}.contact-content{grid-template-columns:1fr 1fr;align-items:start;gap:36px;display:grid}.contact-content>:nth-child(2){align-self:end}.contact-heading{margin-bottom:30px}.contact-heading h2{color:#fff;letter-spacing:0;margin:0 0 10px;font-size:clamp(38px,4.6vw,43px);font-weight:900;line-height:1.24}.contact-heading p{color:#8f8f8f;width:min(430px,100%);margin:0;font-size:14px;font-weight:800;line-height:1.36}.contact-list{gap:22px;display:grid}.contact-link-card{background:#181a19;border:2px solid #8f8f8f47;align-items:center;gap:12px;min-height:65px;padding:11px 14px;transition:border-color .16s,box-shadow .16s,transform .16s;display:flex;box-shadow:4px 4px #050606}.contact-link-card svg{color:#000;background:#558113;width:32px;height:32px;padding:6px}.contact-link-card span:last-child{gap:5px;min-width:0;display:grid}.contact-link-card strong{color:#8f8f8f;font-size:12px;font-weight:500;line-height:1}.contact-link-card em{overflow-wrap:anywhere;color:#fff;font-size:12px;font-style:normal;font-weight:900;line-height:1.1;transition:color .16s}.contact-link-card:hover,.contact-link-card:focus-visible{border-color:#558113;transform:translateY(-4px);box-shadow:5px 6px #050606}.contact-link-card:hover em,.contact-link-card:focus-visible em{color:#558113}.contact-form{background:#171918;border:2px solid #8f8f8f52;gap:26px;padding:40px 36px;display:grid;box-shadow:4px 4px #070808}.contact-form label{gap:7px;display:grid}.contact-form span{color:#8f8f8f;font-size:12px;font-weight:500;line-height:1}.contact-form input,.contact-form textarea{color:#fff;width:100%;font:inherit;background:#0e100f;border:1px solid #8f8f8f59;border-radius:0;outline:none;font-size:12px}.contact-form input{height:35px;padding:0 10px}.contact-form textarea{resize:vertical;min-height:150px;padding:10px}.contact-form input:focus,.contact-form textarea:focus{border-color:#558113}.contact-form input:disabled,.contact-form textarea:disabled,.contact-form button:disabled{cursor:not-allowed;opacity:.68}.contact-form-status{margin:-8px 0 -6px;font-size:12px;font-weight:800;line-height:1.35}.contact-form-status.success{color:#8fcb3f}.contact-form-status.error{color:#ff7b7b}.contact-form button{color:#0e100f;cursor:pointer;background:#558113;border:0;border-radius:0;min-height:34px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500;line-height:1}@media (width<=980px){.contact-content{grid-template-columns:1fr}.contact-form{width:100%}}@media (width<=560px){.contact-section{padding:64px 18px}.contact-inner{min-height:auto}.contact-heading h2{font-size:34px}.contact-form{padding:20px 16px 16px}}@property --sky-top{syntax:"<color>";inherits:false;initial-value:#c0d9ff}@property --sky-bottom{syntax:"<color>";inherits:false;initial-value:#71baff}.home-scene{--sky-top:#ff8c4e;--sky-bottom:#c0d9ff;background:linear-gradient(to bottom, var(--sky-top), var(--sky-bottom));min-height:100vh;margin:0;animation-name:sky-timelapse;animation-duration:120s;animation-timing-function:linear;animation-iteration-count:infinite;position:relative;overflow:hidden}.landblock{z-index:3;pointer-events:none;width:100%;min-width:1785px;max-width:1785px;image-rendering:pixelated;image-rendering:crisp-edges;position:absolute;bottom:0;right:0}.steve-canvas{z-index:10;pointer-events:none;width:100%;height:350px;position:absolute;bottom:18px;left:0}.fade-in-text{opacity:0;animation:1.2s ease-out forwards fadeInText;transform:translateY(20px)}@keyframes fadeInText{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes sky-timelapse{0%,to{--sky-top:#ff8c4e;--sky-bottom:#c0d9ff}11.111%{--sky-top:#c0d9ff;--sky-bottom:#71baff}22.222%{--sky-top:#71baff;--sky-bottom:#567dd2}33.333%{--sky-top:#567dd2;--sky-bottom:#ff8c4e}44.444%{--sky-top:#ff8c4e;--sky-bottom:#182b57}55.555%{--sky-top:#071126;--sky-bottom:#071126}66.666%{--sky-top:#071126;--sky-bottom:#182b57}77.777%{--sky-top:#182b57;--sky-bottom:#567dd2}88.888%{--sky-top:#567dd2;--sky-bottom:#ff8c4e}}.celestial-layer{z-index:1;pointer-events:none;position:absolute;inset:0;overflow:hidden}.celestial-body{opacity:0;width:clamp(58px,7vw,108px);height:auto;image-rendering:pixelated;image-rendering:crisp-edges;will-change:transform, opacity;position:absolute;top:0;left:0}.sun-body{filter:drop-shadow(0 0 20px #ffef9abf);width:clamp(58px,8vw,300px)}.moon-body{filter:drop-shadow(0 0 16px #d6e6ff8c);width:clamp(58px,5.5vw,300px)}.cloud-layer{z-index:2;pointer-events:none;position:absolute;inset:0 0 26%;overflow:hidden}.cloud-track{will-change:transform;width:200%;height:100%;animation:120s linear infinite cloud-drift;display:flex;transform:translate(-50%)}.cloud-set{flex:0 0 50%;height:100%;position:relative}.cloud{height:auto;image-rendering:pixelated;image-rendering:crisp-edges;filter:drop-shadow(10px 12px 8px #3a6c9e38);position:absolute}.cloud-big-one{width:clamp(142px,16vw,244px);top:9%;left:2%}.cloud-mid-one{width:clamp(118px,13vw,178px);top:10%;left:31%}.cloud-big-two{width:clamp(166px,19vw,268px);top:17%;left:49%}.cloud-small-one{width:clamp(80px,9vw,124px);top:2%;left:70%}.cloud-mid-two{width:clamp(118px,13vw,176px);top:14%;left:78%}.cloud-big-three{width:clamp(148px,15vw,226px);top:29%;left:76%}@keyframes cloud-drift{0%{transform:translate(-50%)}to{transform:translate(0)}}.hero-copy{z-index:4;width:min(800px,100vw - 50px);color:var(--white);text-shadow:4px 4px 2px #3d77b86b;font-family:Minecraft,JetBrains Mono,monospace;position:absolute;top:clamp(370px,40vh,600px);left:clamp(40px,7vw,120px)}.hero-copy h2{letter-spacing:0;margin:0 0 22px;font-size:clamp(35px,5vw,70px);font-weight:400;line-height:1}.hero-copy p{width:min(600px,100%);margin:0;font-size:clamp(15px,1.45vw,20px);font-weight:100;line-height:1.35}.stars{z-index:0;object-fit:cover;opacity:0;pointer-events:none;image-rendering:pixelated;image-rendering:crisp-edges;padding-top:2vh;animation:120s linear infinite stars-night}@keyframes stars-night{0%,42%,78%,to{opacity:0}55%,72%{opacity:1}}@media (width<=900px){.home-scene{min-height:calc(100vh - 62px)}.hero-copy{width:min(500px,100vw - 350px);margin-left:-20px;padding-top:40px}.hero-copy h2{width:min(500px,100vw - 200px)}.cloud-layer{bottom:34%}}@media (width<=560px){.home-scene{min-height:calc(100vh - 62px)}.hero-copy{text-shadow:3px 3px #3d77b86b;width:min(500px,100vw - 50px);margin-top:-30px;margin-left:-20px;padding-top:0}.hero-copy h2{width:min(500px,100vw - 100px);font-size:28px;line-height:1.08}.hero-copy p{font-size:12px}.cloud-layer{bottom:40%}}@media (width<=325px){.hero-copy h2{width:200px}.hero-copy p{width:300px}}@media (height<=950px){.hero-copy h2,.hero-copy p{display:none}}.project-section{color:#fff;background:#191b1b;border-top:1px solid #c3c9b785;padding:clamp(92px,11vw,120px) clamp(34px,8vw,100px);font-family:JetBrains Mono,monospace}.project-inner{width:min(846px,100%);margin:0 auto}.project-heading{margin-bottom:18px}.project-heading h2{color:#fff;letter-spacing:0;margin:0;font-size:clamp(36px,4.4vw,42px);font-weight:800;line-height:1.08}.project-heading p{color:#8f8f8f;margin:4px 0 0;font-size:12px;font-weight:800;line-height:1.4}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.project-card{background:#1f211f;border:2px solid #8f8f8f5c;flex-direction:column;min-width:0;height:100%;display:flex;overflow:hidden;box-shadow:0 3px 6px #0000008c}.project-image-button{cursor:zoom-in;background:#e9eef2;border:0;border-bottom:4px solid #353735;width:100%;padding:0;display:block}.project-card-image{aspect-ratio:16/9;object-fit:cover;object-position:top center;width:100%;transition:filter .16s,transform .16s}.project-image-button:hover .project-card-image,.project-image-button:focus-visible .project-card-image{filter:brightness(1.08);transform:scale(1.015)}.project-preview{background:#e9eef2;border-bottom:4px solid #353735;place-items:center;min-height:150px;display:grid}.chat-window{width:104px;height:132px;padding-top:12px;position:relative}.chat-title{color:#4b7fb7;text-align:center;margin-bottom:8px;font-size:4px;font-weight:800}.chat-line{background:#cad8e2;width:78px;height:3px;margin:0 0 5px 14px}.chat-line.short{width:44px}.chat-line.medium{width:62px}.chat-choice{background:#f5f9fb;border-left:5px solid #9fd5ff;width:86px;height:14px;margin:8px 0 0 12px}.chat-input{background:#f7fbfd;border-radius:8px;justify-content:space-between;align-items:center;height:8px;padding:0 3px;display:flex;position:absolute;bottom:4px;left:0;right:0}.chat-input span{background:#d6e2e9;width:28px;height:2px}.chat-input i{background:#b7e4ff;border-radius:50%;width:6px;height:6px}.project-card-body{flex-direction:column;flex:1;padding:20px 24px;display:flex}.project-card-body>div:last-child{margin-top:auto}.project-card h3{color:#fff;margin:0 0 12px;font-size:15px;font-weight:800;line-height:1.2}.project-card-body p{color:#8f8f8f;min-height:54px;margin:0 0 25px;font-size:11px;font-weight:800;line-height:1.25}.project-tags{flex-wrap:wrap;gap:8px;min-height:19px;margin:0 0 15px;padding:0;list-style:none;display:flex}.project-tags li{color:#8f8f8f;border:1px solid #8f8f8f6b;padding:4px 5px;font-size:8px;line-height:1}.project-actions{border-top:2px solid #8f8f8f38;gap:14px;padding-top:15px;display:flex}.project-actions a{color:#8f8f8f;font-size:10px;font-weight:900;line-height:1}.project-actions a:first-child{color:#558113}.project-gallery-modal{z-index:100;background:#000000c2;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.project-gallery-panel{background:#171918;border:2px solid #8f8f8f73;gap:14px;width:min(920px,100%);padding:18px;display:grid;position:relative;box-shadow:6px 6px #050606}.gallery-close{z-index:1;color:#fff;cursor:pointer;background:#111413;border:2px solid #ffffffb3;place-items:center;width:36px;height:36px;display:grid;position:absolute;top:10px;right:10px}.gallery-close svg{width:20px;height:20px}.gallery-image-frame{background:#e9eef2;place-items:center;display:grid;overflow:hidden}.gallery-image-frame img{object-fit:contain;width:100%;max-height:72vh}.gallery-controls{grid-template-columns:42px 1fr 42px;align-items:center;gap:12px;display:grid}.gallery-controls button{color:#fff;cursor:pointer;background:#111413;border:2px solid #8f8f8f6b;place-items:center;width:42px;height:36px;display:grid}.gallery-controls button:hover,.gallery-controls button:focus-visible,.gallery-close:hover,.gallery-close:focus-visible{color:#a6ff00;border-color:#558113}.gallery-controls span{color:#8f8f8f;text-align:center;font-size:12px;font-weight:800}@media (width<=1100px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=680px){.project-section{padding:64px 18px}.project-grid{grid-template-columns:1fr}.project-preview{min-height:170px}.project-gallery-modal,.project-gallery-panel{padding:12px}}.portfolio-shell{background:var(--panel);grid-template-columns:252px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{z-index:20;background:#1f2220;border-right:4px solid #c3c9b785;flex-direction:column;display:flex;position:relative}.page-content{background:#111413;min-width:0}.mobile-menu-toggle{display:none}.profile{text-align:center;border-bottom:4px solid #c3c9b78c;flex-direction:column;justify-content:center;align-items:center;min-height:334px;padding:34px 16px 28px;display:flex}.avatar-frame{background:var(--gray);border:4px solid #7d8874;width:102px;height:102px;margin-bottom:30px;overflow:hidden;box-shadow:5px 5px #0e0f0f}.avatar-frame img{object-fit:cover;object-position:43% 57%;width:160%;height:160%;position:relative;top:-40%;transform:scaleX(-1)}.profile h1{color:var(--leaf);margin:0 0 18px;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:400;line-height:1.25}.profile p{color:var(--sage);margin:0;font-size:16px;line-height:1.2}.side-nav{gap:14px;padding:18px 6px;display:grid;position:sticky;top:0}.nav-link{min-height:48px;color:var(--sage);align-items:center;gap:15px;padding:0 16px;font-size:16px;line-height:1;transition:background-color .16s,color .16s;display:flex}.nav-link.active{color:var(--white);background:var(--moss);border-left:4px solid #a2d577}.nav-link:hover{color:var(--white);background:var(--moss)}.contact-footer{color:#8f8f8f;margin:0 18px 18px;font-size:13px;font-weight:500;line-height:1.5}@media (width<=900px){body{overflow:auto}.portfolio-shell{grid-template-columns:1fr}.sidebar{border-bottom:4px solid #c3c9b785;border-right:0;align-self:start;position:sticky;top:0}.profile,.avatar-frame{display:none}.profile h1{margin-bottom:10px;font-size:17px}.side-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:0;padding:0}.nav-link{justify-content:center;gap:8px;min-height:58px;padding:0 8px;font-size:12px}}@media (width<=560px){.mobile-menu-toggle{z-index:40;color:#fff;cursor:pointer;background:#111413d1;border:2px solid #ffffffb8;place-items:center;width:38px;height:38px;padding-right:30px;display:grid;position:fixed;top:12px;right:12px}.mobile-menu-toggle svg{width:24px;height:24px;transition:transform .18s}.mobile-menu-toggle.open svg{transform:rotate(180deg)}.sidebar{z-index:30;border-bottom:4px solid #c3c9b785;transition:transform .22s;position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}.sidebar.open{transform:translateY(0)}.side-nav{background:#1f2220;grid-template-columns:repeat(1,minmax(0,1fr));padding-top:65px;position:static;box-shadow:0 6px #00000061}.nav-link{justify-content:flex-start;min-height:48px;padding:0 18px}}
