*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f4f8;--bg-2:#fff;--bg-3:#e8eef5;--accent:#1d4ed8;--accent-2:#0369a1;--text:#0f172a;--text-muted:#475569;--text-faint:#94a3b8;--border:#cbd5e1;--font-sans:"Outfit", sans-serif;--font-mono:"JetBrains Mono", monospace;--radius:10px;--transition:.2s ease}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border)}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.section-label{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:.82rem;display:block}.skill-tag{font-family:var(--font-mono);background:var(--bg-3);border:1px solid var(--border);color:var(--text-muted);transition:all var(--transition);cursor:default;border-radius:4px;padding:.35rem .8rem;font-size:.85rem}.skill-tag:hover{border-color:var(--accent);color:var(--accent)}.btn{border-radius:var(--radius);letter-spacing:.04em;transition:all var(--transition);cursor:pointer;border:none;align-items:center;padding:.65rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:#1e40af;box-shadow:0 8px 28px #1d4ed840}.btn--ghost{color:var(--text);border:1px solid var(--border);background:0 0}.btn--ghost:hover{border-color:var(--text-muted);transform:translateY(-2px)}.navbar{z-index:100;transition:background var(--transition), border-color var(--transition);border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:1.2rem 3rem;display:flex;position:fixed;top:0;left:0;right:0}.navbar--scrolled{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom-color:var(--border);background:#f0f4f8eb}.navbar__brand{font-family:var(--font-mono);color:var(--accent);letter-spacing:3px;transition:opacity var(--transition);font-size:.95rem;font-weight:500}.navbar__brand:hover{opacity:.7}.navbar__links{gap:2.5rem;list-style:none;display:flex}.nav-link{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);transition:color var(--transition);padding-bottom:2px;font-size:.88rem;font-weight:500;position:relative}.nav-link:after{content:"";background:var(--accent);width:0;height:1px;transition:width var(--transition);position:absolute;bottom:-2px;left:0}.nav-link:hover,.nav-link--active{color:var(--text)}.nav-link:hover:after,.nav-link--active:after{width:100%}@media (width<=600px){.navbar{padding:1rem 1.25rem}.navbar__links{gap:1.25rem}.nav-link{font-size:.74rem}}.footer{border-top:1px solid var(--border);margin-top:4rem;padding:2rem 3rem}.footer__inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;max-width:1100px;margin:0 auto;display:flex}.footer__brand{font-family:var(--font-mono);color:var(--text-muted);font-size:.88rem}.footer__links{gap:1.5rem;display:flex}.footer__links a{color:var(--text-faint);transition:color var(--transition);font-size:.88rem}.footer__links a:hover{color:var(--accent)}.footer__copy{font-family:var(--font-mono);color:var(--text-faint);font-size:.8rem}@media (width<=600px){.footer{padding:1.5rem}.footer__copy{display:none}}.home{padding-top:4.5rem}.hero{flex-direction:column;justify-content:center;min-height:100vh;padding:7rem 3rem 5rem;display:flex;position:relative;overflow:hidden}.hero__grid{background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);opacity:.55;background-size:64px 64px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(70% 60% at 40% 30%,#000 0%,#0000 75%);mask-image:radial-gradient(70% 60% at 40% 30%,#000 0%,#0000 75%)}.hero__glow{pointer-events:none;background:radial-gradient(circle,#1d4ed812 0%,#0000 65%);width:600px;height:600px;position:absolute;top:10%;left:-10%}.hero__content{z-index:1;max-width:820px;position:relative}.hero__inner{z-index:1;justify-content:space-between;align-items:center;gap:4rem;width:100%;max-width:1100px;display:flex;position:relative}.hero__content{flex:1;max-width:580px}.hero__photo-wrap{flex-shrink:0;width:260px;height:260px;position:relative}.hero__photo-ring{background:conic-gradient(var(--accent) 0deg, transparent 90deg, var(--accent) 180deg, transparent 270deg);opacity:.35;border-radius:50%;animation:8s linear infinite spin;position:absolute;inset:-8px}@keyframes spin{to{transform:rotate(360deg)}}.hero__photo{z-index:1;object-fit:cover;object-position:center top;border:3px solid var(--bg-2);border-radius:50%;width:100%;height:100%;display:block;position:relative;box-shadow:0 20px 60px #1d4ed826}@media (width<=768px){.hero__inner{flex-direction:column-reverse;align-items:flex-start;gap:2rem}.hero__photo-wrap{width:120px;height:120px}.hero__photo-ring{inset:-5px}}.hero__eyebrow{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);align-items:center;gap:.6rem;margin-bottom:1.5rem;font-size:.85rem;animation:.6s both fadeUp;display:inline-flex}.hero__dot{background:var(--accent-2);width:7px;height:7px;box-shadow:0 0 8px var(--accent-2);border-radius:50%;animation:2.2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.hero__name{letter-spacing:-.035em;background:linear-gradient(135deg, #0f172a 0%, var(--accent) 60%, #1e40af 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.6rem;font-size:clamp(2.5rem,7vw,6rem);font-weight:900;line-height:.9;animation:.6s 50ms both fadeUp}.hero__roles{font-family:var(--font-mono);color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:.45rem;margin-bottom:1.8rem;font-size:.9rem;animation:.6s .1s both fadeUp;display:flex}.sep{color:var(--text-faint)}.hero__bio{max-width:560px;color:var(--text-muted);margin-bottom:2.5rem;font-size:1.1rem;line-height:1.78;animation:.6s .15s both fadeUp}.hero__cta{flex-wrap:wrap;gap:.75rem;animation:.6s .2s both fadeUp;display:flex}.hero__corner-info{flex-direction:column;align-items:flex-end;gap:.3rem;display:flex;position:absolute;bottom:2.5rem;right:3rem}.hero__corner-info span{font-family:var(--font-mono);letter-spacing:.08em;color:var(--text-faint);opacity:.5;font-size:.78rem}.skills-section{border-top:1px solid var(--border);padding:5rem 3rem}.skills-section__header{margin-bottom:2rem}.skills-section__header h2{letter-spacing:-.02em;font-size:1.9rem;font-weight:700}.skills-cloud{flex-wrap:wrap;gap:.55rem;display:flex}.about-section{border-top:1px solid var(--border);padding:5rem 3rem}.about-section__header{margin-bottom:2.5rem}.about-section__header h2{letter-spacing:-.02em;font-size:1.9rem;font-weight:700}.about-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;display:grid}.about-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.7rem;padding:1.75rem;transition:all .25s;display:flex}.about-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 16px 48px #0006}.about-card__icon{font-size:1.7rem}.about-card h3{letter-spacing:-.01em;font-size:1rem;font-weight:700}.about-card p{color:var(--text-muted);font-size:.86rem;line-height:1.72}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.hero{padding:5rem 1.5rem 4rem}.hero__corner-info{display:none}.skills-section,.about-section{padding:4rem 1.5rem}}.skills-categories{flex-direction:column;gap:1.5rem;display:flex}.skills-category__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.resume-page{min-height:100vh;padding-top:4.5rem}.resume-wrap{max-width:860px;margin:0 auto;padding:4rem 2rem 6rem}.resume-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:4rem;display:flex}.resume-header h1{letter-spacing:-.03em;font-size:3rem;font-weight:800;line-height:1}.rs{margin-bottom:4rem}.rs__label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:.75rem;font-size:1rem}.timeline{padding-left:1.25rem;position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:8px;bottom:0;left:0}.tl-item{margin-bottom:2.5rem;padding-left:1.75rem;position:relative}.tl-item__dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 0 3px var(--bg), 0 0 0 4px #f7c94866;border-radius:50%;position:absolute;top:7px;left:-1.7rem}.tl-item__row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.4rem;margin-bottom:.25rem;display:flex}.tl-item__org{font-family:var(--font-mono);letter-spacing:.06em;color:var(--accent);font-size:1rem}.tl-item__org-wrap{align-items:center;gap:10px;display:flex}.tl-item__logo{object-fit:contain;border-radius:6px;width:50px;height:50px}.tl-item__date{font-family:var(--font-mono);color:var(--text-faint);font-size:.8rem}.tl-item__title{letter-spacing:-.01em;margin-bottom:.2rem;font-size:1.1rem;font-weight:600}.tl-item__sub{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:.8rem;font-size:.82rem}.tl-item__bullets{flex-direction:column;gap:.45rem;list-style:none;display:flex}.tl-item__bullets li{color:var(--text-muted);padding-left:1.1rem;font-size:1rem;line-height:1.75;position:relative}.tl-item__bullets li:before{content:"›";color:var(--accent);font-weight:700;position:absolute;left:0}.tag-row{flex-wrap:wrap;gap:.45rem;margin-top:.75rem;display:flex}.skills-tbl{flex-direction:column;gap:0;display:flex}.skills-tbl__row{border-bottom:1px solid var(--border);grid-template-columns:140px 1fr;align-items:baseline;gap:1.5rem;padding:.9rem 0;display:grid}.skills-tbl__cat{font-family:var(--font-mono);letter-spacing:.06em;color:var(--accent);font-size:.82rem}.skills-tbl__val{color:var(--text-muted);font-size:1rem;line-height:1.6}@media (width<=600px){.resume-header{flex-direction:column;align-items:flex-start}.skills-tbl__row{grid-template-columns:1fr;gap:.25rem}.tl-item__row{flex-direction:column;align-items:flex-start}}.projects-page{min-height:100vh;padding-top:4.5rem}.projects-wrap{max-width:1100px;margin:0 auto;padding:4rem 2rem 6rem}.projects-header{margin-bottom:3.5rem}.projects-header h1{letter-spacing:-.03em;font-size:3rem;font-weight:800}.projects-sub{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em;margin-top:.6rem;font-size:.88rem}.projects-sub a{color:var(--accent);transition:opacity var(--transition);text-decoration:none}.projects-sub a:hover{opacity:.7;text-decoration:underline}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.1rem;display:grid}.proj-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.9rem;padding:1.75rem;transition:all .25s;display:flex}.proj-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 20px 60px #00000080}.proj-card__top{justify-content:space-between;align-items:center;display:flex}.proj-card__meta{align-items:center;gap:10px;display:flex}.proj-card__github{opacity:.7;border-radius:6px;justify-content:center;align-items:center;padding:6px;font-size:1.2rem;transition:all .2s;display:flex}.proj-card__github:hover{opacity:1;background:#ffffff14;transform:scale(1.1)}.proj-card__type{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:.78rem}.proj-card__date{font-family:var(--font-mono);color:var(--text-faint);font-size:.78rem}.proj-card__title{letter-spacing:-.02em;font-size:1.12rem;font-weight:700;line-height:1.3}.proj-card__desc{color:var(--text-muted);font-size:.95rem;line-height:1.72}.proj-card__highlights{flex-wrap:wrap;gap:.4rem;display:flex}.highlight-pill{font-family:var(--font-mono);color:var(--accent);background:#f7c94814;border:1px solid #f7c94840;border-radius:4px;padding:.22rem .65rem;font-size:.78rem}.proj-card__tags{flex-wrap:wrap;gap:.4rem;margin-top:auto;display:flex}.proj-card__link{color:var(--accent-2);transition:gap var(--transition);align-items:center;gap:.3rem;margin-top:.25rem;font-size:.82rem;font-weight:600;display:inline-flex}.proj-card__link:hover{gap:.6rem}@media (width<=600px){.projects-grid{grid-template-columns:1fr}}.proj-card__links{gap:10px;margin-top:14px;display:flex}.proj-card__demo{background:#ffffff14;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.proj-card__demo:hover{background:#ffffff29;transform:translateY(-1px)}.proj-card__demo svg{font-size:.85rem}.proj-card__image-wrap{border-radius:10px;width:100%;height:160px;margin-bottom:12px;overflow:hidden}.proj-card__image{object-fit:cover;width:100%;height:100%;transition:transform .3s}.proj-card:hover .proj-card__image{transform:scale(1.05)}.certs-page{min-height:100vh;padding-top:4.5rem}.certs-wrap{max-width:860px;margin:0 auto;padding:4rem 2rem 6rem}.certs-header{margin-bottom:3.5rem}.certs-header h1{letter-spacing:-.03em;font-size:3rem;font-weight:800}.certs-notice{font-family:var(--font-mono);color:var(--accent);opacity:.8;margin-top:.75rem;font-size:.75rem}.certs-notice code{background:#f7c9481a;border-radius:3px;padding:.1em .4em;font-size:.72rem}.certs-list{flex-direction:column;gap:1rem;display:flex}.cert-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;align-items:flex-start;gap:1.5rem;padding:1.75rem;transition:all .25s;display:flex}.cert-card:hover{border-color:var(--accent);transform:translate(5px)}.cert-card--placeholder{opacity:.65}.cert-card__icon{text-align:center;flex-shrink:0;width:3rem;padding-top:.1rem;font-size:2rem;line-height:1}.cert-card__icon img{object-fit:contain;width:40px;height:40px}.cert-card__body{flex-direction:column;flex:1;gap:.55rem;display:flex}.cert-card__top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.4rem;display:flex}.cert-card__issuer{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:.8rem}.cert-card__date{font-family:var(--font-mono);color:var(--text-faint);font-size:.8rem}.cert-card__title{letter-spacing:-.01em;font-size:1.1rem;font-weight:700}.cert-card__desc{color:var(--text-muted);font-size:.95rem;line-height:1.68}.cert-card__skills{flex-wrap:wrap;gap:.4rem;display:flex}.cert-card__verify{font-family:var(--font-mono);color:var(--accent-2);transition:opacity var(--transition);margin-top:.2rem;font-size:.85rem}.cert-card__verify:hover{opacity:.7}.certs-add{border:1px dashed var(--border);border-radius:12px;align-items:center;gap:1rem;margin-top:.5rem;padding:1.4rem 1.75rem;display:flex}.certs-add span{color:var(--text-faint);text-align:center;width:3rem;font-size:1.5rem}.certs-add p{font-family:var(--font-mono);color:var(--text-faint);font-size:.8rem}@media (width<=600px){.cert-card{flex-direction:column;gap:1rem}}
