:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body{width:100%;min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh;margin:0;padding:0;text-align:center;background-color:#f0f4ff;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Source Sans Pro,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:flex;flex-direction:column}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em;background-color:#1a1a1a;border-radius:8px;margin:2rem auto;max-width:1200px}.read-the-docs{color:#888;padding:1rem}h1{font-size:3.2em;line-height:1.1;margin:2rem 0}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s;color:#61dafb}button:hover{border-color:#61dafb}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}footer{background-color:#4a4a4a;color:#fff;padding:2rem;text-align:center;margin-top:auto;width:100%}footer p{margin:0;font-size:.9rem}*{margin:0;padding:0;box-sizing:border-box}.navbar{background:#0a0e1ee0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.85rem 0;position:sticky;top:0;z-index:1000;width:100%;transition:transform .3s ease,opacity .3s ease;animation:navEnter .6s ease-out both;box-shadow:0 4px 24px #0000004d,0 1px #6366f126}.navbar:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#6366f1,#a855f7,#06b6d4,#ec4899,#6366f1);background-size:300% 100%;animation:gradientBorder 5s linear infinite}@keyframes gradientBorder{0%{background-position:0% 0}to{background-position:300% 0}}.navbar.hidden{transform:translateY(-100%);opacity:0}.navbar.navbar-secondary{animation:navSecondaryEnter .65s cubic-bezier(.22,1,.36,1) both}@keyframes navEnter{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes navItemIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes navSecondaryEnter{0%{opacity:0;transform:translateY(-14px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes navSecondaryItemIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.navbar-container{width:100%;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-logo a{display:inline-flex;align-items:center;text-decoration:none;transition:opacity .3s ease,filter .3s ease}.navbar-logo a:hover{opacity:.85;filter:drop-shadow(0 0 8px rgba(99,102,241,.5))}.navbar-logo img{width:76px;height:auto;display:block}.navbar-menu{display:flex;gap:4rem;align-items:center;margin-left:auto}.navbar.navbar-secondary .navbar-menu{gap:3rem}.navbar-menu a{color:#e2e8f0;text-decoration:none;font-size:1rem;font-weight:500;position:relative;padding:.5rem 0;border-bottom:none;transition:color .25s ease}.navbar-menu a:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,#6366f1,#a855f7);border-radius:1px;transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.22,1,.36,1)}.navbar-menu a:hover{color:#6366f1}.navbar-menu a:hover:after,.navbar-menu a.is-active:after{transform:scaleX(1);transform-origin:left}.navbar-menu a.is-active{color:#6366f1;font-weight:600}.navbar-menu a.navbar-cta{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;padding:.45rem 1.2rem;border-radius:50px;font-weight:600;box-shadow:0 4px 14px #6366f159;transition:transform .25s ease,box-shadow .25s ease,color .25s ease}.navbar-menu a.navbar-cta:after{display:none}.navbar-menu a.navbar-cta:hover{color:#fff;transform:translateY(-2px);box-shadow:0 7px 20px #6366f180}@media(min-width:769px){.navbar:not(.navbar-secondary) .navbar-menu a{opacity:0;animation:navItemIn .5s ease-out forwards}.navbar:not(.navbar-secondary) .navbar-menu a:nth-child(1){animation-delay:.1s}.navbar:not(.navbar-secondary) .navbar-menu a:nth-child(2){animation-delay:.18s}.navbar:not(.navbar-secondary) .navbar-menu a:nth-child(3){animation-delay:.26s}.navbar:not(.navbar-secondary) .navbar-menu a:nth-child(4){animation-delay:.34s}.navbar:not(.navbar-secondary) .navbar-menu a:nth-child(5){animation-delay:.42s}.navbar:not(.navbar-secondary) .navbar-menu a:nth-child(6){animation-delay:.5s}.navbar.navbar-secondary .navbar-menu a{opacity:0;animation:navSecondaryItemIn .45s ease-out forwards}.navbar.navbar-secondary .navbar-menu a:nth-child(1){animation-delay:.1s}.navbar.navbar-secondary .navbar-menu a:nth-child(2){animation-delay:.18s}.navbar.navbar-secondary .navbar-menu a:nth-child(3){animation-delay:.26s}.navbar.navbar-secondary .navbar-menu a:nth-child(4){animation-delay:.34s}}.hamburger{display:none;flex-direction:column;cursor:pointer;gap:.4rem;margin-left:auto}.hamburger span{width:25px;height:3px;background-color:#e2e8f0;border-radius:3px;transition:all .3s ease}.hamburger span.active:nth-child(1){transform:rotate(45deg) translate(10px,10px)}.hamburger span.active:nth-child(2){opacity:0}.hamburger span.active:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}@media(max-width:768px){.hamburger{display:flex}.navbar-menu{position:absolute;top:100%;left:0;width:100%;flex-direction:column;justify-content:flex-start;align-items:stretch;background:#0a0e1ef5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);gap:0;max-height:0;overflow:hidden;transition:max-height .35s ease;margin-left:0;border-bottom:1px solid rgba(99,102,241,.15);box-shadow:0 8px 24px #0006}.navbar-menu.active{max-height:420px}.navbar-menu a{padding:.9rem 1.5rem;text-align:center;border-bottom:1px solid rgba(99,102,241,.08);width:100%;display:block}.navbar-menu a:after{display:none}.navbar-menu a.navbar-cta{margin:.8rem auto;width:fit-content;display:block;padding:.6rem 2rem;border-bottom:none}.navbar-container{padding:0 1rem}.navbar-logo img{width:64px}}@media(prefers-reduced-motion:reduce){.navbar,.navbar-menu a{animation:none;opacity:1}.navbar:before{animation:none}}.footer-section{background-color:#0f172a;color:#e0e0e0;padding:3rem 2rem 2rem;margin-top:0;border-top:1px solid rgba(96,165,250,.15)}.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer-column{display:flex;flex-direction:column;align-items:center}.footer-column h3{font-size:1.2rem;margin-bottom:1rem;color:#fff;text-align:left}.footer-contact{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.footer-column p,.footer-column a{margin-bottom:.5rem;color:#b0b0b0;text-decoration:none;transition:color .3s ease}.footer-column a:hover{color:#fff}.footer-column ul{list-style:none;padding:0}.footer-column ul li{margin-bottom:.5rem}.footer-column ul li a{margin-bottom:0}.footer-social{display:flex;flex-wrap:wrap;gap:2rem}.social-link-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#b0b0b0;text-decoration:none;transition:all .3s ease;padding:.5rem}.social-icon{font-size:2rem;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.social-logo{width:2rem;height:2rem;object-fit:contain;transition:transform .3s ease}.social-name{font-size:.9rem;text-align:center;white-space:nowrap}.social-link-item:hover{color:#fff}.social-link-item:hover .social-icon,.social-link-item:hover .social-logo{transform:scale(1.2)}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid rgba(96,165,250,.12);color:#94b9ff80}@media(max-width:768px){.footer-content{grid-template-columns:1fr;gap:1.5rem}.footer-section{padding:2rem 1.5rem 1.5rem}.footer-social{gap:1rem}}.floating-menu{position:fixed;bottom:4rem;right:2rem;z-index:999;font-family:inherit}.fab-main{position:relative;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#61dafb,#00bcd4);border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #61dafb66;transition:all .3s ease;z-index:1001}.fab-main:hover{transform:scale(1.1);box-shadow:0 6px 16px #61dafb99}.fab-main:active{transform:scale(.95)}.fab-icon{position:absolute;inset:0;pointer-events:none;transform-origin:center;transition:transform .3s ease}.fab-icon:before,.fab-icon:after{content:"";position:absolute;top:50%;left:50%;background:#fff;border-radius:2px;transform:translate(-50%,-50%)}.fab-icon:before{width:42%;height:2.5px}.fab-icon:after{width:2.5px;height:42%}.fab-icon.open{transform:rotate(225deg)}.fab-menu{position:absolute;bottom:80px;right:0;display:flex;flex-direction:column;gap:1rem;opacity:0;visibility:hidden;transition:all .3s ease;transform:translateY(20px)}.fab-menu.active{opacity:1;visibility:visible;transform:translateY(0)}.fab-item{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1.25rem;background-color:#2a2a2a;color:#fff;text-decoration:none;border-radius:50px;border:1px solid #61dafb;cursor:pointer;transition:all .3s ease;opacity:0;transform:scale(.8) translate(20px);animation-fill-mode:forwards}.fab-menu.active .fab-item{opacity:1;transform:scale(1) translate(0)}.fab-menu.active .fab-item:nth-child(1){animation:slideIn .3s ease .05s forwards}.fab-menu.active .fab-item:nth-child(2){animation:slideIn .3s ease .1s forwards}.fab-menu.active .fab-item:nth-child(3){animation:slideIn .3s ease .15s forwards}.fab-menu.active .fab-item:nth-child(4){animation:slideIn .3s ease .2s forwards}.fab-menu.active .fab-item:nth-child(5){animation:slideIn .3s ease .25s forwards}@keyframes slideIn{0%{opacity:0;transform:scale(.8) translate(20px)}to{opacity:1;transform:scale(1) translate(0)}}.fab-item:hover{background-color:#61dafb;color:#1f1f1f;transform:scale(1.05) translate(-5px);box-shadow:0 4px 12px #61dafb4d}.fab-label{font-size:.95rem;font-weight:500;white-space:nowrap}@media(max-width:768px){.floating-menu{bottom:2.5rem;right:1rem}.fab-main{width:50px;height:50px}.fab-icon{font-size:1.5rem}.fab-menu{bottom:65px}.fab-item{padding:.6rem 1rem;font-size:.9rem}.fab-label{font-size:.85rem}}@media(max-width:480px){.floating-menu{bottom:2rem;right:.75rem}.fab-main{width:45px;height:45px}.fab-icon{font-size:1.3rem}.fab-menu{bottom:60px;gap:.75rem}.fab-item{padding:.5rem .9rem}}.portfolio-container{width:100%;min-height:100vh;background-color:#f0f4ff;color:#1e293b;padding:0 0 2rem;--page-delay: .7s;position:relative;overflow:hidden;isolation:isolate;animation:fadeInPage .6s ease-in;animation-delay:var(--page-delay);animation-fill-mode:both}.portfolio-container:before,.portfolio-container:after{content:"";position:absolute;border-radius:40%;filter:blur(90px);pointer-events:none;z-index:0}.portfolio-container:before{width:min(58vw,760px);height:min(58vw,760px);top:-18%;left:-14%;background:radial-gradient(circle at 30% 30%,rgba(99,102,241,.28),transparent 62%),radial-gradient(circle at 70% 65%,rgba(139,92,246,.22),transparent 70%);animation:gasDriftOne 17s ease-in-out infinite alternate}.portfolio-container:after{width:min(54vw,680px);height:min(54vw,680px);right:-10%;bottom:-16%;background:radial-gradient(circle at 35% 35%,rgba(59,130,246,.25),transparent 64%),radial-gradient(circle at 75% 60%,rgba(6,182,212,.18),transparent 72%);animation:gasDriftTwo 21s ease-in-out infinite alternate}.portfolio-container>*{position:relative;z-index:1}.reveal-on-scroll{opacity:0;transform:translateY(34px) scale(.985);transition:opacity .72s ease,transform .72s cubic-bezier(.22,1,.36,1);transition-delay:var(--reveal-delay, 0ms);will-change:opacity,transform}.reveal-on-scroll.is-visible{opacity:1;transform:translateY(0) scale(1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes revealUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes blobOne{0%{transform:translate(0) scale(1)}to{transform:translate(70px,55px) scale(1.18)}}@keyframes blobTwo{0%{transform:translate(0) scale(1)}to{transform:translate(-55px,-38px) scale(1.12)}}@keyframes blobThree{0%{transform:translate(0) scale(1)}50%{transform:translate(-25px,-48px) scale(1.09)}to{transform:translate(38px,22px) scale(.9)}}@keyframes particleFloat{0%,to{transform:translateY(0) scale(1)}33%{transform:translateY(-16px) translate(6px) scale(1.15)}66%{transform:translateY(8px) translate(-4px) scale(.88)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes bounce{0%,to{transform:translate(0)}50%{transform:translate(8px)}}.portfolio-hero{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:3rem;padding:5rem 2rem 6rem;text-align:left;border:1px solid rgba(160,204,255,.45);border-radius:0;margin:0;animation:slideDown .7s ease-out;animation-delay:var(--page-delay);animation-fill-mode:both;min-height:100vh;min-height:100svh;position:relative;overflow:hidden;background:linear-gradient(135deg,#eef2ff,#faf5ff 45%,#ecfeff);box-shadow:0 22px 48px #6366f11a;cursor:crosshair}.portfolio-hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(99,102,241,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.07) 1px,transparent 1px);background-size:65px 65px;pointer-events:none;z-index:0}.portfolio-hero:after{content:"";position:absolute;inset:0;background:#eef2ff26;opacity:var(--hero-overlay-opacity, 1);pointer-events:none;z-index:1}.portfolio-hero>*{position:relative;z-index:2}.hero-aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}.aurora-blob{position:absolute;border-radius:50%;filter:blur(72px);will-change:transform}.aurora-blob--1{width:min(60vw,640px);height:min(60vw,640px);top:-22%;left:-12%;background:radial-gradient(circle,rgba(99,102,241,.5),rgba(129,140,248,.24) 50%,transparent 70%);animation:blobOne 14s ease-in-out infinite alternate}.aurora-blob--2{width:min(52vw,560px);height:min(52vw,560px);top:15%;right:-14%;background:radial-gradient(circle,rgba(168,85,247,.45),rgba(196,181,253,.2) 50%,transparent 70%);animation:blobTwo 18s ease-in-out infinite alternate}.aurora-blob--3{width:min(40vw,420px);height:min(40vw,420px);bottom:-8%;left:28%;background:radial-gradient(circle,rgba(6,182,212,.42),rgba(34,211,238,.18) 50%,transparent 70%);animation:blobThree 22s ease-in-out infinite alternate}.aurora-blob--4{width:min(38vw,400px);height:min(38vw,400px);top:30%;left:35%;background:radial-gradient(circle,rgba(236,72,153,.35),rgba(244,114,182,.15) 50%,transparent 70%);animation:blobOne 26s ease-in-out infinite alternate-reverse}.hero-spotlight{position:absolute;inset:0;background:radial-gradient(520px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(99,102,241,.12),rgba(129,140,248,.05) 45%,transparent 68%);pointer-events:none;transition:background .08s ease;z-index:2}.hero-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:2}.hero-particle{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.9),rgba(129,140,248,.5) 55%,transparent);box-shadow:0 0 8px #6366f18c,0 0 18px #818cf847;animation:particleFloat linear infinite;will-change:transform}.hero-rings{position:absolute;left:27%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:1}.hero-ring{position:absolute;border-radius:50%;border:1px solid rgba(99,102,241,.18);width:calc(280px + var(--ri) * 140px);height:calc(280px + var(--ri) * 140px);top:50%;left:50%;transform:translate(-50%,-50%);animation:ringPulse calc(4s + var(--ri) * 1.8s) ease-in-out calc(var(--ri) * -1.5s) infinite}@keyframes ringPulse{0%,to{opacity:.06;transform:translate(-50%,-50%) scale(1)}50%{opacity:.28;transform:translate(-50%,-50%) scale(1.05)}}.hero-shooting-stars{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}.shooting-star{position:absolute;height:1px;width:160px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.65),transparent);top:calc(6% + var(--si) * 15%);left:-180px;opacity:0;border-radius:1px;animation:shootAcross calc(5s + var(--si) * 2.8s) linear calc(var(--si) * -4.5s) infinite}@keyframes shootAcross{0%{left:-180px;opacity:0}4%{opacity:.9}90%{opacity:.7}to{left:calc(100% + 180px);opacity:0}}.cursor-blink{display:inline-block;color:#6366f1;font-weight:300;margin-left:1px;animation:blink .85s step-end infinite}.hero-image{width:min(45%,520px);aspect-ratio:1 / 1;height:auto;min-height:0;position:relative;border-radius:50%;overflow:hidden;background-color:#fff0;background-image:url(/assets/Profile-removebg-preview-DerVSDrf.png);background-repeat:no-repeat;background-position:center;background-size:contain;opacity:0;animation:revealUp .7s ease-out calc(var(--page-delay) + .15s) forwards,gentleFloat 6s ease-in-out calc(var(--page-delay) + 1.2s) infinite;filter:drop-shadow(0 12px 40px rgba(99,102,241,.3));transition:filter .4s ease}.hero-image:hover{filter:drop-shadow(0 18px 55px rgba(99,102,241,.55))}.hero-image:after{content:"";position:absolute;inset:0;border-radius:50%;border:3px solid #e0e0e000;pointer-events:none}.hero-text{width:55%;max-width:520px;opacity:0;animation:revealUp .7s ease-out calc(var(--page-delay) + .3s) forwards}.portfolio-hero h1{font-size:3.2rem;margin-bottom:1rem;color:#0f172a}.portfolio-hero p{font-size:1.2rem;color:#475569;max-width:500px;min-height:1.8em}.projects-section{max-width:1200px;margin:4rem auto;padding:0 2rem}.section-button{background:none;border:none;font-size:2rem;font-weight:700;color:#0f172a;cursor:pointer;text-transform:uppercase;letter-spacing:1px;margin:0 auto 3rem;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:color .3s ease;padding:0;font-family:inherit}.section-button:hover{color:#6366f1}.section-button .arrow{display:inline-block;transition:transform .3s ease}.section-button:hover .arrow{transform:translate(5px)}.projects-grid{display:flex;overflow-x:auto;overflow-y:hidden;gap:2rem;padding:2rem 0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.projects-grid::-webkit-scrollbar{height:8px}.projects-grid::-webkit-scrollbar-track{background:#6366f112;border-radius:10px}.projects-grid::-webkit-scrollbar-thumb{background:#61dafb;border-radius:10px}.projects-grid::-webkit-scrollbar-thumb:hover{background:#00bcd4}.project-card-link{text-decoration:none;color:inherit;display:block;flex:0 0 280px;min-width:280px}.project-card{background-color:#fff;border-radius:8px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;cursor:pointer;border:1px solid rgba(99,102,241,.12);animation:slideUp .6s ease-out both;animation-delay:var(--page-delay);display:flex;flex-direction:column;height:100%}.project-card-link:nth-child(1) .project-card{animation-delay:calc(var(--page-delay) + .1s)}.project-card-link:nth-child(2) .project-card{animation-delay:calc(var(--page-delay) + .2s)}.project-card-link:nth-child(3) .project-card{animation-delay:calc(var(--page-delay) + .3s)}.project-card-link:nth-child(4) .project-card{animation-delay:calc(var(--page-delay) + .4s)}.project-card-link:nth-child(5) .project-card{animation-delay:calc(var(--page-delay) + .5s)}.project-card-link:nth-child(6) .project-card{animation-delay:calc(var(--page-delay) + .6s)}.project-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #6366f12e;border-color:#6366f152}.project-image{width:100%;height:160px;overflow:hidden;background-color:#f5f7ff}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-image img{transform:scale(1.05)}.project-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.project-content h3{font-size:1.3rem;margin-bottom:.5rem;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-content h3:hover{color:#6366f1}.project-description{font-size:.85rem;color:#64748b;margin-bottom:1rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:3;-webkit-line-clamp:3;-webkit-box-orient:vertical;text-align:left}.show-more-btn{background:none;border:none;cursor:pointer;padding:0}.show-more-card{background:linear-gradient(135deg,#61dafb,#00bcd4);display:flex;align-items:center;justify-content:center;min-height:350px}.show-more-content{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center;gap:1rem}.show-more-content h3{font-size:1.5rem;font-weight:700;margin:0}.show-more-content p{font-size:.95rem;margin:0;opacity:.9}.show-more-arrow{font-size:2rem;font-weight:700;animation:bounce 2s infinite}@media(max-width:768px){.portfolio-hero{flex-direction:column;text-align:center;gap:2rem;padding:4rem 1.5rem 5rem;margin:0;border-radius:0;min-height:100vh;min-height:100svh;cursor:default}.hero-image{width:min(78vw,360px);aspect-ratio:1 / 1;height:auto;min-height:0;margin:0 auto}.hero-text{width:100%}.portfolio-hero h1{font-size:2.4rem}.portfolio-hero p{font-size:1rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.projects-section h2{font-size:1.5rem}.aurora-blob--1{width:80vw;height:80vw}.aurora-blob--2{width:70vw;height:70vw}.aurora-blob--3{width:55vw;height:55vw}}@media(prefers-reduced-motion:reduce){.portfolio-container:before,.portfolio-container:after,.aurora-blob,.hero-particle{animation:none}.portfolio-hero,.hero-image,.hero-text{animation:none;opacity:1}.reveal-on-scroll{opacity:1;transform:none;transition:none}}.skills-section{max-width:none;width:100%;margin:6rem auto;padding:4rem 2rem;text-align:center;animation:fadeIn .8s ease-out}.skills-title{font-size:2.5rem;font-weight:700;margin-bottom:4rem;color:#0f172a;letter-spacing:.5px}.skills-service-list{display:flex;flex-direction:column;gap:2.25rem;max-width:1100px;margin:0 auto 4rem}.skills-service-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:2.5rem;align-items:start;text-align:left}.skills-service-title{font-size:2.2rem;font-weight:500;color:#0f172a;margin:0}.skills-service-text{font-size:.95rem;color:#64748b;line-height:1.7;margin:.35rem 0 0}.skills-marquee{position:relative;overflow:hidden;width:100%;cursor:grab;touch-action:pan-y}.skills-marquee-track{display:flex;align-items:center;gap:2rem;width:max-content;will-change:transform}.skills-marquee.is-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.skills-marquee-track.is-paused{cursor:pointer}.skill-bubble{display:flex;align-items:center;justify-content:center;padding:.6rem 1rem;background:linear-gradient(135deg,#61dafb,#00bcd4);color:#fff;border-radius:50px;font-size:.85rem;font-weight:500;white-space:nowrap;box-shadow:0 4px 12px #61dafb4d;transition:transform .3s ease,box-shadow .3s ease;cursor:default;border:2px solid transparent;flex:0 0 auto}.skill-bubble-text{display:inline-block;animation:bubbleTilt 2s ease-in-out infinite}.skill-bubble:hover{transform:translateY(-8px) scale(1.05);box-shadow:0 8px 20px #61dafb80;border-color:#61dafb80}@keyframes bubbleTilt{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.skills-title{font-size:2rem;margin-bottom:3rem}.skills-service-row{grid-template-columns:1fr;gap:.75rem}.skills-service-title{font-size:1.6rem}.skills-marquee-track{gap:1.5rem}.skill-bubble{padding:.75rem 1.25rem;font-size:.95rem}}@media(max-width:480px){.skills-section{margin:4rem auto;padding:2rem 1rem}.skills-title{font-size:1.75rem;margin-bottom:2rem}.skills-service-list{margin-bottom:2.5rem}.skills-service-title{font-size:1.35rem}.skills-marquee-track{gap:1rem}.skill-bubble{padding:.6rem 1rem;font-size:.85rem}}.biography-page{width:100%;min-height:100vh;background-color:#f5f5f5;color:#333;padding:4rem 0;--page-delay: .7s;position:relative;overflow:hidden;isolation:isolate;animation:fadeInPage .6s ease-in;animation-delay:var(--page-delay);animation-fill-mode:both}.biography-page:before,.biography-page:after{content:"";position:absolute;border-radius:40%;filter:blur(90px);pointer-events:none;z-index:0}.biography-page:before{width:min(58vw,760px);height:min(58vw,760px);top:-18%;left:-14%;background:radial-gradient(circle at 30% 30%,rgba(189,120,255,.35),transparent 62%),radial-gradient(circle at 70% 65%,rgba(125,74,236,.28),transparent 70%);animation:gasDriftOne 17s ease-in-out infinite alternate}.biography-page:after{width:min(54vw,680px);height:min(54vw,680px);right:-10%;bottom:-16%;background:radial-gradient(circle at 35% 35%,rgba(169,92,255,.3),transparent 64%),radial-gradient(circle at 75% 60%,rgba(92,43,196,.24),transparent 72%);animation:gasDriftTwo 21s ease-in-out infinite alternate}.biography-page>*{position:relative;z-index:1}.biography-section{max-width:1080px;margin:0 auto;padding:0 2rem;min-height:calc(100vh - 8rem);display:flex;flex-direction:column}.biography-title{font-size:2.6rem;margin-bottom:2rem;color:#333;text-align:center}.biography-grid{display:grid;grid-template-columns:340px 1fr;gap:2.25rem;align-items:center}.biography-photo-wrap{margin:0;border-radius:22px;overflow:hidden;background:linear-gradient(145deg,#ececec,#fff);border:1px solid #e1e1e1;box-shadow:0 16px 30px #14141414}.biography-photo{display:block;width:100%;height:100%;object-fit:cover}.biography-content{text-align:left}.biography-name{margin:0;font-size:1.8rem;color:#1f1f1f}.biography-role{margin:.4rem 0 1.2rem;color:#7f4d2b;font-size:1rem;font-weight:600}.biography-text{font-size:1.05rem;color:#666;line-height:1.7;margin:0 0 1rem}.biography-hobbies{margin-top:2rem;padding:1.5rem;display:flex;align-items:center;justify-content:center;flex:1;min-height:620px;position:relative;overflow:hidden;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);border-radius:0;border-top:1px solid #e5e5e5;border-bottom:1px solid #e5e5e5}.biography-hobbies:before{content:"";position:absolute;inset:0;background:#ffffff94;z-index:1}.biography-hobbies-bg{position:absolute;inset:0;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(4,minmax(0,1fr));gap:0;padding:0;z-index:0}.biography-hobbies-bg-tile{display:block;width:100%;height:100%;background-size:cover;background-position:center}.biography-hobbies-bg-tile:nth-child(1){grid-column:1 / span 2;grid-row:1 / span 2}.biography-hobbies-bg-tile:nth-child(2){grid-column:3 / span 1;grid-row:1 / span 2}.biography-hobbies-bg-tile:nth-child(3){grid-column:4 / span 2;grid-row:1 / span 1}.biography-hobbies-bg-tile:nth-child(4){grid-column:6 / span 1;grid-row:1 / span 1}.biography-hobbies-bg-tile:nth-child(5){grid-column:4 / span 3;grid-row:2 / span 2}.biography-hobbies-bg-tile:nth-child(6){grid-column:1 / span 1;grid-row:3 / span 1}.biography-hobbies-bg-tile:nth-child(7){grid-column:2 / span 2;grid-row:3 / span 2}.biography-hobbies-bg-tile:nth-child(8){grid-column:1 / span 1;grid-row:4 / span 1}.biography-hobbies-bg-tile:nth-child(9){grid-column:4 / span 3;grid-row:4 / span 1}.biography-hobbies-content{text-align:left;max-width:620px;flex:1 1 620px;padding:1.5rem;border-radius:20px;background:#ffffffbd;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.biography-hobbies-foreground{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:1.5rem;width:min(1100px,calc(100vw - 4rem));margin:0 auto;transform:translate(72px)}.biography-hobbies-profile-wrap{flex:0 0 260px;width:260px;height:320px;margin:0;overflow:hidden;border-radius:24px;border:1px solid rgba(255,255,255,.65);box-shadow:0 18px 40px #1414142e;background:#ffffff4d}.biography-hobbies-profile{display:block;width:100%;height:100%;object-fit:cover}.biography-hobbies-title{margin:0 0 .65rem;font-size:1.2rem;color:#2b2b2b}.biography-link{color:#7f4d2b;font-weight:600;text-decoration:none;border-bottom:1px solid rgba(127,77,43,.45)}.biography-link:hover{color:#5e381f;border-bottom-color:#5e381fcc}.biography-meta{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.biography-meta span{display:inline-block;border:1px solid #ddd;border-radius:999px;padding:.4rem .9rem;font-size:.88rem;color:#4e4e4e;background-color:#fcfcfc}@media(max-width:768px){.biography-section{min-height:auto}.biography-title{font-size:2rem}.biography-grid{grid-template-columns:1fr;gap:1.5rem}.biography-photo-wrap{max-width:360px;margin:0 auto}.biography-content{text-align:center}.biography-meta{justify-content:center}.biography-hobbies{margin-top:1.5rem;min-height:540px;text-align:center}.biography-hobbies-bg{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(6,minmax(0,1fr));gap:0;padding:0}.biography-hobbies-bg-tile:nth-child(1){grid-column:1 / span 1;grid-row:1 / span 2}.biography-hobbies-bg-tile:nth-child(2){grid-column:2 / span 1;grid-row:1 / span 1}.biography-hobbies-bg-tile:nth-child(3){grid-column:2 / span 1;grid-row:2 / span 1}.biography-hobbies-bg-tile:nth-child(4){grid-column:1 / span 2;grid-row:3 / span 1}.biography-hobbies-bg-tile:nth-child(5){grid-column:1 / span 1;grid-row:4 / span 2}.biography-hobbies-bg-tile:nth-child(6){grid-column:2 / span 1;grid-row:4 / span 1}.biography-hobbies-bg-tile:nth-child(7){grid-column:2 / span 1;grid-row:5 / span 1}.biography-hobbies-bg-tile:nth-child(8){grid-column:1 / span 1;grid-row:6 / span 1}.biography-hobbies-bg-tile:nth-child(9){grid-column:2 / span 1;grid-row:6 / span 1}.biography-hobbies-foreground{flex-direction:column;width:min(100%,calc(100vw - 1rem));gap:1rem;transform:none}.biography-hobbies-content{text-align:center;max-width:100%;flex-basis:auto;padding:1.1rem}.biography-hobbies-profile-wrap{width:min(280px,calc(100vw - 2rem));height:300px;flex-basis:auto}}@media(prefers-reduced-motion:reduce){.biography-page:before,.biography-page:after{animation:none}}.project-page{max-width:900px;margin:4rem auto;padding:2rem;background-color:#f5f5f5;min-height:calc(100vh - 300px);--page-delay: .7s;position:relative;isolation:isolate;animation:fadeIn .6s ease-in}.project-page:before,.project-page:after{content:"";position:fixed;border-radius:40%;filter:blur(90px);pointer-events:none;z-index:0}.project-page:before{width:min(58vw,760px);height:min(58vw,760px);top:-18%;left:-14%;background:radial-gradient(circle at 30% 30%,rgba(189,120,255,.35),transparent 62%),radial-gradient(circle at 70% 65%,rgba(125,74,236,.28),transparent 70%);animation:gasDriftOne 17s ease-in-out infinite alternate}.project-page:after{width:min(54vw,680px);height:min(54vw,680px);right:-10%;bottom:-16%;background:radial-gradient(circle at 35% 35%,rgba(169,92,255,.3),transparent 64%),radial-gradient(circle at 75% 60%,rgba(92,43,196,.24),transparent 72%);animation:gasDriftTwo 21s ease-in-out infinite alternate}.project-page>*{position:relative;z-index:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDownIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.back-button{display:inline-block;margin-bottom:2rem;padding:.75rem 1.5rem;background-color:#1f1f1f;color:#fff;text-decoration:none;border-radius:4px;transition:background-color .3s ease;font-weight:500;animation:slideDownIn .6s ease-out}.project-page h1{font-size:2.5rem;margin-bottom:2rem;color:#333;animation:slideDownIn .7s ease-out .1s both}.project-main-image{width:100%;height:400px;object-fit:cover;border-radius:8px;box-shadow:0 4px 15px #0000001a;animation:zoomIn .7s ease-out .2s both;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;cursor:zoom-in}.project-main-image.is-draggable,.lightbox-image.is-draggable{cursor:grab}.project-main-image.is-dragging,.lightbox-image.is-dragging{cursor:grabbing}.project-main-video{border:0}.project-slider{position:relative;margin-bottom:1rem}.slider-fullscreen-btn{position:absolute;right:.75rem;bottom:.75rem;border:none;border-radius:999px;padding:.45rem .9rem;background-color:#1f1f1fd1;color:#fff;font-size:.8rem;cursor:pointer;transition:background-color .25s ease}.slider-fullscreen-btn:hover{background-color:#61dafbe6}.slider-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border:none;border-radius:999px;background-color:#1f1f1fd1;color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background-color .25s ease,transform .25s ease}.slider-nav:hover{background-color:#61dafbe6;transform:translateY(-50%) scale(1.06)}.slider-nav-prev{left:.75rem}.slider-nav-next{right:.75rem}.slider-dots{display:flex;flex-wrap:wrap;justify-content:center;gap:.45rem;margin-bottom:2rem}.slider-dot{width:10px;height:10px;border-radius:999px;border:none;background-color:#bdbdbd;cursor:pointer;transition:transform .2s ease,background-color .2s ease}.slider-dot:hover{transform:scale(1.1)}.slider-dot.active{background-color:#1f1f1f}.slider-lightbox{position:fixed;inset:0;z-index:9999;background-color:#000000eb;display:flex;align-items:center;justify-content:center;padding:1rem}.lightbox-image{max-width:96vw;max-height:92vh;width:auto;height:auto;object-fit:contain;border-radius:10px}.lightbox-video{width:min(96vw,1400px);height:min(90vh,788px);border:0;object-fit:initial}.lightbox-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:none;border-radius:999px;background-color:#ffffff2e;color:#fff;font-size:1.1rem;cursor:pointer}.lightbox-nav{z-index:2}.project-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-bottom:2rem}.project-gallery-image{width:100%;height:140px;object-fit:cover;border-radius:8px;box-shadow:0 2px 10px #00000014}.project-category{font-size:.95rem;color:#61dafb;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;animation:slideDownIn .6s ease-out .3s both}.project-description{font-size:1.1rem;line-height:1.8;color:#666;margin-bottom:2rem;animation:slideDownIn .6s ease-out .4s both}.project-video{margin-bottom:2rem}.project-video h2{font-size:1.2rem;margin-bottom:.75rem;color:#333}.project-video-frame-wrap{position:relative;width:100%;padding-top:56.25%;border-radius:10px;overflow:hidden;box-shadow:0 4px 15px #0000001a}.project-video-frame{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.project-tags{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:2rem;animation:slideDownIn .6s ease-out .5s both}.project-tags .tag{background-color:#e0e0e0;color:#333;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;transition:all .3s ease}.project-tags .tag:hover{background-color:#61dafb;color:#fff}.back-button{display:inline-block;margin-bottom:2rem;padding:.75rem 1.5rem;background-color:#1f1f1f;color:#fff;text-decoration:none;border-radius:4px;transition:background-color .3s ease;font-weight:500}.back-button:hover{background-color:#61dafb;color:#1f1f1f}@media(max-width:768px){.project-page{margin:2rem auto;padding:1.5rem}.project-page h1{font-size:1.8rem}.project-main-image{height:250px}.slider-nav{width:38px;height:38px}.slider-nav-prev{left:.5rem}.slider-nav-next{right:.5rem}.slider-fullscreen-btn{right:.5rem;bottom:.5rem;font-size:.75rem}.project-description{font-size:1rem}}@media(prefers-reduced-motion:reduce){.project-page:before,.project-page:after{animation:none}}.projectlist-container{width:100%;min-height:100vh;background-color:#f0f4ff;color:#1e293b;padding:0 0 4rem;--page-delay: .5s;position:relative;overflow:hidden;isolation:isolate;animation:fadeInPage .5s ease-in both}.projectlist-container:before,.projectlist-container:after{content:"";position:absolute;border-radius:40%;filter:blur(90px);pointer-events:none;z-index:0}.projectlist-container:before{width:min(58vw,760px);height:min(58vw,760px);top:-18%;left:-14%;background:radial-gradient(circle at 30% 30%,rgba(99,102,241,.25),transparent 62%),radial-gradient(circle at 70% 65%,rgba(139,92,246,.2),transparent 70%);animation:gasDriftOne 17s ease-in-out infinite alternate}.projectlist-container:after{width:min(54vw,680px);height:min(54vw,680px);right:-10%;bottom:-16%;background:radial-gradient(circle at 35% 35%,rgba(59,130,246,.22),transparent 64%),radial-gradient(circle at 75% 60%,rgba(6,182,212,.16),transparent 72%);animation:gasDriftTwo 21s ease-in-out infinite alternate}.projectlist-container>*{position:relative;z-index:1}.projectlist-hero{position:relative;display:flex;align-items:center;justify-content:center;padding:5rem 2rem 4.5rem;text-align:center;overflow:hidden;background:linear-gradient(135deg,#eef2ff,#faf5ff 45%,#ecfeff);border-bottom:1px solid rgba(99,102,241,.12)}.projectlist-hero-bg{position:absolute;inset:0;pointer-events:none}.projectlist-hero-bg:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(99,102,241,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.07) 1px,transparent 1px);background-size:65px 65px}.pl-blob{position:absolute;border-radius:50%;filter:blur(64px);will-change:transform}.pl-blob--1{width:40vw;max-width:480px;height:40vw;max-height:480px;top:-20%;left:-8%;background:radial-gradient(circle,rgba(99,102,241,.42),transparent 65%);animation:blobOne 14s ease-in-out infinite alternate}.pl-blob--2{width:32vw;max-width:380px;height:32vw;max-height:380px;top:10%;right:-6%;background:radial-gradient(circle,rgba(168,85,247,.36),transparent 65%);animation:blobTwo 18s ease-in-out infinite alternate}.pl-blob--3{width:26vw;max-width:300px;height:26vw;max-height:300px;bottom:-15%;left:40%;background:radial-gradient(circle,rgba(6,182,212,.32),transparent 65%);animation:blobThree 22s ease-in-out infinite alternate}.projectlist-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1rem}.projectlist-badge{display:inline-flex;align-items:center;gap:.5rem;background:#6366f11a;border:1px solid rgba(99,102,241,.28);color:#6366f1;padding:.35rem 1rem;border-radius:50px;font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;animation:revealUp .6s ease-out .15s both}.badge-dot{width:7px;height:7px;border-radius:50%;background:#6366f1;animation:pulseDot 2s ease-in-out infinite}@keyframes pulseDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.6}}.projectlist-hero h1{font-size:clamp(2.6rem,6vw,4.2rem);font-weight:800;background:linear-gradient(135deg,#0f172a 20%,#6366f1 60%,#a855f7 90%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1;margin:0;animation:revealUp .6s ease-out .25s both}.projectlist-hero p{font-size:1.15rem;color:#64748b;max-width:460px;margin:0;animation:revealUp .6s ease-out .35s both}.projectlist-section{max-width:1400px;margin:0 auto;padding:3rem 2rem 0}.projectlist-filters{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:2rem}.projectlist-search{flex:1 1 360px;max-width:520px;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;color:#94a3b8;display:flex;pointer-events:none}.projectlist-search input{width:100%;padding:.82rem 1rem .82rem 2.6rem;border-radius:999px;border:1px solid rgba(99,102,241,.18);background:#fff;color:#1e293b;font-size:.95rem;outline:none;transition:border-color .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #6366f10f}.projectlist-search input::placeholder{color:#94a3b8}.projectlist-search input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.projectlist-filter{display:flex;flex-direction:column;gap:.35rem;flex:0 0 220px;position:relative}.projectlist-filter label{font-size:.82rem;font-weight:500;color:#64748b;padding-left:.5rem}.pl-dropdown{position:relative}.pl-dropdown-trigger{width:100%;padding:.82rem 1rem .82rem 1.1rem;border-radius:999px;border:1px solid rgba(99,102,241,.22);background:#fff;color:#1e293b;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.6rem;box-shadow:0 2px 8px #6366f112;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;font-family:inherit;outline:none}.pl-dropdown-trigger:hover{border-color:#6366f166;box-shadow:0 4px 14px #6366f11f}.pl-dropdown-trigger.open{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126;background:#fafbff}.pl-chevron{flex-shrink:0;color:#6366f1;transition:transform .25s ease}.pl-dropdown-trigger.open .pl-chevron{transform:rotate(180deg)}.pl-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fffffff5;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,.2);border-radius:14px;box-shadow:0 8px 32px #6366f126,0 2px 8px #0000000f;z-index:100;overflow:hidden;max-height:0;opacity:0;pointer-events:none;transform:translateY(-6px) scale(.98);transition:max-height .28s cubic-bezier(.22,1,.36,1),opacity .22s ease,transform .25s cubic-bezier(.22,1,.36,1)}.pl-dropdown-menu.open{max-height:320px;opacity:1;pointer-events:auto;transform:translateY(0) scale(1);overflow-y:auto}.pl-dropdown-menu::-webkit-scrollbar{width:4px}.pl-dropdown-menu::-webkit-scrollbar-track{background:transparent}.pl-dropdown-menu::-webkit-scrollbar-thumb{background:#6366f140;border-radius:4px}.pl-dropdown-option{width:100%;padding:.65rem 1rem;background:transparent;border:none;color:#374151;font-size:.9rem;font-weight:400;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.5rem;transition:background .15s ease,color .15s ease;text-align:left;font-family:inherit;outline:none}.pl-dropdown-option:first-child{border-radius:13px 13px 0 0}.pl-dropdown-option:last-child{border-radius:0 0 13px 13px}.pl-dropdown-option:hover{background:#6366f112;color:#6366f1}.pl-dropdown-option.active{background:#6366f11a;color:#6366f1;font-weight:600}.pl-dropdown-option.active svg{color:#6366f1;flex-shrink:0}.projectlist-results{font-size:.88rem;color:#64748b;padding:0 .5rem;align-self:center;white-space:nowrap}.projectlist-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:.5rem 0 2rem}.projectlist-grid .project-card-link{text-decoration:none;color:inherit;display:block;opacity:0;animation:cardEntrance .5s cubic-bezier(.22,1,.36,1) calc(var(--card-index, 0) * 55ms + .1s) forwards}@keyframes cardEntrance{0%{opacity:0;transform:translateY(22px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.projectlist-grid .project-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid rgba(99,102,241,.1);display:flex;flex-direction:column;height:100%;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;cursor:pointer}.projectlist-grid .project-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #6366f12e;border-color:#6366f14d}.projectlist-grid .project-image{width:100%;height:180px;overflow:hidden;background:#f5f7ff;position:relative}.projectlist-grid .project-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.projectlist-grid .project-card:hover .project-image img{transform:scale(1.08)}.project-card-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#6366f1e0,#a855f7e0);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.projectlist-grid .project-card:hover .project-card-overlay{opacity:1}.project-card-cta{color:#fff;font-weight:600;font-size:.95rem;letter-spacing:.04em;transform:translateY(8px);transition:transform .3s ease}.projectlist-grid .project-card:hover .project-card-cta{transform:translateY(0)}.projectlist-grid .project-content{padding:1.1rem;flex:1;display:flex;flex-direction:column}.projectlist-grid .project-content h3{font-size:1.05rem;font-weight:600;margin-bottom:.4rem;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .2s ease}.projectlist-grid .project-card:hover .project-content h3{color:#6366f1}.projectlist-grid .project-description{font-size:.82rem;color:#64748b;margin-bottom:.8rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:3;-webkit-line-clamp:3;-webkit-box-orient:vertical;text-align:left;flex:1}.project-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:auto}.tag{display:inline-block;background:#6366f114;color:#6366f1;border:1px solid rgba(99,102,241,.22);padding:.18rem .55rem;border-radius:50px;font-size:.7rem;font-weight:500}.projectlist-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 2rem;color:#64748b}.empty-icon{font-size:2.5rem}.projectlist-empty p{font-size:1rem;margin:0}@keyframes fadeInPage{0%{opacity:0}to{opacity:1}}@keyframes revealUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes blobOne{0%{transform:translate(0) scale(1)}to{transform:translate(60px,50px) scale(1.15)}}@keyframes blobTwo{0%{transform:translate(0) scale(1)}to{transform:translate(-50px,-35px) scale(1.1)}}@keyframes blobThree{0%{transform:translate(0) scale(1)}50%{transform:translate(-20px,-40px) scale(1.08)}to{transform:translate(35px,18px) scale(.92)}}@media(max-width:1200px){.projectlist-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.projectlist-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.projectlist-hero{padding:4rem 1.5rem 3.5rem}.projectlist-hero h1{font-size:2.4rem}.projectlist-section{padding:2rem 1rem 0}.projectlist-filters{flex-direction:column;align-items:stretch}.projectlist-search,.projectlist-filter{max-width:100%;flex:1 1 auto}}@media(max-width:480px){.projectlist-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.projectlist-container:before,.projectlist-container:after,.pl-blob{animation:none}.projectlist-grid .project-card-link{animation:none;opacity:1}}.contact-section{background-color:#f5f5f5;padding:4rem 2rem;--page-delay: .7s;position:relative;overflow:hidden;isolation:isolate;animation:contactFadeIn .7s ease-out both}.contact-section:before,.contact-section:after{content:"";position:absolute;border-radius:40%;filter:blur(90px);pointer-events:none;z-index:0}.contact-section:before{width:min(58vw,760px);height:min(58vw,760px);top:-18%;left:-14%;background:radial-gradient(circle at 30% 30%,rgba(189,120,255,.35),transparent 62%),radial-gradient(circle at 70% 65%,rgba(125,74,236,.28),transparent 70%);animation:gasDriftOne 17s ease-in-out infinite alternate}.contact-section:after{width:min(54vw,680px);height:min(54vw,680px);right:-10%;bottom:-16%;background:radial-gradient(circle at 35% 35%,rgba(169,92,255,.3),transparent 64%),radial-gradient(circle at 75% 60%,rgba(92,43,196,.24),transparent 72%);animation:gasDriftTwo 21s ease-in-out infinite alternate}.contact-section>*{position:relative;z-index:1}.contact-container{max-width:620px;margin:0 auto}.contact-title{font-size:3rem;font-family:Georgia,Times New Roman,serif;margin-bottom:2rem;color:#1f1f1f;animation:contactRiseIn .7s ease-out .12s both}.contact-form{display:flex;flex-direction:column;gap:1rem}.contact-field{display:flex;flex-direction:column;gap:.5rem;opacity:0;transform:translateY(14px);animation:contactRiseIn .55s ease-out both}.contact-field:nth-of-type(1){animation-delay:.2s}.contact-field:nth-of-type(2){animation-delay:.32s}.contact-field:nth-of-type(3){animation-delay:.44s}.contact-label{display:flex;align-items:flex-start;font-size:.95rem;color:#333}.contact-input,.contact-textarea{width:100%;padding:.9rem 1rem;border:none;background-color:#efefef;font-size:.95rem;color:#333;transform:translateZ(0);transition:box-shadow .25s ease,transform .25s ease,background-color .25s ease}.contact-input::placeholder,.contact-textarea::placeholder{color:#9a9a9a}.contact-textarea{resize:vertical;min-height:140px}.contact-input:focus,.contact-textarea:focus{outline:none;background-color:#fff;box-shadow:0 8px 24px #1f1f1f1f;transform:translateY(-2px)}.contact-submit{align-self:center;margin-top:.5rem;padding:.6rem 2.2rem;border-radius:999px;border:1px solid #1f1f1f;background:transparent;color:#1f1f1f;font-size:.95rem;cursor:pointer;opacity:0;animation:contactRiseIn .55s ease-out .58s both;transition:background-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease}.contact-submit:hover{background-color:#1f1f1f;color:#fff;transform:translateY(-2px);box-shadow:0 10px 18px #1f1f1f33}.contact-submit:active{transform:translateY(0);box-shadow:none}.contact-submit:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.contact-status{margin-top:.25rem;text-align:center;font-size:.9rem}.contact-status-success{color:#0f7a34}.contact-status-error{color:#b42318}@keyframes contactFadeIn{0%{opacity:0}to{opacity:1}}@keyframes gasDriftOne{0%{transform:translateZ(0) scale(1);opacity:.8}50%{transform:translate3d(40px,22px,0) scale(1.07);opacity:1}to{transform:translate3d(80px,45px,0) scale(.96);opacity:.75}}@keyframes gasDriftTwo{0%{transform:translateZ(0) scale(1);opacity:.72}45%{transform:translate3d(-34px,-18px,0) scale(1.06);opacity:.95}to{transform:translate3d(-72px,-34px,0) scale(.94);opacity:.68}}@keyframes contactRiseIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.contact-section:before,.contact-section:after,.contact-section,.contact-title,.contact-field,.contact-submit{animation:none;opacity:1;transform:none}.contact-input,.contact-textarea,.contact-submit{transition:none}}@media(max-width:600px){.contact-section{padding:3rem 1.5rem}.contact-title{font-size:2.4rem}}
