@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;1,9..40,300&display=swap);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}.project-card{background:#0f172a;border-radius:12px;box-shadow:0 10px 30px #00000059;color:#fff;display:flex;gap:25px;margin-top:30px;padding:24px;transition:transform .2s ease,box-shadow .2s ease}.project-image-wrapper{background:#1e293b;flex-shrink:0;max-width:600px;overflow:hidden;position:relative}.project-image-wrapper,.project-image-wrapper img{border-radius:6px;height:100%;max-height:400px;width:100%}.project-image-wrapper img{display:block;object-fit:cover;transition:opacity .25s ease}.carousel-btn{align-items:center;background:#0000008c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.4rem;height:36px;justify-content:center;line-height:1;opacity:0;position:absolute;top:50%;transform:translateY(-50%);transition:opacity .2s ease,background .2s ease;width:36px;z-index:2}.project-image-wrapper:hover .carousel-btn{opacity:1}.carousel-btn:hover{background:#38bdf8bf}.carousel-btn--prev{left:8px}.carousel-btn--next{right:8px}.carousel-dots{bottom:10px;display:flex;gap:6px;left:50%;position:absolute;transform:translateX(-50%);z-index:2}.carousel-dot{background:#fff6;border:none;border-radius:50%;cursor:pointer;height:8px;padding:0;transition:background .2s ease,transform .2s ease;width:8px}.carousel-dot.active{background:#38bdf8;transform:scale(1.25)}.carousel-counter{background:#0000008c;border-radius:999px;color:#fff;font-size:.75rem;letter-spacing:.03em;padding:2px 8px;position:absolute;right:10px;top:8px;z-index:2}.project-content{align-items:flex-start;display:flex;flex-direction:column}.project-content h4{font-size:1.4rem;margin-top:0}.project-description{color:#cbd5f5;line-height:1.5;margin:10px 0 15px}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:15px}.tag{border-radius:999px;font-size:.85rem;font-weight:500;padding:5px 12px;transition:transform .15s ease,outline .15s ease;white-space:nowrap}.project-content a{color:#38bdf8;font-weight:600;text-decoration:none}.project-content a:hover{text-decoration:underline}.details-toggle{background:none;border:none;color:#2563eb;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:10px;margin-top:10px;padding:0}.details-toggle:hover{text-decoration:underline}.project-details{color:#e5e7eb;margin:0 0 15px 18px;padding:0}.project-details li{line-height:1.4;margin-bottom:6px}@media (max-width:768px){.project-card{flex-direction:column}.project-image-wrapper{max-width:100%}.carousel-btn{opacity:1}}.hero{align-items:center;background:#020917;display:flex;font-family:DM Sans,sans-serif;justify-content:center;min-height:80vh;overflow:hidden;padding:80px 48px 72px;position:relative;text-align:center}.hero-grid{background-image:linear-gradient(#38bdf80a 1px,#0000 0),linear-gradient(90deg,#38bdf80a 1px,#0000 0);background-size:48px 48px;inset:0;mask-image:radial-gradient(ellipse 80% 60% at 50% 0,#000 30%,#0000 100%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0,#000 30%,#0000 100%)}.hero-glow,.hero-grid{pointer-events:none;position:absolute}.hero-glow{background:radial-gradient(ellipse,#38bdf81a 0,#0000 70%);height:360px;left:50%;top:-100px;transform:translateX(-50%);width:600px}.hero-content{max-width:680px;position:relative;z-index:1}.hero-badge{align-items:center;background:#38bdf814;border:.5px solid #38bdf840;border-radius:999px;color:#38bdf8;display:inline-flex;font-size:11px;font-weight:400;gap:8px;letter-spacing:.08em;margin-bottom:32px;padding:5px 16px;text-transform:uppercase}.badge-dot{animation:badge-pulse 2s ease-in-out infinite;background:#38bdf8;border-radius:50%;flex-shrink:0;height:6px;width:6px}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.25}}.hero-h1{color:#f1f5f9;font-family:Playfair Display,serif;font-size:clamp(2.4rem,6vw,3.6rem);font-weight:500;letter-spacing:-.5px;line-height:1.12;margin:0 0 8px}.hero-name{color:#38bdf8}.hero-subtitle{color:#475569;font-family:Playfair Display,serif;font-size:1.2rem;font-weight:400;letter-spacing:-.2px;margin:0 0 20px}.hero-p{color:#64748b;font-size:1rem;font-weight:300;line-height:1.75;margin:0 auto 40px;max-width:500px}.hero-ctas{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:16px}.btn-primary{align-items:center;background:#38bdf8;border:none;border-radius:8px;box-shadow:0 0 24px #38bdf840;color:#020917;cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600;gap:8px;padding:12px 26px;text-decoration:none;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.btn-primary:hover{background:#7dd3fc;box-shadow:0 0 32px #38bdf866;transform:translateY(-2px)}.btn-resume{align-items:center;background:#0000;border:.5px solid #1e293b;border-radius:8px;color:#94a3b8;cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:400;gap:8px;padding:11px 22px;text-decoration:none;transition:color .15s ease,border-color .15s ease,transform .15s ease}.btn-resume:hover{border-color:#334155;color:#f1f5f9;transform:translateY(-2px)}.hero-socials{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.social-link{align-items:center;background:#ffffff05;border:.5px solid #0f172a;border-radius:8px;color:#334155;display:inline-flex;font-size:.85rem;font-weight:400;gap:7px;padding:7px 14px;text-decoration:none;transition:color .15s ease,border-color .15s ease,transform .15s ease}.social-link svg{flex-shrink:0;height:15px;width:15px}.social-link:hover{border-color:#38bdf84d;color:#38bdf8;transform:translateY(-2px)}.hero-divider{background:linear-gradient(90deg,#0000,#38bdf833,#0000);bottom:0;height:1px;left:0;position:absolute;right:0}.hero-corner-label{bottom:20px;color:#1e293b;font-family:DM Sans,sans-serif;font-size:11px;letter-spacing:.1em;position:absolute;right:48px;text-transform:uppercase}@media (max-width:600px){.hero{padding:60px 24px 56px}.hero-ctas{align-items:center;flex-direction:column}.btn-primary,.btn-resume{justify-content:center;width:100%}.hero-corner-label{display:none}}.about{margin:80px auto;max-width:900px;padding:0 20px}.about h3{font-size:2rem;margin-bottom:20px}.about p{color:#334155;font-size:1rem;line-height:1.7;margin-bottom:15px}.about-highlights{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:30px}.about-highlights div{background:#f8fafc;border-radius:10px;box-shadow:0 4px 12px #0000000d;padding:20px}.about-highlights h4{margin-bottom:8px}.about-highlights div{margin-bottom:2rem}.about-highlights h4{color:#38bdf8;font-size:1.2rem;margin-bottom:.5rem}.about-highlights ul{color:#6c8fff;list-style-type:disc;padding-left:20px}.about-highlights li{margin-bottom:4px}.tech-filter{padding:4rem 1rem 2rem;text-align:center}.section-title{font-size:2.2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.5rem}.section-subtitle{color:#aaa;font-size:1rem;margin-bottom:2rem}.tag-legend{gap:.75rem;justify-content:center}.tag-chip{background:#0000;border:.5px solid var(--tag-color);border-radius:999px;color:var(--tag-color);cursor:pointer;font-size:.85rem;font-weight:400;padding:.65rem 1.3rem;transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}.tag-chip:hover{background:color-mix(in srgb,var(--tag-color) 12%,#0000);box-shadow:0 4px 14px color-mix(in srgb,var(--tag-color) 20%,#0000)}.tag-chip.active,.tag-chip:hover{border-color:var(--tag-color);color:var(--tag-color);transform:translateY(-2px)}.tag-chip.active{background:color-mix(in srgb,var(--tag-color) 18%,#0000);box-shadow:0 4px 14px color-mix(in srgb,var(--tag-color) 25%,#0000);font-weight:500}.filter-summary{align-items:center;display:flex;font-size:.9rem;gap:1rem;justify-content:center;margin-top:1.5rem}.clear-btn{background:none;border:none;color:#ff6b6b;cursor:pointer;font-weight:600;transition:opacity .15s ease}.clear-btn:hover{opacity:.75;text-decoration:underline}.tag-legend{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.legend-tag{opacity:.7}.legend-tag:hover{opacity:1}.active-tag{opacity:1;outline:2px solid #000;outline-offset:2px;transform:scale(1.05)}html{scroll-behavior:smooth}.btn{cursor:pointer}.footer{background:#020617;border-top:1px solid #1e293b;color:#94a3b8;padding:48px 20px 32px}.footer-inner{gap:32px;margin:0 auto;max-width:900px}.footer-brand,.footer-inner{align-items:center;display:flex;flex-direction:column}.footer-brand{gap:4px}.footer-name{color:#f1f5f9;font-size:1.4rem;font-weight:700;letter-spacing:-.3px}.footer-role{color:#38bdf8;font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase}.footer-links{display:flex;flex-wrap:wrap;gap:24px;justify-content:center}.footer-link{align-items:center;color:#94a3b8;display:flex;font-size:.9rem;font-weight:500;gap:8px;text-decoration:none;transition:color .2s ease,transform .2s ease}.footer-link svg{flex-shrink:0;height:18px;transition:color .2s ease;width:18px}.footer-link:hover{color:#38bdf8;transform:translateY(-2px)}.footer-inner:before{display:none}.footer-bottom{border-top:1px solid #1e293b;color:#475569;font-size:.78rem;letter-spacing:.02em;padding-top:24px;text-align:center;width:100%}@media (max-width:600px){.footer-links{align-items:center;flex-direction:column;gap:16px}}
/*# sourceMappingURL=main.207acfe3.css.map*/