:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-card:#1e293b;--bg-hover:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#38bdf8;--accent-secondary:#818cf8;--accent-glow:#38bdf826;--border:#334155;--success:#34d399;--warning:#fbbf24;--max-width:1100px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--header-height)}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-secondary)}img{max-width:100%}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.section{padding:5rem 0}.section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:inline-block}.section-title{color:var(--text-primary);margin-bottom:3rem;font-size:2rem;font-weight:700}@media (width<=768px){.section{padding:3rem 0}.section-title{margin-bottom:2rem;font-size:1.6rem}}.header{height:var(--header-height);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;background:#0f172ad9;position:fixed;top:0;left:0;right:0}.header-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.header-logo{color:var(--accent);letter-spacing:-.02em;font-size:1.3rem;font-weight:800}.header-nav{gap:.25rem;display:flex}.header-link{color:var(--text-secondary);border-radius:6px;padding:.5rem .85rem;font-size:.875rem;font-weight:500;transition:color .2s,background .2s}.header-link:hover{color:var(--text-primary);background:var(--bg-hover)}.hero{min-height:100vh;padding-top:var(--header-height);align-items:center;display:flex}.hero-content{max-width:720px}.hero-greeting{color:var(--accent);margin-bottom:1rem;font-size:1rem;font-weight:500}.hero-name{letter-spacing:-.02em;background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:3.5rem;font-weight:800;line-height:1.1}.hero-title{color:var(--text-secondary);margin-bottom:1.5rem;font-size:2rem;font-weight:600}.hero-summary{color:var(--text-secondary);max-width:600px;margin-bottom:2.5rem;font-size:1.1rem;line-height:1.7}.hero-actions{gap:1rem;margin-bottom:2.5rem;display:flex}.hero-links{gap:1rem;display:flex}.hero-link{width:40px;height:40px;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.hero-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-glow)}.btn{cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{color:#0f172a;background:var(--accent)}.btn-primary:hover{box-shadow:0 0 20px var(--accent-glow);background:#7dd3fc}.btn-secondary{color:var(--accent);border-color:var(--accent);background:0 0}.btn-secondary:hover{background:var(--accent-glow)}.btn-large{padding:1rem 2.5rem;font-size:1.05rem}.strengths-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;display:grid}.strength-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.75rem;transition:transform .2s,border-color .2s,box-shadow .2s}.strength-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 30px #38bdf814}.strength-icon{margin-bottom:1rem;font-size:1.75rem;display:block}.strength-title{margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.strength-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.skill-group{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.skill-category{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:1rem;font-size:.85rem;font-weight:600}.skill-items{flex-wrap:wrap;gap:.5rem;display:flex}.skill-tag{color:var(--text-primary);background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;padding:.35rem .85rem;font-size:.85rem;font-weight:500;transition:border-color .2s,color .2s;display:inline-block}.skill-tag:hover{border-color:var(--accent);color:var(--accent)}.skill-tag-link{cursor:pointer;scroll-margin-top:calc(var(--header-height) + 1rem)}.timeline{position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:0}.timeline-item{padding-bottom:2.5rem;padding-left:2rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{background:var(--accent);border:2px solid var(--bg-primary);width:12px;height:12px;box-shadow:0 0 0 2px var(--accent);border-radius:50%;position:absolute;top:4px;left:-5px}.timeline-content{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:border-color .2s}.timeline-content:hover{border-color:var(--accent)}.timeline-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.25rem;display:flex}.timeline-company{font-size:1.2rem;font-weight:700}.timeline-period{color:var(--text-muted);white-space:nowrap;padding-top:.2rem;font-size:.85rem}.timeline-role{color:var(--accent);margin-bottom:1rem;font-size:.95rem;font-weight:500}.timeline-highlights{flex-direction:column;gap:.5rem;list-style:none;display:flex}.timeline-highlights li{color:var(--text-secondary);padding-left:1.25rem;font-size:.9rem;line-height:1.6;position:relative}.timeline-highlights li:before{content:"▹";color:var(--accent);position:absolute;left:0}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.75rem;transition:transform .2s,border-color .2s}.project-card:hover{border-color:var(--accent);transform:translateY(-4px)}.project-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.project-folder{color:var(--accent)}.project-link{color:var(--text-secondary);transition:color .2s}.project-link:hover{color:var(--accent)}.project-name{margin-bottom:.75rem;font-size:1.15rem;font-weight:600}.project-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.edu-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;gap:1.5rem;max-width:600px;padding:2rem;transition:border-color .2s;display:flex}.edu-card:hover{border-color:var(--accent)}.edu-icon{background:var(--accent-glow);width:56px;height:56px;color:var(--accent);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.edu-degree{margin-bottom:.3rem;font-size:1.15rem;font-weight:600}.edu-school{color:var(--text-secondary);margin-bottom:.2rem;font-size:.95rem}.edu-year{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem}.edu-accred{color:var(--success);background:#34d3991a;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.playground-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:flex-start;display:flex}.playground-toggle{border:1px solid var(--border);color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;margin-top:.3rem;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s}.playground-toggle:hover{background:var(--accent-glow);border-color:var(--accent)}.vim-intro{color:var(--text-secondary);max-width:700px;margin-bottom:1.5rem;font-size:.95rem;line-height:1.7}.vim-intro kbd{color:var(--text-primary);background:var(--bg-hover);border:1px solid var(--border);box-shadow:0 1px 0 var(--border);border-radius:4px;padding:.15rem .5rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;display:inline-block}.vim-container{border:1px solid #162240;border-radius:12px;overflow:hidden}.vim-header{background:#0b1120;border-bottom:1px solid #162240;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.vim-mode{letter-spacing:.05em;color:#0f172a;text-align:center;border-radius:4px;min-width:60px;padding:.2rem .6rem;font-size:.75rem;font-weight:700;transition:background-color .15s}.vim-filename{color:var(--text-muted);flex:1;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem}.vim-actions{gap:.5rem;display:flex}.vim-btn{color:var(--text-secondary);background:var(--bg-hover);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.3rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s}.vim-btn:hover{color:var(--text-primary);border-color:var(--accent)}.vim-btn-reset:hover{color:#f87171;border-color:#f87171}.vim-editor .cm-editor{height:500px;max-height:70vh}.vim-editor .cm-editor .cm-scroller{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace}.vim-body.vim-split{display:flex}.vim-body.vim-split .vim-editor{border-right:1px solid #162240;width:50%}.vim-body.vim-split .vim-preview{width:50%}.vim-preview{background:#0b1120;height:500px;max-height:70vh;overflow-y:auto}.vim-btn-active{color:var(--accent);border-color:var(--accent);background:var(--accent-glow)}.markdown-body{color:#e2e8f0;padding:1.5rem;font-size:.9rem;line-height:1.7}.markdown-body h1,.markdown-body h2,.markdown-body h3{color:#f1f5f9;margin:1.5rem 0 .5rem}.markdown-body h1{border-bottom:1px solid #162240;padding-bottom:.3rem;font-size:1.5rem}.markdown-body h2{font-size:1.2rem}.markdown-body h3{color:#38bdf8;font-size:1rem}.markdown-body p{margin:.5rem 0}.markdown-body ul{margin:.25rem 0;padding-left:1.5rem}.markdown-body li{margin:.15rem 0}.markdown-body code{background:#1e293b;border-radius:4px;padding:.1rem .4rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85em}.markdown-body pre{background:#1e293b;border-radius:8px;padding:1rem;overflow-x:auto}.terminal-intro{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.7}.terminal-intro kbd{color:var(--text-primary);background:var(--bg-hover);border:1px solid var(--border);border-radius:4px;padding:.15rem .5rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;display:inline-block}.terminal-container{cursor:text;background:#0a0e1a;border:1px solid #162240;border-radius:12px;overflow:hidden}.terminal-output{white-space:pre-wrap;word-break:break-all;scrollbar-width:thin;scrollbar-color:#1e293b transparent;max-height:500px;padding:1.25rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;line-height:1.6;overflow-y:auto}.terminal-prompt{color:#34d399;-webkit-user-select:none;user-select:none}.terminal-input,.terminal-output .terminal-input{color:#e2e8f0;font-family:inherit;font-size:inherit;line-height:inherit;caret-color:#e2e8f0;background:0 0;border:none;outline:none;width:calc(100% - 1.5rem);padding:0}.terminal-line{align-items:center;display:flex}.terminal-input{flex:1}.terminal-output .terminal-output{color:#94a3b8}.contact{text-align:center}.contact-content{max-width:600px;margin:0 auto}.contact-title{margin-bottom:1rem;font-size:2rem;font-weight:700}.contact-text{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem;line-height:1.7}.contact-details{justify-content:center;align-items:center;gap:.5rem;margin-top:2rem;font-size:.9rem;display:flex}.contact-item{color:var(--text-secondary);transition:color .2s}.contact-item:hover{color:var(--accent)}.contact-sep{color:var(--text-muted)}.footer{border-top:1px solid var(--border);text-align:center;padding:2rem 0}.footer-text{color:var(--text-muted);font-size:.8rem;line-height:1.8}@media (width<=768px){.header-nav{display:none}.hero-name{font-size:2.4rem}.hero-title{font-size:1.35rem}.hero-summary{font-size:1rem}.hero-actions{flex-direction:column}.skills-grid,.projects-grid,.strengths-grid{grid-template-columns:1fr}.timeline-header{flex-direction:column;gap:.25rem}.edu-card{flex-direction:column;align-items:flex-start}.contact-details{flex-direction:column;gap:.5rem}.contact-sep{display:none}.vim-header{flex-wrap:wrap}.vim-filename{order:-1;width:100%}.vim-editor .cm-editor{height:350px}.vim-body.vim-split{flex-direction:column}.vim-body.vim-split .vim-editor,.vim-body.vim-split .vim-preview{border-right:none;width:100%}.vim-body.vim-split .vim-editor{border-bottom:1px solid #162240}.vim-preview{height:350px}.terminal-output{max-height:350px;padding:1rem;font-size:.8rem}}@media (width>=769px) and (width<=1024px){.skills-grid,.projects-grid,.strengths-grid{grid-template-columns:repeat(2,1fr)}}
