.modal-overlay{-webkit-backdrop-filter:blur(12px)saturate(150%);backdrop-filter:blur(12px)saturate(150%);z-index:1000;width:100vw;height:100vh;padding:var(--space-xl);opacity:0;animation:fadeIn var(--transition-base) forwards;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}@keyframes fadeIn{to{opacity:1}}.modal-content{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);width:100%;max-width:850px;max-height:90vh;box-shadow:var(--shadow-md), 0 0 40px #ffffff05;flex-direction:column;display:flex;position:relative;overflow-y:auto}.modal-close{top:var(--space-lg);right:var(--space-lg);border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text2);transition:all var(--transition-fast);z-index:2;justify-content:center;align-items:center;display:flex;position:absolute}.modal-close:hover{background:var(--accent);color:var(--bg);transform:rotate(90deg)}.modal-body{padding:var(--space-3xl);gap:var(--space-xl);flex-direction:column;display:flex}.modal-header{gap:var(--space-sm);padding-right:var(--space-2xl);flex-direction:column;display:flex}.modal-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.03em;font-size:clamp(2rem,4vw,3rem);font-weight:600;line-height:1.1}.modal-tagline{color:var(--accent2);letter-spacing:.02em;font-size:1.15rem;font-weight:400}.modal-links{gap:var(--space-md);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.modal-link{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);background:var(--accent);color:var(--bg);transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em;border:1px solid #0000;padding:.75rem 1.5rem;font-size:.85rem;font-weight:600;display:inline-flex}.modal-link:hover{color:var(--bg);transform:translateY(-2px);box-shadow:0 4px 15px #ffffff26}.modal-link--secondary{color:var(--text);border:1px solid var(--border-strong);background:0 0}.modal-link--secondary:hover{background:var(--surface2);color:var(--text);border-color:var(--text);box-shadow:none}.modal-description{color:var(--text2);max-width:700px;font-size:1.05rem;font-weight:300;line-height:1.8}.modal-stack{gap:var(--space-sm);padding-top:var(--space-lg);border-top:1px solid var(--border);flex-wrap:wrap;display:flex}.modal-tech{border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);color:var(--text2);text-transform:uppercase;letter-spacing:.05em;padding:.3rem .8rem;font-size:.75rem;font-weight:500}:root{--bg:#000;--surface:#0a0a0a;--surface2:#111;--surface3:#1a111a;--panel-bg:#0a0a0acc;--panel-border:#ffffff0d;--border:#ffffff0a;--border-hover:#ffffff1f;--border-strong:#fff3;--accent:#fff;--accent-dim:#ffffff1a;--accent-glow:#ffffff0d;--accent2:#94a3b8;--accent2-dim:#94a3b81a;--green:#86efac;--red:#fca5a5;--yellow:#fde047;--cyan:#7dd3fc;--text:#fff;--text2:#a1a1aa;--text3:#71717a;--muted:#3f3f46;--font-display:"Plus Jakarta Sans", "Inter", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2.25rem;--space-2xl:3.5rem;--space-3xl:5rem;--radius-sm:2px;--radius-md:4px;--radius-lg:8px;--radius-xl:16px;--ease-out:cubic-bezier(.16, 1, .3, 1);--transition-fast:.2s var(--ease-out);--transition-base:.4s var(--ease-out);--transition-slow:.7s var(--ease-out);--glass-bg:#0a0a0a99;--glass-blur:blur(20px) saturate(180%);--shadow-sm:0 4px 12px #00000080;--shadow-md:0 8px 24px #000000b3;--glow:0 0 20px #ffffff0d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);color:var(--text);background:var(--bg);letter-spacing:-.011em;width:100vw;height:100vh;font-weight:400;line-height:1.5;overflow:hidden}body:before{content:"";opacity:.04;pointer-events:none;z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");width:100%;height:100%;position:fixed;top:0;left:0}#root{width:100vw;height:100vh;position:relative;overflow:hidden}a{color:var(--text);transition:all var(--transition-fast);border-bottom:1px solid var(--border);text-decoration:none}a:hover{border-bottom-color:var(--text);color:var(--text)}a:focus-visible{outline:1px solid var(--text);outline-offset:4px}button{font-family:var(--font-body);cursor:pointer;color:inherit;font-size:inherit;transition:all var(--transition-fast);background:0 0;border:none}button:focus-visible{outline:1px solid var(--text);outline-offset:4px}::selection{background:var(--accent);color:var(--bg)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--muted);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.8}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeInUp .8s var(--ease-out) both}.fade-in-scale{animation:fadeInScale .6s var(--ease-out) both}.section-divider{background:linear-gradient(to right, var(--border), transparent);height:1px;margin:var(--space-2xl) 0;width:100%}.portfolio-layout{background:var(--bg);grid-template-columns:52fr 48fr;width:100vw;height:100vh;display:grid;overflow:hidden}.left-panel{padding:var(--space-3xl) var(--space-3xl);scroll-padding-top:var(--space-3xl);position:relative;overflow:hidden auto}.left-panel__inner{gap:var(--space-3xl);flex-direction:column;width:100%;max-width:900px;margin:0 auto;display:flex}.right-panel{background:var(--surface);border-left:1px solid var(--panel-border);z-index:10;height:100vh;position:relative;overflow:hidden;box-shadow:-10px 0 30px #00000080}.right-panel:before{content:"";background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);z-index:-1;position:absolute;inset:0}.portfolio-layout--single{grid-template-columns:1fr}.left-panel--centered .left-panel__inner{max-width:800px;margin:0 auto}.terminal-toggle-fab{bottom:var(--space-xl);right:var(--space-xl);border-radius:var(--radius-sm);background:var(--surface2);width:48px;height:48px;color:var(--text);border:1px solid var(--border-strong);cursor:pointer;z-index:100;transition:all var(--transition-base);box-shadow:var(--shadow-md);justify-content:center;align-items:center;display:flex;position:fixed}.terminal-toggle-fab:hover{background:var(--text);color:var(--bg);transform:translateY(-2px)}@media (width<=1024px){.portfolio-layout{grid-template-columns:1fr;height:auto;overflow:auto}.left-panel{height:auto;overflow:visible}.right-panel{border-left:none;border-top:1px solid var(--panel-border);height:600px}body{overflow:auto}}.hero{gap:var(--space-lg);margin-top:var(--space-xl);flex-direction:column;display:flex;position:relative}.hero__name{font-family:var(--font-display);color:var(--text);letter-spacing:-.04em;text-transform:uppercase;font-size:clamp(2.5rem,6vw,4.2rem);font-weight:600;line-height:1.05}.hero__title{color:var(--text2);letter-spacing:.05em;text-transform:uppercase;margin-top:-.5rem;font-size:1.125rem;font-weight:500}.hero__meta{align-items:center;gap:var(--space-lg);margin-top:var(--space-sm);flex-wrap:wrap;display:flex}.hero__location{color:var(--text3);align-items:center;gap:var(--space-xs);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;display:flex}.hero__badges{gap:var(--space-sm);display:flex}.hero__badge{border-radius:var(--radius-sm);background:var(--surface2);color:var(--text2);border:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;padding:.25rem .75rem;font-size:.7rem;font-weight:500}.hero__availability{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);background:var(--accent-dim);border:1px solid var(--border-strong);text-transform:uppercase;letter-spacing:.1em;width:fit-content;padding:.4rem .8rem;font-size:.75rem;display:inline-flex}.hero__availability-dot{border-radius:50%;width:6px;height:6px;position:relative}.hero__availability-dot--active{background:var(--green);box-shadow:0 0 8px var(--green)}.hero__bio{color:var(--text2);max-width:620px;margin-top:var(--space-md);letter-spacing:-.01em;font-size:1.1rem;font-weight:400;line-height:1.6}.hero:after{content:"";bottom:calc(-1 * var(--space-xl));background:var(--accent);width:100px;height:2px;position:absolute;left:0}.links-row{gap:var(--space-sm);flex-wrap:wrap;display:flex}.links-row__item{align-items:center;gap:var(--space-sm);color:var(--text2);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em;padding:.4rem .9rem;font-size:.75rem;font-weight:600;text-decoration:none;display:inline-flex}.links-row__item:hover{border-color:var(--accent);color:var(--accent);background:var(--surface3);text-decoration:none;transform:translateY(-2px);box-shadow:0 4px 10px #0000004d}.links-row__item:focus-visible{outline:1px solid var(--accent);outline-offset:4px}.links-row__icon{flex-shrink:0;width:14px;height:14px}.stack-section{gap:var(--space-xl);flex-direction:column;display:flex}.stack-section__heading{font-family:var(--font-display);color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:var(--space-sm);align-items:center;gap:var(--space-md);font-size:.75rem;font-weight:700;display:flex}.stack-section__heading:after{content:"";background:linear-gradient(to right, var(--border-strong), transparent);flex:1;height:1px}.stack-filters{gap:var(--space-sm);flex-wrap:wrap;display:flex}.stack-filters__btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text3);transition:all var(--transition-fast);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:0 0;padding:.3rem .8rem;font-size:.7rem;font-weight:600}.stack-filters__btn:hover{border-color:var(--border-hover);color:var(--text2);background:var(--surface2)}.stack-filters__btn--active{border-color:var(--accent);color:var(--bg);background:var(--accent)}.stack-chips{gap:var(--space-sm);flex-wrap:wrap;display:flex}.stack-chip{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text2);background:var(--surface2);transition:all var(--transition-base);padding:.35rem .75rem;font-size:.8rem;font-weight:500}.stack-chip--highlighted{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);box-shadow:0 0 15px #ffffff08}.stack-chip--dimmed{opacity:.15;filter:grayscale()}.projects-section{gap:var(--space-xl);flex-direction:column;display:flex}.projects-section__heading{font-family:var(--font-display);color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:var(--space-sm);align-items:center;gap:var(--space-md);font-size:.75rem;font-weight:700;display:flex}.projects-section__heading:after{content:"";background:linear-gradient(to right, var(--border-strong), transparent);flex:1;height:1px}.projects-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.project-card{padding:var(--space-lg);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);transition:all var(--transition-base);gap:var(--space-sm);flex-direction:column;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--accent);transform-origin:0;width:100%;height:2px;transition:transform var(--transition-base);position:absolute;top:0;left:0;transform:scaleX(0)}.project-card:hover{border-color:var(--border-hover);background:var(--surface2);box-shadow:var(--shadow-md);transform:translateY(-4px)}.project-card:hover:before{transform:scaleX(1)}.project-card--featured{background:var(--surface2);border-color:var(--border-strong);grid-column:1/-1}.project-card__header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.project-card__name{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;font-size:1.25rem;font-weight:600}.project-card__featured-badge{border-radius:var(--radius-sm);background:var(--accent);color:var(--bg);text-transform:uppercase;letter-spacing:.1em;padding:.2rem .6rem;font-size:.6rem;font-weight:700}.project-card__links{gap:var(--space-md);margin-top:.25rem;display:flex}.project-card__link{color:var(--text3);transition:all var(--transition-fast);border:none}.project-card__link:hover{color:var(--accent);transform:scale(1.1)}.project-card__tagline{color:var(--accent2);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:500}.project-card__description{color:var(--text2);margin:var(--space-xs) 0;font-size:.9rem;line-height:1.6}.project-card__stack{gap:var(--space-xs);flex-wrap:wrap;margin-top:auto;display:flex}.project-card__tech{border-radius:var(--radius-sm);background:var(--bg);color:var(--text3);border:1px solid var(--border);text-transform:uppercase;padding:.15rem .5rem;font-size:.65rem;font-weight:600}@media (width<=640px){.projects-grid{grid-template-columns:1fr}}.experience-section{gap:var(--space-xl);flex-direction:column;display:flex}.experience-section__heading{font-family:var(--font-display);color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:var(--space-sm);align-items:center;gap:var(--space-md);font-size:.75rem;font-weight:700;display:flex}.experience-section__heading:after{content:"";background:linear-gradient(to right, var(--border-strong), transparent);flex:1;height:1px}.timeline{gap:var(--space-2xl);padding-left:var(--space-xl);flex-direction:column;display:flex;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), var(--border), transparent);width:1px;position:absolute;top:8px;bottom:8px;left:2px}.timeline-entry{gap:var(--space-sm);flex-direction:column;display:flex;position:relative}.timeline-entry:before{content:"";left:calc(-1 * var(--space-xl) - 2px);background:var(--bg);border:2px solid var(--accent);z-index:2;border-radius:50%;width:9px;height:9px;position:absolute;top:8px}.timeline-entry__header{flex-direction:column;gap:.25rem;display:flex}.timeline-entry__company{font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;font-size:1.1rem;font-weight:600}.timeline-entry__location{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.timeline-entry__role{color:var(--accent2);margin-top:2px;font-size:.9rem;font-weight:500}.timeline-entry__duration{color:var(--text3);font-size:.75rem;font-family:var(--font-mono)}.timeline-entry__bullets{gap:var(--space-sm);margin-top:var(--space-sm);flex-direction:column;list-style:none;display:flex}.timeline-entry__bullet{color:var(--text2);padding-left:var(--space-lg);font-size:.9rem;line-height:1.6;position:relative}.timeline-entry__bullet:before{content:"";background:var(--border-strong);width:12px;height:1px;position:absolute;top:10px;left:0}.education-section{gap:var(--space-xl);flex-direction:column;display:flex}.education-section__heading{font-family:var(--font-display);color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:var(--space-sm);align-items:center;gap:var(--space-md);font-size:.75rem;font-weight:700;display:flex}.education-section__heading:after{content:"";background:linear-gradient(to right, var(--border-strong), transparent);flex:1;height:1px}.education-entries{gap:var(--space-lg);flex-direction:column;display:flex}.education-entry{padding:var(--space-lg);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);gap:var(--space-sm);flex-direction:column;display:flex;position:relative;overflow:hidden}.education-entry:before{content:"";background:var(--border-strong);width:2px;height:100%;position:absolute;top:0;left:0}.education-entry__degree{font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;font-size:1.1rem;font-weight:600}.education-entry__university{color:var(--accent2);font-size:.9rem;font-weight:500}.education-entry__meta{gap:var(--space-md);color:var(--text3);font-size:.8rem;font-family:var(--font-mono);margin-top:2px;display:flex}.certifications-section{gap:var(--space-xl);flex-direction:column;display:flex}.certifications-section__heading{font-family:var(--font-display);color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:var(--space-sm);align-items:center;gap:var(--space-md);font-size:.75rem;font-weight:700;display:flex}.certifications-section__heading:after{content:"";background:linear-gradient(to right, var(--border-strong), transparent);flex:1;height:1px}.certifications-list{gap:var(--space-md);flex-direction:column;display:flex}.certification-item{padding:.8rem var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);transition:all var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.certification-item:hover{border-color:var(--border-strong);background:var(--surface2);transform:translate(4px)}.certification-item__info{flex-direction:column;gap:2px;display:flex}.certification-item__title{font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;border:none;font-size:.95rem;font-weight:600}.certification-item__title:hover{color:var(--accent);border:none}.certification-item__issuer{color:var(--accent2);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.certification-item__date{color:var(--text3);font-size:.75rem;font-family:var(--font-mono);flex-shrink:0}.achievements-section{gap:var(--space-xl);flex-direction:column;display:flex}.achievements-section__heading{font-family:var(--font-display);color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:var(--space-sm);align-items:center;gap:var(--space-md);font-size:.75rem;font-weight:700;display:flex}.achievements-section__heading:after{content:"";background:linear-gradient(to right, var(--border-strong), transparent);flex:1;height:1px}.achievements-list{gap:var(--space-sm);flex-direction:column;display:flex}.achievement-item{color:var(--text2);padding-left:var(--space-lg);font-size:.9rem;line-height:1.6;position:relative}.achievement-item:before{content:"";background:var(--border-strong);width:12px;height:1px;position:absolute;top:10px;left:0}.footer{gap:var(--space-md);padding-bottom:var(--space-lg);flex-direction:column;display:flex}.footer__text{color:var(--text3);font-size:.8rem}.footer__socials{gap:var(--space-md);display:flex}.footer__social-link{color:var(--text3);transition:color var(--transition-fast);border:none;align-items:center;display:flex}.footer__social-link:hover{color:var(--text);border:none}.footer__social-link svg{width:16px;height:16px}.terminal{background:0 0;flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.terminal:after{content:"";pointer-events:none;z-index:20;opacity:.3;background:linear-gradient(#12101000 50%,#0000001a 50%) 0 0/100% 3px,linear-gradient(90deg,#ff000005,#00ff0003,#0000ff05) 0 0/3px 100%;width:100%;height:100%;position:absolute;top:0;left:0}.terminal-chrome{padding:.75rem var(--space-lg);border-bottom:1px solid var(--panel-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;flex-shrink:0;align-items:center;display:flex;position:relative}.terminal-chrome__dots{gap:10px;display:flex}.terminal-chrome__dot{border-radius:var(--radius-sm);border:1px solid var(--panel-border);width:12px;height:12px;transition:all var(--transition-fast)}.terminal-chrome__dot--red{cursor:pointer;background:#fca5a533}.terminal-chrome__dot--yellow{background:#fde0471a}.terminal-chrome__dot--green{background:#86efac1a}.terminal-chrome:hover .terminal-chrome__dot--red{background:var(--red);box-shadow:0 0 10px var(--red)}.terminal-chrome__title{color:var(--text3);font-size:.7rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.2em;position:absolute;left:50%;transform:translate(-50%)}.terminal-body{padding:var(--space-xl) var(--space-lg);scroll-behavior:smooth;flex-direction:column;flex:1;gap:8px;display:flex;overflow:hidden auto}.terminal-line{white-space:pre-wrap;word-break:break-word;font-size:.85rem;line-height:1.5;font-family:var(--font-mono)}.terminal-line--prompt{margin-top:var(--space-sm);border-left:2px solid var(--accent);padding-left:var(--space-sm);gap:0;display:flex}.terminal-line__prompt-user{color:var(--accent);font-weight:600}.terminal-line__prompt-separator{color:var(--text3);opacity:.5}.terminal-line__prompt-path{color:var(--text2)}.terminal-line__prompt-dollar{color:var(--accent);margin-right:var(--space-sm)}.terminal-line__command{color:var(--text)}.terminal-line--output{color:var(--text2);font-weight:300}.terminal-line--header{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.terminal-line--error{color:var(--red);background:#fca5a50d;padding:2px 4px}.terminal-line--muted{color:var(--muted)}.terminal-line--success{color:var(--green)}.terminal-line--link{color:var(--cyan);cursor:pointer;border-bottom:1px solid var(--panel-border)}.terminal-line--link:hover{color:var(--text);border-bottom-color:var(--accent)}.terminal-hints{gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--panel-border);background:#0003;flex-wrap:wrap;flex-shrink:0;display:flex}.terminal-hints__pill{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text3);cursor:pointer;transition:all var(--transition-fast);font-size:.65rem;font-family:var(--font-mono);text-transform:uppercase;background:0 0;padding:.2rem .5rem}.terminal-hints__pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.terminal-input{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--panel-border);background:#ffffff05;flex-shrink:0;align-items:center;display:flex}.terminal-input__prompt{margin-right:var(--space-sm);flex-shrink:0;align-items:center;font-size:.85rem;display:flex}.terminal-input__field{color:var(--text);font-family:var(--font-mono);caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1;font-size:.85rem}.terminal-input__field::placeholder{color:var(--muted);opacity:.5}
