:root{--color:#f0f0f0;--accent:#76B900;--accent-rgb:118,185,0;--accent-hover:#8ecf00;--bg:#111111;--bg-elevated:#161616;--bg-card:rgba(22,27,34,0.65);--border:rgba(118, 185, 0, 0.15);--border-hover:rgba(118, 185, 0, 0.35);--text:#f0f0f0;--text-dim:#a0a0a0;--text-muted:#666;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-pill:999px;--ease-out:cubic-bezier(0.16, 1, 0.3, 1);--transition-fast:0.2s var(--ease-out);--transition-med:0.45s var(--ease-out)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body,html{overflow-x:hidden;background-color:var(--bg);background-image:radial-gradient(ellipse at 50% 0,rgba(var(--accent-rgb),.03) 0,transparent 60%);font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:17px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color)}.collapse-btn[collapsed=true]+.collapse-body{opacity:0;font-size:0;transition:opacity .4s,font-size .3s .4s}.collapse-btn[collapsed=true]+.collapse-body p{padding:0!important;transition:padding .3s .3s}.collapse-btn[collapsed=false]+.collapse-body{font-size:inherit;opacity:1;transition:opacity .3s .3s,font-size .3s}.collapse-btn[collapsed=false]+.collapse-body p{transition:padding .3s}nav{position:fixed;top:0;right:0;background-color:transparent;width:0;z-index:5}.menu-btn{position:fixed;padding:20px;top:0;left:0;right:0;display:flex;gap:0;transition:all .7s;z-index:1;justify-content:flex-end;pointer-events:none}nav .btn{opacity:0;pointer-events:none;padding:8px 16px;fill:var(--accent)}.menu-btn>button.btn:last-child{padding:8px 24px;margin-left:12px}.social-bar{display:flex;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.18);border-radius:14px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.3),0 0 20px rgba(var(--accent-rgb),.08);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);opacity:0;pointer-events:none;transition:all .2s ease}html[data-scroll=true] .social-bar{opacity:1;pointer-events:all}.social-bar a{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;fill:var(--accent);transition:all .2s ease;text-decoration:none;cursor:pointer;position:relative}.social-bar a:not(:last-child){border-right:1px solid rgba(var(--accent-rgb),.12)}.social-bar a:hover{background-color:rgba(var(--accent-rgb),.12)}.social-bar a:active{background-color:rgba(var(--accent-rgb),.2)}.active .social-bar{background-color:var(--accent);border-color:var(--accent);box-shadow:0 0 30px rgba(var(--accent-rgb),.25);opacity:1!important;pointer-events:all!important}.active .social-bar a{fill:var(--bg)}.active .social-bar a:not(:last-child){border-right-color:rgba(17,17,17,.2)}.active .social-bar a:hover{background-color:rgba(17,17,17,.1)}nav svg{transition:all .2s}html[data-scroll=true] nav .btn{opacity:1;pointer-events:all}.active .btn{box-shadow:0 0 24px rgba(var(--accent-rgb),.25);background-color:var(--accent);color:var(--bg);fill:var(--bg);border-color:var(--accent);opacity:1!important;pointer-events:all!important}.active .btn:hover{box-shadow:0 0 36px rgba(var(--accent-rgb),.4)}.active .btn:active{box-shadow:0 0 12px rgba(var(--accent-rgb),.2)}.menu-body{background-color:rgba(17,17,17,.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);color:var(--text);font-size:2em;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:600;text-decoration:none!important;position:fixed;top:0;bottom:0;left:100vw;right:-100px;z-index:0;transition:all .7s;display:inline-flex;gap:16px;flex-direction:column;padding-top:70px;padding-right:20px;align-items:flex-end;overflow:hidden;box-sizing:border-box;opacity:0}.menu-body a{text-decoration:none!important;transition:color .2s}.menu-body a:hover{color:var(--accent)}.active .menu-body{left:0;right:0;opacity:1}@media (min-width:540px){.menu-btn{justify-content:flex-end}.active .menu-btn{translate:-28px}.menu-body{padding-right:50px}}#tip-scroll{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);font-family:Inter,sans-serif;font-size:13px;font-weight:500;letter-spacing:.05em;box-shadow:0 0 20px rgba(var(--accent-rgb),.15);background-color:rgba(17,17,17,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--accent);transition:opacity .3s;padding:6px 24px;border:rgba(var(--accent-rgb),.3) solid 1px;border-radius:var(--radius-pill);pointer-events:none;display:none;opacity:1;z-index:4}html[data-scroll=true] #tip-scroll{opacity:0}nav.mobile-open #tip-scroll{opacity:0!important}@media (orientation:portrait){#tip-scroll{display:block}}.webgl{position:fixed;top:0;left:0;width:100%;min-height:100svh;height:100lvh;outline:0;z-index:1;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;touch-action:pan-y;user-select:none;-webkit-user-select:none}#vignette{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1;background:0 0;transition:opacity .3s}#hero-backup{display:flex;flex-direction:column;justify-content:center;gap:16px;position:absolute;top:0;left:0;right:0;bottom:0;width:clamp(0px,95vw,580px);margin:auto;color:var(--color);outline:0;z-index:0}#hero-backup h1,#hero-backup h3{margin:0;text-align:left}#hero-backup h3{font-family:"Press Start 2P",cursive;color:var(--accent);font-size:.9em}#hero-backup ul{margin-left:32px}#textarea{position:fixed;top:0;right:0;outline:0;z-index:-1;opacity:0}#loading{color:var(--accent);background-color:var(--bg);position:fixed;inset:0;z-index:6;transition:opacity .4s ease;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:10vw}#loading h2{text-align:center;margin:0;padding:0;font-family:"Press Start 2P",cursive;font-weight:400;font-size:clamp(14px, 3vw, 22px);color:var(--accent);background:0 0;letter-spacing:.05em}#loading-items{height:40px;overflow:hidden;text-overflow:ellipsis;font-family:"JetBrains Mono",monospace;font-size:12px;color:#444;text-align:center;max-width:500px}#loading-bar{position:relative;width:min(400px,80vw);height:3px;border:none;border-radius:2px;background-color:#1a1a1a;box-shadow:none}#loading-bar-progress{position:absolute;top:0;bottom:0;left:0;right:0;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.4, 0, .2, 1);box-shadow:0 0 20px rgba(var(--accent-rgb),.4)}h1{display:inline-block;color:var(--text);background:0 0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:700;font-size:clamp(1.8em, 5vw, 2.6em);letter-spacing:-.03em;padding:0;margin:auto;margin-top:0;margin-bottom:.3em}h2{display:inline-block;font-size:clamp(1.1em, 3vw, 1.4em);text-align:center;color:var(--accent);background:0 0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:600;letter-spacing:-.02em;padding:0;margin:auto;margin-top:.3em;margin-bottom:.3em}h3{font-size:1.1em;text-align:center;color:var(--text-dim);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:500;padding-top:4px;padding-bottom:8px;margin:auto;margin-top:.3em;margin-bottom:.3em}hr{width:60px;height:1px;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.4),transparent);margin:auto;margin-top:48px;margin-bottom:48px;border:none}a{display:inline-block;color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}main{color:var(--color);margin-top:200vh;text-align:center;position:relative;z-index:2;background-color:var(--bg)}main::before{content:"";position:absolute;top:-200px;left:0;right:0;height:200px;background:linear-gradient(to bottom,transparent,var(--bg));pointer-events:none;z-index:2}section{padding:80px 20px;position:relative;max-width:1200px;margin:0 auto 40px}section::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:min(680px,90%);border-bottom:1px solid rgba(255,255,255,.05)}section:last-of-type::after{display:none}.section-label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:block}.accent-line{width:48px;height:2px;background:linear-gradient(90deg,var(--accent),transparent);border:none;margin:20px auto 0}.about-card{display:flex;gap:40px;align-items:flex-start;max-width:820px;margin:0 auto;padding:40px;background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-md);text-align:left;transition:border-color var(--transition-med)}.about-card:hover{border-color:var(--border-hover)}.about-photo-wrap{flex-shrink:0;width:180px;height:250px;border-radius:var(--radius-md);overflow:hidden;position:relative;box-shadow:0 8px 32px rgba(0,0,0,.4)}.about-photo-wrap img{width:100%;height:100%;object-fit:cover;display:block}.about-photo-wrap::after{content:"";position:absolute;inset:0;border-radius:var(--radius-md);box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.15);pointer-events:none}.about-text{flex:1;min-width:0}.about-text h1{margin-bottom:4px;text-align:left;font-size:clamp(1.5em, 4vw, 2em)}.about-text .subtitle{color:var(--accent);font-family:"JetBrains Mono",monospace;font-size:.85em;font-weight:500;margin-bottom:20px}.about-text p{color:var(--text-dim);line-height:1.8;font-size:.95em;margin-bottom:16px;padding:0;width:auto;text-align:left}.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;list-style:none;padding:0}.about-tags li{display:inline-block;padding:4px 14px;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.78em;font-family:"JetBrains Mono",monospace;color:var(--text-dim);background:rgba(var(--accent-rgb),.04);transition:border-color var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.about-tags li:hover{border-color:var(--border-hover);background:rgba(var(--accent-rgb),.08);color:var(--accent)}@media (max-width:700px){.about-card{flex-direction:column;align-items:center;text-align:center;padding:28px 20px}.about-photo-wrap{width:140px;height:190px}.about-text h1{text-align:center}.about-text .subtitle{text-align:center}.about-text p{text-align:center}.about-tags{justify-content:center}}.projects-section-title{text-align:center;margin-bottom:12px}.projects-section-label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;display:block}.projects-section-rule{width:48px;height:1px;background:var(--accent);margin:24px auto 48px;border:none;opacity:.5}.project-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:36px}.project-filters button{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.04em;padding:6px 16px;border-radius:var(--radius-pill);border:1px solid rgba(var(--accent-rgb),.15);background:rgba(var(--accent-rgb),.04);color:var(--text-dim);cursor:pointer;transition:all var(--transition-fast)}.project-filters button:hover{border-color:rgba(var(--accent-rgb),.3);color:var(--accent);background:rgba(var(--accent-rgb),.08)}.project-filters button.active{border-color:var(--accent);background:var(--accent);color:var(--bg);font-weight:600}.project-grid{columns:1;column-gap:20px;column-fill:balance;max-width:1140px;margin:0 auto;padding:0}@media (min-width:640px){.project-grid{columns:2}}@media (min-width:1024px){.project-grid{columns:3}}.pcard{break-inside:avoid;background:var(--bg-elevated);border:1px solid rgba(var(--accent-rgb),.08);border-radius:var(--radius-md);padding:24px;margin-bottom:20px;transition:background var(--transition-med),border-color var(--transition-med),transform .4s var(--ease-out),box-shadow .4s var(--ease-out);cursor:default;position:relative;overflow:hidden;opacity:0;transform:translateY(24px)}.pcard.revealed{opacity:1;transform:translateY(0);transition:opacity .5s ease,transform .5s ease,background var(--transition-med),border-color var(--transition-med),box-shadow .4s var(--ease-out)}.pcard::before{content:'';position:absolute;inset:0;border-radius:var(--radius-md);background:radial-gradient(circle at 70% 0,rgba(var(--accent-rgb),.04),transparent 60%);pointer-events:none}.pcard::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),rgba(var(--accent-rgb),.2));opacity:0;transition:opacity var(--transition-fast)}.pcard:hover{background:#1c1c1c;border-color:rgba(var(--accent-rgb),.28);transform:translateY(-6px);box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 0 1px rgba(var(--accent-rgb),.15)}.pcard:hover::after{opacity:1}.pcard-header{display:flex;align-items:baseline;gap:10px;margin-bottom:16px;flex-wrap:wrap}.pcard-img{margin:-24px -24px 16px;border-radius:var(--radius-md) var(--radius-md) 0 0;overflow:hidden}.pcard-img img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#1a1a1a;transition:transform .5s var(--ease-out)}.pcard:hover .pcard-img img{transform:scale(1.04)}.pcard-title{font-family:Inter,-apple-system,sans-serif;font-size:1.05rem;font-weight:600;color:var(--text);line-height:1.35;display:inline;letter-spacing:-.01em;margin:0;text-align:left;padding:0;width:auto;background:0 0}.pcard-year{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.04em;color:var(--text-muted);white-space:nowrap}.pcard-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;list-style:none;padding:0;width:auto;text-align:left}.pcard-tags li{font-size:.72rem;padding:3px 10px;border-radius:var(--radius-pill);color:#888;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);font-family:"JetBrains Mono",monospace;letter-spacing:.02em;transition:border-color var(--transition-fast),color var(--transition-fast)}.pcard:hover .pcard-tags li{border-color:rgba(var(--accent-rgb),.15);color:var(--text-dim)}.pcard-desc{font-size:.86rem;line-height:1.72;color:#8a8a8a;margin:0;padding:0;width:auto;text-align:left}.pcard-sep{height:1px;background:rgba(var(--accent-rgb),.1);margin:14px 0}.pcard-context{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--text-muted);font-family:"JetBrains Mono",monospace;letter-spacing:.02em}.pcard-context-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:.6}.pcard[data-hidden=true]{display:none}.projects-note{text-align:center;color:var(--text-muted);margin-top:48px;font-size:.85rem;padding:0 20px}.contact-card{max-width:600px;margin:0 auto;padding:48px 40px;background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;transition:border-color var(--transition-med)}.contact-card:hover{border-color:var(--border-hover)}.contact-card h1{text-align:center;margin-bottom:8px;font-size:clamp(1.3em, 4vw, 1.8em)}.contact-card p{color:var(--text-dim);line-height:1.7;margin-bottom:32px;text-align:center;width:auto;padding:0}.contact-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn{position:relative;font-family:Inter,-apple-system,sans-serif;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;box-shadow:0 0 20px rgba(var(--accent-rgb),.1);background:rgba(var(--accent-rgb),.1);color:var(--accent);fill:var(--accent);cursor:pointer;transition:all var(--transition-fast);padding:12px 28px;border:1px solid rgba(var(--accent-rgb),.25);border-radius:var(--radius-sm);text-decoration:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.btn:hover{background:rgba(var(--accent-rgb),.18);box-shadow:0 0 40px rgba(var(--accent-rgb),.25);transform:translateY(-2px);color:var(--accent-hover);fill:var(--accent-hover)}.btn:active{transform:translateY(0) scale(.97);box-shadow:0 0 12px rgba(var(--accent-rgb),.15)}.btn-primary{background:var(--accent);color:var(--bg);fill:var(--bg);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);color:var(--bg);fill:var(--bg);box-shadow:0 0 40px rgba(var(--accent-rgb),.35)}footer{position:relative;z-index:2;max-width:820px;margin:0 auto;padding:48px 20px 32px;text-align:center;color:var(--text-muted);font-size:12px}footer::before{content:"";display:block;width:80px;height:1px;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.3),transparent);margin:0 auto 32px}.footer-social{display:flex;justify-content:center;gap:16px;margin-bottom:20px}.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;fill:var(--text-muted);border:1px solid rgba(255,255,255,.06);border-radius:50%;transition:all var(--transition-fast)}.footer-social a:hover{fill:var(--accent);border-color:rgba(var(--accent-rgb),.3);background:rgba(var(--accent-rgb),.06)}.footer-credits{margin-bottom:8px}.footer-copy{color:#444}.skills,p{padding:16px;text-align:left;line-height:1.7;width:clamp(0px,95vw,680px);margin:auto;box-sizing:border-box;color:silver}.skills{display:flex;flex-wrap:wrap;align-content:center;justify-content:center;align-items:center;gap:10px;text-align:center;list-style-type:none;transition:all .3s}.skills li{display:inline-block;padding:4px 12px;border:1px solid var(--border);border-radius:6px;font-size:.9em;color:var(--text-dim);background:rgba(var(--accent-rgb),.05)}.image{display:flex;align-items:flex-start;justify-content:center;flex-wrap:wrap;gap:16px;margin:auto}.image *{box-sizing:border-box;width:clamp(0px,95vw,1200px);border-radius:var(--radius-sm);box-shadow:0 4px 24px rgba(0,0,0,.4)}.portrait{position:relative;width:clamp(0px,95vw,780px);padding:0;height:400px;margin:auto;overflow:hidden;display:flex;align-items:center;justify-content:center;border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,.5)}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal-stagger>.reveal:first-child{transition-delay:0s}.reveal-stagger>.reveal:nth-child(2){transition-delay:80ms}.reveal-stagger>.reveal:nth-child(3){transition-delay:0.16s}.reveal-stagger>.reveal:nth-child(4){transition-delay:0.24s}@font-face{font-family:public-pixel;src:url("/assets/fonts/public-pixel.woff");font-display:swap}@font-face{font-family:chill;src:url("/assets/fonts/chill.woff");font-display:swap}#mobile-interact-controls{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:4;display:none;opacity:0;transition:opacity .3s var(--ease-out);pointer-events:none}@media (pointer:coarse),(max-width:1024px){#mobile-interact-controls{display:block}#mobile-interact-controls.visible{opacity:1;pointer-events:auto}}#mobile-exit-controls{position:fixed;top:20px;right:20px;z-index:10;display:none;opacity:0;transition:opacity .3s var(--ease-out);pointer-events:none}#mobile-exit-controls.visible{display:block;opacity:1;pointer-events:auto}.mobile-control-btn{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:rgba(var(--accent-rgb),.15);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--accent);fill:var(--accent);border:1px solid rgba(var(--accent-rgb),.35);border-radius:var(--radius-pill);box-shadow:0 4px 24px rgba(0,0,0,.4),0 0 30px rgba(var(--accent-rgb),.15);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.mobile-control-btn:active,.mobile-control-btn:hover{background:rgba(var(--accent-rgb),.25);border-color:var(--accent);box-shadow:0 4px 32px rgba(0,0,0,.5),0 0 40px rgba(var(--accent-rgb),.25);transform:scale(1.02)}.mobile-control-btn:active{transform:scale(.98)}body.interaction-mode{overflow:hidden;touch-action:none}body.interaction-mode #hero-backup,body.interaction-mode #tip-scroll,body.interaction-mode footer,body.interaction-mode main,body.interaction-mode nav{opacity:0;pointer-events:none;transition:opacity .3s var(--ease-out)}