:root{--bg-primary:#fff;--bg-secondary:#f5f7fa;--text-primary:#1a202c;--text-secondary:#4a5568;--accent-primary:#3b82f6;--accent-hover:#2563eb;--border-color:#e2e8f0;--shadow:#0000001a;--card-bg:#fff}[data-theme=dark]{--bg-primary:#1a202c;--bg-secondary:#2d3748;--text-primary:#f7fafc;--text-secondary:#e2e8f0;--accent-primary:#60a5fa;--accent-hover:#3b82f6;--border-color:#4a5568;--shadow:#0000004d;--card-bg:#2d3748}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--bg-primary);color:#1a202c;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;transition:background-color .3s ease,color .3s ease}code{background-color:#f5f7fa;background-color:var(--bg-secondary);border-radius:4px;font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.9em;padding:2px 6px}a{color:#3b82f6;color:var(--accent-primary);text-decoration:none;transition:color .2s ease}a:hover{color:#2563eb;color:var(--accent-hover)}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section{padding:80px 0}.section-title{color:#1a202c;color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-align:center}.section-subtitle{color:#4a5568;color:var(--text-secondary);font-size:1.125rem;margin:0 auto 3rem;max-width:600px;text-align:center}html{scroll-behavior:smooth}.btn{background-color:#3b82f6;background-color:var(--accent-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:12px 24px;text-align:center;transition:all .3s ease}.btn:hover{background-color:#2563eb;background-color:var(--accent-hover);box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.btn-outline{background-color:initial;border:2px solid #3b82f6;border:2px solid var(--accent-primary);color:#3b82f6;color:var(--accent-primary)}.btn-outline:hover{background-color:#3b82f6;background-color:var(--accent-primary);color:#fff}.App{display:flex;flex-direction:column;min-height:100vh}main{flex:1 1}.footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:4rem;padding:2rem 0;text-align:center}.footer p{color:var(--text-secondary);font-size:.9rem}.header{background-color:var(--bg-primary);border-bottom:1px solid #0000;left:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.header.scrolled{border-bottom-color:var(--border-color);box-shadow:0 2px 20px var(--shadow)}.header-content{justify-content:space-between;padding:1.25rem 0}.header-content,.logo{align-items:center;display:flex}.logo{cursor:pointer}.logo-text{color:var(--accent-primary);font-size:1.5rem;font-weight:700}.nav{align-items:center;display:flex;gap:2rem}.nav-link{background:none;border:none;color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:500;padding:.5rem 0;position:relative;transition:color .2s ease}.nav-link:after{background-color:var(--accent-primary);bottom:0;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-link:hover{color:var(--accent-primary)}.nav-link:hover:after{width:100%}.mobile-menu-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:4px;padding:.5rem}.mobile-menu-toggle span{background-color:var(--text-primary);border-radius:2px;height:3px;transition:all .3s ease;width:25px}@media (max-width:768px){.mobile-menu-toggle{display:flex}.nav{background-color:var(--bg-primary);box-shadow:0 4px 20px var(--shadow);flex-direction:column;gap:1.5rem;left:0;padding:2rem;position:fixed;right:0;top:70px;transform:translateX(-100%);transition:transform .3s ease}.nav.mobile-open{transform:translateX(0)}.nav-link{font-size:1.125rem;text-align:left;width:100%}}.theme-toggle{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .3s ease}.theme-toggle:hover{background-color:var(--bg-secondary);transform:rotate(15deg)}.theme-icon{color:var(--text-primary);transition:transform .3s ease}.hero{align-items:center;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding-top:80px;position:relative}.hero:before{animation:float 20s ease-in-out infinite;background:radial-gradient(circle,var(--accent-primary) 0,#0000 70%);content:"";height:100%;opacity:.1;position:absolute;right:-50%;top:-50%;width:100%}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(-50px,50px)}}.hero-content{animation:fadeInUp 1s ease-out;max-width:800px;position:relative;text-align:center;z-index:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-title{color:var(--text-primary);font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.hero-title .accent{color:var(--accent-primary);display:inline-block}.hero-subtitle{color:var(--text-secondary);font-size:2rem;font-weight:600;margin-bottom:1.5rem}.hero-description{color:var(--text-secondary);font-size:1.25rem;line-height:1.8;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;max-width:600px}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.5rem}.hero-description{font-size:1.125rem}.hero-buttons{align-items:center;flex-direction:column}.hero-buttons .btn{max-width:300px;width:100%}}@media (max-width:480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1.25rem}}.about{background-color:var(--bg-primary)}.about-content{margin:0 auto;max-width:800px}.about-text p{color:var(--text-secondary);font-size:1.125rem;line-height:1.8;margin-bottom:1.5rem}.cv-section{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px var(--shadow);margin-top:3rem;padding:2rem}.cv-section h3{color:var(--text-primary);font-size:1.75rem;margin-bottom:1.5rem}.cv-highlights{list-style:none;margin-bottom:2rem}.cv-highlights li{border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:1.125rem;padding:.75rem 0}.cv-highlights li:last-child{border-bottom:none}.cv-highlights strong{color:var(--text-primary)}.cv-section .btn{margin-top:1rem}@media (max-width:768px){.about-text p{font-size:1rem}.cv-section{padding:1.5rem}.cv-section h3{font-size:1.5rem}.cv-highlights li{font-size:1rem}}.skills{background-color:var(--bg-secondary)}.skills-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.skill-category{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px var(--shadow);padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.skill-category:hover{box-shadow:0 6px 20px var(--shadow);transform:translateY(-5px)}.category-title{border-bottom:2px solid var(--accent-primary);color:var(--accent-primary);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem}.skills-list{display:flex;flex-direction:column;gap:1.5rem}.skill-item{width:100%}.skill-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.skill-name{color:var(--text-primary);font-size:1rem;font-weight:500}.skill-level{color:var(--accent-primary);font-size:.875rem;font-weight:600}.skill-bar{background-color:var(--bg-secondary);border-radius:4px;height:8px;overflow:hidden;width:100%}.skill-progress{animation:slideIn 1.5s ease-out;background:linear-gradient(90deg,var(--accent-primary),var(--accent-hover));border-radius:4px;height:100%;transition:width 1s ease}@keyframes slideIn{0%{width:0}}@media (max-width:768px){.skills-grid{grid-template-columns:1fr}.skill-category{padding:1.5rem}.category-title{font-size:1.25rem}}.projects{background-color:var(--bg-primary)}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin:0 auto;max-width:1200px}.project-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px var(--shadow);display:flex;flex-direction:column;padding:2rem;transition:all .3s ease}.project-card:hover{box-shadow:0 8px 24px var(--shadow);transform:translateY(-8px)}.project-card.featured{border:2px solid var(--accent-primary)}.project-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.project-title{color:var(--text-primary);flex:1 1;font-size:1.5rem;font-weight:600}.project-status{border-radius:20px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase;white-space:nowrap}.project-description{color:var(--text-secondary);flex:1 1;line-height:1.7;margin-bottom:1.5rem}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{font-weight:500;padding:.375rem .75rem}.project-links{display:flex;gap:1rem;margin-top:auto}.project-link{align-items:center;background-color:var(--accent-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;padding:.625rem 1.25rem;text-decoration:none;transition:all .3s ease}.project-link:hover{background-color:var(--accent-hover);color:#fff;transform:translateY(-2px)}.project-link svg{height:18px;width:18px}.project-link-showcase{background:linear-gradient(135deg,#667eea,#764ba2)}.project-link-showcase:hover{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 4px 15px #667eea66}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}.project-card{padding:1.5rem}.project-header,.project-links{flex-direction:column}}.showcase-page{background-color:var(--bg-primary);bottom:0;left:0;opacity:0;overflow-y:auto;position:fixed;right:0;top:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease;z-index:2000}.showcase-page.visible{opacity:1;transform:translateY(0)}.showcase-header{background-color:var(--card-bg);border-bottom:1px solid var(--border-color);box-shadow:0 2px 10px var(--shadow);padding:1.5rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.showcase-header-content{align-items:center;display:flex;gap:2rem;justify-content:space-between}.showcase-back-btn{align-items:center;background:none;border:none;border-radius:8px;color:var(--accent-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1rem;transition:all .3s ease}.showcase-back-btn:hover{background-color:var(--bg-secondary);transform:translateX(-4px)}.showcase-back-btn svg{transition:transform .3s ease}.showcase-back-btn:hover svg{transform:translateX(-4px)}.showcase-header-info{align-items:center;display:flex;flex:1 1;gap:1rem}.showcase-header-info h1{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.showcase-status{border-radius:20px;font-size:.75rem;font-weight:600;padding:.375rem .875rem;text-transform:uppercase;white-space:nowrap}.status-completed{background-color:#10b98144;color:#059669}.status-in-development{background-color:#3b82f644;color:#2563eb}.status-planned{background-color:#f59e0b44;color:#d97706}.showcase-header-actions{display:flex;gap:.75rem}.showcase-header-link{align-items:center;background-color:var(--accent-primary);border-radius:8px;color:#fff;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;text-decoration:none;transition:all .3s ease}.showcase-header-link:hover{background-color:var(--accent-hover);box-shadow:0 4px 12px var(--shadow);color:#fff;transform:translateY(-2px)}.showcase-main{background-color:var(--bg-primary);min-height:calc(100vh - 200px);padding:3rem 0}.showcase-content-wrapper{margin:0 auto;max-width:900px}.showcase-tech-tags{border-bottom:2px solid var(--border-color);display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:3rem;padding-bottom:2rem}.tech-tag{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--accent-primary);font-size:.875rem;font-weight:600;padding:.5rem 1rem}.showcase-markdown-content{color:var(--text-primary);font-size:1.0625rem;line-height:1.8}.showcase-markdown-content h1{border-bottom:3px solid var(--accent-primary);color:var(--text-primary);font-size:2.5rem;font-weight:700;margin:2rem 0 1.5rem;padding-bottom:.5rem}.showcase-markdown-content h2{color:var(--text-primary);font-size:2rem;font-weight:600;margin:2.5rem 0 1.25rem}.showcase-markdown-content h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:2rem 0 1rem}.showcase-markdown-content h4{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem}.showcase-markdown-content p{color:var(--text-secondary);line-height:1.8;margin:1.25rem 0}.showcase-markdown-content ol,.showcase-markdown-content ul{margin:1.25rem 0;padding-left:2rem}.showcase-markdown-content li{color:var(--text-secondary);line-height:1.7;margin:.75rem 0}.showcase-markdown-content ul li::marker{color:var(--accent-primary)}.showcase-markdown-content ol li::marker{color:var(--accent-primary);font-weight:600}.showcase-markdown-content a{border-bottom:1px solid var(--accent-primary);color:var(--accent-primary);text-decoration:none;transition:all .2s ease}.showcase-markdown-content a:hover{border-bottom-color:var(--accent-hover);color:var(--accent-hover)}.showcase-markdown-content img{border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 20px var(--shadow);height:auto;margin:2rem 0;max-width:100%}.showcase-markdown-content code{background-color:var(--bg-secondary);border-radius:4px;color:var(--accent-primary);font-family:Courier New,monospace;font-size:.9em;padding:.25rem .5rem}.showcase-markdown-content pre{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin:1.5rem 0;overflow-x:auto;padding:1.5rem}.showcase-markdown-content pre code{background:none;color:var(--text-primary);padding:0}.showcase-markdown-content blockquote{border-left:4px solid var(--accent-primary);color:var(--text-secondary);font-style:italic;margin:1.5rem 0;padding-left:1.5rem}.showcase-markdown-content hr{border:none;border-top:2px solid var(--border-color);margin:3rem 0}.showcase-markdown-content table{border-collapse:collapse;margin:2rem 0;width:100%}.showcase-markdown-content table td,.showcase-markdown-content table th{border:1px solid var(--border-color);padding:.75rem;text-align:left}.showcase-markdown-content table th{background-color:var(--bg-secondary);color:var(--text-primary);font-weight:600}.showcase-markdown-content table td{color:var(--text-secondary)}.showcase-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{animation:spin .8s linear infinite;border:4px solid var(--bg-secondary);border-radius:50%;border-top-color:var(--accent-primary);height:48px;margin-bottom:1rem;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.showcase-loading p{color:var(--text-secondary);font-size:1.125rem}.showcase-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:4rem;padding:2rem 0}.showcase-footer-back{background:none;border:none;border-radius:8px;color:var(--accent-primary);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.showcase-footer-back:hover{background-color:var(--bg-primary);transform:translateX(-4px)}@media (max-width:768px){.showcase-header-content{align-items:flex-start;flex-direction:column;gap:1rem}.showcase-header-info{align-items:flex-start;flex-direction:column;width:100%}.showcase-header-info h1{font-size:1.5rem}.showcase-header-actions{flex-direction:column;width:100%}.showcase-header-link{justify-content:center;width:100%}.showcase-back-btn span{display:none}.showcase-main{padding:2rem 0}.showcase-markdown-content h1{font-size:2rem}.showcase-markdown-content h2{font-size:1.5rem}.showcase-markdown-content{font-size:1rem}}.showcase-page{scrollbar-color:var(--accent-primary) var(--bg-secondary);scrollbar-width:thin}.showcase-page::-webkit-scrollbar{width:10px}.showcase-page::-webkit-scrollbar-track{background:var(--bg-secondary)}.showcase-page::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:5px}.showcase-page::-webkit-scrollbar-thumb:hover{background:var(--accent-hover)}.contact{background-color:var(--bg-secondary)}.contact-content{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.contact-info{display:flex;flex-direction:column;gap:2rem}.contact-item{align-items:flex-start;background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:1.5rem;padding:1.5rem;transition:all .3s ease}.contact-item:hover{box-shadow:0 4px 12px var(--shadow);transform:translateX(5px)}.contact-icon{align-items:center;background-color:var(--accent-primary);border-radius:10px;color:#fff;display:flex;height:48px;justify-content:center;min-width:48px}.contact-item h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.contact-item a{color:var(--accent-primary);font-size:1rem;word-break:break-all}.contact-item p{color:var(--text-secondary);font-size:1rem}.contact-cta{align-items:center;background-color:var(--card-bg);border:2px solid var(--accent-primary);border-radius:12px;box-shadow:0 4px 12px var(--shadow);display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.contact-cta h3{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:1.5rem}.contact-cta p{color:var(--text-secondary);font-size:1.125rem;line-height:1.8;margin-bottom:2rem;max-width:400px}@media (max-width:968px){.contact-content{gap:3rem;grid-template-columns:1fr}.contact-cta{padding:2rem}.contact-cta h3{font-size:1.75rem}}@media (max-width:768px){.contact-item{align-items:center;flex-direction:column;text-align:center}.contact-icon{margin-bottom:.5rem}}
/*# sourceMappingURL=main.6f214cf9.css.map*/