@import"https://fonts.googleapis.com/css2?family=DM+Mono:ital,wght@0,300;0,400;0,500;1,400&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--bg-surface: #111118;--bg-card: #16161e;--bg-card-hover: #1c1c26;--border: rgba(255, 255, 255, .07);--border-hover: rgba(255, 255, 255, .14);--text-primary: #f0f0f5;--text-secondary: #8a8a9a;--text-muted: #4a4a60;--accent: #5eead4;--accent-dim: rgba(94, 234, 212, .12);--accent-glow: rgba(94, 234, 212, .06);--font-mono: "DM Mono", "Fira Code", monospace;--font-sans: "DM Sans", system-ui, sans-serif;--nav-h: 68px;--section-pad: clamp(80px, 10vw, 120px);--card-radius: 14px;--ease: cubic-bezier(.25, .1, .25, 1)}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}body{font-family:var(--font-sans);background:var(--bg);color:var(--text-primary);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{text-decoration:none;color:inherit}ul{list-style:none}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);transition:background .35s var(--ease),border-color .35s var(--ease),backdrop-filter .35s var(--ease);border-bottom:1px solid transparent}.navbar.scrolled{background:#0a0a0fd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-color:var(--border)}.nav-container{max-width:1120px;margin:0 auto;padding:0 clamp(20px,5vw,48px);height:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-mono);font-size:1rem;font-weight:500;letter-spacing:-.01em;color:var(--text-primary);transition:color .2s}.nav-logo:hover,.logo-bracket{color:var(--accent)}.logo-name{color:var(--text-primary)}.nav-links.desktop{display:flex;align-items:center;gap:32px}.nav-link{font-family:var(--font-mono);font-size:.8rem;font-weight:400;letter-spacing:.04em;color:var(--text-secondary);transition:color .2s;position:relative}.nav-link:after{content:"";position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{transform:scaleX(1)}.nav-resume-btn{font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:.04em;color:var(--accent);border:1px solid rgba(94,234,212,.35);padding:6px 18px;border-radius:6px;transition:background .2s,border-color .2s}.nav-resume-btn:hover{background:var(--accent-dim);border-color:var(--accent)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.hamburger span{display:block;width:22px;height:1.5px;background:var(--text-secondary);border-radius:2px;transition:transform .3s var(--ease),opacity .3s}.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{background:#0a0a0ff5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);display:flex;flex-direction:column;padding:20px clamp(20px,5vw,48px);gap:4px;overflow:hidden}.mobile-menu a{font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary);padding:12px 0;border-bottom:1px solid var(--border);transition:color .2s}.mobile-menu a:hover{color:var(--accent)}.mobile-menu .mobile-resume{color:var(--accent);border-bottom:none;margin-top:8px}.section{padding-top:var(--section-pad);padding-bottom:var(--section-pad);padding-left:clamp(20px,5vw,48px);padding-right:clamp(20px,5vw,48px);max-width:1120px;margin:0 auto}.hero{min-height:100vh;padding-top:calc(var(--nav-h) + 60px);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.hero-grid-bg{position:fixed;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0;mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.4) 0%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.4) 0%,transparent 70%)}.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.hero-content{display:flex;flex-direction:column;gap:20px}.hero-eyebrow{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);letter-spacing:.08em}.hero-name{font-family:var(--font-mono);font-size:clamp(3rem,6vw,5rem);font-weight:500;line-height:1;letter-spacing:-.03em;color:var(--text-primary)}.hero-name-accent{color:var(--accent)}.hero-title{font-family:var(--font-sans);font-size:clamp(1.1rem,2.5vw,1.4rem);font-weight:300;color:var(--text-secondary);letter-spacing:.01em}.hero-bio{font-size:1rem;color:var(--text-secondary);line-height:1.8;max-width:480px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:4px}.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#0a0a0f;font-family:var(--font-mono);font-size:.82rem;font-weight:500;letter-spacing:.04em;padding:12px 28px;border-radius:8px;transition:transform .2s var(--ease),box-shadow .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #5eead440}.btn-arrow{transition:transform .2s}.btn-primary:hover .btn-arrow{transform:translate(3px)}.btn-ghost{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:.82rem;font-weight:400;letter-spacing:.04em;color:var(--text-secondary);padding:12px 20px;border:1px solid var(--border-hover);border-radius:8px;transition:color .2s,border-color .2s}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-hover)}.hero-tech-wrap{display:flex;flex-direction:column;gap:10px;margin-top:8px}.tech-label{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.hero-tech{display:flex;flex-wrap:wrap;gap:8px}.tech-chip{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);padding:4px 12px;border-radius:100px}.hero-code-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--card-radius);overflow:hidden;box-shadow:0 0 80px #5eead40a}.code-card-header{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.dot{width:10px;height:10px;border-radius:50%}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.code-card-filename{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);margin-left:6px}.code-card-body{padding:24px;font-family:var(--font-mono);font-size:.82rem;line-height:1.8;overflow:auto}.code-keyword{color:#c792ea}.code-var{color:#82aaff}.code-prop{color:#f78c6c}.code-string{color:#c3e88d}.code-plain{color:#8a8a9a}.code-cursor{color:var(--accent);animation:blink 1.2s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.scroll-hint{position:absolute;bottom:40px;left:clamp(20px,5vw,48px);font-family:var(--font-mono);font-size:1.1rem;color:var(--text-muted);z-index:1}.projects-section{width:100%;max-width:none;padding-left:clamp(20px,5vw,48px);padding-right:clamp(20px,5vw,48px);padding-top:var(--section-pad);padding-bottom:var(--section-pad)}.projects-header{max-width:1120px;margin:0 auto clamp(48px,6vw,72px);display:flex;flex-direction:column;gap:14px}.section-eyebrow{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);letter-spacing:.1em;text-transform:uppercase}.section-heading{font-family:var(--font-mono);font-size:clamp(2rem,4vw,2.8rem);font-weight:500;letter-spacing:-.03em;color:var(--text-primary);line-height:1.1}.section-sub{font-size:.95rem;color:var(--text-secondary);line-height:1.8;max-width:640px}.projects-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--card-radius);padding:32px 30px;display:flex;flex-direction:column;gap:20px;position:relative;transition:border-color .25s var(--ease),background .25s var(--ease),transform .25s var(--ease);overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}.project-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-3px)}.project-card:hover:before{opacity:1}.project-card--wide{grid-column:1 / -1;display:grid;grid-template-columns:1fr}.card-index{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:.08em}.card-body{display:flex;flex-direction:column;gap:12px;flex:1}.card-title{font-family:var(--font-mono);font-size:clamp(1.05rem,2vw,1.2rem);font-weight:500;color:var(--text-primary);letter-spacing:-.02em;line-height:1.3}.card-role{font-family:var(--font-mono);font-size:.74rem;color:var(--accent);letter-spacing:.04em}.card-desc{font-size:.92rem;color:var(--text-secondary);line-height:1.75}.card-impact{margin-top:4px}.impact-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:10px}.impact-list{display:flex;flex-direction:column;gap:8px}.impact-list li{font-size:.88rem;color:var(--text-secondary);padding-left:16px;position:relative;line-height:1.7}.impact-list li:before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono);font-size:.8rem}.card-footer{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;padding-top:16px;border-top:1px solid var(--border);margin-top:auto}.card-tech{display:flex;flex-wrap:wrap;gap:6px}.tech-tag{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);background:#ffffff0a;border:1px solid var(--border);padding:3px 10px;border-radius:4px;letter-spacing:.02em}.card-actions{display:flex;gap:10px;align-items:center;flex-shrink:0}.card-btn{font-family:var(--font-mono);font-size:.76rem;font-weight:500;letter-spacing:.04em;padding:8px 18px;border-radius:6px;transition:all .2s var(--ease);white-space:nowrap}.card-btn--outline{color:var(--text-secondary);border:1px solid var(--border-hover)}.card-btn--outline:hover{color:var(--text-primary);border-color:#ffffff40}.card-btn--solid{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(94,234,212,.2)}.card-btn--solid:hover{background:#5eead42e;border-color:#5eead466}@media(max-width:900px){.hero-inner{grid-template-columns:1fr;gap:48px}.hero-code-card{display:none}.projects-grid{grid-template-columns:1fr}.project-card--wide{grid-column:1}}@media(max-width:640px){.nav-links.desktop{display:none}.hamburger{display:flex}.hero-name{font-size:2.8rem}.card-footer{flex-direction:column;align-items:flex-start}}@media(min-width:641px){.hamburger,.mobile-menu{display:none}}.contact-section{position:relative;padding-top:var(--section-pad);padding-bottom:var(--section-pad)}.contact-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--border-hover),transparent);margin-bottom:clamp(48px,7vw,80px)}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}.contact-left{display:flex;flex-direction:column;gap:18px}.contact-heading{font-family:var(--font-mono);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:500;line-height:1.05;letter-spacing:-.03em;color:var(--text-primary)}.contact-accent{color:var(--accent)}.contact-sub{font-size:.95rem;color:var(--text-secondary);line-height:1.8;max-width:380px}.contact-email-btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:clamp(.78rem,1.5vw,.9rem);font-weight:400;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-hover);padding:14px 22px;border-radius:8px;margin-top:8px;transition:border-color .25s var(--ease),background .25s var(--ease),transform .2s;word-break:break-all}.contact-email-btn:hover{border-color:var(--accent);background:var(--accent-glow);transform:translateY(-2px)}.email-arrow{color:var(--accent);flex-shrink:0;transition:transform .2s}.contact-email-btn:hover .email-arrow{transform:translate(2px,-2px)}.contact-right{display:flex;flex-direction:column;gap:14px;padding-top:4px}.contact-socials-label{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.contact-socials{display:flex;flex-direction:column;gap:10px}.social-card{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 18px;transition:border-color .25s var(--ease),background .25s var(--ease),transform .2s;position:relative;overflow:hidden}.social-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}.social-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translate(4px)}.social-card:hover:before{opacity:1}.social-icon{width:36px;height:36px;border-radius:8px;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.social-info{display:flex;flex-direction:column;gap:2px;flex:1}.social-label{font-family:var(--font-mono);font-size:.82rem;font-weight:500;color:var(--text-primary)}.social-handle{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.social-arrow{font-family:var(--font-mono);color:var(--text-muted);font-size:.9rem;transition:transform .2s,color .2s}.social-card:hover .social-arrow{transform:translate(3px);color:var(--accent)}.footer{border-top:1px solid var(--border);background:var(--bg-surface)}.footer-inner{max-width:1120px;margin:0 auto;padding:clamp(32px,5vw,52px) clamp(20px,5vw,48px);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px}.footer-left{display:flex;flex-direction:column;gap:8px}.footer-logo{font-family:var(--font-mono);font-size:.9rem;font-weight:500;color:var(--text-primary)}.footer-logo-bracket{color:var(--accent)}.footer-copy{font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono)}.footer-links{display:flex;flex-wrap:wrap;gap:24px;align-items:center}.footer-links a{font-family:var(--font-mono);font-size:.78rem;color:var(--text-secondary);transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-bar{border-top:1px solid var(--border);padding:14px clamp(20px,5vw,48px);text-align:center}.footer-bar span{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);letter-spacing:.04em}@media(max-width:760px){.contact-inner{grid-template-columns:1fr}.footer-inner{flex-direction:column;align-items:flex-start}.footer-links{gap:16px}}
