*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;font-family:Inter,system-ui,-apple-system,sans-serif}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{line-height:1.2}a{color:inherit;text-decoration:none}:root{--color-primary:#2563eb;--color-primary-light:#dbeafe;--color-primary-dark:#1d4ed8;--color-accent:#0ea5e9;--color-bg:#fff;--color-bg-alt:#1e293b;--color-surface:#fff;--color-surface-alt:#f1f5f9;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-border:#8999ad;--hero-bg:#ecf7ff;--hero-dot-color:#0000004d;--color-glass-border:#0003;--color-glass-bg:#0000000d;--shadow-sm:0 1px 2px #0000000a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--section-padding:clamp(3rem, 8vw, 6rem);--content-width:1200px;--content-padding:clamp(1rem, 4vw, 2rem)}:root[data-theme=dark]{--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-alt:#334155;--color-text:#f1f5f9;--color-text-secondary:#cbd5e1;--color-text-muted:#90a0b6;--color-border:#4d73a8;--color-primary-light:#2563eb40;--color-primary-dark:#93c5fd;--hero-bg:#0f172a;--hero-dot-color:#fff3;--color-glass-border:#ffffff2e;--color-glass-bg:#ffffff0f;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #00000080, 0 8px 10px -6px #0000004d}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(7px)}}[data-reveal]{opacity:0;transition:opacity var(--transition-slow), transform var(--transition-slow);transition-delay:calc(min(var(--stagger,0), 7) * 60ms);transform:translateY(18px)}[data-reveal].revealed{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transition:none;transform:none}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.content{max-width:var(--content-width);padding:0 var(--content-padding);margin:0 auto}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{letter-spacing:-.02em;color:var(--color-text);margin:0;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800}.section-header h2:after{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-full);width:2.5rem;height:3px;margin:.75rem auto 0;display:block}.icon-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.icon-btn:hover{background:var(--color-surface-alt);box-shadow:var(--shadow-md)}.icon-btn:focus-visible{outline-offset:3px;outline:2px solid #fff9}.theme-toggle{z-index:2;width:40px;height:40px;font-size:16px;position:absolute;top:1.25rem;right:1.25rem}.hero{background-color:var(--hero-bg);padding:var(--section-padding) var(--content-padding);padding-bottom:calc(var(--section-padding) + 5rem);text-align:center;min-height:88vh;color:var(--color-text);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:0 0;position:absolute;inset:0}:root[data-theme=dark] .hero:before{background:radial-gradient(100% 150% at 50% 10%,#25a0eb59 0%,#0000 65%)}.hero:after{content:"";background-image:radial-gradient(var(--hero-dot-color) 1px, transparent 1px);pointer-events:none;background-size:28px 28px;position:absolute;inset:0}.hero-content{z-index:1;flex-direction:column;align-items:center;gap:1.5rem;max-width:640px;display:flex;position:relative}.profile-image-ring{background:linear-gradient(135deg,#2563eb,#38bdf8,#818cf8);border-radius:50%;padding:3px;animation:.6s cubic-bezier(.34,1.56,.64,1) both scaleIn;display:inline-block}.profile-image{object-fit:cover;background:var(--hero-bg);border-radius:50%;width:400px;height:400px;display:block}.hero h1{letter-spacing:-.03em;margin:0;font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1;animation:.55s cubic-bezier(.4,0,.2,1) .12s both fadeUp}.tagline{opacity:.72;max-width:460px;margin:0;font-size:clamp(1rem,2.5vw,1.2rem);line-height:1.65;animation:.55s cubic-bezier(.4,0,.2,1) .22s both fadeUp}.resume-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.95rem;font-weight:500;text-decoration:none;animation:.55s cubic-bezier(.4,0,.2,1) .27s both fadeUp;display:inline-flex}.resume-btn:hover{background:var(--color-surface-alt);box-shadow:var(--shadow-md)}.social-links{justify-content:center;gap:.625rem;animation:.55s cubic-bezier(.4,0,.2,1) .32s both fadeUp;display:flex}.social-link{width:46px;height:46px;font-size:19px;text-decoration:none}.hero-scroll-hint{color:var(--color-text);z-index:1;width:26px;height:26px;animation:.55s cubic-bezier(.4,0,.2,1) .5s both fadeUp,2.4s ease-in-out 1.2s infinite bounce;position:absolute;bottom:3rem;left:50%;transform:translate(-50%)}.hero-scroll-hint svg{width:100%;height:100%}@media (width<=768px){.hero{min-height:70vh}.profile-image{width:320px;height:320px}}@media (width<=480px){.profile-image{width:240px;height:240px}}.technologies{padding:var(--section-padding) 0;background:var(--color-bg)}.tech-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.125rem;display:grid}@media (width<=768px){.tech-grid{grid-template-columns:1fr}}.tech-card{--tech-color-text:color-mix(in srgb, var(--tech-color) 60%, #000);background:color-mix(in srgb, var(--tech-color) 15%, transparent);border-left:3px solid var(--tech-color);padding:1.375rem 1.5rem}:root[data-theme=dark] .tech-card{--tech-color-text:var(--tech-color)}.tech-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.875rem;display:flex}.tech-title{color:var(--tech-color-text);align-items:center;gap:.5rem;font-size:1.125rem;display:flex}.tech-header h3{margin:0;font-size:.9375rem;font-weight:600}.experience-years{color:var(--color-text-muted);white-space:nowrap;font-size:.8rem;font-weight:500}.tech-areas{flex-wrap:wrap;gap:.35rem;display:flex}.tech-tag{background:color-mix(in srgb, var(--tech-color) 12%, transparent);color:var(--tech-color-text);border-radius:var(--radius-full);padding:.2rem .625rem;font-size:.8rem;font-weight:500}.employers{padding:var(--section-padding) 0;background:var(--color-surface-alt)}.timeline{flex-direction:column;gap:36px;display:flex;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--color-primary), var(--color-accent) 90%, transparent);border-radius:var(--radius-full);opacity:.35;width:2px;position:absolute;top:24px;bottom:0;left:127px}.timeline-item{grid-template-columns:96px 16px 1fr;align-items:start;column-gap:24px;display:grid}.years-text{color:var(--color-text);justify-self:end;margin-top:24px;font-size:14px;font-weight:700}.timeline-dot{background:var(--color-text);border:2px solid var(--color-surface-alt);width:16px;height:16px;box-shadow:0 0 0 2px var(--color-text);border-radius:50%;flex-shrink:0;justify-self:center;margin-top:24px}.card-years-mobile{display:none}.timeline-card{background:var(--color-surface);border:1px solid var(--color-glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;gap:.875rem;padding:1.25rem 1.5rem;display:flex;position:relative}.timeline-card-header{flex-direction:column;gap:.2rem;display:flex}.timeline-card-header h3{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:700}.employer-position{color:var(--color-accent);font-size:.875rem;font-weight:600}.employer-location{color:var(--color-text-muted);font-size:.8rem}.employer-duties{flex-direction:column;gap:.3rem;margin:0;padding-left:1.1rem;display:flex}.employer-duties li{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.employer-technologies{flex-wrap:wrap;gap:.4rem;display:flex}.employer-tech-tag{color:var(--color-accent);background:var(--color-primary-light);border-radius:var(--radius-full);white-space:nowrap;padding:.2rem .65rem;font-size:.72rem;font-weight:600}:root:not([data-theme=dark]) .employer-position,:root:not([data-theme=dark]) .employer-tech-tag{color:var(--color-primary)}@media (width<=600px){.timeline:before{left:7px}.timeline-item{grid-template-columns:16px 1fr}.years-text{display:none}.card-years-mobile{color:var(--color-text-muted);font-size:.78rem;font-weight:600;display:block;position:absolute;top:1.25rem;right:1.5rem}}.projects{padding:var(--section-padding) 0;background:var(--color-bg)}.projects-grid{flex-wrap:wrap;justify-content:center;gap:1.375rem;display:flex}.projects-grid>*{flex:0 340px;max-width:100%}@media (width<=768px){.projects-grid>*{flex-basis:100%}}.project-card{background:var(--color-surface);border-radius:var(--radius-lg);color:inherit;transition:box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base);border:1px solid #64788c4d;flex-direction:column;padding:1.75rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-accent));transform-origin:0;height:3px;transition:transform var(--transition-base);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover{box-shadow:var(--shadow-xl);border-color:#0000;transform:translateY(-4px)}.project-card:hover:before{transform:scaleX(1)}.project-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.project-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.625rem;display:flex}.project-title{align-items:center;gap:8px;display:flex}.project-icon{height:32px}.project-header h3{color:var(--color-text);transition:color var(--transition-fast);margin:0;font-size:1.125rem;font-weight:700;line-height:1.35}.project-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.35rem;display:flex}.project-year{color:var(--color-text-muted);padding-top:2px;font-size:.8125rem;font-weight:500}.project-status{background:var(--color-primary-light);color:var(--color-primary-dark);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:3px 8px;font-size:.7rem;font-weight:700;line-height:1.2}.project-description{color:var(--color-text-secondary);margin:0 0 .625rem;font-size:.9375rem;font-weight:500;line-height:1.5}.project-details{color:var(--color-text-muted);flex-grow:1;margin:0 0 1.375rem;font-size:.875rem;line-height:1.65}.project-technologies{flex-wrap:wrap;gap:.35rem;margin-top:auto;display:flex}.project-tech-tag{background:var(--color-surface-alt);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);padding:3px 10px;font-size:.8rem;font-weight:500}.project-card:hover .project-tech-tag{background:var(--color-primary-light);color:var(--color-primary-dark);border-color:#0000}.footer{background:var(--color-bg-alt);color:#fff9;padding:2.25rem var(--content-padding);text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;font-size:.875rem;display:flex}.footer p{margin:0}.footer-button{border-radius:var(--radius-md);transition:all var(--transition-base);color:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0d;border:1.5px solid #ffffff2e;padding:.45rem 1.125rem;font-size:.875rem;font-weight:500;text-decoration:none}.footer-button:hover{color:#fff;background:#ffffff1f;border-color:#ffffff73}
