@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&family=JetBrains+Mono:wght@400;700&family=Be+Vietnam+Pro:wght@300;400;600;800&display=swap";:root{--bg-color:#030711;--bg-secondary:#0f172a;--accent-color:#22d3ee;--accent-glow:#0891b2;--text-primary:#f8fafc;--text-secondary:#94a3b8;--glass-bg:#0f172a99;--glass-border:#22d3ee1a;--card-shadow:0 8px 32px 0 #0000005e;--font-main:"Outfit", sans-serif;--font-mono:"JetBrains Mono", monospace;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}#main-bg-canvas{z-index:0;pointer-events:none;position:fixed;inset:0}.vlab-bg-aurora{background:radial-gradient(80% 60% at 30% 30%,#22d3ee2e 0%,#0000 60%),radial-gradient(70% 50% at 70% 70%,#a855f72e 0%,#0000 60%),#030711;animation:8s ease-in-out infinite alternate vlabAurora}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@keyframes vlabAurora{to{background:radial-gradient(80% 60% at 70% 20%,#22d3ee38 0%,#0000 60%),radial-gradient(70% 50% at 30% 80%,#a855f738 0%,#0000 60%),#030711}}.vlab-bg-grid{background-color:#030711;background-image:linear-gradient(#22d3ee0d 1px,#0000 1px),linear-gradient(90deg,#22d3ee0d 1px,#0000 1px);background-size:60px 60px}.vlab-bg-noise{background-color:#030711;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E")}.vlab-bg-synth{background-color:#0000;background-image:repeating-linear-gradient(0deg,#0000,#0000 59px,#a855f714 60px),repeating-linear-gradient(90deg,#0000,#0000 59px,#a855f70d 60px);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);font-family:var(--font-main);line-height:1.6;transition:font-family .3s;overflow-x:hidden}#app{z-index:1;position:relative}footer{z-index:2;position:relative}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--bg-secondary);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--card-shadow);border-radius:20px;padding:2rem}.project-card.glass{padding:0}.glass:hover{border-color:var(--accent-color);transition:var(--transition)}.glass:not(.project-card):hover{transform:translateY(-5px)}.container{max-width:1200px;margin:0 auto;padding:0 2rem}section{padding:100px 0}h1,h2,h3{letter-spacing:-.02em;font-weight:800}.gradient-text{background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent-color) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.mono{font-family:var(--font-mono);color:var(--accent-color);font-size:.9rem}nav{z-index:1000;width:100%;transition:var(--transition);padding:1.5rem 0;position:fixed;top:0}nav.scrolled{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#030711cc;padding:1rem 0}.nav-content{justify-content:space-between;align-items:center;display:flex}.logo{color:var(--text-primary);font-size:1.5rem;font-weight:800;text-decoration:none}.nav-links{gap:2.5rem;list-style:none;display:flex}.nav-links a{color:var(--text-secondary);transition:var(--transition);font-weight:500;text-decoration:none}.nav-links a:hover{color:var(--accent-color)}select.glass{border:1px solid var(--glass-border);font-family:var(--font-main);color:var(--accent-color);cursor:pointer;transition:var(--transition);background:#0f172a66;outline:none;font-size:.8rem;font-weight:600}select.glass:hover{border-color:var(--accent-color);background:#0f172acc}select.glass option{background:var(--bg-color);color:var(--text-primary)}#hero{align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.hero-content{z-index:2;position:relative}.hero-badge{border:1px solid var(--accent-color);background:#22d3ee1a;border-radius:50px;margin-bottom:1.5rem;padding:.5rem 1rem;display:inline-block}h1{margin-bottom:1.5rem;font-size:clamp(3rem,8vw,5rem);line-height:1.1}.hero-description{color:var(--text-secondary);max-width:600px;margin-bottom:2.5rem;font-size:1.25rem}.cta-group{gap:1.5rem;display:flex}.btn{transition:var(--transition);cursor:pointer;border-radius:12px;padding:1rem 2rem;font-weight:600;text-decoration:none}.btn-primary{background:var(--accent-color);color:var(--bg-color)}.btn-primary:hover{background:var(--text-primary);transform:scale(1.05)}.btn-secondary{border:1px solid var(--glass-border);color:var(--text-primary);background:var(--glass-bg)}.btn-secondary:hover{background:var(--glass-border)}.bento-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:1.5rem;margin-top:3rem;display:grid}.bento-item{flex-direction:column;justify-content:space-between;padding:2rem;display:flex}.bento-1{grid-area:span 2/span 2}.bento-2{grid-area:span 1/span 2}.bento-3,.bento-4{grid-area:span 1/span 1}.bento-5{grid-area:span 1/span 2}.skill-tags{flex-wrap:wrap;gap:.75rem;margin-top:1rem;display:flex}.skill-tag{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:8px;padding:.4rem 1rem;font-size:.9rem}.reveal{opacity:0;transform:translateY(30px)}.modal{z-index:2000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#030711f2;width:100%;height:100%;display:none;position:fixed;top:0;left:0;overflow:auto}.modal-content{border-radius:30px;width:90%;max-width:1000px;max-height:85vh;margin:5% auto;padding:3rem;position:relative;overflow-y:auto}.close-modal{color:var(--text-secondary);cursor:pointer;transition:var(--transition);z-index:10;font-size:2rem;font-weight:700;position:absolute;top:2rem;right:2.5rem}.close-modal:hover{color:var(--accent-color)}.tech-tag{color:var(--accent-color);border:1px solid var(--accent-glow);border-radius:4px;margin-right:5px;padding:2px 8px;font-size:.8rem}.project-card{cursor:pointer;flex-direction:column;padding:0;display:flex;overflow:hidden}.project-card-body{flex:1;padding:1.6rem 1.8rem 1.2rem}.project-card-img-wrap{width:100%;line-height:0;overflow:hidden}.project-card-img-wrap img{object-fit:cover;opacity:.85;width:100%;height:210px;transition:var(--transition);display:block}.project-card:hover .project-card-img-wrap img{opacity:1;transform:scale(1.04)}.modal-grid{grid-template-columns:1.5fr 1fr;gap:3rem;margin-top:2rem;display:grid}.nav-settings{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:12px;align-items:center;gap:.75rem;padding:.4rem .8rem;display:flex}.settings-group{align-items:center;gap:.4rem;display:flex}.settings-label{color:var(--text-secondary);font-size:.7rem}.settings-divider{background:var(--glass-border);width:1px;height:1.5rem}.settings-select{font-size:.8rem;background:0 0!important;border:none!important;padding:0!important}.nav-cta{padding:.6rem 1.2rem;font-size:.9rem}.hamburger{border:1px solid var(--glass-border);cursor:pointer;z-index:1100;background:0 0;border-radius:10px;flex-direction:column;gap:5px;padding:.55rem .65rem;display:none}.hamburger span{background:var(--accent-color);width:22px;height:2px;transition:var(--transition);border-radius:4px;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid var(--glass-border);z-index:1200;background:#030711f7;flex-direction:column;gap:2rem;width:min(320px,85vw);height:100vh;padding:5rem 2rem 2.5rem;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.mobile-menu.open{transform:translate(0)}.mobile-menu-close{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:8px;padding:.3rem .6rem;font-size:1.1rem;position:absolute;top:1.4rem;right:1.4rem}.mobile-menu-close:hover{color:var(--accent-color);border-color:var(--accent-color)}.mobile-nav-links{flex-direction:column;gap:.4rem;list-style:none;display:flex}.mobile-nav-link{color:var(--text-secondary);transition:var(--transition);border-radius:10px;padding:.75rem 1rem;font-size:1.1rem;font-weight:600;text-decoration:none;display:block}.mobile-nav-link:hover,.mobile-nav-link:active{color:var(--accent-color);background:#22d3ee12}.mobile-settings{border:1px solid var(--glass-border);background:#ffffff0a;border-radius:14px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.mobile-menu-overlay{z-index:1150;opacity:0;pointer-events:none;background:#00000080;transition:opacity .3s;position:fixed;inset:0}.mobile-menu-overlay.open{opacity:1;pointer-events:all}@media (width<=1024px){.nav-links{gap:1.5rem}.bento-grid{grid-template-columns:repeat(2,1fr)}.bento-1,.bento-2{grid-area:span 1/span 2}.bento-3,.bento-4{grid-column:span 1}.bento-5{grid-column:span 2}}@media (width<=768px){.nav-links,.nav-settings,.nav-cta{display:none}.hamburger{display:flex}nav{padding:1rem 0}.container{padding:0 1.25rem}section{padding:70px 0}#hero{height:auto;min-height:100svh;padding:100px 0 60px}h1{font-size:clamp(2.4rem,10vw,3.5rem)}.hero-description{font-size:1rem}.cta-group{flex-direction:column;gap:1rem}.btn{text-align:center}.bento-grid{grid-template-columns:1fr;gap:1rem}.bento-1,.bento-2,.bento-3,.bento-4,.bento-5{grid-area:span 1/span 1}#projects-grid{grid-template-columns:1fr!important}.modal-grid{grid-template-columns:1fr;gap:1.5rem}.modal-content{width:95%;margin:2% auto;padding:2rem 1.4rem}.glass{padding:1.4rem}.project-card.glass{padding:0}.project-card-body{padding:1.2rem 1.4rem 1rem}}@media (width<=480px){.container{padding:0 1rem}h2{font-size:clamp(1.6rem,8vw,2.2rem)}.hero-badge{font-size:.7rem}.bento-item{padding:1.2rem}.project-card-body{padding:1rem 1.2rem .8rem}.project-card-img-wrap img{height:180px}}.logo-group{align-items:center;gap:.75rem;display:flex}.nav-avatar-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:0;transition:transform .25s,box-shadow .25s;display:flex}.nav-avatar-btn:hover{box-shadow:0 0 0 3px var(--accent-color);transform:scale(1.1)}.nav-avatar-img{object-fit:cover;object-position:top;border:2px solid var(--glass-border);border-radius:50%;width:38px;height:38px;transition:border-color .25s;display:block}.nav-avatar-btn:hover .nav-avatar-img{border-color:var(--accent-color)}.avatar-lightbox{z-index:2000;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);opacity:0;pointer-events:none;background:#030711d9;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.avatar-lightbox.open{opacity:1;pointer-events:all}.avatar-lightbox-inner{flex-direction:column;align-items:center;gap:1rem;transition:transform .35s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;transform:scale(.85)}.avatar-lightbox.open .avatar-lightbox-inner{transform:scale(1)}.avatar-lightbox-img{object-fit:cover;object-position:top;border:4px solid var(--accent-color);border-radius:50%;width:clamp(220px,35vw,380px);height:clamp(220px,35vw,380px);display:block;box-shadow:0 0 0 8px #22d3ee1f,0 0 60px #22d3ee40,0 30px 80px #0009}.avatar-lightbox-name{text-align:center;margin:0;font-size:1.6rem;font-weight:800}.avatar-lightbox-title{color:var(--text-secondary);text-align:center;letter-spacing:.1em;text-transform:uppercase;margin:0;font-size:.85rem}.avatar-lightbox-close{border:1px solid var(--glass-border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:#0f172ae6;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:-1rem;right:-1rem}.avatar-lightbox-close:hover{color:var(--accent-color);border-color:var(--accent-color)}
