:root{--bg:#f5f7fb;--bg-elevated:#fff;--bg-card:#fff;--text:#4b5563;--text-bright:#111827;--text-heading:#0f172a;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-muted:#2563eb1f;--secondary:#0891b2;--border:#d1d5db;--success:#16a34a;--font-sans:"Plus Jakarta Sans", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--radius:8px;--radius-lg:12px;--shadow:0 10px 30px #0f172a14;--transition:.2s ease}*{box-sizing:border-box}html{scroll-padding-top:3.5rem}@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}.skip-link{z-index:200;color:var(--bg);background:var(--accent);border-radius:0 0 var(--radius) 0;padding:.75rem 1.25rem;font-size:.9375rem;font-weight:600;text-decoration:none;transition:transform .2s;position:absolute;top:0;left:0;transform:translateY(-100%)}.skip-link:focus{outline:2px solid var(--text-heading);outline-offset:2px;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.skip-link{transition:none}}body{font:16px/1.6 var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;background-image:radial-gradient(80% 50% at 50% -20%,#2563eb26,#0000),radial-gradient(60% 40% at 100% 0,#0891b20d,#0000);margin:0}#root{min-height:100vh}.navbar{z-index:100;-webkit-backdrop-filter:blur(8px);background:linear-gradient(#fff 0%,#f9fafbf2 100%);border-bottom:1px solid #d1d5dbcc;padding:.625rem 1.5rem .75rem;position:sticky;top:0;box-shadow:0 8px 20px #0f172a0f}.navbar-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.25rem;max-width:820px;margin:0 auto;display:flex}.navbar-brand{box-sizing:border-box;min-height:44px;color:var(--text-heading);letter-spacing:-.02em;white-space:nowrap;opacity:.95;transition:color var(--transition), opacity var(--transition);align-items:center;padding:.5rem .25rem;font-size:.9375rem;font-weight:600;text-decoration:none;display:inline-flex}.navbar-brand:hover{color:var(--accent);opacity:1}.navbar-brand:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.navbar-nav{flex-wrap:wrap;align-items:center;gap:.125rem;display:flex}.navbar-menu-button{min-width:44px;min-height:44px;color:var(--text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.85rem;font-weight:500;display:none}.navbar-menu-icon{font-size:1.1rem;line-height:1}.navbar-menu-label{font-size:.8rem}.navbar-menu-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (width<=640px){.navbar-inner{gap:.5rem}.navbar-menu-button{display:inline-flex}.navbar-nav{flex-direction:column;align-items:stretch;width:100%;margin-top:.25rem;display:none}.navbar-nav-open{display:flex}.navbar-link{justify-content:flex-start;padding:.55rem .75rem}}.navbar-link{box-sizing:border-box;min-width:44px;min-height:44px;color:var(--text);border-radius:var(--radius);transition:color var(--transition), background var(--transition);justify-content:center;align-items:center;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;text-decoration:none;display:inline-flex}.navbar-link:hover{color:var(--text-bright);background:#ffffff0a}.navbar-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.navbar-link-primary{color:var(--accent);background:var(--accent-muted)}.navbar-link-primary:hover{color:var(--bg);background:var(--accent)}.portfolio{max-width:820px;margin:0 auto;padding:0 1.5rem 4rem}.hero{text-align:center;flex-direction:column;justify-content:center;min-height:0;padding:2rem 1.5rem 2.5rem;display:flex;position:relative}.hero-skill-bg{z-index:1;pointer-events:none;position:absolute;inset:0;overflow:hidden}.hero-skill-bg-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));align-content:start;justify-items:center;gap:1.25rem;width:100%;height:100%;padding:2rem;display:grid}.hero-skill-bg-item{opacity:.2;width:56px;height:56px;color:var(--skill-color,var(--text));transition:opacity .2s}.hero-skill-bg-item svg{width:100%;height:100%;display:block}.hero-bg{z-index:2;pointer-events:none;background:radial-gradient(80% 70% at 50% 45%,#f8fafcf5 0%,#0000 55%),linear-gradient(#fffffffa 0%,#f9fafbf5 40%,#f1f5f9fa 100%);position:absolute;inset:0}.hero-avatar{object-fit:cover;border:2px solid var(--border);width:120px;height:120px;box-shadow:var(--shadow);border-radius:50%;margin-bottom:.75rem;margin-left:auto;margin-right:auto;display:block}.hero-content{z-index:3;position:relative}.hero-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-muted);border-radius:999px;margin-bottom:.5rem;padding:.3rem .85rem;font-size:.75rem;font-weight:600;display:inline-block}.hero h1{color:var(--text-heading);letter-spacing:-.03em;margin:0 0 .35rem;font-size:clamp(1.85rem,4.5vw,2.75rem);font-weight:700}.hero-location{color:var(--text);margin-bottom:.5rem;font-size:.9rem}.hero-summary{color:var(--text-bright);max-width:32rem;margin:0 auto .85rem;font-size:.95rem;line-height:1.55}.hero-nav{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.hero-btn{border-radius:var(--radius);min-width:44px;min-height:44px;transition:background var(--transition), border-color var(--transition), color var(--transition), transform .2s ease;justify-content:center;align-items:center;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.hero-btn-primary{color:var(--bg);background:var(--accent)}.hero-btn-primary:hover{background:var(--accent-hover)}@media (prefers-reduced-motion:no-preference){.hero-btn-primary:hover{transform:translateY(-1px)}}.hero-btn-outline{color:var(--text-bright);border:1px solid var(--border)}.hero-btn-outline:hover{border-color:var(--accent);color:var(--accent)}.hero-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.section{border-bottom:1px solid var(--border);padding:2.75rem 0}.section:last-of-type{border-bottom:none}.section-title{letter-spacing:-.02em;color:var(--text-heading);border-left:3px solid var(--accent);margin:0 0 1.5rem;padding-left:1rem;font-size:1.5rem;font-weight:600;line-height:1.3}.summary-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:65ch;color:var(--text);margin:0;padding:1.5rem 1.75rem;font-size:1rem;line-height:1.65}.summary-block p{margin:0}.job-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);margin-bottom:1rem;padding:1.5rem}@media (prefers-reduced-motion:reduce){.job-card{transition:none}}.job-card:hover{border-color:#2563eb66;box-shadow:0 4px 20px #00000040}.job-header{margin-bottom:1rem}.job-role{color:var(--text-heading);margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.job-company{color:var(--accent);margin:0 0 .2rem;font-size:.9rem}.job-meta{color:var(--text);margin:0;font-size:.85rem}.job-list{margin:0;padding-left:1.25rem}.job-list li{margin:.35rem 0;line-height:1.55}.contrib-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);transition:border-color var(--transition);margin-bottom:.85rem;padding:1.35rem 1.5rem}.contrib-card:hover{border-left-color:var(--accent-hover)}.contrib-card strong{color:var(--text-heading);margin-bottom:.35rem;font-size:1rem;display:block}.skills-grid{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.skill-group{border-bottom:1px solid var(--border);margin-bottom:1.75rem;padding-bottom:1.5rem}.skill-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.skill-group-label{color:var(--text-heading);letter-spacing:.01em;margin-bottom:.6rem;font-size:.9rem;font-weight:600}.skill-badge{font-size:.8rem;font-family:var(--font-mono);color:var(--text);background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;padding:.3rem .65rem;display:inline-block}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);margin-bottom:1rem;padding:1.35rem}@media (prefers-reduced-motion:reduce){.project-card{transition:none}}.project-card:hover{border-color:#2563eb66;box-shadow:0 4px 20px #00000040}.project-title a{color:var(--secondary);font-size:1.05rem;font-weight:600;text-decoration:none}.project-title a:hover{color:var(--accent)}.project-title a:focus-visible,.more-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.project-desc{color:var(--text);margin:.5rem 0 .75rem;font-size:.95rem;line-height:1.5}.project-tech{flex-wrap:wrap;gap:.4rem;display:flex}.project-tag{font-size:.75rem;font-family:var(--font-mono);color:var(--text);background:#edf2ff;border-radius:4px;padding:.2rem .5rem}.more-link{min-height:44px;color:var(--accent);align-items:center;margin-top:.75rem;padding:.25rem 0;font-weight:500;text-decoration:none;display:inline-flex}.more-link:hover{text-decoration:underline}.edu-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);margin-bottom:1rem;padding:1.25rem}.edu-card:hover{border-color:#2563eb59}.edu-card h3{color:var(--text-heading);margin:0 0 .35rem;font-size:1rem;font-weight:600}.edu-dates{color:var(--accent);margin-bottom:.5rem;font-size:.9rem}.courses-list{margin:0;padding:0;list-style:none}.courses-list li{border-bottom:1px solid var(--border);padding:.65rem 0;font-size:.95rem}.courses-list li:last-child{border-bottom:none}.courses-list a{color:var(--secondary);text-underline-offset:2px;text-decoration:underline}.courses-list a:hover{color:var(--accent)}.courses-list a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.lang-grid{flex-wrap:wrap;gap:.75rem;display:flex}.lang-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem 1rem;font-size:.95rem}.lang-item strong{color:var(--text-heading)}.info-list{margin:0;padding:0;list-style:none}.info-list li{border-bottom:1px solid var(--border);padding:.6rem 0;font-size:.95rem}.info-list li:last-child{border-bottom:none}.info-list strong{color:var(--text-bright)}.case-grid{flex-direction:column;gap:1rem;display:flex}.case-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);padding:1.5rem 1.75rem}.case-card:hover{border-color:#2563eb66;box-shadow:0 4px 20px #00000040}.case-card-header{margin-bottom:.5rem}.case-card-title{color:var(--text-heading);margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.case-card-meta{color:var(--text);flex-wrap:wrap;gap:.35rem;margin:0;font-size:.85rem;display:flex}.case-card-problem{margin:.75rem 0;font-size:.95rem}.case-card-section{margin-top:.75rem}.case-card-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-heading);margin:0 0 .35rem;font-size:.85rem;font-weight:600}.case-card-section ul{margin:0;padding-left:1.25rem;font-size:.95rem}.case-card-section li{margin:.25rem 0;line-height:1.55}.blog-topic-summary{color:var(--text);margin:0 0 .5rem;font-size:.9rem;line-height:1.45}.blog-disclaimer{color:var(--text-muted,#6b7280);max-width:56ch;margin:0 0 1.25rem;font-size:.8rem;line-height:1.5}.blog-categories{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.blog-category-btn{color:var(--text);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.35rem .75rem;font-size:.85rem;font-weight:500}.blog-category-btn:hover{background:var(--bg);border-color:var(--accent)}.blog-category-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.blog-category-btn-active{color:var(--accent);border-color:var(--accent);background:var(--bg)}.blog-card-category{text-transform:uppercase;letter-spacing:.04em;color:var(--accent);margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:inline-block}.blog-list{flex-direction:column;gap:1rem;display:flex}.blog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);padding:1.35rem 1.5rem}.blog-card:hover{border-color:#2563eb66;box-shadow:0 4px 20px #00000040}.blog-card-header{margin-bottom:.75rem}.blog-card-meta{color:var(--text);flex-wrap:wrap;gap:.35rem;margin:0 0 .35rem;font-size:.8rem;display:flex}.blog-card-title{color:var(--text-heading);margin:0 0 .4rem;font-size:1.1rem;font-weight:600}.blog-card-excerpt{color:var(--text);margin:0;font-size:.95rem}.blog-card-tags{flex-wrap:wrap;gap:.35rem;display:flex}.blog-tag{font-size:.75rem;font-family:var(--font-mono);color:var(--text);background:#edf2ff;border:1px solid #e5e7eb;border-radius:999px;padding:.2rem .5rem}.blog-read-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;transition:background var(--transition), border-color var(--transition), color var(--transition), transform .15s ease;background:#f9fafb;border-radius:999px;margin-top:.75rem;padding:.4rem .9rem;font-size:.8rem;font-weight:600}.blog-read-btn:hover{border-color:var(--accent);color:var(--accent)}.blog-read-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.blog-article{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);margin-top:2rem;padding:1.75rem 1.9rem}.blog-article-header{margin-bottom:1rem}.blog-article-title{color:var(--text-heading);margin:.15rem 0 0;font-size:1.35rem;font-weight:600}.blog-article-body{color:var(--text);font-size:.95rem}.blog-article-section+.blog-article-section{margin-top:1rem}.blog-article-heading{color:var(--text-heading);margin:0 0 .35rem;font-size:1rem;font-weight:600}.blog-article-section p{margin:.25rem 0;line-height:1.6}.contact{text-align:center;border:1px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(#0000 0%,#1d4ed80f 100%);margin-top:.5rem;padding:3.5rem 2rem}.contact-title{color:var(--text-heading);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.contact-text{color:var(--text);max-width:36ch;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;font-size:.95rem}.contact-nav{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.contact-btn{border-radius:var(--radius);min-width:44px;min-height:44px;transition:background var(--transition), border-color var(--transition), color var(--transition), transform .2s ease;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-weight:600;text-decoration:none;display:inline-flex}.contact-btn-primary{color:var(--bg);background:var(--accent)}.contact-btn-primary:hover{background:var(--accent-hover)}@media (prefers-reduced-motion:no-preference){.contact-btn-primary:hover{transform:translateY(-1px)}}.contact-btn-outline{color:var(--text-bright);border:1px solid var(--border)}.contact-btn-outline:hover{border-color:var(--accent);color:var(--accent)}.contact-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.contact-disclaimer{color:#6b7280;max-width:46ch;margin-top:1.75rem;margin-left:auto;margin-right:auto;font-size:.8rem;line-height:1.5}@media (width<=640px){.portfolio{padding:0 1rem 3rem}.hero{padding:1.5rem 1rem 2rem}.section{padding:1.75rem 0}}
