:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--border-color: #30363d;--border-hover: #484f58;--text-primary: #e6edf3;--text-secondary:#8b949e;--text-tertiary: #484f58;--accent: #39d353;--accent-blue: #58a6ff;--accent-orange: #f78166;--accent-purple: #d2a8ff;--font-sans: "Syne", sans-serif;--font-mono: "JetBrains Mono", monospace;--font-size-body: 14px;--font-size-mono-sm: 11px;--font-size-heading: 2rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 2rem;--space-xl: 4rem;--space-2xl: 8rem;--max-width: 900px;--nav-height: 56px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--transition-fast: .1s ease;--transition-base: .2s ease;--transition-theme: .3s ease}html.light{--bg-primary: #ffffff;--bg-secondary: #f6f8fa;--bg-tertiary: #eaeef2;--border-color: #d0d7de;--border-hover: #afb8c1;--text-primary: #1f2328;--text-secondary:#656d76;--text-tertiary: #afb8c1;--accent: #1a7f37;--accent-blue: #0969da;--accent-orange: #bc4c00;--accent-purple: #8250df}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:var(--font-size-body)}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-theme),color var(--transition-theme),border-color var(--transition-theme)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}img,svg{display:block;max-width:100%}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}*{scrollbar-width:thin;scrollbar-color:var(--border-hover) var(--bg-tertiary)}*,*:before,*:after{transition:background-color var(--transition-theme),color var(--transition-theme),border-color var(--transition-theme)}a,button,input,[class*=btn]{transition:background-color var(--transition-theme),color var(--transition-theme),border-color var(--transition-theme),opacity var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base)}.section{padding-block:var(--space-xl);width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--space-lg)}.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--space-lg)}.mono{font-family:var(--font-mono)}.section-label{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.12em;display:block;margin-bottom:var(--space-md);-webkit-user-select:none;user-select:none}.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:var(--font-size-mono-sm);font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);line-height:1.6;white-space:nowrap}.badge-ai{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.badge-backend{border-color:var(--accent-orange);color:var(--accent-orange);background:color-mix(in srgb,var(--accent-orange) 8%,transparent)}.badge-devops{border-color:var(--accent-blue);color:var(--accent-blue);background:color-mix(in srgb,var(--accent-blue) 8%,transparent)}.badge-frontend{border-color:var(--accent-purple);color:var(--accent-purple);background:color-mix(in srgb,var(--accent-purple) 8%,transparent)}.badge-neutral{border-color:var(--border-color);color:var(--text-secondary);background:transparent}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--font-size-mono-sm);font-weight:500;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;text-decoration:none;white-space:nowrap;line-height:1}.btn-primary{border-color:var(--accent);color:var(--accent);background:transparent}.btn-primary:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 20%,transparent)}.btn-primary:active{transform:translateY(1px)}.btn-secondary{border-color:var(--border-color);color:var(--text-secondary);background:transparent}.btn-secondary:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-tertiary)}.btn-secondary:active{transform:translateY(1px)}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg)}.card:hover{border-color:var(--border-hover)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes typewriter{0%{width:0}to{width:100%}}.fade-in-up{animation:fadeInUp .5s ease both}.cursor-blink:after{content:"▋";display:inline-block;margin-left:2px;animation:blink 1s step-end infinite;color:var(--accent)}@media (max-width: 768px){:root{--font-size-heading: 1.5rem;--space-xl: 2.5rem;--space-2xl: 4rem;--nav-height: 48px}.section{padding-inline:var(--space-md);padding-block:var(--space-lg)}.container{padding-inline:var(--space-md)}.btn-primary,.btn-secondary{padding:8px 12px;font-size:10px}.card{padding:var(--space-md)}}section[id]{scroll-margin-top:var(--nav-height)}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding-inline:var(--space-lg);transition:background-color var(--transition-theme),border-color var(--transition-theme),backdrop-filter var(--transition-base)}.navbar.scrolled{background-color:color-mix(in srgb,var(--bg-secondary) 88%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border-color)}.navbar-logo{font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--accent);-webkit-user-select:none;user-select:none;text-decoration:none}.navbar-links{display:flex;align-items:center;gap:var(--space-lg)}.navbar-link{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;text-decoration:none;transition:color var(--transition-base)}.navbar-link:hover{color:var(--text-primary)}.navbar-actions{display:flex;align-items:center;gap:var(--space-sm)}.navbar-icon-btn{display:flex;align-items:center;justify-content:center;min-width:32px;height:28px;padding-inline:6px;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:none;border:1px solid transparent;font-family:var(--font-mono);font-size:var(--font-size-mono-sm);letter-spacing:.06em;transition:color var(--transition-base),background-color var(--transition-base),border-color var(--transition-base)}.navbar-icon-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary);border-color:var(--border-color)}.navbar-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}.hamburger-line{display:block;width:20px;height:2px;background-color:var(--text-primary);border-radius:2px;transition:transform .25s ease,opacity .25s ease}.navbar-hamburger.open .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-hamburger.open .hamburger-line:nth-child(2){opacity:0}.navbar-hamburger.open .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{display:none;position:fixed;top:var(--nav-height);left:0;right:0;z-index:99;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-direction:column;padding:var(--space-md) var(--space-lg);gap:var(--space-sm)}.mobile-menu.open{display:flex}.mobile-menu-link{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;padding-block:var(--space-sm);border-bottom:1px solid var(--border-color);text-decoration:none;transition:color var(--transition-base)}.mobile-menu-link:hover{color:var(--text-primary)}.mobile-menu-link:last-of-type{border-bottom:none}@media (max-width: 768px){.navbar{padding-inline:var(--space-md)}.navbar-links,.navbar-cv-btn{display:none}.navbar-hamburger{display:flex}}.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:var(--nav-height);padding-inline:var(--space-lg);position:relative}.terminal{width:100%;max-width:700px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.terminal-header{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border-color);background-color:var(--bg-tertiary)}.terminal-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}.terminal-title{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-tertiary);margin-left:var(--space-xs)}.terminal-body{padding:var(--space-md) var(--space-lg);min-height:150px;display:flex;flex-direction:column;gap:14px}.terminal-line{display:flex;flex-direction:column;gap:3px;animation:fadeInUp .25s ease both}.terminal-prompt-row{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--font-size-body)}.terminal-prompt-sym{color:var(--accent);font-weight:700;flex-shrink:0}.terminal-cmd{color:var(--accent);font-family:var(--font-mono)}.terminal-output{font-family:var(--font-mono);font-size:var(--font-size-body);color:var(--text-secondary);padding-left:18px;line-height:1.5}.terminal-cursor{display:inline-block;width:7px;height:14px;background-color:var(--accent);vertical-align:text-bottom;margin-left:3px;animation:blink 1s step-end infinite}.hero-cta{display:flex;gap:var(--space-md);margin-top:var(--space-lg);flex-wrap:wrap;justify-content:center;animation:fadeInUp .5s ease both}.scroll-indicator{position:absolute;bottom:var(--space-lg);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-tertiary);animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}@media (max-width: 768px){.hero{padding-inline:var(--space-md)}.terminal-body{padding:var(--space-md);gap:12px}.terminal-output{font-size:12px;padding-left:0;margin-top:2px}.hero-cta{flex-direction:column;align-items:stretch;width:100%;max-width:280px}}.stack-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md);margin-top:var(--space-lg)}@media (min-width: 480px){.stack-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.stack-grid{grid-template-columns:repeat(3,1fr)}}.stack-category-name{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-sm)}.stack-badges{display:flex;flex-wrap:wrap;gap:6px}.timeline{position:relative;margin-top:var(--space-lg);padding-left:36px}.timeline:before{content:"";position:absolute;left:7px;top:10px;bottom:10px;width:2px;background:linear-gradient(to bottom,var(--accent),var(--border-color))}.timeline-entry{position:relative;margin-bottom:var(--space-xl)}.timeline-entry:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-30px;top:8px;width:16px;height:16px;border-radius:50%;border:2px solid;background-color:var(--bg-primary)}.timeline-dot.active{border-color:var(--accent);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 40%,transparent)}.timeline-dot.inactive{border-color:var(--border-color)}.timeline-period{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-tertiary);margin-bottom:6px}.timeline-title{font-family:var(--font-sans);font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:4px;line-height:1.4}.timeline-institution{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--accent-blue);margin-bottom:var(--space-sm)}.timeline-description{font-size:var(--font-size-body);color:var(--text-secondary);line-height:1.7}@media (max-width: 768px){.timeline{padding-left:28px}.timeline-dot{left:-24px;width:14px;height:14px}}.projects-filters{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:var(--space-md);margin-bottom:var(--space-lg)}.filter-btn{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);padding:4px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--text-secondary);background:transparent;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:color var(--transition-base),border-color var(--transition-base),background-color var(--transition-base)}.filter-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.filter-btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.projects-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}@media (min-width: 640px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.project-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);cursor:default;transition:background-color var(--transition-theme),color var(--transition-theme),border-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base)}.project-card:hover{border-color:var(--border-hover);transform:translateY(-3px);box-shadow:0 8px 24px #0003}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm)}.project-card-name{font-family:var(--font-mono);font-weight:500;font-size:.9rem;color:var(--text-primary);line-height:1.4}.project-card-tags{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}.project-card-desc{font-size:var(--font-size-body);color:var(--text-secondary);line-height:1.7;flex:1}.project-card-stack{display:flex;flex-wrap:wrap;gap:4px}.project-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-sm);border-top:1px solid var(--border-color);gap:var(--space-sm)}.project-lang{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-secondary)}.project-lang-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}@media (max-width: 768px){.project-card{padding:var(--space-md)}.project-card-header{flex-direction:column}.project-card-tags{justify-content:flex-start}}.footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding-block:var(--space-xl)}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);max-width:var(--max-width);margin-inline:auto;padding-inline:var(--space-lg)}.footer-logo{font-family:var(--font-mono);font-weight:700;font-size:1rem;color:var(--accent);-webkit-user-select:none;user-select:none}.footer-links{display:flex;align-items:center;gap:var(--space-xl);flex-wrap:wrap;justify-content:center}.footer-link{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;text-decoration:none;background:none;border:none;transition:color var(--transition-base)}.footer-link:hover{color:var(--accent)}.footer-copy-feedback{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--accent);animation:fadeInUp .25s ease}.footer-credits{font-family:var(--font-mono);font-size:var(--font-size-mono-sm);color:var(--text-tertiary);text-align:center;line-height:1.8}@media (max-width: 768px){.footer-links{gap:var(--space-lg)}}
