.terminal-text{font-size:1.5rem;margin-bottom:1rem}@media (max-width: 768px){.terminal-text{font-size:1.2rem;margin-bottom:.75rem}}.prompt{color:var(--accent)}.cursor{animation:blink 1s infinite}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.typing{overflow:hidden;white-space:nowrap;animation:typing 2s steps(30,end)}.typing-complete{overflow:hidden;white-space:nowrap;width:100%}@keyframes typing{0%{width:0}to{width:100%}}.subtitle{color:var(--comment);margin-bottom:1.5rem;font-size:.95rem}@media (max-width: 768px){.subtitle{font-size:.85rem;margin-bottom:1rem}}.inline-nav{margin-bottom:3rem;display:flex;flex-wrap:wrap;gap:.75rem}@media (max-width: 768px){.inline-nav{margin-bottom:2rem;gap:.5rem}}.inline-nav a{margin-right:1.5rem;font-size:.9rem}@media (max-width: 768px){.inline-nav a{margin-right:0;font-size:.85rem}}.about-text{background:var(--code-bg);padding:1.5rem;border-radius:4px;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;font-size:.9rem;line-height:1.6}@media (max-width: 768px){.about-text{padding:1rem;font-size:.85rem;line-height:1.5}}.experience-item{margin-bottom:1rem;padding:1rem;background:var(--code-bg);border-radius:4px}.experience-item:last-child{margin-bottom:0}.experience-header{color:var(--accent);margin-bottom:.5rem}.experience-meta{color:var(--comment);font-size:.9rem;margin-bottom:.5rem}.achievement{color:var(--text);margin-bottom:.3rem;font-size:.95rem}.key-achievement{color:var(--accent)}@media (max-width: 768px){.experience-item{padding:.75rem;margin-bottom:.75rem}.experience-header{font-size:1rem}.experience-meta{font-size:.85rem;line-height:1.4}.achievement{font-size:.9rem;line-height:1.5}}.code-block{background:var(--code-bg);padding:1.5rem;border-radius:4px;overflow-x:auto}.tech-grid{display:grid;gap:.5rem}.tech-category{color:var(--comment)}@media (max-width: 768px){.code-block{padding:1rem;font-size:.9rem}.tech-grid{gap:.4rem;font-size:.85rem}}.project{background:var(--code-bg);padding:1rem;margin-bottom:1rem;border-radius:4px}.project-header{color:var(--accent);margin-bottom:.5rem}.project-description{color:var(--text);margin-bottom:.5rem}.project-tech{color:var(--comment);font-size:.9rem}.project-links{margin-top:.5rem}.project-links a{margin-right:1rem;font-size:.9rem}@media (max-width: 768px){.project{padding:.75rem}.project-header{font-size:.95rem}.project-description{font-size:.9rem;line-height:1.5}.project-tech{font-size:.85rem}.project-links{display:flex;flex-wrap:wrap;gap:.5rem}.project-links a{margin-right:0;font-size:.85rem}}.contact-line{display:flex;align-items:center;gap:.5rem}.contact-function{color:var(--accent);cursor:pointer}.contact-function:hover{text-decoration:underline}.copy-email-button{background:transparent;border:none;color:var(--comment);cursor:pointer;padding:.25rem .5rem;font-size:.85rem;transition:color .3s ease;display:inline-flex;align-items:center}.copy-email-button:hover{color:var(--accent)}@media (max-width: 768px){.code-block{padding:1rem;font-size:.9rem}}.theme-switcher{position:fixed;top:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;z-index:1000}@media (max-width: 768px){.theme-switcher{top:.5rem;right:.5rem;font-size:.75rem;gap:.25rem}.theme-label{display:none}.theme-select-wrapper{min-width:90px}.theme-select{padding:.35rem 1.75rem .35rem .5rem;font-size:.8rem}.theme-select-arrow{right:.5rem;font-size:.65rem}}.theme-label{color:var(--comment);font-size:.9rem}.theme-select-wrapper{position:relative;display:inline-block}.theme-select-button{background:var(--code-bg);color:var(--text);border:1px solid var(--comment);border-radius:4px;padding:.4rem 2rem .4rem .6rem;font-family:Fira Code,monospace;font-size:.9rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0003;width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.theme-select-button:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000004d}.theme-select-button:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #bd93f933}.theme-select-button:active{transform:translateY(1px)}.theme-select-arrow{color:var(--comment);font-size:.7rem;transition:all .3s ease;flex-shrink:0}.theme-select-arrow.open{transform:rotate(180deg)}.theme-select-button:hover .theme-select-arrow{color:var(--accent)}.theme-dropdown-menu{position:absolute;top:calc(100% + .25rem);left:0;right:0;background:var(--code-bg);border:1px solid var(--comment);border-radius:4px;box-shadow:0 4px 12px #0006;z-index:1001;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.theme-dropdown-item{width:100%;background:transparent;border:none;color:var(--text);padding:.6rem .75rem;font-family:Fira Code,monospace;font-size:.9rem;cursor:pointer;text-align:left;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease}.theme-dropdown-item:hover{background:var(--bg)}.theme-dropdown-item.selected{background:var(--accent);color:var(--bg)}.theme-checkmark{flex-shrink:0;width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;color:currentColor}.theme-checkmark svg{width:100%;height:100%;stroke:currentColor}@media (max-width: 768px){.theme-select-button{padding:.35rem 1.75rem .35rem .5rem;font-size:.8rem}.theme-select-arrow{font-size:.65rem}.theme-dropdown-item{padding:.5rem .6rem;font-size:.85rem}}.terminal-hint{position:fixed;bottom:1rem;right:1rem;color:var(--comment);font-size:.85rem;padding:.5rem 1rem;background:var(--code-bg);border-radius:4px;border:1px solid var(--comment);z-index:100;opacity:.7;transition:opacity .3s ease}.terminal-hint:hover{opacity:1}.terminal-hint kbd{background:var(--bg);padding:.2rem .4rem;border-radius:3px;border:1px solid var(--comment);font-family:Fira Code,monospace;font-size:.8rem}.terminal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.terminal-window{width:100%;max-width:800px;max-height:80vh;background:var(--bg);border:1px solid var(--comment);border-radius:8px;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080}.terminal-header{background:var(--code-bg);padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--comment)}.terminal-title{color:var(--text);font-size:.9rem}.terminal-close{background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.terminal-close:hover{color:var(--accent)}.terminal-body{padding:1rem;overflow-y:auto;flex:1;font-family:Fira Code,monospace;font-size:.9rem;line-height:1.6}.terminal-welcome{color:var(--comment);margin-bottom:1rem}.terminal-line{margin-bottom:.5rem;white-space:pre-wrap;word-break:break-word}.terminal-line.input{color:var(--text)}.terminal-line.output{color:var(--comment);margin-left:1rem}.terminal-prompt{color:var(--accent);margin-right:.5rem}.terminal-input-line{display:flex;align-items:center;margin-top:.5rem}.terminal-input{flex:1;background:transparent;border:none;color:var(--text);font-family:Fira Code,monospace;font-size:.9rem;outline:none;width:100%}.terminal-input::placeholder{color:var(--comment)}@media (max-width: 768px){.terminal-overlay{padding:1rem .5rem .5rem;align-items:flex-start}.terminal-window{max-height:95vh;width:100%}.terminal-header{padding:.5rem .75rem}.terminal-title{font-size:.8rem}.terminal-close{width:28px;height:28px;font-size:1.3rem}.terminal-body{font-size:.8rem;padding:.75rem;line-height:1.5}.terminal-welcome{font-size:.75rem;margin-bottom:.75rem}.terminal-line{margin-bottom:.4rem;font-size:.8rem}.terminal-line.output{margin-left:.5rem}.terminal-prompt,.terminal-input{font-size:.8rem}.terminal-hint{display:none}}@media (min-width: 769px){.terminal-hint{display:block}.terminal-toggle-mobile{display:none}}.terminal-toggle-mobile{position:fixed;bottom:1rem;right:1rem;background:var(--code-bg);border:1px solid var(--comment);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);font-size:1.2rem;z-index:100;transition:all .3s ease;box-shadow:0 2px 8px #0000004d}@media (max-width: 768px){.terminal-toggle-mobile{bottom:.75rem;right:.75rem;width:44px;height:44px;font-size:1rem}}.terminal-toggle-mobile:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.1)}@media (min-width: 769px){.terminal-toggle-mobile{display:none}}.shortcuts-toggle{position:fixed;bottom:1rem;left:1rem;background:var(--code-bg);border:1px solid var(--comment);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);font-size:1.2rem;z-index:100;transition:all .3s ease}.shortcuts-toggle:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.1)}.shortcuts-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.shortcuts-modal{background:var(--bg);border:1px solid var(--comment);border-radius:8px;max-width:500px;width:100%;box-shadow:0 10px 40px #00000080}.shortcuts-header{background:var(--code-bg);padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--comment)}.shortcuts-header h3{color:var(--accent);margin:0;font-size:1rem;font-weight:400}.shortcuts-close{background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.shortcuts-close:hover{color:var(--accent)}.shortcuts-list{padding:1.5rem}.shortcut-item{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:.75rem;background:var(--code-bg);border-radius:4px}.shortcut-item:last-child{margin-bottom:0}.shortcut-key{background:var(--bg);color:var(--accent);padding:.4rem .8rem;border-radius:4px;border:1px solid var(--comment);font-family:Fira Code,monospace;font-size:.85rem;min-width:60px;text-align:center;display:inline-block}.shortcut-desc{color:var(--text);flex:1}@media (max-width: 768px){.shortcuts-toggle{width:44px;height:44px;font-size:1rem;bottom:.75rem;left:.75rem;box-shadow:0 2px 8px #0000004d}.shortcuts-modal{max-width:95%;margin:.5rem}.shortcuts-header{padding:.75rem}.shortcuts-header h3{font-size:.9rem}.shortcuts-list{padding:1rem}.shortcut-item{padding:.5rem;margin-bottom:.75rem;flex-direction:column;align-items:flex-start;gap:.5rem}.shortcut-key{min-width:auto;width:100%;text-align:center}.shortcut-desc{font-size:.9rem}}.scroll-progress-container{position:fixed;top:0;left:0;right:0;height:2px;background:var(--code-bg);z-index:9999;pointer-events:none;overflow:hidden}.scroll-progress-bar{height:100%;background:var(--accent);will-change:width;transform:translateZ(0)}.scroll-to-top{position:fixed;bottom:1rem;right:1rem;background:var(--code-bg);border:1px solid var(--comment);border-radius:4px;padding:.5rem .75rem;color:var(--text);cursor:pointer;font-family:Fira Code,monospace;font-size:.85rem;display:flex;align-items:center;gap:.5rem;z-index:100;transition:all .3s ease;box-shadow:0 2px 8px #0000004d}.scroll-to-top:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.scroll-arrow{font-size:1rem}.scroll-label{font-size:.8rem}@media (max-width: 768px){.scroll-to-top{bottom:5.5rem;right:.75rem;padding:.4rem .6rem;font-size:.8rem}.scroll-label{display:none}.scroll-arrow{font-size:1.1rem}}.container{max-width:800px;margin:0 auto;padding:2rem;min-height:100vh}@media (max-width: 768px){.container{padding:1rem}}a{color:var(--text);text-decoration:none;transition:color .3s ease}a:hover{color:var(--accent)}.divider{color:var(--comment);margin:3rem 0;font-size:.9rem}@media (max-width: 768px){.divider{margin:2rem 0;font-size:.85rem}}section{margin-bottom:3rem}@media (max-width: 768px){section{margin-bottom:2rem}}h2{color:var(--accent);font-size:1.2rem;font-weight:400;margin-bottom:1.5rem}@media (max-width: 768px){h2{font-size:1rem;margin-bottom:1rem}}.skip-to-content{position:absolute;left:-9999px;z-index:999;padding:1rem;background:var(--code-bg);color:var(--accent);text-decoration:none}.skip-to-content:focus{left:1rem;top:1rem}@media (max-width: 768px){.skip-to-content:focus{left:.5rem;top:.5rem}}:root{--bg: #282a36;--text: #f8f8f2;--accent: #bd93f9;--comment: #6272a4;--code-bg: #44475a}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Fira Code,monospace;background:var(--bg);color:var(--text);line-height:1.6;font-size:16px;font-variant-ligatures:common-ligatures;-webkit-font-feature-settings:"liga" on,"calt" on;font-feature-settings:"liga" on,"calt" on}@media (max-width: 768px){body{font-size:14px;line-height:1.5}}#root{min-height:100vh}
