:root{--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:#dbeafe;--bg:#fff;--bg-alt:#f8fafc;--surface:#f1f5f9;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--text-on-accent:#fff;--radius:.5rem;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--max-w:860px;--section-gap:4rem;--bg-glass:#ffffffe0}[data-theme=dark]{--bg:#0f172a;--bg-alt:#1e293b;--surface:#334155;--border:#475569;--text:#f1f5f9;--text-muted:#94a3b8;--accent:#3b82f6;--accent-hover:#60a5fa;--accent-light:#1e3a5f;--bg-glass:#0f172ae0}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes hero-gradient{0%,to{background-position:0%}50%{background-position:100%}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.7;transition:background .2s,color .2s}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}img{max-width:100%;display:block}h1,h2,h3,h4{color:var(--text);font-weight:700;line-height:1.25}h1{font-size:clamp(2rem,5vw,3rem)}h2{font-size:clamp(1.4rem,3vw,1.75rem)}h3{font-size:1.125rem}p{margin-bottom:.75rem}p:last-child{margin-bottom:0}.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:1.25rem}.skip-link{background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius);z-index:9999;padding:.5rem 1rem;font-weight:600;transition:top .15s;position:absolute;top:-100%;left:1rem}.skip-link:focus{top:1rem}.topbar{z-index:100;background:var(--bg);border-bottom:1px solid var(--border);padding:.6rem 0;transition:background .3s,box-shadow .3s,border-color .3s;position:sticky;top:0}.topbar.scrolled{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border-bottom-color:#0000;box-shadow:0 2px 20px #00000014}.topbar .container{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.topbar-left{color:var(--text-muted);letter-spacing:.01em;font-size:.95rem;font-weight:700}.fw-switcher{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.fw-switcher a,.fw-switcher span{border-radius:var(--radius);border:1px solid var(--border);white-space:nowrap;padding:.25rem .65rem;font-size:.8rem;font-weight:500;transition:background .15s,color .15s,transform .15s,box-shadow .15s}.fw-switcher a{color:var(--text-muted);background:0 0}.fw-switcher a:hover{background:var(--surface);color:var(--text);text-decoration:none;transform:translateY(-1px);box-shadow:0 3px 10px #2563eb26}.fw-switcher [aria-current=page]{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent);pointer-events:none}.theme-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;padding:.3rem .6rem;font-size:1rem;line-height:1;transition:background .15s,transform .35s cubic-bezier(.34,1.56,.64,1)}.theme-toggle:hover{background:var(--border);transform:rotate(18deg)}.theme-toggle:active{transform:rotate(35deg)scale(.88)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{background:linear-gradient(-45deg, var(--bg-alt), var(--bg), var(--accent-light), var(--bg-alt));border-bottom:1px solid var(--border);background-size:400% 400%;padding:4rem 0 3rem;animation:18s infinite hero-gradient}.hero .container{align-items:center;gap:2rem;display:flex}.hero-body{flex:1;min-width:0}.hero-photo{object-fit:cover;object-position:center top;border:3px solid var(--border);width:140px;height:140px;box-shadow:var(--shadow-md);border-radius:50%;flex-shrink:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .3s,border-color .3s;animation:.65s cubic-bezier(.16,1,.3,1) .1s both fade-up}.hero-photo:hover{border-color:var(--accent);box-shadow:0 0 0 5px var(--accent-light), 0 8px 28px #2563eb33;transform:scale(1.06)}.hero-name{background:linear-gradient(120deg, var(--text) 35%, var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;animation:.55s cubic-bezier(.16,1,.3,1) both fade-up}.hero-title{color:var(--accent);margin-bottom:.5rem;font-size:1.25rem;font-weight:600;animation:.55s cubic-bezier(.16,1,.3,1) 90ms both fade-up}.hero-tagline{color:var(--text-muted);margin-bottom:.25rem;font-size:1rem;animation:.55s cubic-bezier(.16,1,.3,1) .17s both fade-up}.hero-location{color:var(--text-muted);margin-bottom:1.25rem;font-size:.9rem;animation:.55s cubic-bezier(.16,1,.3,1) .23s both fade-up}.hero-links{flex-wrap:wrap;gap:1rem;animation:.55s cubic-bezier(.16,1,.3,1) .31s both fade-up;display:flex}.hero-links a{align-items:center;gap:.35rem;font-size:.9rem;font-weight:500;transition:color .15s,transform .2s;display:inline-flex;position:relative}.hero-links a:after{content:"";transform-origin:100%;background:currentColor;width:100%;height:1.5px;transition:transform .25s;position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.hero-links a:hover{text-decoration:none;transform:translateY(-1px)}.hero-links a:hover:after{transform-origin:0;transform:scaleX(1)}.section{padding:var(--section-gap) 0;border-bottom:1px solid var(--border)}.section:last-of-type{border-bottom:none}.section-heading{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;padding-bottom:.5rem;font-size:.75rem;font-weight:700;position:relative}.section-heading:after{content:"";background:var(--accent);transform-origin:0;border-radius:1px;width:2.5rem;height:2px;transition:transform .45s cubic-bezier(.16,1,.3,1) .2s;position:absolute;bottom:0;left:0;transform:scaleX(0)}.section-heading.is-visible:after{transform:scaleX(1)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;display:grid}.skill-category{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,border-color .2s}.skill-category:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 24px #2563eb1a}.skill-category-name{text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:.6rem;font-size:.8rem;font-weight:700}.skill-tags{flex-wrap:wrap;gap:.35rem;display:flex}.skill-tag{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:default;border-radius:999px;padding:.2rem .6rem;font-size:.78rem;transition:background .15s,color .15s,border-color .15s,transform .15s}.skill-tag:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent);transform:translateY(-1px)}.experience-company{margin-bottom:2rem}.experience-company+.experience-company{margin-top:2.5rem}.company-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;gap:.25rem;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.company-name{color:var(--text);font-size:1.1rem;font-weight:700}.company-location{color:var(--text-muted);font-size:.875rem}.role{border-left:3px solid var(--accent-light);margin-bottom:1.25rem;padding-left:1rem;transition:border-left-color .2s,transform .2s cubic-bezier(.16,1,.3,1)}.role:hover{border-left-color:var(--accent);transform:translate(3px)}.role-header{flex-wrap:wrap;justify-content:space-between;gap:.2rem;margin-bottom:.5rem;display:flex}.role-title{color:var(--text);font-size:.975rem;font-weight:600}.role-dates{color:var(--text-muted);white-space:nowrap;font-size:.825rem}.role-bullets{margin:0;padding-left:1.1rem}.role-bullets li{color:var(--text);margin-bottom:.35rem;font-size:.9rem;line-height:1.6}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.project-card{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:1.25rem;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,border-color .2s;display:flex}.project-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 32px #2563eb1f}.project-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.project-name{color:var(--text);font-size:1rem;font-weight:700}.project-date{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.project-link{font-size:.8rem;font-weight:500}.project-bullets{margin:0;padding-left:1.1rem}.project-bullets li{color:var(--text-muted);margin-bottom:.3rem;font-size:.875rem;line-height:1.55}.education-list{flex-direction:column;gap:1rem;display:flex}.education-item{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;gap:.25rem;padding:1rem 1.25rem;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,border-color .2s;display:flex}.education-item:hover{box-shadow:var(--shadow-md);border-color:var(--accent);transform:translateY(-2px)}.education-institution{font-size:1rem;font-weight:700}.education-credential{color:var(--text-muted);margin-top:.15rem;font-size:.875rem}.education-dates{color:var(--text-muted);white-space:nowrap;font-size:.825rem}.about-site{background:var(--bg-alt)}.about-site-intro{color:var(--text-muted);max-width:640px;margin-bottom:2rem;font-size:.95rem}.build-pillars{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-bottom:2.5rem;display:grid}.pillar-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:1.25rem;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,border-color .2s;display:flex}.pillar-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 32px #2563eb1f}.pillar-icon{font-size:1.4rem;line-height:1}.pillar-title{color:var(--text);font-size:.95rem;font-weight:700}.pillar-desc{color:var(--text-muted);flex:1;margin:0;font-size:.875rem;line-height:1.6}.pillar-tags{flex-wrap:wrap;gap:.35rem;margin-top:.25rem;display:flex}.pillar-tag{background:var(--accent-light);color:var(--accent);letter-spacing:.02em;border-radius:999px;padding:.15rem .55rem;font-size:.72rem;font-weight:600}.fw-switcher-large{flex-wrap:wrap;gap:.5rem;display:flex}.fw-switcher-large a,.fw-switcher-large span{border-radius:var(--radius);border:2px solid var(--border);white-space:nowrap;padding:.5rem 1.1rem;font-size:.9rem;font-weight:600;transition:background .2s,color .2s,border-color .2s,transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s}.fw-switcher-large a{color:var(--text);background:var(--surface)}.fw-switcher-large a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none;transform:translateY(-2px);box-shadow:0 6px 18px #2563eb2e}.fw-switcher-large [aria-current=page]{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent);pointer-events:none}footer{background:var(--bg-alt);border-top:1px solid var(--border);padding:2rem 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.footer-copy{color:var(--text-muted);font-size:.825rem}.footer-links{gap:1rem;display:flex}.footer-links a{font-size:.85rem;font-weight:500}.reveal{opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);transform:translateY(18px)}.reveal.is-visible{opacity:1;transform:none}.reveal--stagger{transition-delay:calc(var(--reveal-i,0) * 70ms)}@media (width<=640px){.hero .container{flex-direction:column;align-items:flex-start}.hero-photo{width:96px;height:96px}.skills-grid,.projects-grid,.build-pillars{grid-template-columns:1fr}.company-header,.role-header{flex-direction:column}.footer-inner{flex-direction:column;align-items:flex-start}.fw-switcher-large{flex-direction:column}.hero-stats{gap:1.25rem}.back-to-top{bottom:1.25rem;right:1.25rem}}@keyframes pulse-dot{0%{box-shadow:0 0 #16a34a80}70%{box-shadow:0 0 0 7px #16a34a00}to{box-shadow:0 0 #16a34a00}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.available-badge{color:#16a34a;letter-spacing:.02em;text-transform:uppercase;align-items:center;gap:.45rem;margin-bottom:.6rem;font-size:.78rem;font-weight:700;display:inline-flex}.available-badge:before{content:"";background:#16a34a;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2.2s ease-out infinite pulse-dot}[data-theme=dark] .available-badge{color:#4ade80}[data-theme=dark] .available-badge:before{background:#4ade80;animation:none;box-shadow:0 0 6px #4ade80b3}.hero-resume-btn{background:var(--accent);border-radius:var(--radius);border:1.5px solid var(--accent);align-items:center;gap:.35rem;padding:.3rem .9rem;font-size:.85rem;font-weight:700;transition:background .15s,border-color .15s,transform .2s,box-shadow .2s;display:inline-flex;color:var(--text-on-accent)!important;text-decoration:none!important}.hero-resume-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-2px);box-shadow:0 5px 14px #2563eb59;text-decoration:none!important}.hero-stats{flex-wrap:wrap;gap:2rem;margin-top:1.5rem;display:flex}.stat{flex-direction:column;gap:.1rem;display:flex}.stat-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:1.6rem;font-weight:800;line-height:1.1}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.7rem;font-weight:700}.hero-tagline.typewriter-active:after{content:"|";color:var(--accent);margin-left:1px;font-weight:300;animation:1.1s step-end infinite blink;display:inline-block}.topbar-progress{background:var(--accent);pointer-events:none;border-radius:0 1px 1px 0;width:0%;height:2px;transition:width 80ms linear;position:absolute;bottom:0;left:0}.back-to-top{z-index:200;background:var(--accent);width:44px;height:44px;color:var(--text-on-accent);cursor:pointer;opacity:0;pointer-events:none;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;line-height:1;transition:opacity .25s,transform .25s,background .15s;display:flex;position:fixed;bottom:2rem;right:2rem;transform:translateY(10px);box-shadow:0 4px 16px #2563eb59}.back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:hover{background:var(--accent-hover);transform:translateY(-3px)}.available-badge{animation:.55s cubic-bezier(.16,1,.3,1) both fade-up}.hero-name{animation:.55s cubic-bezier(.16,1,.3,1) 90ms both fade-up}.hero-title{animation:.55s cubic-bezier(.16,1,.3,1) .18s both fade-up}.hero-tagline{animation:.55s cubic-bezier(.16,1,.3,1) .26s both fade-up}.hero-location{animation:.55s cubic-bezier(.16,1,.3,1) .32s both fade-up}.hero-links{animation:.55s cubic-bezier(.16,1,.3,1) .4s both fade-up}.hero-stats{animation:.55s cubic-bezier(.16,1,.3,1) .47s both fade-up}
