*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0d1a0d;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{min-height:100vh}body{margin:0}a{font-weight:500;color:inherit;text-decoration:none}button{font-family:inherit}@media(max-width:768px){html{-webkit-tap-highlight-color:transparent}button,a{-webkit-tap-highlight-color:transparent;touch-action:manipulation}}html{scroll-behavior:smooth}body{overflow-x:hidden}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#0006;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:50}.navbar-left{position:relative;z-index:100}.profile-cta{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border:1px solid rgba(255,255,255,.2);border-radius:50px;padding:.5rem 1rem .5rem .5rem;cursor:pointer;transition:all .3s ease}.profile-cta:hover{background:linear-gradient(135deg,#ffffff26,#ffffff14);border-color:#ffffff4d}.profile-img{width:36px;height:36px;border-radius:50%;object-fit:cover}.profile-name{color:#ffffffe6;font-size:.95rem;font-weight:500}.contact-card-overlay{position:fixed;inset:0;z-index:1000;background:transparent;animation:fadeIn .2s ease}.contact-card-overlay.closing{animation:fadeOut .2s ease forwards}.contact-card{position:fixed;top:80px;left:2rem;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;min-width:240px;box-shadow:0 8px 32px #0006;z-index:1001;animation:fadeIn .2s ease;overflow:hidden}.contact-card.closing{animation:fadeOut .2s ease forwards}.contact-card-gm-button{background:none;border:none;padding:0;margin:0 0 0 auto;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.contact-card-gm{width:50px;height:auto;pointer-events:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.contact-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.contact-card-img{width:48px;height:48px;border-radius:50%;object-fit:cover}.contact-card-header h3{color:#fff;font-size:1rem;margin:0;font-weight:600}.contact-card-links{display:flex;flex-direction:column;gap:.5rem}.contact-link{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;color:#fffc;text-decoration:none;border-radius:8px;transition:all .2s ease;font-size:.9rem}.contact-link:hover{background:#ffffff1a;color:#fff}.contact-link svg{flex-shrink:0}.contact-email{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;color:#fffc;font-size:.9rem;-webkit-user-select:all;user-select:all}.contact-email svg{flex-shrink:0}.contact-card-repo{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.repo-link{display:flex;align-items:center;gap:.5rem;color:#fffc;text-decoration:none;font-size:.85rem;margin-bottom:.75rem;transition:color .2s ease}.repo-link:hover{color:#fff}.repo-tech{display:flex;flex-wrap:wrap;gap:.5rem}.repo-tech-pill{display:flex;align-items:center;gap:.35rem;background:#ffffff1a;color:#ffffffb3;padding:.25rem .6rem;border-radius:12px;font-size:.75rem}.repo-tech-pill svg{flex-shrink:0}.navbar-center{position:absolute;left:50%;transform:translate(-50%)}.project-tabs{display:flex;gap:.5rem;background:#0000004d;padding:.25rem;border-radius:12px}.project-tab{padding:.5rem 1.25rem;border:none;border-radius:10px;background:transparent;color:#fff9;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.project-tab:hover:not(.coming-soon){color:#ffffffe6;background:#ffffff0d}.project-tab.active{background:#ffffff1a;color:#fff}.project-tab.coming-soon{cursor:not-allowed;opacity:.5}.coming-soon-badge{font-size:.65rem;background:#ffffff26;padding:.15rem .4rem;border-radius:4px;margin-left:.5rem;vertical-align:middle;text-transform:uppercase;letter-spacing:.5px}.navbar-right{display:flex;align-items:center}.site-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(var(--theme-color-rgb),.25);transition:all .2s ease}.site-link:hover{background:rgba(var(--theme-color-rgb),.4)}.site-icon{width:24px;height:24px;border-radius:4px}.site-link.icon-swap{animation:iconSwap .4s cubic-bezier(.34,1.56,.64,1)}@keyframes iconSwap{0%{transform:scale(1) rotate(0)}30%{transform:scale(0) rotate(-90deg)}60%{transform:scale(0) rotate(90deg)}to{transform:scale(1) rotate(0)}}@media(max-width:768px){.navbar{padding:.75rem 1rem;flex-wrap:wrap;gap:.75rem}.navbar-left{order:1;z-index:auto}.navbar-center{order:3;position:static;transform:none;width:100%;display:flex;justify-content:center}.navbar-right{order:2}.profile-cta{padding:.4rem;gap:0}.profile-name{display:none}.profile-img{width:32px;height:32px}.project-tabs{gap:.25rem}.project-tab{padding:.4rem .75rem;font-size:.85rem}.coming-soon-badge{font-size:.55rem;padding:.1rem .3rem;margin-left:.25rem}.site-link{width:36px;height:36px}.site-icon{width:20px;height:20px}.contact-card-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:1000}.contact-card-overlay.closing{animation:fadeOut .25s ease forwards}.contact-card{position:fixed;inset:auto 0 0;margin:0;border-radius:20px 20px 0 0;min-width:100%;max-width:100%;width:100%;padding:1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px));animation:slideUp .3s ease;box-sizing:border-box;z-index:1001}.contact-card.closing{animation:slideDown .3s ease forwards}.contact-card-header{justify-content:center;flex-direction:column;text-align:center;gap:.5rem}.contact-card-img{width:64px;height:64px}.contact-card-links{gap:.75rem}.contact-link{justify-content:center;padding:.75rem 1rem;background:#ffffff0d}.contact-card-gm{position:absolute;width:80px;bottom:10px;right:10px;margin-left:0}.contact-card-gm-button{position:absolute;width:80px;height:80px;bottom:10px;right:10px;margin:0}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}}@media(max-width:400px){.project-tab{padding:.35rem .5rem;font-size:.8rem}.coming-soon-badge{display:none}}.carousel-container{position:relative;display:flex;align-items:center;justify-content:center;padding:1rem}.carousel-viewport{position:relative;width:400px;height:500px;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0006;background:#0003;display:flex;align-items:center;justify-content:center}.carousel-image{max-width:100%;max-height:100%;display:block;border-radius:12px;object-fit:contain}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#00000080;border:1px solid rgba(255,255,255,.2);color:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.carousel-btn:hover{background:#000000b3;color:#fff}.prev-btn{left:-60px}.next-btn{right:-60px}.carousel-dots{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);display:flex;gap:10px}.carousel-dot{width:10px;height:10px;border-radius:50%;background:#ffffff4d;border:none;cursor:pointer;transition:all .2s ease;padding:0}.carousel-dot.active{background:#ffffffe6;transform:scale(1.2)}.carousel-dot:hover{background:#fff9}@media(max-width:768px){.carousel-container{padding:.5rem;margin-bottom:2rem}.carousel-viewport{width:100%;max-width:350px;height:450px}.carousel-btn{width:36px;height:36px}.prev-btn{left:8px}.next-btn{right:8px}.carousel-dots{bottom:-30px;gap:8px}.carousel-dot{width:8px;height:8px}}@media(max-width:400px){.carousel-btn{width:32px;height:32px}.carousel-btn svg{width:18px;height:18px}}.project-details{flex:1;padding:2rem;display:flex;flex-direction:column;justify-content:center}.details-title{font-size:2.5rem;font-weight:700;color:#fff;margin:0 0 1.5rem}.details-description{font-size:1.1rem;line-height:1.6;color:#ffffffd9;margin:0 0 1rem;max-width:450px}.details-secondary{font-size:.95rem;color:#fff9;margin:0 0 2rem}.built-with{margin-bottom:2rem}.built-with-label{display:block;font-size:.9rem;color:#fff9;margin-bottom:.75rem}.tech-pills{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.tech-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem .5rem .65rem;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:50px;transition:all .2s ease}.tech-pill:hover{background:#ffffff1f;transform:translateY(-2px)}.tech-pill svg{flex-shrink:0}.tech-pill-name{font-size:.85rem;font-weight:500;color:#ffffffe6}.open-source-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50px;color:#fff;text-decoration:none;font-size:.95rem;font-weight:500;transition:all .2s ease;width:fit-content}.open-source-btn:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}@media(max-width:768px){.project-details{padding:1rem;align-items:center;text-align:center}.details-title{font-size:2rem;margin-bottom:1rem}.details-description{font-size:1rem;max-width:100%}.details-secondary{font-size:.9rem;margin-bottom:1.5rem}.built-with{margin-bottom:1.5rem;width:100%}.tech-pills{justify-content:center}.tech-pill{padding:.4rem .75rem .4rem .5rem}.tech-pill-name{font-size:.8rem}.open-source-btn{padding:.65rem 1rem;font-size:.9rem}}@media(max-width:400px){.details-title{font-size:1.75rem}.details-description{font-size:.95rem;line-height:1.5}.tech-pill{padding:.35rem .6rem .35rem .4rem;gap:.35rem}.tech-pill svg{width:20px;height:20px}.tech-pill-name{font-size:.75rem}}.app{min-height:100vh;display:flex;flex-direction:column;background-size:200% 200%;animation:gradientShift 20s ease infinite;position:relative}.gm-splash{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.08),transparent 55%),radial-gradient(circle at 70% 80%,rgba(255,255,255,.06),transparent 60%),#000c;animation:gmSplashFade 1.8s ease forwards;pointer-events:auto}.gm-splash-img{width:min(520px,70vw);height:auto;filter:drop-shadow(0 20px 35px rgba(0,0,0,.5));animation:gmGraffiti 1.8s ease forwards;pointer-events:auto;cursor:pointer}.theme-transition{position:fixed;inset:0;opacity:0;pointer-events:none;z-index:0;transition:opacity .2s ease;background-size:200% 200%;animation:gradientShift 20s ease infinite}.theme-transition.phase-in{opacity:1}.theme-transition.phase-out{opacity:0}.theme-transition.theme-green{background:linear-gradient(135deg,#1a2a1a,#0d1a0d,#1a1a1a,#0d1a0d,#1a2a1a);background-size:200% 200%}.theme-transition.theme-blue{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a,#1e293b,#0f172a);background-size:200% 200%}.app.theme-green{--theme-color: #4ade80;--theme-color-rgb: 74, 222, 128;background:linear-gradient(135deg,#1a2a1a,#0d1a0d,#1a1a1a,#0d1a0d,#1a2a1a);background-size:200% 200%}.app.theme-blue{--theme-color: #3b82f6;--theme-color-rgb: 59, 130, 246;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a,#1e293b,#0f172a);background-size:200% 200%}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes gmSplashFade{0%{opacity:0}12%{opacity:1}70%{opacity:1}to{opacity:0}}@keyframes gmGraffiti{0%{opacity:0;transform:scale(.85) rotate(-3deg)}20%{opacity:1;transform:scale(1) rotate(1.5deg)}75%{opacity:1;transform:scale(1.02) rotate(0)}to{opacity:0;transform:scale(.98) rotate(0)}}.main-content{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 4rem;position:relative;z-index:1}.content-wrapper{display:flex;align-items:center;justify-content:center;gap:6rem;max-width:1200px;width:100%}.content-wrapper.animate-in{animation:slideIn .4s cubic-bezier(.34,1.56,.64,1) forwards}.content-wrapper.transitioning-left{animation:slideOutLeft .3s cubic-bezier(.55,0,1,.45) forwards}.content-wrapper.transitioning-right{animation:slideOutRight .3s cubic-bezier(.55,0,1,.45) forwards}@keyframes slideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(-60px) scale(.9)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(60px) scale(.9)}}@media(max-width:1000px){.main-content{padding:1.5rem}.content-wrapper{flex-direction:column;gap:2rem}}@media(prefers-reduced-motion:reduce){.gm-splash,.gm-splash-img,.theme-transition.active{animation:none}}@media(max-width:768px){.main-content{padding:1rem;align-items:flex-start}.content-wrapper{gap:1.5rem}}@media(max-width:400px){.main-content{padding:.75rem}}
