body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--accent:#3b82f6;--accent-hover:#2563eb;--card-bg:#fffc;--glow:#3b82f633;--shadow:#0000000d}.portfolio-wrapper{background:#f8fafc;background:var(--bg-primary);background-image:radial-gradient(at 40% 20%,#3b82f633 0,#0000 50%),radial-gradient(at 80% 0,#0ea5e933 0,#0000 50%),radial-gradient(at 0 50%,#2563eb33 0,#0000 50%);color:#1e293b;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh;overflow-x:hidden;position:relative}.portfolio-wrapper:before{animation:backgroundShift 20s ease-in-out infinite;background:radial-gradient(circle at 20% 80%,#3b82f614 0,#0000 50%),radial-gradient(circle at 80% 20%,#0ea5e914 0,#0000 50%),radial-gradient(circle at 40% 40%,#2563eb14 0,#0000 50%)}.portfolio-wrapper:after,.portfolio-wrapper:before{content:"";height:100%;left:0;position:fixed;top:0;width:100%;z-index:-1}.portfolio-wrapper:after{background-image:linear-gradient(#3b82f608 1px,#0000 0),linear-gradient(90deg,#3b82f608 1px,#0000 0);background-size:50px 50px;opacity:.5}@keyframes backgroundShift{0%,to{transform:rotate(0deg) scale(1)}50%{transform:rotate(5deg) scale(1.1)}}.container{margin:0 auto;max-width:1200px;padding:2rem;position:relative;z-index:1}header{animation:fadeInDown 1s ease-out;margin-bottom:5rem;text-align:center}h1{color:#000;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;letter-spacing:-.02em;margin-bottom:1rem}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.subtitle{color:#64748b;color:var(--text-secondary);font-size:1.25rem;font-weight:400;letter-spacing:.05em}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:4rem}.project-card{animation:fadeInUp .8s ease-out forwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;background:var(--card-bg);border:1px solid #0000000f;border-radius:1.5rem;box-shadow:0 4px 6px #0000000d,0 10px 15px #00000008;cursor:pointer;opacity:0;overflow:hidden;padding:0;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-card:first-child{animation-delay:.1s}.project-card:nth-child(2){animation-delay:.2s}.project-card:nth-child(3){animation-delay:.3s}.gradient-border{animation:gradientRotate 3s linear infinite;background:linear-gradient(45deg,#3b82f6,#0ea5e9,#06b6d4,#3b82f6);background:linear-gradient(45deg,var(--accent),#0ea5e9,#06b6d4,var(--accent));background-size:300% 300%;bottom:-3px;left:-3px;right:-3px;top:-3px;z-index:-1}.gradient-border,.inner-glow{border-radius:1.5rem;opacity:0;position:absolute;transition:opacity .4s ease}.inner-glow{bottom:0;box-shadow:inset 0 0 50px #3b82f633;left:0;pointer-events:none;right:0;top:0;z-index:1}.project-card:hover .inner-glow{opacity:1}@keyframes gradientRotate{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.project-card:hover .gradient-border{opacity:1}.project-card:hover{border-color:#0000;box-shadow:0 30px 60px #3b82f640,0 20px 40px #0000001a,0 0 80px #3b82f633;transform:translateY(-10px) scale(1.02)}@keyframes cardFloat{0%,to{transform:translateY(-10px) scale(1.03) rotateX(-5deg)}50%{transform:translateY(-15px) scale(1.03) rotateX(-5deg)}}.project-card:before{background:radial-gradient(circle at 50% 50%,#3b82f64d 0,#0000 40%);background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%),#3b82f64d 0,#0000 40%);content:"";height:100%;left:0;opacity:0;pointer-events:none;position:absolute;top:0;transition:opacity .3s ease;width:100%;z-index:1}.project-card:hover:before{animation:pulse 2s ease-in-out infinite;opacity:1}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.project-screenshot{align-items:center;background:linear-gradient(135deg,#dbeafe,#bae6fd);color:#3b82f6;color:var(--accent);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:3rem;height:220px;justify-content:center;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);width:100%;z-index:2}.project-screenshot img{border-radius:0;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-card:hover .project-screenshot img{transform:scale(1.05)}.screenshot-fallback{background:linear-gradient(135deg,#dbeafe,#bae6fd);flex-direction:column;height:100%;left:0;opacity:0;position:absolute;text-align:center;top:0;transition:opacity .4s ease;width:100%}.fallback-icon,.screenshot-fallback{align-items:center;display:flex;justify-content:center}.fallback-icon{background:#ffffffe6;border-radius:50%;box-shadow:0 4px 20px #3b82f633;color:#3b82f6;color:var(--accent);height:60px;margin-bottom:15px;width:60px}.screenshot-fallback h3{color:#1e293b;color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:10px 0 5px}.screenshot-fallback p{color:#64748b;color:var(--text-secondary);font-size:.9rem;margin:0}.project-card:hover .project-screenshot{box-shadow:0 10px 30px #3b82f64d;transform:scale(1.1) translateY(-5px)}.project-screenshot:after{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.project-card:hover .project-screenshot:after{left:100%}.project-screenshot:before{background:#ffffffe6;border-radius:.5rem;color:#3b82f6;color:var(--accent);content:"Preview";font-size:.75rem;font-weight:600;opacity:.8;padding:.25rem .75rem;position:absolute;right:10px;top:10px}.project-screenshot img{height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1);width:100%}.project-card:hover .project-screenshot img{transform:scale(1.2)}.project-content{padding:2rem;position:relative;z-index:2}.project-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#0ea5e9);background:linear-gradient(135deg,var(--accent),#0ea5e9);border-radius:1rem;box-shadow:0 8px 16px #3b82f640;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;height:60px;justify-content:center;margin-bottom:1.5rem;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);width:60px}.project-card:hover .project-icon{box-shadow:0 12px 24px #3b82f666,0 0 40px #3b82f64d;transform:rotate(1turn) scale(1.1)}.project-icon:after{background:linear-gradient(45deg,#0000,#ffffff4d,#0000);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg);transition:all .5s;width:200%}.project-card:hover .project-icon:after{animation:iconShine .5s ease-out}@keyframes iconShine{0%{opacity:0;transform:translateX(-100%) translateY(-100%) rotate(45deg)}50%{opacity:1}to{opacity:0;transform:translateX(100%) translateY(100%) rotate(45deg)}}.project-icon svg{color:#fff;height:30px;width:30px}.project-title{color:#1e293b;color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:.5rem;transition:all .4s ease}.project-card:hover .project-title{color:#3b82f6;color:var(--accent);transform:translateX(5px)}.project-url{color:#64748b;color:var(--text-secondary);display:inline-block;font-family:monospace;font-size:.9rem;margin-bottom:1rem;position:relative;transition:all .4s ease}.project-card:hover .project-url{color:#3b82f6;color:var(--accent)}.project-url:after{background:#3b82f6;background:var(--accent);bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .4s ease;width:0}.project-card:hover .project-url:after{width:100%}.project-description{color:#64748b;color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem;transition:all .4s ease}.project-card:hover .project-description{color:#1e293b;color:var(--text-primary)}.project-link{align-items:center;color:#3b82f6;color:var(--accent);display:inline-flex;font-weight:600;gap:.5rem;position:relative;text-decoration:none;transition:all .3s ease}.project-link:after{background:#3b82f6;background:var(--accent);bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.project-link:hover:after{width:100%}.project-link:hover{color:#2563eb;color:var(--accent-hover);transform:translateX(5px)}.arrow{display:inline-block;transition:transform .3s ease}.project-link:hover .arrow{transform:translateX(5px)}.project-card:hover .arrow{animation:arrowBounce 1s ease-in-out infinite}@keyframes arrowBounce{0%,to{transform:translateX(0)}50%{transform:translateX(8px)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.particles{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.particle{animation:float 20s infinite;background:linear-gradient(135deg,#3b82f6,#0ea5e9);background:linear-gradient(135deg,var(--accent),#0ea5e9);border-radius:50%;box-shadow:0 0 20px #3b82f64d;opacity:.4;position:absolute}@keyframes float{0%,to{opacity:0;transform:translateY(0) translateX(0) scale(0)}10%{opacity:.4;transform:scale(1)}90%{opacity:.4;transform:translateY(-100vh) translateX(100px) scale(1)}}@media (max-width:768px){.container{padding:1rem}.projects-grid{gap:1.5rem;grid-template-columns:1fr}header{margin-bottom:3rem}.project-screenshot{height:180px}.project-content{padding:1.5rem}}.App{min-height:100vh;width:100%}
/*# sourceMappingURL=main.bc37e07a.css.map*/