*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#2563eb;--primary-dark:#1d4ed8;--secondary-color:#0ea5e9;--text-primary:#0f172a;--text-secondary:#475569;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-dark:#111827;--border-color:#e2e8f0;--shadow:0 8px 24px #0f172a14;--shadow-lg:0 18px 40px #0f172a1f}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;scroll-behavior:smooth}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{scroll-behavior:smooth}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#2563eb;background:var(--primary-color);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#1d4ed8;background:var(--primary-dark)}.App{overflow-x:hidden;width:100%}section{margin:0 auto;max-width:1200px;padding:clamp(64px,8vw,92px) 20px}.section-header{margin-bottom:clamp(2rem,5vw,3.25rem);text-align:center}.section-title{color:var(--text-primary);font-size:clamp(1.8rem,4vw,2.45rem);font-weight:700;letter-spacing:-.02em;margin-bottom:.85rem}.section-divider{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:999px;height:3px;margin:0 auto;width:72px}.section-subtitle{color:var(--text-secondary);font-size:1.03rem;line-height:1.75;margin:1rem auto 0;max-width:720px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in-up{animation:fadeInUp .6s ease-out}.fade-in{animation:fadeIn .6s ease-out}@media (max-width:768px){section{padding:clamp(56px,9vw,72px) 16px}}@media (prefers-reduced-motion:reduce){.fade-in,.fade-in-up{animation:none!important}}.navbar{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffeb;border-bottom:1px solid #0f172a0f;box-shadow:0 4px 16px #0f172a0f;left:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.navbar.scrolled{background:#fffffffa;border-bottom:1px solid #0f172a14;box-shadow:0 12px 24px #0f172a14}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:.9rem 1.4rem}.navbar-logo{color:var(--text-primary);cursor:pointer;font-size:1.5rem;gap:.5rem}.logo-text,.navbar-logo{align-items:center;display:flex;font-weight:700;transition:all .3s ease}.logo-text{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border-radius:11px;color:#fff;font-size:1.1rem;height:42px;justify-content:center;width:42px}.navbar-logo:hover .logo-text{box-shadow:0 4px 12px #6366f166;transform:rotate(5deg) scale(1.05)}.navbar-menu{align-items:center;display:flex;gap:1.45rem}.navbar-menu a{color:var(--text-primary);font-size:.95rem;font-weight:600;position:relative;text-decoration:none;transition:color .3s ease}.navbar-menu a:after{background:var(--primary-color);bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.navbar-menu a:hover{color:var(--primary-color)}.navbar-menu a:hover:after{width:100%}.navbar-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;padding:5px}.navbar-toggle span{background:var(--text-primary);border-radius:2px;height:3px;transition:all .3s ease;width:25px}@media (max-width:768px){.navbar-container{padding:.8rem 1rem}.navbar-toggle{display:flex}.navbar-menu{background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-lg);flex-direction:column;gap:1rem;left:12px;opacity:0;padding:1.2rem;position:absolute;right:12px;top:100%;transform:translateY(-12px);transition:all .3s ease;visibility:hidden}.navbar-menu.active{opacity:1;transform:translateY(0);visibility:visible}.navbar-toggle.active span:first-child{transform:rotate(45deg) translate(8px,8px)}.navbar-toggle.active span:nth-child(2){opacity:0}.navbar-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}}.hero{align-items:center;background:radial-gradient(circle at 85% 10%,#0ea5e921 0,#0000 38%),radial-gradient(circle at 10% 95%,#2563eb1a 0,#0000 44%),linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:120px 24px 80px;position:relative}.hero:before{animation:pulse 4s ease-in-out infinite;background:radial-gradient(circle,#2563eb1a 0,#0000 70%);content:"";height:100%;position:absolute;right:-50%;top:-50%;width:100%}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.hero:after{background:radial-gradient(circle,#7dd3fc42,#0000 70%);border-radius:999px;content:"";filter:blur(4px);height:420px;left:-140px;position:absolute;top:140px;width:420px}.hero-container{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;max-width:1200px;position:relative;width:100%;z-index:1}.hero-content{animation:slideInLeft .75s ease both;z-index:2}.hero-greeting{background:#dbeafecc;border:1px solid #bfdbfe;border-radius:999px;color:var(--primary-dark);font-size:.88rem;font-weight:700;letter-spacing:.03em;margin-bottom:.9rem;padding:.38rem .72rem;width:-webkit-fit-content;width:fit-content}.hero-name{color:var(--text-primary);font-size:4rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:.5rem}.hero-title{color:var(--primary-color);font-size:1.75rem;font-weight:500;letter-spacing:.02em;margin-bottom:1.5rem;text-transform:uppercase}.hero-description{color:var(--text-secondary);font-size:1.125rem;line-height:1.85;margin-bottom:1.25rem;max-width:600px}.hero-highlights{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:2rem}.hero-highlight-chip{align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;color:#1e3a8a;display:inline-flex;font-size:.8rem;font-weight:600;padding:.45rem .78rem}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.35rem}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.875rem 2rem;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background:var(--primary-color);box-shadow:0 8px 22px #2563eb42;color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 10px 24px #1d4ed852;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-secondary:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}.hero-social{display:flex;gap:.75rem}.hero-social a{align-items:center;background:#fff;border:1px solid #dbeafe;border-radius:50%;box-shadow:var(--shadow);color:var(--primary-dark);display:flex;font-size:1.05rem;height:40px;justify-content:center;transition:all .3s ease;width:40px}.hero-social a:hover{background:#2563eb;box-shadow:var(--shadow-lg);color:#fff;transform:translateY(-3px)}.hero-image{align-items:center;display:flex;justify-content:center;min-width:0}.hero-visual{animation:slideInRight .85s ease both;position:relative;width:min(100%,520px)}.hero-image-wrapper{animation:floatCard 5s ease-in-out infinite;aspect-ratio:1/1;background:linear-gradient(145deg,#fff,#eef2ff);border:1px solid #94a3b83d;border-radius:50%;box-shadow:0 20px 55px #1e293b33;overflow:hidden;padding:clamp(14px,2vw,24px);width:100%}.hero-photo{border-radius:50%;display:block;height:100%;object-fit:contain;transform:scale(1.01);width:100%}.hero-badge{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffe6;border-radius:999px;box-shadow:0 12px 24px #0f172a24;color:#0f172a;display:inline-flex;font-size:.76rem;font-weight:700;justify-content:center;letter-spacing:.03em;padding:.55rem 1rem;position:absolute;white-space:nowrap}.badge-top{animation:badgeDrift 6s ease-in-out infinite;left:-30px;top:16px}.badge-bottom{animation:badgeDrift 6s ease-in-out .8s infinite;bottom:24px;right:-34px}.scroll-indicator{align-items:center;bottom:30px;display:flex;flex-direction:column;gap:10px;left:50%;position:absolute;transform:translateX(-50%);z-index:1}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes badgeDrift{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}.mouse{border:2px solid var(--primary-color);border-radius:15px;height:50px;position:relative;width:30px}.mouse:before{animation:scroll 2s infinite;background:var(--primary-color);border-radius:2px;content:"";height:8px;left:50%;position:absolute;top:8px;transform:translateX(-50%);width:4px}@keyframes scroll{0%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(20px)}}@media (max-width:968px){.hero{padding:110px 20px 72px}.hero-container{gap:2.5rem;grid-template-columns:1fr;text-align:center}.hero-name{font-size:2.5rem}.hero-title{font-size:1.5rem}.hero-description{max-width:100%}.hero-buttons{justify-content:center}.hero-greeting{margin:0 auto .9rem}.hero-highlights,.hero-social{justify-content:center}.hero-image{margin-top:.5rem}.hero-visual{margin:0 auto;max-width:430px}.badge-top{left:10px}.badge-bottom{right:10px}}@media (max-width:480px){.hero{padding-top:95px}.hero-name{font-size:2rem}.hero-title{font-size:1.25rem}.hero-description{font-size:1rem}.btn{font-size:.9rem;padding:.75rem 1.5rem}.hero-badge{font-size:.68rem;padding:.45rem .7rem}.badge-top{left:8px;top:10px}.badge-bottom{bottom:10px;right:8px}}@media (prefers-reduced-motion:reduce){.badge-bottom,.badge-top,.hero-content,.hero-image-wrapper,.hero-visual,.hero:before,.mouse:before{animation:none!important}}.about{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow)}.about-content{grid-gap:clamp(1.5rem,4vw,3rem);align-items:start;display:grid;gap:clamp(1.5rem,4vw,3rem);grid-template-columns:2fr 1fr}.about-text{display:flex;flex-direction:column;gap:1.5rem}.about-intro{font-size:1.07rem}.about-intro,.about-text p{color:var(--text-secondary);line-height:1.85}.about-text p{font-size:1rem}.about-highlights{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.highlight-item{align-items:flex-start;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;display:flex;gap:1rem;padding:1.25rem;transition:transform .25s ease,box-shadow .25s ease}.highlight-item:hover{box-shadow:var(--shadow);transform:translateY(-3px)}.highlight-item i{color:var(--primary-color);font-size:1.5rem;margin-top:2px;min-width:30px}.highlight-item h3{color:var(--text-primary);font-size:1.08rem;font-weight:600;margin-bottom:.35rem}.highlight-item p{color:var(--text-secondary);margin:0}.about-stats{grid-gap:1rem;align-self:stretch;display:grid;gap:1rem;grid-template-columns:1fr}.stat-card{background:linear-gradient(165deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:14px;box-shadow:0 8px 18px #2563eb14;color:var(--text-primary);display:grid;min-height:132px;padding:1.5rem;place-content:center;text-align:center;transition:transform .25s ease,box-shadow .25s ease}.stat-card:hover{box-shadow:0 12px 24px #2563eb1f;transform:translateY(-3px)}.stat-number{color:var(--primary-dark);font-size:clamp(2rem,4vw,2.6rem);font-weight:700;margin-bottom:.35rem}.stat-label{color:var(--text-secondary);font-size:.95rem}@media (max-width:968px){.about-content{grid-template-columns:1fr}.about-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card{min-height:126px;padding:1.2rem}.stat-number{font-size:2rem}}@media (max-width:640px){.about-stats{grid-template-columns:1fr}.highlight-item{flex-direction:column;text-align:center}}.skills{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px}.skills-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:2.25rem}.skill-category{background:#fff;border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow);padding:1.4rem;transition:transform .25s ease,box-shadow .25s ease}.skill-category:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.skill-category-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;margin-bottom:1.25rem;padding-bottom:.85rem}.skill-category-header i{color:var(--primary-color);font-size:1.45rem}.skill-category-header h3{color:var(--text-primary);font-size:1.13rem;font-weight:600}.skill-list{display:flex;flex-direction:column;gap:1rem}.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:.92rem;font-weight:600}.skill-percentage{color:var(--text-secondary);font-size:.875rem;font-weight:500}.skill-bar{background:var(--bg-secondary);height:7px;overflow:hidden;width:100%}.skill-bar,.skill-progress{border-radius:4px;position:relative}.skill-progress{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));height:100%;transition:width 1s ease-out}.skill-progress:after{animation:shimmer 2.5s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}@media (max-width:768px){.skills-grid{grid-template-columns:1fr}}.projects{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow)}.featured-projects{grid-gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.featured-projects,.projects-grid{display:grid;gap:1.25rem;margin-top:2.25rem}.projects-grid{grid-gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.project-card{background:#fff;border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;padding:1.4rem;position:relative;transition:transform .25s ease,box-shadow .25s ease}.project-card:before{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.project-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.project-card:hover:before{transform:scaleX(1)}.project-card.featured{border-color:#bfdbfe}.project-badge{background:var(--bg-secondary);border-radius:20px;color:var(--primary-color);display:inline-block;font-size:.75rem;font-weight:600;margin-bottom:1rem;padding:.375rem .875rem;width:-webkit-fit-content;width:fit-content}.project-title{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin-bottom:.85rem}.project-description{color:var(--text-secondary);flex-grow:1;line-height:1.7;margin-bottom:1.1rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{background:#eff6ff;border:1px solid #dbeafe;border-radius:6px;color:var(--text-primary);font-size:.8rem;font-weight:500;padding:.375rem .75rem}.project-links{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:auto}.project-link{align-items:center;color:var(--primary-color);display:inline-flex;font-size:.88rem;font-weight:600;gap:.4rem;padding:.35rem 0;text-decoration:none;transition:color .2s ease}.project-link:hover{color:var(--primary-dark)}.project-link i{font-size:.78rem}.project-link-muted{color:var(--text-secondary);cursor:default}.project-store-link{background:#f8fbff;border:1px solid #dbeafe;border-radius:8px;padding:.5rem .75rem}.project-store-link.project-link-muted{background:#f8fafc;border-color:var(--border-color)}.more-projects-action{display:flex;justify-content:center;margin-top:2.2rem}.more-projects-btn{background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;color:var(--primary-dark);cursor:pointer;font-size:.9rem;font-weight:700;padding:.62rem 1.15rem;transition:background .2s ease,transform .2s ease,border-color .2s ease}.more-projects-btn:hover{background:#dbeafe;border-color:#93c5fd;transform:translateY(-2px)}.section-header-compact{margin-top:3.2rem}@media (max-width:768px){.featured-projects,.projects-grid{grid-template-columns:1fr}.project-card{padding:1.2rem}}.contact{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px}.contact-container{grid-gap:clamp(1.5rem,4vw,3rem);display:grid;gap:clamp(1.5rem,4vw,3rem);grid-template-columns:1fr 1.5fr;margin-top:2.25rem}.contact-info h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.contact-info>p{color:var(--text-secondary);line-height:1.8;margin-bottom:2rem}.contact-details{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.contact-item{align-items:flex-start;border-radius:12px;display:flex;gap:1rem;padding:.85rem;transition:background .2s ease}.contact-item:hover{background:#ffffff8c}.contact-icon{align-items:center;background:#dbeafe;border-radius:10px;color:var(--primary-dark);display:flex;flex-shrink:0;font-size:1rem;height:42px;justify-content:center;width:42px}.contact-text{display:flex;flex-direction:column;gap:.25rem}.contact-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.contact-value{color:var(--text-primary);font-size:.98rem;font-weight:600;text-decoration:none;transition:color .3s ease}.contact-value:hover{color:var(--primary-color)}.contact-social{display:flex;gap:1rem}.contact-social a{align-items:center;background:#fff;border-radius:50%;box-shadow:var(--shadow);color:var(--text-primary);display:flex;font-size:1.25rem;height:45px;justify-content:center;transition:all .3s ease;width:45px}.contact-social a:hover{background:var(--primary-color);box-shadow:var(--shadow-lg);color:#fff;transform:translateY(-5px)}.contact-form{background:#fff;border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow);padding:1.7rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-primary);display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-family:inherit;font-size:1rem;padding:.8rem .95rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1f;outline:none}.form-group textarea{min-height:120px;resize:vertical}.submit-btn{align-items:center;display:flex;font-size:1rem;gap:.5rem;justify-content:center;padding:1rem 2rem;width:100%}.submit-btn:disabled{cursor:not-allowed;opacity:.7}.form-success{align-items:center;background:#d1fae5;border-radius:8px;color:#065f46;display:flex;font-weight:500;gap:.5rem;margin-top:1rem;padding:1rem}.form-success i{font-size:1.25rem}.form-error{align-items:center;background:#fee2e2;border-radius:8px;color:#991b1b;display:flex;font-weight:500;gap:.5rem;margin-top:1rem;padding:1rem}.form-error i{font-size:1.25rem}@media (max-width:968px){.contact-container{grid-template-columns:1fr}.contact-form{padding:1.35rem}}@media (max-width:640px){.contact-form{padding:1.5rem}.contact-item{flex-direction:column;text-align:center}.contact-icon{margin:0 auto}}.footer{background:var(--bg-dark);color:#fff;margin-top:1.5rem;padding:2.6rem 20px 1.5rem}.footer-container{margin:0 auto;max-width:1200px}.footer-content{grid-gap:1.6rem;display:grid;gap:1.6rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem}.footer-section h3{color:#93c5fd;font-size:1.3rem;margin-bottom:1rem}.footer-section h4{color:#fff;font-size:1rem;margin-bottom:1rem}.footer-section p{color:#cbd5e1;line-height:1.75}.footer-section ul{display:flex;flex-direction:column;gap:.75rem;list-style:none}.footer-section ul a{color:#cbd5e1;text-decoration:none;transition:color .3s ease}.footer-section ul a:hover{color:#93c5fd}.footer-social{display:flex;gap:1rem}.footer-social a{align-items:center;background:#ffffff1f;border-radius:50%;color:#fff;display:flex;font-size:1.125rem;height:40px;justify-content:center;transition:all .3s ease;width:40px}.footer-social a:hover{background:#2563eb;transform:translateY(-3px)}.footer-bottom{align-items:center;border-top:1px solid #ffffff1a;color:#94a3b8;display:flex;flex-wrap:wrap;font-size:.875rem;gap:1rem;justify-content:space-between;padding-top:1.5rem}@media (max-width:640px){.footer-bottom{flex-direction:column;text-align:center}}
/*# sourceMappingURL=main.fcc6075a.css.map*/