*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;max-width:100%;overflow-x:clip}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;max-width:100%;font-family:Outfit,system-ui,sans-serif;line-height:1.6;overflow-x:clip}#root{max-width:100%;min-height:100vh;overflow-x:clip}main{max-width:100%;overflow-x:clip}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}ul{list-style:none}img{max-width:100%;display:block}::selection{color:#fff;background:#38bdf859}:root{--bg:#07070d;--bg-alt:#0c0c14;--surface:#ffffff0a;--border:#ffffff14;--text:#e8e8ef;--text-muted:#9494a8;--accent:#38bdf8;--accent-2:#a78bfa;--accent-3:#34d399;--gradient:linear-gradient(135deg, #38bdf8 0%, #a78bfa 50%, #f472b6 100%);--radius:16px;--radius-lg:24px;--container:min(1120px, 92vw);--nav-height:72px}.container{width:var(--container);margin-inline:auto}.section{scroll-margin-top:calc(var(--nav-height) + 12px);padding:100px 0;position:relative}.section-alt{background:linear-gradient(#0000,#0c0c1499 50%,#0000)}.bg-mesh{z-index:-1;background:var(--bg);position:fixed;inset:0;overflow:hidden}.orb{filter:blur(80px);opacity:.45;border-radius:50%;position:absolute}.orb-1{background:#1e3a5f;width:520px;height:520px;top:-120px;right:-80px}.orb-2{background:#4c1d95;width:400px;height:400px;bottom:10%;left:-100px}.orb-3{opacity:.3;background:#0f766e;width:320px;height:320px;top:40%;right:20%}.grid-overlay{background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 20%,#0000 75%);mask-image:radial-gradient(#000 20%,#0000 75%)}.glass{background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius)}.gradient-text{background:var(--gradient);color:#0000;-webkit-background-clip:text;background-clip:text}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#07070dbf;padding:12px 0;position:fixed;top:0;left:0;right:0}.nav-inner{height:var(--nav-height);justify-content:space-between;align-items:center;display:flex}.logo{align-items:center;gap:10px;display:flex}.logo-mark{background:var(--gradient);color:#0a0a0f;border-radius:10px;place-items:center;width:40px;height:40px;font-size:.85rem;font-weight:700;display:grid}.logo-text{font-size:.95rem;font-weight:600}.nav-links{gap:8px;display:flex}.nav-links button{color:var(--text-muted);padding:8px 14px;font-size:.9rem;transition:color .2s;position:relative}.nav-links button:hover,.nav-links button.active{color:var(--text)}.nav-indicator{z-index:-1;background:#38bdf81f;border-radius:8px;position:absolute;inset:0}.nav-toggle{padding:8px;font-size:1.5rem}.mobile-menu{border-top:1px solid var(--border);background:#07070df2;overflow:hidden}.mobile-menu ul{padding:16px 4vw 24px}.mobile-menu button{text-align:left;width:100%;color:var(--text-muted);padding:12px 0;font-size:1rem;display:block}.mobile-only{display:none}.desktop-only{display:flex}.hero{min-height:100vh;padding-top:var(--nav-height);align-items:center;display:flex}.hero-grid{grid-template-columns:1fr 1fr;align-items:center;gap:48px;display:grid}.hero-heading{justify-content:flex-start;align-items:center;gap:12px;margin-bottom:16px;display:flex}.hero-avatar{object-fit:cover;object-position:center top;background:linear-gradient(var(--bg), var(--bg)) padding-box, var(--gradient) border-box;border:3px solid #0000;border-radius:50%;flex-shrink:0;width:120px;height:120px;box-shadow:0 12px 40px #00000059}.hero-visual{position:relative}.code-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:#0c0c14e6;position:relative;overflow:hidden;box-shadow:0 24px 80px #00000080}.code-card-glow{pointer-events:none;background:radial-gradient(circle,#38bdf826,#0000 60%);position:absolute;inset:-50%}.code-header{border-bottom:1px solid var(--border);background:#0000004d;align-items:center;gap:8px;padding:14px 18px;display:flex}.code-header span{background:#ff5f57;border-radius:50%;width:12px;height:12px}.code-header span:nth-child(2){background:#febc2e}.code-header span:nth-child(3){background:#28c840}.code-header p{color:var(--text-muted);margin-left:auto;font-family:JetBrains Mono,monospace;font-size:.75rem}.code-card pre{margin:0;padding:24px;overflow-x:hidden}.code-card code{color:#c4b5fd;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;font-family:JetBrains Mono,monospace;font-size:.8rem;line-height:1.7;display:block}.badge-anchor{z-index:2;position:absolute}.badge-center{top:-16px;left:50%;transform:translate(-50%)}.badge-right{top:auto;bottom:-16px;right:-20px;transform:none}.floating-badge{background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:nowrap;border-radius:12px;align-items:center;gap:8px;padding:10px 16px;font-size:.85rem;font-weight:600;display:flex;box-shadow:0 8px 24px #0000004d}.badge-years{color:var(--accent)}.eyebrow{color:var(--accent-3);background:#34d39914;border:1px solid #34d39940;border-radius:999px;align-items:center;gap:8px;margin-bottom:20px;padding:6px 14px;font-size:.85rem;display:inline-flex}.pulse-dot{background:var(--accent-3);width:8px;height:8px;box-shadow:0 0 12px var(--accent-3);border-radius:50%;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.hero-title{letter-spacing:-.03em;margin-bottom:0;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1}.hero-role{color:var(--text-muted);margin-bottom:20px;font-size:1.15rem}.role-divider{color:var(--border);margin:0 10px}.hero-tagline{color:var(--text-muted);max-width:560px;margin-bottom:32px;font-size:1.05rem;line-height:1.75}.hero-tagline strong{color:var(--accent);font-weight:500}.hero-cta{flex-wrap:wrap;gap:14px;margin-bottom:36px;display:flex}.btn{border-radius:12px;justify-content:center;align-items:center;padding:14px 28px;font-size:.95rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.btn-primary{background:var(--gradient);color:#0a0a0f;box-shadow:0 8px 32px #38bdf840}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px #38bdf859}.btn-ghost{border:1px solid var(--border);color:var(--text)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-large{margin-top:40px;padding:16px 36px;font-size:1rem}.hero-social{gap:12px;display:flex}.hero-social a{border:1px solid var(--border);width:44px;height:44px;color:var(--text-muted);border-radius:12px;place-items:center;font-size:1.1rem;transition:all .2s;display:grid}.hero-social a:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-3px)}.scroll-hint{border:2px solid var(--border);border-radius:12px;justify-content:center;width:24px;height:40px;padding-top:8px;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.scroll-hint span{background:var(--accent);border-radius:2px;width:4px;height:8px}.section-heading{text-align:center;max-width:640px;margin:0 auto 56px}.section-label{text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:12px;font-size:.8rem;font-weight:600;display:inline-block}.section-heading h2{letter-spacing:-.02em;margin-bottom:12px;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700}.section-heading p{color:var(--text-muted);font-size:1.05rem}.about-summary{text-align:center;max-width:780px;color:var(--text-muted);margin:0 auto 48px;font-size:1.1rem;line-height:1.8}.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;display:grid}.stat-card{text-align:center;padding:28px 20px}.stat-value{background:var(--gradient);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:800;line-height:1.2;display:block}.stat-label{color:var(--text-muted);margin-top:6px;font-size:.85rem}.education-card{max-width:720px;margin:0 auto;padding:32px 36px}.edu-badge{text-transform:uppercase;letter-spacing:.1em;color:var(--accent-2);margin-bottom:12px;font-size:.75rem;font-weight:600;display:inline-block}.education-card h3{margin-bottom:6px;font-size:1.25rem}.education-card>p{color:var(--text-muted);margin-bottom:16px}.edu-meta{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.edu-highlight{color:var(--accent-3);background:#34d3991f;border-radius:8px;padding:4px 12px;font-size:.9rem;font-weight:500}.skills-section{overflow:visible}.skills-scroll-track{padding-top:24px;position:relative}.skills-section-sticky{top:calc(var(--nav-height) + 16px);z-index:2;padding-top:24px;padding-bottom:48px;position:sticky}.skills-section-sticky .section-heading{margin-bottom:56px}.skills-section-sticky .section-label{z-index:1;margin-bottom:16px;display:inline-block;position:relative}.skills-section-sticky .section-heading h2{margin-bottom:16px}.skills-section-sticky .section-heading p{margin-bottom:0;line-height:1.6}.skills-pizza-hint{text-align:center;color:var(--text-muted);max-width:420px;min-height:1.25rem;margin:0 auto 48px;padding:0 12px;font-size:.85rem}.skills-pizza-layout{align-items:center;gap:36px;margin-bottom:8px;display:flex}.skills-pizza-active-card{z-index:4;border-radius:var(--radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #38bdf840;flex:42%;min-width:0;min-height:220px;margin:0;padding:20px 24px;position:relative;box-shadow:0 12px 40px #00000059}.skills-pizza-active-card h3{text-align:left;margin-bottom:14px;font-size:1rem;transition:color .25s}.skills-pizza-active-card ul{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.skills-pizza-active-card li{color:var(--text-muted);align-items:center;gap:6px;font-size:.85rem;display:flex}.skills-pizza-active-card .skill-icon{color:var(--card-accent,var(--accent-2));flex-shrink:0;font-size:1rem;transition:color .25s}.skills-pizza-stage{aspect-ratio:480/260;flex:52%;width:100%;min-width:0;max-height:280px;position:relative}.skills-pizza-outer-ring{pointer-events:none;transition:fill .25s,stroke .25s,filter .25s}.skills-pizza-wheel{z-index:2;position:absolute;inset:0}.skills-pizza-svg{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.pizza-slice-path{cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none;transition:stroke .2s,stroke-width .2s,filter .2s}.pizza-slice-path:focus,.pizza-slice-path:focus-visible{outline:none}.pizza-slice-path:hover{filter:brightness(1.1)}.pizza-slice-path--active{filter:brightness(1.15)}.skills-pizza-labels{z-index:3;pointer-events:none;position:absolute;inset:0}.pizza-slice-label{color:#ffffff8c;text-align:center;max-width:72px;font-size:.7rem;font-weight:600;line-height:1.2;transition:color .2s,font-size .2s;position:absolute;transform:translate(-50%,-50%)}.pizza-slice-label--active{color:var(--accent);font-size:.78rem}.skills-pizza-core{z-index:5;background:radial-gradient(circle at 35% 35%,#fde68a,#d97706 45%,#92400e 100%);border:3px solid #ffffff26;border-radius:50%;width:40px;height:40px;position:absolute;bottom:0;left:50%;transform:translate(-50%,50%);box-shadow:0 0 24px #fbbf2459}.skills-pizza-dots{z-index:6;justify-content:center;gap:10px;margin-top:32px;padding-top:8px;display:flex;position:relative}.skills-pizza-dots button{cursor:pointer;background:#ffffff40;border:none;border-radius:50%;outline:none;width:8px;height:8px;padding:0;transition:transform .2s,background .2s}.skills-pizza-dots button:focus,.skills-pizza-dots button:focus-visible{outline:none;box-shadow:0 0 0 2px #38bdf873}.skills-pizza-dots button.active{background:var(--accent);transform:scale(1.35)}.skill-card{padding:28px}.skill-card h3{color:var(--accent);margin-bottom:18px;font-size:1rem;font-weight:600}.skill-card li{color:var(--text-muted);border-bottom:1px solid #ffffff0a;align-items:center;gap:10px;padding:8px 0;font-size:.92rem;display:flex}.skill-card li:last-child{border-bottom:none}.skill-icon{color:var(--accent-2);flex-shrink:0;font-size:1.1rem}.timeline{max-width:800px;margin:0 auto;padding-left:32px;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--accent), var(--accent-2), transparent);width:2px;position:absolute;top:8px;bottom:8px;left:7px}.timeline-item{margin-bottom:28px;padding:28px 32px;position:relative}.timeline-dot{background:var(--bg);border:3px solid var(--accent);border-radius:50%;width:16px;height:16px;position:absolute;top:36px;left:-32px;box-shadow:0 0 16px #38bdf880}.timeline-period{color:var(--accent);margin-bottom:8px;font-size:.8rem;font-weight:600;display:inline-block}.timeline-content h3{margin-bottom:4px;font-size:1.15rem}.timeline-company{color:var(--text-muted);margin-bottom:16px;font-size:.95rem}.timeline-content ul{flex-direction:column;gap:10px;display:flex}.timeline-content li{color:var(--text-muted);padding-left:18px;font-size:.92rem;line-height:1.6;position:relative}.timeline-content li:before{content:"▸";color:var(--accent-2);position:absolute;left:0}.projects-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.project-card{flex-direction:column;padding:0;transition:box-shadow .3s,border-color .3s;display:flex;position:relative;overflow:hidden}.project-card:hover{border-color:#38bdf840;box-shadow:0 16px 48px #38bdf81f}.project-carousel{background:#0c0c14;width:100%;height:280px;position:relative;overflow:hidden}.project-carousel-link{z-index:1;cursor:pointer;display:block;position:absolute;inset:0}.project-carousel-link img{object-fit:cover;object-position:top center;width:100%;height:100%;position:absolute;inset:0}.project-carousel-link:hover img{opacity:.92}.carousel-btn{z-index:2;border:1px solid var(--border);width:32px;height:32px;color:var(--text);opacity:0;background:#07070dbf;border-radius:50%;place-items:center;font-size:1rem;transition:opacity .2s,background .2s;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.project-carousel:hover .carousel-btn{opacity:1}.carousel-btn:hover{color:var(--accent);background:#38bdf833}.carousel-btn-prev{left:10px}.carousel-btn-next{right:10px}.carousel-dots{z-index:2;gap:6px;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.carousel-dots button{background:#ffffff59;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s,transform .2s}.carousel-dots button.active{background:var(--accent);transform:scale(1.2)}.project-placeholder{background:linear-gradient(135deg,#38bdf81a,#a78bfa1a);place-items:center;height:280px;display:grid}.project-placeholder span{background:var(--gradient);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800}.project-body{flex:1;padding:20px 24px 24px;transition:color .2s;display:block}.project-footer{justify-content:space-between;align-items:center;gap:12px;display:flex}.project-body:hover h3{color:var(--accent)}.project-footer h3{flex:1;min-width:0;margin:0;font-size:1.05rem;font-weight:600}.project-link{color:var(--accent);white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;font-size:.85rem;display:inline-flex}.project-shine{background:linear-gradient(90deg,#0000,#ffffff0f,#0000);width:60%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%;transform:skew(-20deg)}.project-card:hover .project-shine{left:150%}.contact-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:8px;display:grid}.contact-card{align-items:flex-start;gap:16px;padding:24px;transition:border-color .2s;display:flex}.contact-card:hover{border-color:#38bdf84d}.contact-card svg{color:var(--accent);margin-top:2px;font-size:1.4rem}.contact-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:4px;font-size:.75rem;display:block}.contact-value{word-break:break-all;font-size:.95rem}#contact .btn-large{width:fit-content;margin-inline:auto;display:flex}.footer{border-top:1px solid var(--border);text-align:center;padding:32px 0 48px}.footer p{color:var(--text-muted);font-size:.9rem}.footer strong{color:var(--text)}@media (width>=901px){.section{padding:64px 0}.section-heading{margin-bottom:40px}.about-summary{margin-bottom:32px}.stats-grid{margin-bottom:24px}.skills-scroll-track{padding-top:0}.skills-section-sticky{padding-top:8px;padding-bottom:24px}.skills-section-sticky .section-heading{margin-bottom:36px}.skills-pizza-hint{margin-bottom:32px}.timeline-item{margin-bottom:20px}#contact .btn-large{margin-top:28px}.footer{padding:24px 0 36px}}@media (width<=900px){.section{padding:40px 0;overflow-x:clip}.section-heading{margin-bottom:28px}.about-summary{margin-bottom:20px}.stats-grid{margin-bottom:16px}.container{box-sizing:border-box;width:100%;max-width:100%;padding-inline:clamp(16px,4vw,24px)}.hero-visual{max-width:100%;overflow:hidden}.code-card-glow{inset:-15%}.hero-grid{text-align:center;grid-template-columns:1fr;gap:28px}.hero{min-height:auto;padding-top:calc(var(--nav-height) + 16px);padding-bottom:24px}.hero-content{flex-direction:column;align-items:center;display:flex}.hero-heading{flex-direction:column;justify-content:center;gap:16px;margin-bottom:12px}.hero-avatar{width:110px;height:110px}.hero-title{font-size:clamp(2rem,8vw,3rem)}.hero-role{flex-direction:column;align-items:center;gap:6px;margin-bottom:12px;font-size:1rem;display:flex}.role-divider,.hero-subtitle{display:none}.hero-tagline{margin-bottom:16px;padding:0 4px;font-size:.98rem}.hero-cta{justify-content:center;margin-bottom:20px}.hero-social{justify-content:center}.hero-visual{width:100%;max-width:480px;margin:0 auto}.code-card{min-width:0}.code-card pre{padding:16px;overflow-x:hidden}.code-card code{font-size:.68rem;line-height:1.65}.code-header{padding:12px 14px}.code-header p{font-size:.7rem}.badge-anchor{display:none}.stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}.projects-grid{grid-template-columns:1fr;gap:20px}.contact-grid{grid-template-columns:1fr}.desktop-only{display:none}.mobile-only{display:block}.scroll-hint{display:none}}@media (width<=768px){.section{padding:32px 0}.section-heading{margin-bottom:24px;padding:0 4px}.section-heading h2{font-size:clamp(1.6rem,6vw,2rem)}.section-heading p{font-size:.95rem}.about-summary{margin-bottom:16px;padding:0 4px;font-size:1rem}.stats-grid{gap:12px;margin-bottom:12px}.education-card{padding:24px 20px}.edu-meta{flex-direction:column;align-items:flex-start;gap:10px}.skills-scroll-track{padding-top:0;min-height:auto!important}.skills-section-sticky{padding-top:0;padding-bottom:8px;position:relative;top:auto}.skills-section-sticky .section-heading{margin-bottom:20px}.skills-pizza-hint{margin:0 auto 14px;font-size:.8rem}.skills-pizza-layout{flex-direction:column;gap:16px;margin-bottom:0}.skills-pizza-dots{margin-top:14px;padding-top:0}.skills-section{overflow-x:clip}.skills-pizza-stage{flex:none;width:100%;max-width:360px;max-height:240px;margin:0 auto;overflow:hidden}.skills-pizza-svg{overflow:hidden}.skills-pizza-outer-ring{filter:none!important}.pizza-slice-path:hover,.pizza-slice-path--active{filter:none}.skills-pizza-active-card{flex:none;width:100%;min-height:180px;padding:18px 20px}.pizza-slice-label{max-width:56px;font-size:.62rem}.timeline{padding-left:28px}.timeline-item{margin-bottom:12px;padding:20px 18px}.timeline-dot{top:28px;left:-28px}.project-carousel,.project-placeholder{height:220px}.project-footer{flex-direction:column;align-items:flex-start;gap:8px}.project-link{white-space:normal}.carousel-btn{opacity:1;width:36px;height:36px}.project-card:hover,.stat-card:hover{transform:none}}@media (width<=560px){:root{--nav-height:64px}.section{padding:24px 0}.section-heading{margin-bottom:20px}.about-summary{margin-bottom:12px}.navbar{padding:8px 0;padding-top:max(8px, env(safe-area-inset-top))}.nav-inner{height:56px}.logo-text{text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:.85rem;overflow:hidden}.logo-mark{width:36px;height:36px;font-size:.75rem}.hero{padding-top:calc(var(--nav-height) + 12px);padding-bottom:20px}.hero-grid{gap:24px}.hero-title{font-size:clamp(1.85rem,9vw,2.5rem)}.hero-avatar{width:96px;height:96px}.hero-tagline{font-size:.92rem;line-height:1.65}.code-card pre{padding:14px}.code-card code{font-size:.62rem;line-height:1.6}.btn{width:100%;max-width:280px;padding:13px 20px}.hero-cta{flex-direction:column;align-items:center;width:100%}.hero-social a{width:44px;height:44px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.stat-card{padding:16px 12px}.stat-value{font-size:1.75rem}.stat-label{font-size:.78rem}.skills-section-sticky .section-heading{margin-bottom:16px}.skills-pizza-hint{margin-bottom:12px}.skills-pizza-stage{max-height:210px}.skills-pizza-active-card li{font-size:.82rem}.timeline-content h3{font-size:1.05rem}.timeline-content li{font-size:.88rem}.project-body{padding:16px 18px 20px}.project-footer h3{font-size:.98rem}.contact-card{padding:20px}.contact-value{word-break:break-word;font-size:.88rem}#contact .btn-large{width:100%;max-width:100%}.footer{padding:16px 0 max(20px, env(safe-area-inset-bottom));padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.footer p{padding:0 8px;font-size:.82rem}}@media (hover:hover) and (pointer:fine){.carousel-btn{opacity:0}.project-carousel:hover .carousel-btn{opacity:1}}
