:root{--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-tertiary: #1a1a24;--bg-card: #15151e;--bg-card-hover: #1c1c28;--text-primary: #e8e8ed;--text-secondary: #a0a0b0;--text-muted: #606070;--accent: #00d4aa;--accent-dim: rgba(0, 212, 170, .15);--accent-glow: rgba(0, 212, 170, .4);--border: #2a2a38;--border-light: #1e1e2a;--success: #00d4aa;--warning: #ffb347;--error: #ff6b6b;--font-display: "Inter", "Segoe UI", "Helvetica Neue", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SFMono-Regular", "SF Mono", "Cascadia Code", "JetBrains Mono", "Consolas", "Liberation Mono", monospace;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--max-w: 1280px;--gutter: clamp(1.25rem, 4vw, 3rem);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px}[data-theme=light]{--bg-primary: #fafafa;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f5;--bg-card: #ffffff;--bg-card-hover: #f5f5fa;--text-primary: #1a1a24;--text-secondary: #4a4a5a;--text-muted: #8a8a9a;--accent: #00a080;--accent-dim: rgba(0, 160, 128, .1);--accent-glow: rgba(0, 160, 128, .3);--border: #e0e0e8;--border-light: #f0f0f5}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:5rem}body{font-family:var(--font-display);font-weight:400;font-size:1rem;line-height:1.7;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip;transition:background-color .4s ease,color .4s ease}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}::selection{background:var(--accent);color:var(--bg-primary)}.skip-link{position:absolute;top:-100%;left:1rem;padding:.75rem 1.5rem;background:var(--accent);color:var(--bg-primary);font-family:var(--font-mono);font-size:.875rem;font-weight:600;border-radius:var(--radius-sm);z-index:9999;transition:top .2s}.skip-link:focus{top:1rem}.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}.section{padding:clamp(4rem,10vw,8rem) 0}.section-alt{background:var(--bg-secondary)}.section-header{margin-bottom:3rem}.section-label{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--accent);margin-bottom:.75rem}.section-label:before{content:"//";opacity:.6}.section-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.15;letter-spacing:-.02em}.section-desc{font-size:1.0625rem;color:var(--text-secondary);max-width:600px;margin-top:1rem}.grid-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;opacity:.03;background-image:linear-gradient(var(--accent) 1px,transparent 1px),linear-gradient(90deg,var(--accent) 1px,transparent 1px);background-size:60px 60px}@media(max-width:768px){.grid-bg{display:none}}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:#0a0a0fcc;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid transparent;transition:border-color .3s,background-color .4s}[data-theme=light] .nav{background:#fafafad9}.nav.scrolled{border-bottom-color:var(--border)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:4rem;max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}.nav-brand{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.25rem}.nav-brand span{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:.5rem;list-style:none}.nav-links a{display:block;padding:.5rem 1rem;font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:color .2s,background .2s}.nav-links a:hover,.nav-links a.nav-active{color:var(--accent);background:var(--accent-dim)}.nav-actions{display:flex;align-items:center;gap:.75rem}.lang-toggle{height:40px;padding:0 .375rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:1.25rem;line-height:1;transition:background .2s}.lang-toggle:hover{background:var(--accent-dim)}.theme-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:color .2s,background .2s}.theme-toggle:hover{color:var(--text-primary);background:var(--accent-dim)}.theme-toggle svg{width:20px;height:20px}.sun-icon{display:none}.moon-icon,[data-theme=light] .sun-icon{display:block}[data-theme=light] .moon-icon{display:none}.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px}.nav-toggle span{display:block;width:100%;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .3s,opacity .3s}.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:768px){.nav-toggle{display:flex}.nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:1rem;gap:.25rem;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s var(--ease-out)}.nav-links.open{opacity:1;visibility:visible;transform:translateY(0)}.nav-links a{padding:.75rem 1rem;font-size:.9375rem}}.hero{min-height:100vh;min-height:100dvh;display:flex;align-items:center;padding-top:6rem;position:relative}@media(min-width:901px){.hero{overflow:hidden}}.hero-content{position:relative;z-index:1}.hero-terminal{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:.8125rem;color:var(--text-muted);margin-bottom:1.5rem}.hero-terminal-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero-name{font-size:clamp(3rem,10vw,6rem);font-weight:700;line-height:1.05;letter-spacing:-.03em;margin-bottom:1rem}.hero-name span{color:var(--accent)}.hero-tagline{font-family:var(--font-mono);font-size:clamp(1rem,2.5vw,1.5rem);font-weight:400;color:var(--text-secondary);margin-bottom:2rem;min-height:2em}.typing-cursor{display:inline-block;width:3px;height:1.2em;background:var(--accent);margin-left:2px;animation:blink 1s step-end infinite;vertical-align:text-bottom}@keyframes blink{50%{opacity:0}}.hero-desc{font-size:1.125rem;color:var(--text-secondary);max-width:560px;margin-bottom:2.5rem;line-height:1.8}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-family:var(--font-mono);font-size:.875rem;font-weight:600;border-radius:var(--radius-sm);transition:all .25s var(--ease-out)}.btn-primary{background:var(--accent);color:var(--bg-primary)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn svg{width:18px;height:18px}.hero-decoration{position:absolute;right:0;top:50%;transform:translateY(-50%);width:45%;max-width:500px;opacity:.1;pointer-events:none}@media(max-width:900px){.hero-decoration{display:none}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.skill-card{padding:1.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .3s var(--ease-out)}.skill-card:hover{background:var(--bg-card-hover);border-color:var(--accent);transform:translateY(-4px)}.skill-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:var(--radius-sm);margin-bottom:1.25rem;color:var(--accent)}.skill-icon svg{width:24px;height:24px}.skill-title{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.skill-desc{font-size:.9375rem;color:var(--text-secondary);line-height:1.65}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}.skill-tag{padding:.25rem .625rem;background:var(--bg-tertiary);border-radius:999px;font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:all .3s var(--ease-out)}.project-card:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:0 20px 60px #0000004d}.project-img{width:100%;height:200px;object-fit:cover;border-bottom:1px solid var(--border)}.project-body{padding:1.5rem}.project-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.project-tag{padding:.25rem .625rem;background:var(--accent-dim);border-radius:999px;font-family:var(--font-mono);font-size:.6875rem;font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.project-title{font-size:1.25rem;font-weight:600;margin-bottom:.75rem}.project-desc{font-size:.9375rem;color:var(--text-secondary);line-height:1.65}.project-links{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.project-link{display:inline-flex;align-items:center;gap:.375rem;font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:.375rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);transition:color .2s,border-color .2s}.project-link:hover{color:var(--accent);border-color:var(--accent)}.project-link svg{width:14px;height:14px}.error-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;font-family:var(--font-display);color:var(--text-primary);background:var(--bg-primary);padding:2rem;text-align:center}.error-fallback h1{font-size:1.5rem;margin-bottom:1rem}.error-fallback p{color:var(--text-secondary);margin-bottom:1.5rem}.error-fallback button{padding:.75rem 1.5rem;background:var(--accent);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:1rem}.projects-cta{text-align:center;margin-top:3rem}.projects-cta a{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.9375rem;font-weight:500;color:var(--accent);transition:gap .2s}.projects-cta a:hover{gap:.75rem}.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center}@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:2.5rem}}.about-image-wrapper{position:relative}.about-image{width:100%;max-width:380px;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border)}.about-image-decoration{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border:1px solid var(--accent);border-radius:var(--radius-lg);opacity:.3;z-index:-1}.about-content h3{font-size:1.5rem;font-weight:600;margin-bottom:1.25rem}.about-content p{color:var(--text-secondary);margin-bottom:1.25rem;line-height:1.8}.about-content p:last-of-type{margin-bottom:2rem}.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding-top:2rem;border-top:1px solid var(--border)}.about-stat-value{font-family:var(--font-mono);font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.about-stat-label{font-size:.8125rem;color:var(--text-muted)}.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem}@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:3rem}}.contact-info h3{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.contact-detail{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.contact-detail-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:var(--radius-sm);color:var(--accent);flex-shrink:0}.contact-detail-icon svg{width:20px;height:20px}.contact-detail-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.contact-detail-value{font-size:.9375rem;color:var(--text-primary)}.contact-detail-value a:hover{color:var(--accent)}.contact-availability{padding:1.25rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:2rem}.contact-availability h4{font-size:.9375rem;font-weight:600;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.contact-availability h4:before{content:"";width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 2s infinite}.contact-availability p{font-size:.875rem;color:var(--text-secondary);line-height:1.65}.contact-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:2rem}.visually-hidden-field{position:absolute;left:-9999px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.form-group input,.form-group textarea{width:100%;padding:.875rem 1rem;font-family:var(--font-display);font-size:.9375rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group textarea{min-height:140px;resize:vertical}.form-status{padding:.875rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:1rem;display:none}.form-status.visible{display:block}.contact-inline-link{color:inherit;text-decoration:underline}.form-status.success{background:#00d4aa1a;color:var(--success);border:1px solid rgba(0,212,170,.3)}.form-status.error{background:#ff6b6b1a;color:var(--error);border:1px solid rgba(255,107,107,.3)}.form-submit{width:100%;padding:1rem;background:var(--accent);color:var(--bg-primary);font-family:var(--font-mono);font-size:.9375rem;font-weight:600;border-radius:var(--radius-sm);transition:all .25s var(--ease-out)}.form-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.form-submit:disabled{opacity:.6;cursor:not-allowed}.footer{padding:3rem 0;border-top:1px solid var(--border)}.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}.footer-brand{font-family:var(--font-mono);font-size:1.125rem;font-weight:700}.footer-brand span{color:var(--accent)}.footer-links{display:flex;gap:2rem;list-style:none}.footer-links a{font-family:var(--font-mono);font-size:.8125rem;color:var(--text-muted);transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-copy{width:100%;text-align:center;font-size:.8125rem;color:var(--text-muted);margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.stagger-children>*{opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}.stagger-children.visible>*:nth-child(1){transition-delay:.05s}.stagger-children.visible>*:nth-child(2){transition-delay:.1s}.stagger-children.visible>*:nth-child(3){transition-delay:.15s}.stagger-children.visible>*:nth-child(4){transition-delay:.2s}.stagger-children.visible>*:nth-child(5){transition-delay:.25s}.stagger-children.visible>*:nth-child(6){transition-delay:.3s}.stagger-children.visible>*{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.reveal,.stagger-children>*{opacity:1;transform:none;transition:none}}
