@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap);.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.w-full{width:100%}.h-full{height:100%}.max-w-full{max-width:100%}.max-h-full{max-height:100%}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d}.shadow-md{box-shadow:0 4px 6px -1px #0000001a}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}@media (min-width:640px){.sm\\:block{display:block}.sm\\:hidden{display:none}.sm\\:flex{display:flex}.sm\\:grid{display:grid}}@media (min-width:768px){.md\\:block{display:block}.md\\:hidden{display:none}.md\\:flex{display:flex}.md\\:grid{display:grid}.md\\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\\:block{display:block}.lg\\:hidden{display:none}.lg\\:flex{display:flex}.lg\\:grid{display:grid}.lg\\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}:focus-visible{outline:2px solid #3182ce;outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-bg:#fff;--secondary-bg:#f8fafc;--card-bg:#fff;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#718096;--accent:#3182ce;--accent-hover:#2c5aa0;--border:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--section-padding:5rem 0;--container-padding:0 1.5rem;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}.dark{--primary-bg:#0f172a;--secondary-bg:#1e293b;--card-bg:#1e293b;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#64748b;--accent:#60a5fa;--accent-hover:#3b82f6;--border:#334155;--border-light:#475569;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0000004d}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--primary-bg);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}body,h1,h2,h3,h4,h5,h6{color:#1a202c;color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:1rem}h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:2rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{color:#4a5568;color:var(--text-secondary);margin-bottom:1rem}.text-primary{color:#1a202c;color:var(--text-primary)}.text-secondary{color:#4a5568;color:var(--text-secondary)}.text-muted{color:#718096;color:var(--text-muted)}.container{margin:0 auto;max-width:1200px;padding:0 1.5rem;padding:var(--container-padding)}.section{padding:5rem 0;padding:var(--section-padding)}.section-title{margin-bottom:3rem;text-align:center}.section-subtitle{color:#718096;color:var(--text-muted);font-size:1.125rem;margin-bottom:4rem;text-align:center}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fff;background-color:var(--primary-bg);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);left:0;position:fixed;right:0;top:0;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);z-index:1000}.header-content{align-items:center;display:flex;justify-content:space-between;padding:1rem 0}.logo{color:#1a202c;color:var(--text-primary);font-size:1.5rem;font-weight:700;text-decoration:none}.nav{align-items:center;display:flex;gap:2rem}.nav-link{border-radius:.5rem;color:#4a5568;color:var(--text-secondary);font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.nav-link.active,.nav-link:hover{background-color:#f1f5f9;background-color:var(--border-light);color:#3182ce;color:var(--accent)}.dark-toggle{background:none;border:none;border-radius:.5rem;color:#4a5568;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;padding:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.dark-toggle:hover{background-color:#f1f5f9;background-color:var(--border-light);color:#3182ce;color:var(--accent)}.hero{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);background:linear-gradient(135deg,var(--primary-bg) 0,var(--secondary-bg) 100%);display:flex;min-height:100vh;padding-top:5rem}.hero-content{margin:0 auto;max-width:800px;text-align:center}.hero-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3182ce,#2c5aa0);background:linear-gradient(135deg,var(--accent) 0,var(--accent-hover) 100%);-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:800;margin-bottom:1.5rem}.hero-subtitle{color:#4a5568;color:var(--text-secondary);font-size:1.25rem;margin-bottom:2rem}.hero-description{color:#718096;color:var(--text-muted);font-size:1.125rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:600px}.btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.btn-primary{background-color:#3182ce;background-color:var(--accent);color:#fff}.btn-primary:hover{background-color:#2c5aa0;background-color:var(--accent-hover);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background-color:initial;border:2px solid #3182ce;border:2px solid var(--accent);color:#3182ce;color:var(--accent)}.btn-secondary:hover{background-color:#3182ce;background-color:var(--accent);color:#fff;transform:translateY(-2px)}.card{background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:1rem;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.card:hover{border-color:#3182ce;border-color:var(--accent);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-card{background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:1rem;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.project-card:hover{border-color:#3182ce;border-color:var(--accent);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-image{height:200px;object-fit:cover;width:100%}.project-content{padding:1.5rem}.project-title{color:#1a202c;color:var(--text-primary);font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.project-description{color:#4a5568;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-tag{background-color:#3182ce;background-color:var(--accent);border-radius:1rem;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.tech-tag:hover{background-color:#2c5aa0;background-color:var(--accent-hover);transform:translateY(-1px)}.project-metrics{grid-gap:1rem;border-top:1px solid #f1f5f9;border-top:1px solid var(--border-light);display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin:1rem 0;padding:1rem 0}.metric{text-align:center}.metric-value{color:#3182ce;color:var(--accent);font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.metric-label{color:#718096;color:var(--text-muted);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.project-link{border:2px solid #3182ce;border:2px solid var(--accent);border-radius:.5rem;color:#3182ce;color:var(--accent);display:inline-block;font-weight:600;margin-top:1rem;padding:.5rem 1rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.project-link:hover{background-color:#3182ce;background-color:var(--accent);color:#fff;transform:translateY(-2px)}.project-link-disabled{border:2px solid #e2e8f0;border:2px solid var(--border);border-radius:.5rem;color:#718096;color:var(--text-muted);cursor:not-allowed;display:inline-block;font-weight:600;margin-top:1rem;opacity:.7;padding:.5rem 1rem}.grid{grid-gap:2rem;display:grid;gap:2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4,.skills-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.skills-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.skill-card{background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:1rem;padding:1.5rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.skill-card:hover{border-color:#3182ce;border-color:var(--accent);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.skill-icon{font-size:2rem;margin-bottom:1rem}.skill-title{color:#1a202c;color:var(--text-primary);font-weight:600;margin-bottom:.5rem}.skill-description{color:#4a5568;color:var(--text-secondary);font-size:.875rem}.timeline{margin:0 auto;max-width:800px;position:relative}.timeline:before{background-color:#e2e8f0;background-color:var(--border);bottom:0;content:"";left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}.timeline-item{margin-bottom:3rem;position:relative;width:50%}.timeline-item:nth-child(odd){left:0;padding-right:2rem}.timeline-item:nth-child(2n){left:50%;padding-left:2rem}.timeline-content{background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:1rem;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.timeline-content:hover{border-color:#3182ce;border-color:var(--accent);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.timeline-dot{background-color:#3182ce;background-color:var(--accent);border:3px solid #fff;border:3px solid var(--primary-bg);border-radius:50%;height:1rem;position:absolute;top:1.5rem;width:1rem}.timeline-item:nth-child(odd) .timeline-dot{right:-.5rem}.timeline-item:nth-child(2n) .timeline-dot{left:-.5rem}.certification-card{align-items:center;background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:1rem;display:flex;gap:1rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.certification-card:hover{border-color:#3182ce;border-color:var(--accent);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.certification-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:3rem;justify-content:center;width:3rem}.certification-content{flex:1 1}.certification-title{color:#1a202c;color:var(--text-primary);font-weight:600;margin-bottom:.25rem}.certification-issuer{color:#4a5568;color:var(--text-secondary);font-size:.875rem}.contact-form{margin:0 auto;max-width:600px}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-weight:600;margin-bottom:.5rem}.form-input,.form-label,.form-textarea{color:#1a202c;color:var(--text-primary)}.form-input,.form-textarea{background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;padding:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}.form-input:focus,.form-textarea:focus{border-color:#3182ce;border-color:var(--accent);box-shadow:0 0 0 3px #3182ce1a;outline:none}.form-textarea{min-height:120px;resize:vertical}.contact-info{align-items:center;background-color:#fff;background-color:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.5rem;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.contact-info:hover{border-color:#3182ce;border-color:var(--accent);transform:translateY(-1px)}.contact-icon{color:#3182ce;color:var(--accent);flex-shrink:0;height:2rem;width:2rem}.contact-text{color:#4a5568;color:var(--text-secondary)}.footer{background-color:#f8fafc;background-color:var(--secondary-bg);border-top:1px solid #e2e8f0;border-top:1px solid var(--border);padding:2rem 0;text-align:center}.footer-content{color:#718096;color:var(--text-muted)}.scroll-top{align-items:center;background-color:#3182ce;background-color:var(--accent);border-radius:50%;bottom:2rem;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;display:flex;height:3rem;justify-content:center;position:fixed;right:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:3rem;z-index:1000}.scroll-top:hover{background-color:#2c5aa0;background-color:var(--accent-hover);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.mobile-menu-toggle{background:none;border:none;color:#1a202c;color:var(--text-primary);cursor:pointer;display:none;font-size:1.5rem}.mobile-menu{background-color:#fff;background-color:var(--primary-bg);bottom:0;display:none;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:2000}.mobile-menu.active{align-items:center;display:flex;flex-direction:column;justify-content:center}.mobile-menu-close{background:none;border:none;color:#1a202c;color:var(--text-primary);cursor:pointer;font-size:1.5rem;position:absolute;right:1rem;top:1rem}.mobile-nav{display:flex;flex-direction:column;gap:1rem;text-align:center}.mobile-nav-link{border-radius:.5rem;color:#1a202c;color:var(--text-primary);font-size:1.25rem;padding:1rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.mobile-nav-link:hover{background-color:#f1f5f9;background-color:var(--border-light);color:#3182ce;color:var(--accent)}@media (max-width:768px){.nav{display:none}.mobile-menu-toggle{display:block}.hero-title{font-size:2.5rem}.timeline:before{left:1rem}.timeline-item{left:0!important;padding-left:3rem!important;padding-right:0!important;width:100%}.timeline-dot{left:.5rem!important}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.container{padding:0 1rem}.section{padding:3rem 0}}@media (max-width:480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.btn{font-size:.875rem;padding:.5rem 1rem}.card{padding:1rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .6s ease-out}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
/*# sourceMappingURL=main.32712ce2.css.map*/