:root{--bg: #080d1a;--bg-1: #0a1020;--surface: rgba(255, 255, 255, .03);--surface-hover: rgba(255, 255, 255, .06);--border: rgba(255, 255, 255, .07);--border-accent: rgba(56, 189, 248, .25);--accent: #38bdf8;--accent-2: #818cf8;--accent-3: #34d399;--text: #f1f5f9;--text-muted: #94a3b8;--text-faint: #475569;--radius: 12px;--radius-sm: 8px;--transition: all .2s ease;--shadow: 0 4px 32px rgba(0, 0, 0, .5);--gradient: linear-gradient(135deg, #38bdf8, #818cf8)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{background-color:var(--bg);color:var(--text-muted);font-family:Space Grotesk,system-ui,-apple-system,sans-serif;line-height:1.7;min-height:100vh}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}ul{list-style:none}h1,h2,h3,h4,h5{color:var(--text);font-weight:700;line-height:1.2}.gradient-text{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.container{max-width:1100px;margin:0 auto;padding:0 2rem}.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#080d1ae0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center;padding:0 2rem}.nav__inner{max-width:1100px;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between}.nav__logo{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:-.02em;display:flex;align-items:center;gap:.6rem}.nav__logo-img{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.nav__links{display:flex;gap:.25rem}.nav__link{padding:.4rem .85rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:500;color:var(--text-muted);transition:var(--transition)}.nav__link:hover{color:var(--text);background:var(--surface-hover)}.nav__link.active{color:var(--accent);background:#38bdf814}.nav__ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:var(--transition)}.nav__ham:hover{background:var(--surface-hover)}.nav__ham span{display:block;width:22px;height:2px;background:var(--text-muted);border-radius:2px;transition:var(--transition)}.nav__mobile{display:none;position:fixed;top:64px;left:0;right:0;background:#080d1af7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:1rem 1.5rem 1.5rem;z-index:99}.nav__mobile.open{display:block}.nav__mobile-link{display:block;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;color:var(--text-muted);transition:var(--transition)}.nav__mobile-link:hover{color:var(--text);background:var(--surface-hover)}.nav__mobile-link.active{color:var(--accent);background:#38bdf814}.page{padding-top:64px}.section{padding:5rem 0}.section-header{margin-bottom:3rem}.section-label{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}.section-title{font-size:clamp(1.8rem,3vw,2.4rem);color:var(--text);letter-spacing:-.02em}.section-sub{color:var(--text-muted);margin-top:.5rem;font-size:1.025rem}.hero{min-height:calc(100vh - 64px);display:flex;align-items:center;position:relative;overflow:hidden;padding:4rem 0}.hero:before{content:"";position:absolute;top:-10%;right:-5%;width:55%;height:70%;background:radial-gradient(ellipse,rgba(56,189,248,.06) 0%,transparent 65%);pointer-events:none}.hero:after{content:"";position:absolute;bottom:-10%;left:-5%;width:45%;height:60%;background:radial-gradient(ellipse,rgba(129,140,248,.05) 0%,transparent 65%);pointer-events:none}.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center;width:100%}.hero__eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:700;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.25rem;padding:.3rem .85rem;border:1px solid rgba(56,189,248,.2);border-radius:100px;background:#38bdf80a}.hero__eyebrow:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent-3);animation:pulse 2s ease infinite}.hero__name{font-size:clamp(2.6rem,5vw,4rem);font-weight:700;line-height:1.1;letter-spacing:-.03em;color:var(--text);margin-bottom:.75rem}.hero__role{font-size:clamp(1rem,2vw,1.3rem);color:var(--text-muted);margin-bottom:1.75rem;min-height:2rem;font-weight:400}.hero__cursor{display:inline-block;width:2px;height:1em;background:var(--accent);margin-left:2px;vertical-align:middle;animation:blink 1s step-end infinite}.hero__bio{font-size:.975rem;line-height:1.85;color:var(--text-muted);margin-bottom:2rem;max-width:520px}.hero__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.25rem}.hero__tag{padding:.25rem .8rem;border-radius:100px;font-size:.775rem;font-weight:600;border:1px solid var(--border);color:var(--text-muted);background:var(--surface);transition:var(--transition);cursor:default}.hero__tag:hover{border-color:var(--border-accent);color:var(--accent);background:#38bdf80a}.hero__cta{display:flex;gap:.75rem;flex-wrap:wrap}.terminal{background:#0d1117;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow),0 0 0 1px #38bdf80a}.terminal__bar{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;background:#ffffff05;border-bottom:1px solid var(--border)}.terminal__dot{width:11px;height:11px;border-radius:50%}.terminal__dot--r{background:#ff5f57}.terminal__dot--y{background:#febc2e}.terminal__dot--g{background:#28c840}.terminal__label{margin-left:auto;font-size:.7rem;color:var(--text-faint);font-family:JetBrains Mono,Fira Code,Courier New,monospace}.terminal__body{padding:1.25rem 1.25rem 1.5rem;font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-size:.78rem;line-height:1.7}.tl{display:flex;gap:.4rem}.tl--mt{margin-top:.75rem}.tl__p{color:var(--accent);-webkit-user-select:none;user-select:none;flex-shrink:0}.tl__c{color:#e2e8f0}.tl__o{color:var(--text-faint);padding-left:.5rem}.tl__ok{color:var(--accent-3)}.tl__warn{color:#fbbf24}.tl__key{color:#38bdf8;min-width:120px}.tl__val-ok{color:var(--accent-3)}.tl__val-run{color:#38bdf8}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.4rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);border:none;font-family:inherit;white-space:nowrap}.btn--primary{background:var(--gradient);color:#fff;box-shadow:0 2px 16px #38bdf833}.btn--primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px #38bdf84d}.btn--ghost{border:1px solid var(--border);color:var(--text-muted);background:transparent}.btn--ghost:hover{border-color:var(--border-accent);color:var(--text);background:var(--surface)}.btn--sm{padding:.4rem .85rem;font-size:.8rem}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.about-bio{font-size:.975rem;line-height:1.85;color:var(--text-muted);margin-bottom:1.25rem}.about-contact{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:600;color:var(--accent);border:1px solid rgba(56,189,248,.2);padding:.4rem 1rem;border-radius:100px;transition:var(--transition);margin-top:.5rem}.about-contact:hover{background:#38bdf80f}.badges-section{margin-top:2rem}.badges-title{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:1rem}.badges-grid{display:flex;flex-wrap:wrap;gap:.75rem}.skills-section-title{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:1rem}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill{padding:.3rem .8rem;border-radius:100px;border:1px solid var(--border);font-size:.8rem;font-weight:500;color:var(--text-muted);background:var(--surface);transition:var(--transition);cursor:default}.skill:hover{border-color:var(--border-accent);color:var(--accent);background:#38bdf80a}.timeline{position:relative;max-width:760px}.timeline:before{content:"";position:absolute;left:0;top:8px;bottom:24px;width:1px;background:linear-gradient(to bottom,var(--accent),var(--accent-2),rgba(129,140,248,.1))}.timeline__item{padding-left:2.5rem;padding-bottom:2.75rem;position:relative}.timeline__item:last-child{padding-bottom:0}.timeline__dot{position:absolute;left:-5px;top:8px;width:11px;height:11px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 3px #38bdf81f}.timeline__date{font-size:.75rem;font-weight:700;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.4rem}.timeline__role{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:.1rem}.timeline__company{font-size:.875rem;color:var(--accent-2);font-weight:600;margin-bottom:.75rem}.timeline__desc{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.75}.timeline__bullets{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.timeline__bullets li{display:flex;gap:.5rem;font-size:.85rem;color:var(--text-muted);line-height:1.6}.timeline__bullets li:before{content:"▸";color:var(--accent);flex-shrink:0;font-size:.7rem;margin-top:4px}.timeline__tags{display:flex;flex-wrap:wrap;gap:.35rem}.timeline__tag{padding:.18rem .55rem;border-radius:100px;font-size:.725rem;font-weight:500;border:1px solid var(--border);color:var(--text-faint);background:var(--surface)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;transition:var(--transition);position:relative;overflow:hidden;display:flex;flex-direction:column}.project-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient);opacity:0;transition:opacity .2s ease}.project-card:hover{border-color:#38bdf82e;background:var(--surface-hover);transform:translateY(-2px)}.project-card:hover:after{opacity:1}.project__icon{width:42px;height:42px;border-radius:var(--radius-sm);background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:1rem;flex-shrink:0}.project__title{font-size:1.025rem;font-weight:700;color:var(--text);margin-bottom:.5rem}.project__desc{font-size:.85rem;color:var(--text-muted);line-height:1.75;margin-bottom:1.2rem;flex:1}.project__tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1.2rem}.project__tag{padding:.15rem .55rem;border-radius:100px;font-size:.7rem;font-weight:600;border:1px solid var(--border);color:var(--text-faint);background:transparent}.project__links{display:flex;gap:1rem;margin-top:auto}.project__links .project__link{margin-top:0}.project__link{font-size:.82rem;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:.3rem;transition:var(--transition);margin-top:auto}.project__link:hover{gap:.5rem;color:var(--text)}.footer{border-top:1px solid var(--border);padding:2rem 0;margin-top:2rem}.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer__copy{font-size:.82rem;color:var(--text-faint)}.footer__socials{display:flex;gap:.75rem;align-items:center}.footer__social{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:var(--transition)}.footer__social:hover{border-color:var(--border-accent);color:var(--accent);background:var(--surface-hover)}.footer__social svg{width:16px;height:16px;fill:currentColor}.fade-in{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}@media (max-width: 900px){.hero__grid{grid-template-columns:1fr;gap:3rem}.terminal{display:none}.about-grid{grid-template-columns:1fr;gap:2.5rem}}@media (max-width: 768px){.nav__links{display:none}.nav__ham{display:flex}.projects-grid{grid-template-columns:1fr}.container{padding:0 1.25rem}.section{padding:3.5rem 0}.hero{padding:3rem 0}.footer__inner{flex-direction:column;align-items:flex-start;gap:1.25rem}}
