:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.cta-section{position:fixed;top:2rem;right:12rem}.work-button{background:#667eea;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #667eea33;text-decoration:none;display:inline-block}.work-button:hover{background:#5a67d8;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.dark-mode .work-button{background:#667eea;color:#fff}.dark-mode .work-button:hover{background:#5a67d8}@media(max-width:768px){.cta-section{position:relative;top:auto;right:auto;margin-top:2rem;text-align:center}.work-button{padding:.8rem 1.5rem;font-size:.9rem}}@media(max-width:480px){.work-button{padding:.7rem 1.2rem;font-size:.85rem}}.top-right-controls{position:fixed;top:2rem;right:2rem;display:flex;flex-direction:column;gap:.5rem;z-index:1000}.toggle-button{background:var(--theme-bg-secondary);border:2px solid var(--theme-border);border-radius:8px;padding:.5rem;cursor:pointer;transition:all .3s ease;font-size:1rem;font-weight:600;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--theme-text);box-shadow:0 1px 3px #0000001a}.toggle-button:hover{background:var(--theme-accent);color:var(--theme-bg);border-color:var(--theme-accent);transform:translateY(-1px);box-shadow:0 2px 6px #0003}.back-to-top{font-size:1.5rem;animation:fadeInUp .3s ease}.back-to-top:hover{transform:translateY(-3px)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.top-right-controls{top:1rem;right:1rem;gap:.3rem}.toggle-button{min-width:36px;height:36px;font-size:.9rem}.back-to-top{font-size:1.3rem}}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;text-decoration:none;color:var(--theme-text-muted);font-weight:500;transition:all .3s ease}.nav-item:hover{background:var(--theme-bg);color:var(--theme-text)}.nav-item.active{background:var(--theme-accent2);color:var(--theme-bg)}.nav-icon{font-size:1.25rem;display:flex;align-items:center}@media(max-width:768px){.nav-item{padding:.6rem .8rem;font-size:.9rem}}.profile-section{display:flex;flex-direction:column;align-items:center}.profile-image{display:block;margin-bottom:2rem;overflow:hidden;border-radius:50%;border:4px solid var(--theme-accent);cursor:pointer;transition:border-color .3s ease,transform .3s ease}.profile-image:hover{border-color:var(--theme-accent2);transform:scale(1.05)}.avatar{display:block;width:120px;height:120px;object-fit:cover;object-position:center top;transform:scale(1.3)}.nav-menu{display:flex;flex-direction:column;gap:.5rem;width:100%}@media(max-width:768px){.avatar{width:100px;height:100px}}@media(max-width:480px){.avatar{width:80px;height:80px}}.social-section{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.social-link{width:44px;height:44px;border-radius:8px;background:#f8f9fa;display:flex;align-items:center;justify-content:center;text-decoration:none;color:#6c757d;transition:all .3s ease;border:1px solid #e9ecef}.social-link:hover{background:#667eea;color:#fff;border-color:#667eea}.social-icon{width:20px;height:20px;object-fit:contain}.dark-mode .social-link{background:#4a5568;border-color:#2d3748;color:#cbd5e0}.dark-mode .social-link:hover{background:#667eea;color:#fff}.github-activity{margin-bottom:1rem}.github-activity-link{display:block;padding:.5rem;background:var(--theme-bg);border-radius:8px;border:1px solid var(--theme-border);transition:all .3s ease;text-decoration:none}.github-activity-link:hover{border-color:var(--theme-accent);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.github-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.github-label{font-size:.65rem;font-weight:700;color:var(--theme-accent2);letter-spacing:.5px;text-transform:uppercase}.github-external-icon{color:var(--theme-text-muted);font-size:.75rem;transition:color .3s ease}.github-activity-link:hover .github-external-icon{color:var(--theme-accent)}.github-loading{color:var(--theme-text-muted);font-size:.75rem;text-align:center;padding:.5rem 0}.github-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:3px;padding:.25rem}.github-day{aspect-ratio:1;border-radius:2px;transition:transform .2s ease,box-shadow .2s ease}.github-day:hover{transform:scale(1.3);box-shadow:0 0 6px var(--theme-accent)}.github-day.level-0{background:var(--theme-border)}.github-day.level-1{background:color-mix(in srgb,var(--theme-accent) 30%,var(--theme-bg))}.github-day.level-2{background:color-mix(in srgb,var(--theme-accent) 50%,var(--theme-bg))}.github-day.level-3{background:color-mix(in srgb,var(--theme-accent) 75%,var(--theme-bg))}.github-day.level-4{background:var(--theme-accent);box-shadow:0 0 4px var(--theme-accent)}@media(max-width:768px){.github-activity{margin-bottom:.75rem}.github-activity-link{padding:.75rem}.github-grid{grid-template-columns:repeat(15,1fr);gap:4px;padding:.5rem}.github-day{border-radius:3px}}.sidebar{width:280px;background:var(--theme-bg-secondary);border-right:1px solid var(--theme-border);padding:2rem 1.5rem;display:flex;flex-direction:column;justify-content:space-between;position:fixed;height:100vh;left:0;top:0;transition:transform .3s ease,background-color .3s ease,border-color .3s ease;animation:fadeIn .6s ease;z-index:100}.sidebar.collapsed{transform:translate(-100%)}.sidebar-bottom{display:flex;flex-direction:column}.sidebar-toggle{position:fixed;left:284px;top:1rem;width:32px;height:32px;background:var(--theme-bg-secondary);border:1px solid var(--theme-border);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--theme-text-muted);font-size:1.1rem;transition:all .3s ease;z-index:101}.sidebar-toggle:hover{background:var(--theme-bg);color:var(--theme-text);border-color:var(--theme-text-muted)}.sidebar-toggle .material-symbols-outlined{font-size:20px;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 20}.sidebar-toggle.collapsed{left:1rem}@media(max-width:768px){.sidebar{width:100%;max-width:100vw;height:auto;position:relative;padding:1.5rem;border-right:none;border-bottom:1px solid var(--theme-border);transform:none}.sidebar.collapsed{transform:none}.sidebar-toggle{display:none}}.intro-section{margin-bottom:1.5rem;animation:fadeInUp .6s ease .2s both}.section-number{display:inline-block;background:#e9ecef;color:#667eea;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.intro-section h1{font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:.5rem;color:var(--theme-text);transition:color .3s ease}.intro-section h2{font-size:1.5rem;font-weight:600;line-height:1.3;margin-bottom:.75rem;color:var(--theme-text-muted);transition:color .3s ease}.highlight{color:var(--theme-accent);text-decoration:none;cursor:pointer;transition:color .3s ease}.highlight:hover{color:var(--theme-accent-hover)}.description{font-size:1rem;color:var(--theme-text-muted);margin-bottom:1rem;line-height:1.5;transition:color .3s ease}@media(max-width:768px){.intro-section{margin-bottom:1rem}.intro-section h1{font-size:1.75rem;line-height:1.1;margin-bottom:.4rem}.intro-section h2{font-size:1.25rem;line-height:1.2;margin-bottom:.5rem}.description{font-size:.9rem;margin-bottom:.75rem}}@media(max-width:480px){.intro-section h1{font-size:1.5rem}.intro-section h2{font-size:1.1rem}}.skills-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-content:flex-start;flex:1;overflow:hidden;min-height:0}.skill-tag{background:var(--theme-accent);color:var(--theme-bg);padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;transition:all .3s ease;cursor:pointer}.skill-tag:hover{background:var(--theme-accent2)}.skill-tag.active{background:var(--theme-accent2);box-shadow:0 2px 8px #0003}@media(max-width:480px){.skills-tags{gap:.4rem}.skill-tag{font-size:.75rem;padding:.3rem .6rem}}.skill-bar-container{display:flex;align-items:center;gap:.75rem;width:100%;margin-top:.5rem}.skill-bar-track{flex:1;height:8px;background:var(--theme-border);border-radius:4px;overflow:hidden}.skill-bar-fill{height:100%;background:linear-gradient(90deg,var(--theme-accent) 0%,var(--theme-accent2) 100%);border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px var(--theme-accent)}.skill-bar-percentage{font-size:.75rem;font-weight:600;color:var(--theme-accent);min-width:36px;text-align:right}@media(max-width:768px){.skill-bar-track{height:6px}.skill-bar-percentage{font-size:.7rem;min-width:30px}}.skills-section{padding:1rem;border-radius:10px;background:var(--theme-bg-secondary);box-shadow:0 4px 20px #00000026;border:1px solid var(--theme-border);display:flex;flex-direction:column;transition:background-color .3s ease,border-color .3s ease;overflow:hidden;min-height:0;height:100%;max-width:100%;box-sizing:border-box}.skills-section h3{font-size:1rem;font-weight:600;color:var(--theme-text);margin-bottom:.75rem;text-align:center;transition:color .3s ease}.skill-details-area{margin-top:1rem;padding:1rem 1.25rem;background:var(--theme-bg-secondary);border-radius:8px;border:1px solid var(--theme-accent2);animation:fadeIn .2s ease}.skill-description-text{margin-top:.75rem;text-align:center;font-size:.85rem;font-weight:500;color:var(--theme-accent2)}@media(max-width:768px){.skills-section{padding:.75rem;border-radius:8px;height:auto!important;overflow:visible!important;min-height:auto}.skills-section h3{font-size:.9rem;margin-bottom:.5rem}.skill-details-area{margin-top:.75rem;padding:.75rem}.skill-description-text{font-size:.8rem;margin-top:.5rem}}@media(max-width:480px){.skills-section{padding:.5rem}.skill-details-area{margin-top:.5rem;padding:.5rem}.skill-description-text{font-size:.75rem}}.project-card{background:var(--theme-bg-secondary);border-radius:12px;padding:2rem;border:1px solid var(--theme-border);transition:all .3s ease;position:relative;min-height:200px}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:var(--theme-accent2)}.project-card a{text-decoration:none;color:inherit;display:block}.project-card .project-info{display:flex;flex-direction:column;text-align:center;align-items:center}.project-logo{width:80px;height:80px;border-radius:12px;object-fit:cover;margin-bottom:1rem}.project-info h4{font-size:1.3rem;font-weight:600;color:var(--theme-text);margin-bottom:1rem;line-height:1.3;transition:color .3s ease}.project-info p{color:var(--theme-text-muted);font-size:1rem;line-height:1.6;margin-bottom:1.5rem;transition:color .3s ease}.project-tech{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:auto}@media(max-width:768px){.project-card{padding:1.5rem;min-height:auto}.project-logo{width:60px;height:60px;margin-bottom:.75rem}.project-info h4{font-size:1.1rem;margin-bottom:.75rem}.project-info p{font-size:.9rem;line-height:1.5;margin-bottom:1rem}}@media(max-width:480px){.project-card{padding:1rem}.project-info h4{font-size:1rem}.project-info p{font-size:.85rem}}.project-card.placeholder{border:2px dashed var(--theme-border);background:var(--theme-bg);transition:all .3s ease;position:relative;overflow:hidden}.project-card.placeholder:hover{border-color:var(--theme-accent2);background:var(--theme-bg-secondary)}.coming-soon-badge{position:absolute;top:0;left:0;background:var(--theme-accent2);color:var(--theme-bg);font-size:.7rem;font-weight:600;padding:.35rem .75rem;border-radius:0 0 8px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #0003}@media(max-width:480px){.coming-soon-badge{font-size:.6rem;padding:.25rem .5rem}}.projects-section{margin-bottom:3rem;animation:fadeInUp .6s ease .6s both}.projects-section h3{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.projects-section h3 a{color:var(--theme-accent);text-decoration:none;cursor:pointer;transition:color .3s ease}.projects-section h3 a:hover{color:var(--theme-accent-hover)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}@media(max-width:768px){.projects-section h3{font-size:1.3rem;margin-bottom:1rem}.projects-grid{grid-template-columns:1fr;gap:1rem}}#code-block-section{padding:1rem;border-radius:10px;background:var(--theme-bg-secondary);box-shadow:0 4px 20px #00000026;border:1px solid var(--theme-border);transition:background-color .3s ease,border-color .3s ease;max-width:100%;overflow:hidden}#code-block-section h3{margin:0 0 .5rem;color:var(--theme-text);font-size:1rem;transition:color .3s ease}@media(max-width:768px){#code-block-section{padding:.75rem;border-radius:8px}}@media(max-width:480px){#code-block-section{padding:.5rem}.code-block-actions{padding-top:.5rem}}.code-block{margin:.25rem 0;border-radius:6px;overflow:hidden;max-width:100%}.code-block pre{margin:0;border-radius:6px;max-width:100%;overflow-x:auto}.code-block code{font-family:Fira Code,Monaco,Consolas,monospace;font-size:.8rem;line-height:1.5;display:block;overflow-x:auto;padding:.75rem 1rem;text-align:start;tab-size:2;white-space:pre-wrap;word-break:break-word}@media(max-width:768px){.code-block code{font-size:.75rem;padding:.6rem .75rem}}@media(max-width:480px){.code-block code{font-size:.7rem;padding:.5rem}}.code-block-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem .75rem;background:var(--theme-bg);border-radius:6px;margin-bottom:.5rem;border:1px solid var(--theme-border);transition:background-color .3s ease,border-color .3s ease;max-width:100%;box-sizing:border-box}@media(max-width:768px){.code-block-header{flex-direction:column;gap:.5rem;padding:.5rem}}@media(max-width:480px){.code-block-header{padding:.4rem}}.code-theme-switcher{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--theme-bg-secondary);border:2px solid var(--theme-accent2);border-radius:8px;box-shadow:0 2px 12px #00000026;transition:all .3s ease;max-width:100%;box-sizing:border-box}.code-theme-switcher:hover{box-shadow:0 4px 20px #00000040;transform:translateY(-2px)}.theme-icon{font-size:1.1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.code-theme-switcher label{font-weight:600;font-size:.75rem;color:var(--theme-accent);text-transform:uppercase;letter-spacing:.5px;transition:color .3s ease}.code-theme-switcher select{padding:.4rem .75rem;border:1px solid var(--theme-border);border-radius:6px;background-color:var(--theme-bg);color:var(--theme-text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;min-width:160px}.code-theme-switcher select:hover{border-color:var(--theme-accent);background-color:var(--theme-bg-secondary)}.code-theme-switcher select:focus{outline:none;border-color:var(--theme-accent);box-shadow:0 0 0 3px #00000026}@media(max-width:768px){.code-theme-switcher{padding:.35rem .5rem}.code-theme-switcher select{min-width:110px;font-size:.75rem;padding:.35rem .5rem}.code-theme-switcher label{font-size:.65rem}.theme-icon{font-size:.9rem}}@media(max-width:480px){.code-theme-switcher{flex-direction:column;align-items:stretch;width:100%;padding:.5rem}.code-theme-switcher label{text-align:center;margin-bottom:.25rem}.code-theme-switcher select{width:100%;min-width:auto}.theme-icon{display:none}}.download-cv-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:var(--theme-bg);background:var(--theme-accent2);border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;box-shadow:0 3px 12px #0003}.download-cv-button:hover{transform:translateY(-2px);background:var(--theme-accent2-hover);box-shadow:0 5px 16px #00000040}.download-cv-button:active{transform:translateY(0);box-shadow:0 2px 8px #0003}@media(max-width:768px){.download-cv-button{padding:.45rem 1rem;font-size:.8rem}}@media(max-width:480px){.download-cv-button{width:100%;padding:.5rem .75rem}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.skip-link{position:absolute;top:-100px;left:50%;transform:translate(-50%);background:var(--theme-accent);color:var(--theme-bg);padding:.75rem 1.5rem;border-radius:0 0 8px 8px;z-index:1000;font-weight:600;text-decoration:none;transition:top .3s ease}.skip-link:focus{top:0;outline:none}*:focus-visible{outline:2px solid var(--theme-accent);outline-offset:2px}button:focus-visible,a:focus-visible,select:focus-visible{outline:2px solid var(--theme-accent);outline-offset:2px}html,body{overflow-x:hidden}body{background:var(--theme-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--theme-text);line-height:1.6;transition:background-color .3s ease,color .3s ease}.app-container{display:flex;min-height:100vh;background:var(--theme-bg);transition:background-color .3s ease}.email-icon{font-size:1.2rem}.main-content{margin-left:280px;flex:1;padding:3rem;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;width:calc(100vw - 280px);background:var(--theme-bg);transition:margin-left .3s ease,width .3s ease,background-color .3s ease}.sidebar-collapsed .main-content{margin-left:0;width:100vw}.content-section{max-width:1100px;width:100%;text-align:center}.two-column-section{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;align-items:stretch;margin-bottom:2rem;animation:fadeInUp .6s ease .4s both;max-width:100%;overflow:hidden}.tech-tag{background:var(--theme-bg-secondary);color:var(--theme-text);padding:.5rem 1rem;border-radius:16px;font-size:.85rem;font-weight:500;border:1px solid var(--theme-border);transition:background-color .3s ease,color .3s ease}.toggle-button{background:var(--theme-bg-secondary);border-color:var(--theme-border);color:var(--theme-text);transition:all .3s ease}.toggle-button:hover{background:var(--theme-accent);color:var(--theme-bg);border-color:var(--theme-accent)}@media(max-width:768px){.main-content{margin-left:0;padding:1.5rem 1rem;width:100%;min-height:auto}.app-container{flex-direction:column;max-width:100vw;overflow-x:hidden}.content-section{max-width:100%;padding:0;overflow-x:hidden}.two-column-section{grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}.tech-tag{font-size:.75rem;padding:.3rem .7rem}.social-link{width:40px;height:40px}.email-icon{font-size:1rem}.social-icon{width:18px;height:18px}}@media(max-width:480px){.main-content{padding:1rem .75rem}.tech-tag{font-size:.7rem;padding:.25rem .5rem}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--theme-bg, #1a1a2e);padding:2rem}.error-content{text-align:center;max-width:400px;padding:2rem;background:var(--theme-bg-secondary, #16213e);border-radius:12px;border:1px solid var(--theme-border, #0f3460);box-shadow:0 4px 20px #0000004d}.error-icon{font-size:3rem;display:block;margin-bottom:1rem}.error-content h1{color:var(--theme-text, #e4e4e7);font-size:1.5rem;margin-bottom:.75rem}.error-content p{color:var(--theme-text-muted, #a1a1aa);font-size:1rem;margin-bottom:1.5rem;line-height:1.5}.error-button{background:var(--theme-accent, #667eea);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.error-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}
