@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Mono:wght@300;400;500&family=DM+Sans:wght@300;400;500&display=swap";:root{--bg: #0a0a0b;--bg-2: #111114;--bg-3: #18181d;--border: #232329;--border-2: #2e2e38;--text: #e8e8ed;--text-2: #9898a8;--text-3: #5a5a68;--accent: #4f8ef7;--accent-2: #3a6fd8;--accent-glow: rgba(79, 142, 247, .15);--highlight: #f7c24f;--success: #4fd48e;--sidebar-w: 260px;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.7;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:#fff}img{max-width:100%}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--bg-2);border-right:1px solid var(--border);position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100;display:flex;flex-direction:column;padding:0 0 2rem;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh}.sidebar-profile{padding:2rem 1.5rem 1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center}.sidebar-avatar{width:64px;height:64px;border-radius:50%;background:var(--bg-3);border:2px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--accent);margin-bottom:1rem;letter-spacing:1px;overflow:hidden;padding:0}.sidebar-name{font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:.3rem}.sidebar-title{font-size:.72rem;color:var(--text-3);font-family:var(--font-mono);line-height:1.4}.sidebar-actions{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .9rem;border-radius:6px;font-size:.8rem;font-weight:500;font-family:var(--font-body);transition:all .2s;cursor:pointer;border:none;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-2);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border-2);color:var(--text-2)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.sidebar-nav{padding:1.5rem 0;flex:1}.nav-section-label{font-size:.65rem;font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.12em;padding:0 1.5rem;margin-bottom:.5rem;margin-top:1.2rem}.nav-link{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.5rem;font-size:.85rem;color:var(--text-2);transition:all .2s;border-left:2px solid transparent}.nav-link:hover,.nav-link.active{color:var(--text);background:var(--accent-glow);border-left-color:var(--accent)}.nav-link svg{opacity:.6;flex-shrink:0}.sidebar-footer{padding:1rem 1.5rem 0;border-top:1px solid var(--border);display:flex;gap:.75rem}.sidebar-footer a{color:var(--text-3);font-size:.8rem;transition:color .2s}.sidebar-footer a:hover{color:var(--accent)}.page-section{padding:3.5rem 3rem;border-bottom:1px solid var(--border);max-width:900px}.page-section:last-child{border-bottom:none}.section-label{font-size:.65rem;font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.5rem}.section-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:1.5rem;line-height:1.2}.hero-section{padding:4rem 3rem 3.5rem;border-bottom:1px solid var(--border);position:relative;overflow:hidden}.hero-section:before{content:"";position:absolute;top:-80px;right:-80px;width:350px;height:350px;background:radial-gradient(circle,rgba(79,142,247,.08) 0%,transparent 70%);pointer-events:none}.hero-tag{display:inline-flex;align-items:center;gap:.4rem;background:var(--accent-glow);border:1px solid rgba(79,142,247,.25);color:var(--accent);font-size:.72rem;font-family:var(--font-mono);padding:.3rem .7rem;border-radius:20px;margin-bottom:1.2rem;letter-spacing:.05em}.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.hero-name{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:var(--text);line-height:1.2;margin-bottom:.5rem;letter-spacing:0}.hero-subtitle{font-size:1rem;color:var(--text-2);margin-bottom:1.5rem;font-weight:300;max-width:520px}.hero-summary-card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:1.3rem 1.5rem;margin-bottom:1.5rem;max-width:860px}.hero-summary{font-size:.9rem;color:var(--text-2);line-height:1.8;margin:0}.hero-meta{display:flex;flex-wrap:wrap;gap:1.2rem}.hero-meta-item{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-3);font-family:var(--font-mono)}.hero-meta-item svg{color:var(--accent)}.timeline{position:relative;padding-left:1.5rem}.timeline:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:var(--border-2)}.timeline-item{position:relative;padding-bottom:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-1.5rem;top:6px;width:10px;height:10px;border-radius:50%;background:var(--bg-2);border:2px solid var(--border-2);transform:translate(-4px)}.timeline-item.current .timeline-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.timeline-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.3rem}.timeline-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text)}.timeline-badge{font-size:.68rem;font-family:var(--font-mono);background:#4fd48e1a;color:var(--success);border:1px solid rgba(79,212,142,.25);padding:.15rem .55rem;border-radius:20px}.timeline-org{font-size:.85rem;color:var(--accent);margin-bottom:.2rem;font-weight:500}.timeline-meta{display:flex;gap:1rem;font-size:.75rem;color:var(--text-3);font-family:var(--font-mono);margin-bottom:1rem}.timeline-desc{font-size:.875rem;color:var(--text-2);line-height:1.7;margin-bottom:.8rem}.timeline-achievements{margin-bottom:.8rem}.timeline-achievements summary{font-size:.8rem;color:var(--text-3);font-family:var(--font-mono);cursor:pointer;user-select:none;margin-bottom:.6rem}.timeline-achievements summary:hover{color:var(--accent)}.achievement-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;padding-top:.4rem}.achievement-list li{font-size:.82rem;color:var(--text-2);padding-left:1rem;position:relative}.achievement-list li:before{content:"→";position:absolute;left:0;color:var(--accent);font-size:.75rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}.tech-tag{font-size:.7rem;font-family:var(--font-mono);background:var(--bg-3);border:1px solid var(--border);color:var(--text-3);padding:.2rem .55rem;border-radius:4px}.cert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.cert-card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:1.2rem;display:flex;gap:1rem;align-items:flex-start;transition:border-color .2s}.cert-card:hover{border-color:var(--border-2)}.cert-card.major{border-color:#4f8ef74d;background:#4f8ef70a}.cert-card.major:hover{border-color:var(--accent)}.cert-badge-img{width:48px;height:48px;border-radius:8px;object-fit:contain;background:var(--bg-3);flex-shrink:0}.cert-badge-placeholder{width:48px;height:48px;border-radius:8px;background:var(--bg-3);border:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.cert-info{flex:1;min-width:0}.cert-title{font-size:.85rem;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:.25rem}.cert-meta{font-size:.72rem;color:var(--text-3);font-family:var(--font-mono)}.cert-issuer{color:var(--accent)}.major-label{display:inline-block;font-size:.62rem;font-family:var(--font-mono);background:#f7c24f1f;color:var(--highlight);border:1px solid rgba(247,194,79,.25);padding:.1rem .45rem;border-radius:3px;margin-bottom:.3rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.gallery-item{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .2s,transform .2s;cursor:pointer}.gallery-item:hover{border-color:var(--border-2);transform:translateY(-2px)}.gallery-img-wrap{aspect-ratio:4/3;overflow:hidden;background:var(--bg-3);position:relative}.gallery-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.gallery-item:hover .gallery-img-wrap img{transform:scale(1.03)}.gallery-info{padding:.9rem 1rem}.gallery-title{font-size:.83rem;font-weight:600;color:var(--text);margin-bottom:.2rem}.gallery-meta{font-size:.7rem;color:var(--text-3);font-family:var(--font-mono)}.gallery-desc{font-size:.75rem;color:var(--text-3);margin-top:.35rem;line-height:1.5}.modal-overlay{display:none;position:fixed;inset:0;background:#000000d9;z-index:1000;align-items:center;justify-content:center;padding:2rem}.modal-overlay.open{display:flex}.modal-img{max-width:90vw;max-height:85vh;border-radius:8px;box-shadow:0 20px 60px #00000080}.modal-close{position:fixed;top:1.5rem;right:1.5rem;background:var(--bg-2);border:1px solid var(--border-2);color:var(--text);width:36px;height:36px;border-radius:50%;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:var(--bg-3)}.edu-card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:1.3rem 1.5rem}.edu-degree{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.3rem}.edu-school{font-size:.85rem;color:var(--accent);margin-bottom:.2rem}.edu-loc{font-size:.75rem;color:var(--text-3);font-family:var(--font-mono)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.skill-category{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:1.1rem 1.2rem}.skill-cat-title{font-size:.72rem;font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.7rem}.skill-list{list-style:none;display:flex;flex-direction:column;gap:.35rem}.skill-list li{font-size:.82rem;color:var(--text-2)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-2);border-bottom:1px solid var(--border);z-index:200;padding:0 1rem;align-items:center;justify-content:space-between}.mobile-name{font-family:var(--font-display);font-size:.9rem;font-weight:700}.hamburger{background:none;border:none;color:var(--text);cursor:pointer;padding:.3rem}@media(max-width:768px){:root{--sidebar-w: 0px}.mobile-header{display:flex}.sidebar{transform:translate(-100%);width:260px;transition:transform .3s ease;top:56px;height:calc(100vh - 56px)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding-top:56px}.page-section,.hero-section{padding:2rem 1.2rem}.cert-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}
