@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}:root{--bg: #030712;--surface: #0d1117;--surface2: #161b27;--surface3: #1e2537;--primary: #818cf8;--primary-dark: #6366f1;--primary-glow: rgba(99,102,241,.18);--primary-border: rgba(129,140,248,.3);--cyan: #22d3ee;--cyan-glow: rgba(34,211,238,.18);--emerald: #34d399;--emerald-glow: rgba(52,211,153,.18);--rose: #f472b6;--rose-glow: rgba(244,114,182,.18);--amber: #fbbf24;--amber-glow: rgba(251,191,36,.18);--purple: #c084fc;--purple-glow: rgba(192,132,252,.18);--orange: var(--primary);--orange-dim: var(--primary-glow);--orange-glow: var(--primary-border);--blue: var(--cyan);--blue-dim: var(--cyan-glow);--green: var(--emerald);--green-dim: var(--emerald-glow);--yellow: var(--amber);--yellow-dim: var(--amber-glow);--purple-dim: var(--purple-glow);--border-glow: var(--primary-border);--text: #e2e8f0;--text-dim: #94a3b8;--text-muted: #475569;--white: #f8fafc;--border: rgba(255,255,255,.06);--border-hover: rgba(255,255,255,.12);--border-active: rgba(129,140,248,.4);--glass: rgba(13,17,23,.82);--glass-border: rgba(255,255,255,.07);--font-h: "Plus Jakarta Sans", sans-serif;--font-b: "Inter", sans-serif;--font-m: "JetBrains Mono", monospace;--sidebar-w: 280px;--radius: 16px;--radius-sm: 10px;--radius-xs: 6px;--transition: .25s cubic-bezier(.4,0,.2,1);--transition-slow: .4s cubic-bezier(.4,0,.2,1)}body{background:var(--bg);color:var(--text);font-family:var(--font-b);line-height:1.65;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(129,140,248,.08) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0}a{color:inherit;text-decoration:none}img{max-width:100%}button{cursor:pointer;border:none;background:none;font-family:inherit}strong{color:var(--primary);font-weight:600}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--primary-dark);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}::selection{background:var(--primary-glow);color:var(--white)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:linear-gradient(180deg,#0d1117f7,#060912fa);border-right:1px solid var(--glass-border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);overflow-y:auto;overflow-x:hidden;padding:2rem 1.4rem;display:flex;flex-direction:column;gap:1.6rem;z-index:100;transition:transform .35s cubic-bezier(.4,0,.2,1)}.sidebar:after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,transparent 5%,rgba(129,140,248,.35) 40%,rgba(34,211,238,.2) 70%,transparent 95%);pointer-events:none}.main{margin-left:var(--sidebar-w);min-height:100vh;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1}.avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:.55rem;padding-bottom:1.6rem;border-bottom:1px solid var(--glass-border)}.avatar{width:82px;height:82px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--cyan) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-m);font-size:1.4rem;font-weight:700;color:#fff;position:relative;box-shadow:0 0 0 3px var(--surface),0 0 0 5px var(--primary-border),0 0 40px var(--primary-glow)}.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:center 35%;display:block;transform:scale(1.3)}.avatar:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:1.5px solid transparent;border-top-color:var(--primary);border-right-color:#22d3ee99;animation:spin-ring 6s linear infinite;opacity:.7}.sidebar-name{font-family:var(--font-h);font-size:1rem;font-weight:700;color:var(--white);text-align:center;letter-spacing:-.01em}.sidebar-role{font-family:var(--font-m);font-size:.68rem;color:var(--primary);letter-spacing:.06em}.sidebar-status{display:flex;align-items:center;gap:.45rem;background:#34d39914;border:1px solid rgba(52,211,153,.22);border-radius:99px;padding:.28rem .8rem;font-family:var(--font-m);font-size:.6rem;color:var(--emerald);letter-spacing:.05em}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);animation:pulse 2s ease-in-out infinite;flex-shrink:0}.sidebar-section{display:flex;flex-direction:column;gap:.65rem}.sidebar-section-title{font-family:var(--font-m);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);padding-left:.15rem}.info-item{display:flex;align-items:flex-start;gap:.7rem}.info-icon{width:30px;height:30px;border-radius:var(--radius-xs);background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:.72rem;flex-shrink:0}.info-label{font-family:var(--font-m);font-size:.56rem;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase}.info-value{font-family:var(--font-b);font-size:.76rem;color:var(--text-dim);margin-top:.1rem;line-height:1.35}.social-row{display:flex;gap:.5rem;flex-wrap:wrap}.social-btn{width:34px;height:34px;border-radius:var(--radius-xs);background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:.85rem;transition:var(--transition)}.social-btn:hover{border-color:var(--primary-border);color:var(--primary);background:var(--primary-glow);transform:translateY(-2px);box-shadow:0 4px 14px var(--primary-glow)}.sidebar-nav{display:flex;flex-direction:column;gap:.2rem}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .85rem;border-radius:var(--radius-xs);font-family:var(--font-b);font-size:.84rem;color:var(--text-dim);cursor:pointer;transition:var(--transition);border:1px solid transparent;position:relative;overflow:hidden}.nav-item i{width:15px;text-align:center;font-size:.8rem;flex-shrink:0}.nav-item:hover{color:var(--text);background:var(--surface2);border-color:var(--border)}.nav-item.active{background:var(--primary-glow);border-color:var(--primary-border);color:var(--primary);font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:15%;bottom:15%;width:2px;background:linear-gradient(180deg,var(--primary),var(--cyan));border-radius:0 2px 2px 0}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99}.sidebar-backdrop.open{display:block}.hamburger{display:none;position:fixed;top:1rem;left:1rem;width:40px;height:40px;border-radius:var(--radius-xs);background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:var(--text);font-size:1rem;cursor:pointer;z-index:200;align-items:center;justify-content:center;transition:var(--transition)}.hamburger:hover{border-color:var(--primary-border);color:var(--primary)}.page{display:none;padding:3rem 3rem 5rem;min-height:100vh;opacity:0;transform:translateY(14px);transition:opacity .4s ease,transform .4s ease}.page.active{display:block}.page.page-visible{opacity:1;transform:translateY(0)}.page-title{font-family:var(--font-h);font-size:2.25rem;font-weight:800;color:var(--white);margin-bottom:.5rem;letter-spacing:-.025em;line-height:1.15}.page-title span{background:linear-gradient(135deg,var(--primary) 0%,var(--cyan) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-divider{height:2px;background:linear-gradient(90deg,var(--primary-dark),var(--cyan),transparent);margin-bottom:2.5rem;border-radius:99px}.hero{position:relative;height:100vh;min-height:620px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:2rem;padding-left:calc(var(--sidebar-w) + 2rem);background:radial-gradient(ellipse 80% 50% at 50% -5%,rgba(99,102,241,.16) 0%,transparent 60%),radial-gradient(ellipse 55% 40% at 85% 65%,rgba(34,211,238,.08) 0%,transparent 55%),radial-gradient(ellipse 40% 30% at 15% 80%,rgba(192,132,252,.06) 0%,transparent 50%),var(--bg)}.hero:before{content:"";position:absolute;top:-250px;left:50%;transform:translate(-50%);width:900px;height:700px;background:radial-gradient(ellipse,rgba(99,102,241,.1) 0%,transparent 65%);pointer-events:none;z-index:0}#tsparticles{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.1rem;max-width:700px}.hero-avatar{width:118px;height:118px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--cyan) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-m);font-size:2.1rem;font-weight:700;color:#fff;position:relative;box-shadow:0 0 0 4px var(--bg),0 0 0 6px #6366f159,0 0 60px #6366f138,0 0 120px #22d3ee1a;will-change:transform}.hero-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:center 35%;display:block;transform:scale(1.3)}.hero-avatar:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:2px solid transparent;border-top-color:var(--primary);border-right-color:#22d3ee8c;animation:spin-ring 5s linear infinite}.hero-name{font-family:var(--font-h);font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;background:linear-gradient(140deg,var(--white) 30%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-typed-wrap{font-family:var(--font-m);font-size:clamp(.82rem,2vw,1rem);color:var(--cyan);letter-spacing:.04em;min-height:1.6em}.typed-cursor{color:var(--cyan);animation:typed-blink .7s step-end infinite}.hero-meta{display:flex;align-items:center;gap:.9rem;font-family:var(--font-m);font-size:.72rem;color:var(--text-dim);letter-spacing:.06em;flex-wrap:wrap;justify-content:center}.hero-meta>span:first-child{display:flex;align-items:center;gap:.35rem}.hero-meta-sep{color:var(--border)}.hero-available{display:flex;align-items:center;gap:.42rem;color:var(--emerald);background:#34d39914;border:1px solid rgba(52,211,153,.22);border-radius:99px;padding:.28rem .8rem;font-size:.68rem}.hero-available .dot{width:6px;height:6px;border-radius:50%;background:var(--emerald);animation:pulse 2s ease-in-out infinite;flex-shrink:0}.hero-ctas{display:flex;gap:1rem;margin-top:.4rem;flex-wrap:wrap;justify-content:center}.hero-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.78rem 1.85rem;border-radius:var(--radius-sm);font-family:var(--font-b);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);border:none;letter-spacing:.005em}.hero-btn-primary{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;box-shadow:0 4px 24px var(--primary-glow),0 0 0 1px #818cf833}.hero-btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 40px var(--primary-glow),0 0 0 1px #818cf859}.hero-btn-secondary{background:#ffffff0a;color:var(--text);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hero-btn-secondary:hover{border-color:var(--primary-border);color:var(--primary);background:var(--primary-glow);transform:translateY(-2px);box-shadow:0 6px 24px var(--primary-glow)}.hero-scroll{position:absolute;bottom:2rem;left:calc(var(--sidebar-w) + (100% - var(--sidebar-w)) / 2);transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.45rem;font-family:var(--font-m);font-size:.58rem;letter-spacing:.2em;color:var(--text-muted);z-index:1;animation:scroll-bob 2.5s ease-in-out infinite}.hero-scroll i{font-size:.8rem}@keyframes spin-ring{to{transform:rotate(360deg)}}@keyframes typed-blink{50%{opacity:0}}@keyframes scroll-bob{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.about-bio{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.8rem 2rem;font-size:.95rem;line-height:1.82;margin-bottom:2.5rem;position:relative;overflow:hidden;color:var(--text-dim)}.about-bio:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--primary),var(--cyan));border-radius:0 2px 2px 0}.about-bio:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(129,140,248,.3),transparent)}.section-label{font-family:var(--font-m);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.2rem;display:flex;align-items:center;gap:.7rem}.section-label:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}.what-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2.5rem}.what-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);position:relative;overflow:hidden}.what-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(129,140,248,.04),transparent);opacity:0;transition:opacity var(--transition);pointer-events:none}.what-card:hover{border-color:var(--primary-border);transform:translateY(-4px);box-shadow:0 14px 44px #00000059,0 0 0 1px var(--primary-border)}.what-card:hover:after{opacity:1}.what-card-clickable{cursor:pointer}.what-read-more{margin-top:.75rem;font-size:.72rem;font-family:var(--font-m);letter-spacing:.08em;color:var(--primary);display:flex;align-items:center;gap:.35rem;opacity:0;transform:translate(-4px);transition:opacity var(--transition),transform var(--transition)}.what-card-clickable:hover .what-read-more{opacity:1;transform:translate(0)}.what-icon{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0;position:relative;z-index:1}.wi-orange{background:var(--primary-glow);color:var(--primary)}.wi-blue{background:var(--cyan-glow);color:var(--cyan)}.wi-green{background:var(--emerald-glow);color:var(--emerald)}.wi-purple{background:var(--rose-glow);color:var(--rose)}.what-title{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--white);margin-bottom:.35rem;position:relative;z-index:1}.what-desc{font-size:.82rem;color:var(--text-dim);line-height:1.65;position:relative;z-index:1}.cert-row{display:flex;gap:1rem;flex-wrap:wrap}.cert-card{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.1rem 1.4rem;flex:1;min-width:220px;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.cert-card:hover{border-color:#fbbf2466;transform:translateY(-2px);box-shadow:0 8px 28px #00000047}.cert-badge{width:46px;height:46px;border-radius:var(--radius-sm);background:var(--amber-glow);display:flex;align-items:center;justify-content:center;color:var(--amber);font-size:1.3rem;flex-shrink:0}.cert-name{font-family:var(--font-h);font-size:.88rem;font-weight:700;color:var(--white)}.cert-issuer{font-family:var(--font-m);font-size:.6rem;color:var(--text-muted);letter-spacing:.08em;margin-top:.28rem}.timeline{margin-bottom:3rem}.timeline-title{font-family:var(--font-m);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--primary);margin-bottom:1.6rem;display:flex;align-items:center;gap:.55rem}.timeline-title i{color:var(--primary);font-size:.75rem}.tl-item{display:grid;grid-template-columns:110px 20px 1fr;gap:0 1rem;position:relative;padding-bottom:2.5rem}.tl-item:not(:last-child):after{content:"";position:absolute;left:128px;top:18px;bottom:0;width:1px;background:linear-gradient(180deg,var(--primary-dark) 0%,rgba(99,102,241,.08) 100%)}.tl-date{font-family:var(--font-m);font-size:.63rem;color:var(--text-muted);text-align:right;line-height:1.4;padding-top:2px}.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--primary);border:2px solid var(--bg);box-shadow:0 0 0 3px var(--primary-glow),0 0 16px var(--primary-glow);justify-self:center;margin-top:4px;flex-shrink:0;position:relative;z-index:1}.tl-content{padding-left:.25rem}.tl-role{font-family:var(--font-h);font-size:.97rem;font-weight:700;color:var(--white);margin-bottom:.15rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.tl-current-badge{font-family:var(--font-m);font-size:.56rem;letter-spacing:.1em;background:var(--emerald-glow);color:var(--emerald);border:1px solid rgba(52,211,153,.3);border-radius:99px;padding:.14rem .6rem;text-transform:uppercase}.tl-company{font-family:var(--font-m);font-size:.72rem;color:var(--primary);margin-bottom:.9rem}.tl-bullets{list-style:none;display:flex;flex-direction:column;gap:.55rem;margin-bottom:.9rem}.tl-bullets li{font-size:.85rem;color:var(--text-dim);padding-left:1.1rem;position:relative;line-height:1.62}.tl-bullets li:before{content:"▸";position:absolute;left:0;color:var(--primary);font-size:.66rem;top:.18rem}.tl-tags{display:flex;flex-wrap:wrap;gap:.35rem}.tl-tag{font-family:var(--font-m);font-size:.6rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);padding:.18rem .55rem;color:var(--text-muted);transition:var(--transition)}.tl-tag:hover{border-color:var(--primary-border);color:var(--primary);background:var(--primary-glow)}.edu-card{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.2rem 1.5rem;transition:border-color var(--transition),transform var(--transition)}.edu-card:hover{border-color:#22d3ee59;transform:translateY(-2px)}.edu-icon{width:46px;height:46px;border-radius:var(--radius-sm);background:var(--cyan-glow);display:flex;align-items:center;justify-content:center;color:var(--cyan);font-size:1.1rem;flex-shrink:0}.edu-degree{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--white)}.edu-school{font-family:var(--font-m);font-size:.7rem;color:var(--cyan);margin:.15rem 0}.edu-meta{font-family:var(--font-m);font-size:.62rem;color:var(--text-muted);letter-spacing:.06em}.proj-filter{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}.filter-btn{font-family:var(--font-b);font-size:.78rem;font-weight:500;padding:.45rem 1.1rem;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;transition:var(--transition)}.filter-btn:hover{border-color:var(--primary-border);color:var(--primary)}.filter-btn.active{background:linear-gradient(135deg,var(--primary-dark),var(--primary));border-color:transparent;color:#fff;box-shadow:0 4px 18px var(--primary-glow)}.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}.proj-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);display:flex;flex-direction:column;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);overflow:hidden;transform-style:preserve-3d;will-change:transform;position:relative}.proj-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-dark),var(--cyan));opacity:0;transition:opacity var(--transition);z-index:1}.proj-card:hover{border-color:var(--primary-border);transform:translateY(-5px);box-shadow:0 20px 56px #00000073,0 0 0 1px var(--primary-border)}.proj-card:hover:before{opacity:1}.proj-card.hidden{display:none}.proj-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.3rem 1.3rem .9rem}.proj-cat-badge{font-family:var(--font-m);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .65rem;border-radius:99px;border:1px solid}.proj-cat-badge.badge-orange{background:var(--primary-glow);color:var(--primary);border-color:var(--primary-border)}.proj-cat-badge.badge-blue{background:var(--cyan-glow);color:var(--cyan);border-color:#22d3ee4d}.proj-cat-badge.badge-green{background:var(--emerald-glow);color:var(--emerald);border-color:#34d3994d}.proj-cat-badge.badge-purple{background:var(--rose-glow);color:var(--rose);border-color:#f472b64d}.proj-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem}.proj-links{display:flex;gap:.4rem}.proj-link-btn{width:30px;height:30px;border-radius:var(--radius-xs);background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:.8rem;transition:var(--transition)}.proj-link-btn:hover{color:var(--primary);border-color:var(--primary-border);background:var(--primary-glow)}.proj-body{padding:0 1.3rem 1.3rem;display:flex;flex-direction:column;flex:1}.proj-name{font-family:var(--font-h);font-size:.95rem;font-weight:700;color:var(--white);margin-bottom:.5rem;line-height:1.3}.proj-desc{font-size:.82rem;color:var(--text-dim);line-height:1.68;flex:1;margin-bottom:1rem}.proj-footer{margin-top:auto}.proj-techs{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem}.proj-tech{font-family:var(--font-m);font-size:.6rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);padding:.18rem .52rem;color:var(--text-muted);transition:var(--transition)}.proj-tech:hover{color:var(--primary);border-color:var(--primary-border);background:var(--primary-glow)}.proj-metric{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-m);font-size:.6rem;background:var(--emerald-glow);color:var(--emerald);border:1px solid rgba(52,211,153,.3);border-radius:99px;padding:.2rem .7rem}.skills-section{margin-bottom:2.5rem}.skills-section-title{font-family:var(--font-m);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--primary);margin-bottom:1rem;display:flex;align-items:center;gap:.6rem}.skills-section-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--primary-border),transparent)}.skills-chips{display:flex;flex-wrap:wrap;gap:.5rem}.skill-chip{display:flex;align-items:center;gap:.45rem;font-family:var(--font-m);font-size:.7rem;padding:.42rem .9rem;border-radius:99px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);transition:var(--transition);cursor:default}.skill-chip:hover{transform:translateY(-2px);box-shadow:0 4px 18px #00000047}.chip-orange:hover{background:var(--primary-glow);color:var(--primary);border-color:var(--primary-border)}.chip-green:hover{background:var(--emerald-glow);color:var(--emerald);border-color:#34d3994d}.chip-purple:hover{background:var(--rose-glow);color:var(--rose);border-color:#f472b64d}.chip-blue:hover{background:var(--cyan-glow);color:var(--cyan);border-color:#22d3ee4d}.chip-yellow:hover{background:var(--amber-glow);color:var(--amber);border-color:#fbbf244d}.bar-grid{display:flex;flex-direction:column;gap:1.2rem}.bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.bar-name{font-family:var(--font-b);font-size:.85rem;font-weight:500;color:var(--text)}.bar-pct{font-family:var(--font-m);font-size:.72rem;color:var(--primary);font-weight:500}.bar-track{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden;border:1px solid var(--border)}.bar-fill{height:100%;border-radius:99px;width:0;transition:width 1.2s cubic-bezier(.4,0,.2,1);background:linear-gradient(90deg,var(--primary-dark),var(--cyan))}.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}.blog-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.6rem;display:flex;flex-direction:column;gap:.65rem;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.blog-card:hover{border-color:var(--primary-border);transform:translateY(-4px);box-shadow:0 14px 40px #00000052}.blog-cat{font-family:var(--font-m);font-size:.58rem;letter-spacing:.1em;font-weight:600;padding:.2rem .65rem;border-radius:var(--radius-xs);display:inline-block;align-self:flex-start;text-transform:uppercase}.bc-orange{background:var(--primary-glow);color:var(--primary)}.bc-blue{background:var(--cyan-glow);color:var(--cyan)}.bc-green{background:var(--emerald-glow);color:var(--emerald)}.bc-purple{background:var(--rose-glow);color:var(--rose)}.blog-title{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--white);line-height:1.45}.blog-excerpt{font-size:.82rem;color:var(--text-dim);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.blog-meta{font-family:var(--font-m);font-size:.6rem;color:var(--text-muted);letter-spacing:.06em}.blog-read{font-family:var(--font-m);font-size:.68rem;color:var(--primary);letter-spacing:.06em;display:inline-flex;align-items:center;gap:.4rem;margin-top:auto;background:none;border:none;cursor:pointer;padding:0;transition:gap var(--transition),color var(--transition)}.blog-read:hover{gap:.72rem;color:var(--cyan)}.blog-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;pointer-events:none}.blog-modal.open{pointer-events:all}.blog-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);transition:background .4s ease,backdrop-filter .4s ease}.blog-modal.open .blog-modal-backdrop{background:#000000b8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.blog-modal-panel{position:absolute;top:0;right:0;bottom:0;width:min(740px,100%);background:var(--surface);border-left:1px solid var(--glass-border);overflow-y:auto;padding:2rem 2.5rem 4rem;transform:translate(100%);transition:transform .42s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.blog-modal.open .blog-modal-panel{transform:translate(0)}.blog-modal-panel:before{content:"";position:sticky;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-dark),var(--cyan),transparent);flex-shrink:0;display:block;margin:-2rem -2.5rem 0}.blog-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-size:.9rem;cursor:pointer;transition:var(--transition);align-self:flex-end;flex-shrink:0;margin-bottom:1.8rem;margin-top:.5rem}.blog-modal-close:hover{background:#f472b61f;border-color:#f472b666;color:var(--rose);transform:rotate(90deg)}.bm-header{margin-bottom:2rem}.bm-title{font-family:var(--font-h);font-size:clamp(1.3rem,3vw,1.9rem);font-weight:800;color:var(--white);line-height:1.25;letter-spacing:-.02em;margin:.75rem 0 1rem}.bm-meta{display:flex;flex-wrap:wrap;gap:1rem;font-family:var(--font-m);font-size:.68rem;color:var(--text-muted);letter-spacing:.05em}.bm-meta i{margin-right:.3rem;color:var(--primary)}.bm-content{font-size:.93rem;line-height:1.82;color:var(--text-dim)}.bm-content p{margin-bottom:1.2rem}.bm-content h2{font-family:var(--font-h);font-size:1.1rem;font-weight:700;color:var(--white);margin:2rem 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.bm-content strong{color:var(--primary);font-weight:600}.bm-content ul{list-style:none;margin:.5rem 0 1.2rem;display:flex;flex-direction:column;gap:.45rem}.bm-content ul li{padding-left:1.2rem;position:relative}.bm-content ul li:before{content:"▸";position:absolute;left:0;color:var(--primary);font-size:.7rem;top:.2rem}.bm-content pre{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.2rem 1.4rem;overflow-x:auto;margin:.5rem 0 1.4rem;position:relative}.bm-content pre:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-dark),var(--cyan),transparent);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.bm-content code{font-family:var(--font-m);font-size:.8rem;color:var(--cyan);line-height:1.7;white-space:pre}.bm-content p code,.bm-content li code{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);padding:.1rem .45rem;font-size:.8rem;color:var(--rose);white-space:nowrap}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.contact-card{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.1rem 1.4rem;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.contact-card:hover{border-color:var(--primary-border);transform:translateY(-2px);box-shadow:0 10px 32px #0000004d}.cc-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.cc-label{font-family:var(--font-m);font-size:.57rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.cc-val{font-size:.82rem;color:var(--text);margin-top:.12rem}.alert{display:none;align-items:center;gap:1rem;padding:1rem 1.3rem;border-radius:var(--radius);border:1px solid;margin-bottom:1.2rem;font-size:.87rem}.alert.show{display:flex}.alert-success{background:var(--emerald-glow);border-color:#34d3994d;color:var(--emerald)}.alert-error{background:#f8514914;border-color:#f851494d;color:#f87171}.alert-icon{font-size:1.2rem;flex-shrink:0}.alert-title{font-weight:600;margin-bottom:.15rem}.alert-desc{font-size:.82rem;opacity:.85}.contact-form{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:2rem 2.2rem;position:relative;overflow:hidden}.contact-form:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(129,140,248,.3),rgba(34,211,238,.2),transparent)}.form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.8rem;flex-wrap:wrap;gap:.5rem}.form-header h3{font-family:var(--font-h);font-size:1.05rem;font-weight:700;color:var(--white)}.form-badges{display:flex;gap:.5rem;flex-wrap:wrap}.form-badge{font-family:var(--font-m);font-size:.6rem;letter-spacing:.06em;padding:.25rem .75rem;border-radius:99px;border:1px solid;display:flex;align-items:center;gap:.35rem}.fb-orange{background:var(--amber-glow);color:var(--amber);border-color:#fbbf244d}.fb-blue{background:var(--cyan-glow);color:var(--cyan);border-color:#22d3ee4d}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.fg{display:flex;flex-direction:column;gap:.45rem}.fg label{font-family:var(--font-m);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.fg input,.fg textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;color:var(--text);font-family:var(--font-b);font-size:.875rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}.fg textarea{resize:vertical;min-height:130px}.fg input::placeholder,.fg textarea::placeholder{color:var(--text-muted);opacity:.65}.fg input:focus,.fg textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.form-submit{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.88rem 2rem;background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-b);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:0 4px 24px var(--primary-glow),0 0 0 1px #818cf833;width:100%;margin-bottom:1rem}.form-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 40px var(--primary-glow),0 0 0 1px #818cf84d}.form-submit:disabled{opacity:.5;cursor:not-allowed}.form-note{font-family:var(--font-m);font-size:.6rem;color:var(--text-muted);letter-spacing:.07em;text-align:center}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.45);opacity:.5}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px var(--primary-glow)}50%{box-shadow:0 0 40px var(--primary-glow),0 0 80px var(--primary-glow)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.reveal{opacity:0;transform:translateY(24px)}.reveal.visible{opacity:1;transform:translateY(0);transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1)}.tilt-wrapper{transform-style:preserve-3d}.skill-chip{opacity:0;transform:scale(.85) translateY(10px)}.skill-chip.chip-visible{opacity:1;transform:scale(1) translateY(0);transition:opacity .35s ease,transform .35s ease}.hero-avatar,.hero-name,.hero-typed-wrap,.hero-meta,.hero-ctas,.hero-scroll{opacity:0}@media (max-width: 1280px){.proj-grid,.blog-grid{grid-template-columns:1fr 1fr}}@media (max-width: 1024px){.sidebar{transform:translate(-100%);box-shadow:4px 0 40px #0009}.sidebar.open{transform:translate(0)}.hamburger{display:flex}.main{margin-left:0}.page{padding:5rem 2rem 3.5rem}.hero{padding-left:2rem}.hero-content{padding:0 1rem}.hero-scroll{left:50%}}@media (max-width: 1024px){.blog-modal-panel{width:100%}}@media (max-width: 768px){.what-grid,.proj-grid,.blog-grid,.contact-grid,.form-grid{grid-template-columns:1fr}.cert-row{flex-direction:column}.page{padding:4.5rem 1.2rem 3rem}.page-title{font-size:1.85rem}.tl-item{grid-template-columns:80px 16px 1fr;gap:0 .7rem}.tl-item:not(:last-child):after{left:95px}.hero-ctas{flex-direction:column;align-items:center}.contact-form{padding:1.4rem}.form-header{flex-direction:column;align-items:flex-start}.blog-modal-panel{padding:1.5rem 1.2rem 4rem}.bm-title{font-size:1.25rem}}@media (max-width: 480px){.hero{min-height:100svh}.tl-item{grid-template-columns:65px 14px 1fr}.tl-date{font-size:.58rem}.page{padding:4rem 1rem 3rem}.page-title{font-size:1.6rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}.reveal,.skill-chip{opacity:1;transform:none}.hero-avatar,.hero-name,.hero-typed-wrap,.hero-meta,.hero-ctas,.hero-scroll{opacity:1}}
