@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-deep: #0a0e1a;--bg-panel: rgba(10, 14, 30, .65);--bg-card: rgba(15, 20, 40, .5);--accent-cyan: #06b6d4;--accent-violet: #8b5cf6;--accent-indigo: #6366f1;--accent-amber: #f59e0b;--accent-emerald: #10b981;--accent-cyan-rgb: 6, 182, 212;--accent-violet-rgb: 139, 92, 246;--text-primary: #e0e7ff;--text-secondary: #94a3b8;--text-muted: #64748b;--border-glow: rgba(6, 182, 212, .2);--border-subtle: rgba(148, 163, 184, .08);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;overflow:hidden}body{font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-deep);overflow:hidden;position:fixed;width:100%;height:100%}a{color:inherit;text-decoration:none}ul{list-style:none}img{max-width:100%;height:auto}.mono{font-family:var(--font-mono)}#webgl{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}#scroll-container{position:fixed;top:0;left:0;width:100%;height:100%;overflow-y:auto;overflow-x:hidden;z-index:1;-webkit-overflow-scrolling:touch}#scroll-spacer{height:600vh;pointer-events:none}#overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2;pointer-events:none;display:flex;align-items:center;justify-content:center}#warp-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:900;pointer-events:none;background:radial-gradient(circle at center,transparent 0%,rgba(6,182,212,0) 40%,rgba(139,92,246,.1) 100%);opacity:0;transform:scale(1);transition:opacity .1s ease,transform .1s ease;mix-blend-mode:screen}#warp-overlay.active{opacity:1;background:radial-gradient(circle at center,transparent 0%,transparent 40%,rgba(220,230,255,.9) 80%,rgba(255,255,255,1) 100%);transform:scale(2);transition:opacity .15s ease-in .35s,transform 1.5s cubic-bezier(.2,0,0,1);mix-blend-mode:screen}#loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;background:var(--bg-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s ease}.loading-logo{font-family:var(--font-mono);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xl);letter-spacing:2px}.loading-logo span{color:var(--accent-cyan)}.loading-bar{width:clamp(120px,30vw,200px);height:2px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.loading-bar-fill{width:0%;height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-violet));border-radius:2px;animation:loadFill 1.5s ease-out forwards}@keyframes loadFill{to{width:100%}}.section-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(90vw,750px);max-height:85vh;overflow-y:auto;overscroll-behavior:contain;opacity:0;pointer-events:none;z-index:3;background:var(--bg-panel);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-glow);border-radius:var(--radius-xl);padding:clamp(1.5rem,4vw,3rem);transition:opacity .5s ease-out,transform .5s ease-out;will-change:opacity,transform;scrollbar-width:thin;scrollbar-color:rgba(6,182,212,.3) transparent}.section-panel::-webkit-scrollbar{width:4px}.section-panel::-webkit-scrollbar-track{background:transparent}.section-panel::-webkit-scrollbar-thumb{background:#06b6d44d;border-radius:4px}.section-label{font-family:var(--font-mono);font-size:clamp(.65rem,1.5vw,.8rem);color:var(--accent-cyan);letter-spacing:3px;text-transform:uppercase;margin-bottom:var(--space-sm)}.section-title{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:800;color:var(--text-primary);margin-bottom:var(--space-md);line-height:1.15}.section-subtitle{font-size:clamp(.85rem,2vw,1rem);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-xl)}.hero-content{text-align:center}.hero-greeting{font-family:var(--font-mono);font-size:clamp(.8rem,2vw,1rem);color:var(--accent-cyan);margin-bottom:var(--space-md);letter-spacing:2px}.hero-name{font-size:clamp(2.2rem,7vw,4.5rem);font-weight:900;line-height:1.05;margin-bottom:var(--space-sm)}.hero-name-gradient{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-violet),var(--accent-indigo));background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 6s ease infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hero-role{font-family:var(--font-mono);font-size:clamp(.9rem,2.2vw,1.3rem);color:var(--accent-violet);margin-bottom:var(--space-lg);min-height:1.5em}.hero-role .cursor{display:inline-block;width:2px;height:1em;background:var(--accent-cyan);margin-left:2px;animation:blink 1s step-end infinite;vertical-align:text-bottom}@keyframes blink{50%{opacity:0}}.hero-desc{font-size:clamp(.85rem,1.8vw,1.05rem);color:var(--text-secondary);max-width:500px;margin:0 auto var(--space-xl);line-height:1.7}.hero-cta{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.7rem 1.5rem;border-radius:var(--radius-md);font-size:clamp(.8rem,1.5vw,.9rem);font-weight:600;cursor:pointer;transition:all .25s ease;border:none;font-family:var(--font-sans)}.btn-primary{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-violet));color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(var(--accent-cyan-rgb),.3)}.btn-outline{background:transparent;border:1px solid var(--border-glow);color:var(--text-primary)}.btn-outline:hover{border-color:var(--accent-cyan);background:rgba(var(--accent-cyan-rgb),.08)}.hero-scroll{margin-top:var(--space-xl);font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);letter-spacing:4px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.about-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);margin-top:var(--space-lg)}.about-stat{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:clamp(.8rem,2vw,1.2rem);text-align:center}.stat-number{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stat-label{font-size:clamp(.65rem,1.5vw,.8rem);color:var(--text-muted);margin-top:var(--space-xs)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.project-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color .3s ease,transform .3s ease,box-shadow .3s ease}.project-card:hover{border-color:var(--border-glow);transform:translateY(-4px);box-shadow:0 8px 32px #06b6d41f}.project-thumb{position:relative;width:100%;aspect-ratio:16 / 10;overflow:hidden}.project-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.project-card:hover .project-thumb img{transform:scale(1.05)}.project-thumb-overlay{position:absolute;inset:0;background:#0a0e1eb3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.project-thumb-overlay span{color:var(--accent-cyan);font-family:var(--font-mono);font-size:.8rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;border:1px solid rgba(6,182,212,.4);padding:.4rem 1rem;border-radius:var(--radius-sm)}.project-card:hover .project-thumb-overlay{opacity:1}.project-body{padding:clamp(.75rem,2vw,1.25rem)}.project-title{font-size:clamp(.9rem,1.8vw,1.1rem);font-weight:700;margin-bottom:var(--space-xs)}.project-desc{font-size:clamp(.72rem,1.4vw,.82rem);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.project-tag{background:rgba(var(--accent-cyan-rgb),.1);color:var(--accent-cyan);padding:.15rem .55rem;border-radius:var(--radius-sm);font-size:clamp(.55rem,1.1vw,.65rem);font-family:var(--font-mono);white-space:nowrap}.project-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s ease}.project-modal.active{opacity:1;pointer-events:auto}.project-modal-backdrop{position:absolute;inset:0;background:#02040cd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.project-modal-content{position:relative;width:min(90vw,800px);max-height:90vh;background:#0a0e1ef2;border:1px solid rgba(6,182,212,.2);border-radius:var(--radius-lg, 16px);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 80px #0009,0 0 60px #06b6d414;transform:scale(.92) translateY(20px);transition:transform .35s cubic-bezier(.22,1,.36,1)}.project-modal.active .project-modal-content{transform:scale(1) translateY(0)}.project-modal-close{position:absolute;top:12px;right:12px;z-index:10;width:36px;height:36px;border:none;background:#0a0e1eb3;backdrop-filter:blur(8px);color:var(--text-primary);font-size:1rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.project-modal-close:hover{background:#06b6d433;color:var(--accent-cyan)}.project-modal-carousel{position:relative;width:100%;background:#0000004d}.carousel-viewport{width:100%;overflow:hidden}.carousel-track{display:flex;transition:transform .4s cubic-bezier(.22,1,.36,1)}.carousel-slide{min-width:100%;display:flex;align-items:center;justify-content:center;padding:16px}.carousel-slide img{max-width:100%;max-height:55vh;object-fit:contain;border-radius:8px}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:40px;height:40px;border:none;background:#0a0e1eb3;backdrop-filter:blur(8px);color:var(--text-primary);font-size:1.4rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.carousel-prev{left:12px}.carousel-next{right:12px}.carousel-arrow:hover{background:#06b6d440;color:var(--accent-cyan)}.carousel-indicators{display:flex;justify-content:center;gap:8px;padding:12px 0}.carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:#fff3;cursor:pointer;transition:all .3s ease;padding:0}.carousel-dot.active{background:var(--accent-cyan);box-shadow:0 0 8px #06b6d480;transform:scale(1.3)}.project-modal-info{padding:clamp(1rem,3vw,1.5rem);border-top:1px solid rgba(6,182,212,.1)}.project-modal-title{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:700;margin-bottom:var(--space-xs)}.project-modal-desc{font-size:clamp(.8rem,1.6vw,.95rem);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-sm)}.project-modal-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.project-modal-tags .project-tag{font-size:.7rem}.skills-categories{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.skill-category{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:clamp(.8rem,2vw,1.2rem)}.skill-cat-title{font-size:clamp(.75rem,1.5vw,.9rem);font-weight:700;color:var(--accent-cyan);margin-bottom:var(--space-sm)}.skill-list{display:flex;flex-direction:column;gap:var(--space-xs)}.skill-item{font-size:clamp(.7rem,1.3vw,.8rem);color:var(--text-secondary);padding:.15rem 0;display:flex;align-items:center;gap:var(--space-sm)}.skill-dot{width:4px;height:4px;border-radius:50%;background:var(--accent-cyan);flex-shrink:0}.experience-timeline{display:flex;flex-direction:column;gap:var(--space-lg)}.timeline-item{position:relative;padding-left:var(--space-xl);border-left:2px solid var(--border-subtle)}.timeline-dot{position:absolute;left:-6px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--accent-cyan);box-shadow:0 0 12px rgba(var(--accent-cyan-rgb),.5)}.timeline-period{font-family:var(--font-mono);font-size:clamp(.6rem,1.2vw,.75rem);color:var(--accent-violet);margin-bottom:var(--space-xs)}.timeline-role{font-size:clamp(.9rem,2vw,1.1rem);font-weight:700;margin-bottom:2px}.timeline-company{font-size:clamp(.75rem,1.5vw,.85rem);color:var(--accent-cyan);margin-bottom:var(--space-sm)}.timeline-desc{font-size:clamp(.75rem,1.4vw,.85rem);color:var(--text-secondary);line-height:1.5}.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl)}.contact-info-list{display:flex;flex-direction:column;gap:var(--space-lg)}.contact-info-item{display:flex;align-items:flex-start;gap:var(--space-md)}.contact-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(var(--accent-cyan-rgb),.1);border-radius:var(--radius-sm);color:var(--accent-cyan);flex-shrink:0;font-size:1rem}.contact-info-label{font-size:clamp(.6rem,1.2vw,.7rem);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.contact-info-value{font-size:clamp(.8rem,1.6vw,.95rem);color:var(--text-primary)}.contact-info-value.available{color:var(--accent-emerald)}.contact-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-input,.form-textarea{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.7rem .9rem;color:var(--text-primary);font-family:var(--font-sans);font-size:clamp(.8rem,1.5vw,.9rem);transition:border-color .3s ease;width:100%}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-cyan)}.form-textarea{resize:vertical;min-height:80px}.form-label{font-size:clamp(.7rem,1.3vw,.8rem);color:var(--text-secondary);margin-bottom:4px;display:block}.social-row{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);color:var(--text-secondary);transition:all .3s ease;pointer-events:auto}.social-link:hover{color:var(--accent-cyan);border-color:var(--border-glow);transform:translateY(-2px)}.footer-micro{text-align:center;margin-top:var(--space-xl);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);font-size:clamp(.6rem,1.2vw,.7rem);color:var(--text-muted)}.nav-dots{position:fixed;right:clamp(12px,2vw,24px);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:100;pointer-events:auto}.nav-dots-inner{display:flex;flex-direction:column;align-items:center;gap:12px}.nav-arrow{display:none}.nav-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);border:none;cursor:pointer;transition:all .3s ease;opacity:.4;padding:0}.nav-dot.active{background:var(--accent-cyan);opacity:1;box-shadow:0 0 12px rgba(var(--accent-cyan-rgb),.6);transform:scale(1.4)}.nav-dot:hover{opacity:.8;transform:scale(1.3)}.scroll-progress{position:fixed;left:0;top:0;width:2px;height:100%;background:linear-gradient(180deg,var(--accent-cyan),var(--accent-violet));z-index:100;transform-origin:top;transform:scaleY(0)}@media(max-width:768px){.section-panel{width:94vw;max-height:80vh;padding:clamp(1.2rem,3vw,2rem);border-radius:var(--radius-lg)}.about-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.skills-categories{grid-template-columns:1fr;gap:var(--space-sm)}.contact-layout{grid-template-columns:1fr;gap:var(--space-lg)}.nav-dots{right:auto;top:auto;bottom:clamp(16px,3vw,24px);left:50%;transform:translate(-50%);flex-direction:row;gap:6px;background:#0a0e1ebf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(6,182,212,.15);border-radius:999px;padding:8px 10px}.nav-dots-inner{flex-direction:row;gap:10px}.nav-arrow{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--accent-cyan);cursor:pointer;padding:2px;border-radius:50%;transition:all .25s ease;opacity:.7}.nav-arrow:hover{opacity:1;transform:scale(1.2)}.nav-arrow:active{transform:scale(.9)}.nav-dot{width:6px;height:6px}.scroll-progress{display:none}}@media(max-width:480px){.section-panel{width:96vw;max-height:78vh;padding:1rem;border-radius:var(--radius-md)}.hero-name{font-size:clamp(1.8rem,10vw,2.5rem)}.hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn{justify-content:center}.about-grid{grid-template-columns:1fr 1fr;gap:6px}.about-stat{padding:.6rem}.stat-number{font-size:1.3rem}.projects-grid{grid-template-columns:1fr;gap:var(--space-sm)}.project-card{padding:0}.project-thumb{aspect-ratio:16 / 9}.project-tags{gap:3px}.project-modal-content{width:95vw;max-height:95vh}.carousel-slide img{max-height:40vh}.carousel-arrow{width:32px;height:32px;font-size:1.1rem}.social-row{justify-content:center}}#scroll-container::-webkit-scrollbar{width:0}::selection{background:rgba(var(--accent-cyan-rgb),.3);color:var(--text-primary)}#mobile-menu-btn,#mobile-menu-overlay{display:none}@media(max-width:768px){#mobile-menu-btn{display:flex;flex-direction:column;justify-content:space-between;width:44px;height:44px;padding:12px 10px;position:fixed;top:20px;right:20px;z-index:200;background:#0a0e1ecc;border:1px solid rgba(6,182,212,.3);border-radius:8px;backdrop-filter:blur(10px);cursor:pointer;transition:all .3s ease}#mobile-menu-btn .bar{width:100%;height:2px;background:var(--accent-cyan);transition:all .3s;transform-origin:left}#mobile-menu-btn.active .bar:nth-child(1){transform:rotate(45deg)}#mobile-menu-btn.active .bar:nth-child(2){opacity:0}#mobile-menu-btn.active .bar:nth-child(3){transform:rotate(-45deg)}#mobile-menu-overlay{display:flex;flex-direction:column;justify-content:center;align-items:center;position:fixed;top:0;left:0;width:100%;height:100vh;background:#0a0e1ef2;backdrop-filter:blur(20px);z-index:150;opacity:0;pointer-events:none;transition:opacity .4s ease}#mobile-menu-overlay.active{opacity:1;pointer-events:all}.mobile-link{font-size:2rem;font-weight:700;color:var(--text-primary);text-decoration:none;margin:1.5rem 0;opacity:0;transform:translateY(20px);transition:all .4s ease}#mobile-menu-overlay.active .mobile-link{opacity:1;transform:translateY(0)}#mobile-menu-overlay.active .mobile-link:nth-child(1){transition-delay:.1s}#mobile-menu-overlay.active .mobile-link:nth-child(2){transition-delay:.2s}#mobile-menu-overlay.active .mobile-link:nth-child(3){transition-delay:.3s}#mobile-menu-overlay.active .mobile-link:nth-child(4){transition-delay:.4s}#mobile-menu-overlay.active .mobile-link:nth-child(5){transition-delay:.5s}#mobile-menu-overlay.active .mobile-link:nth-child(6){transition-delay:.6s}}.lang-switcher{position:fixed;top:clamp(16px,3vw,24px);right:clamp(16px,3vw,24px);z-index:200;display:flex;align-items:center;gap:4px;background:#0a0e1eb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(6,182,212,.2);border-radius:var(--radius-md);padding:4px 6px;pointer-events:auto;transition:border-color .3s ease}.lang-switcher:hover{border-color:#06b6d466}.lang-sep{color:var(--text-muted);font-size:.7rem;user-select:none;opacity:.4}.lang-btn{background:transparent;border:none;color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:1px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .25s ease}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{color:var(--accent-cyan);background:#06b6d41f;text-shadow:0 0 10px rgba(6,182,212,.4)}@media(max-width:768px){.lang-switcher{top:20px;right:16px;padding:3px 5px}.lang-btn{font-size:.65rem;padding:3px 6px}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
