:root{--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-card: #16161f;--bg-card-hover: #1c1c28;--surface: #1a1a25;--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--text-primary: #f0f0f5;--text-secondary: #9898a8;--text-muted: #6a6a7a;--accent-1: #6366f1;--accent-2: #8b5cf6;--accent-3: #a78bfa;--accent-glow: rgba(99, 102, 241, .3);--gradient-primary: linear-gradient(135deg, var(--accent-1), var(--accent-2));--gradient-text: linear-gradient(135deg, var(--accent-1), var(--accent-3));--gradient-glow: linear-gradient(135deg, rgba(99, 102, 241, .15), rgba(139, 92, 246, .15));--nav-height: 72px;--container-width: 1200px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--transition-fast: .2s cubic-bezier(.4, 0, .2, 1);--transition-smooth: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .6s cubic-bezier(.34, 1.56, .64, 1);--font-main: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-height);font-size:16px}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}ul{list-style:none}::selection{background:var(--accent-1);color:#fff}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--accent-1);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--accent-2)}.cursor-glow{position:fixed;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.06) 0%,transparent 70%);pointer-events:none;z-index:0;transform:translate(-50%,-50%);transition:opacity .3s}#particleCanvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.5}.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}.section{padding:120px 0;position:relative;z-index:1}.section-header{text-align:center;margin-bottom:64px}.section-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:var(--gradient-glow);border:1px solid var(--border);border-radius:100px;font-size:.85rem;font-weight:500;color:var(--accent-3);margin-bottom:20px;letter-spacing:.5px}.section-tag i{font-size:.8rem}.section-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.2;letter-spacing:-.02em}.section-subtitle{color:var(--text-secondary);font-size:1.1rem;margin-top:16px;max-width:500px;margin-left:auto;margin-right:auto}.gradient-text{background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar{position:fixed;top:0;left:0;width:100%;height:var(--nav-height);z-index:1000;transition:all var(--transition-smooth);background:transparent}.navbar.scrolled{background:#0a0a0fb3;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--border)}.nav-container{max-width:var(--container-width);margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-main);font-size:1.4rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px;display:flex;align-items:center;position:relative}.logo-icon{width:44px;height:44px;object-fit:contain;border-radius:10px;transition:transform var(--transition-smooth),filter var(--transition-smooth)}.nav-logo:hover .logo-icon{transform:rotate(-8deg) scale(1.08);filter:drop-shadow(0 0 8px rgba(99,102,241,.4))}.logo-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.6rem}.logo-full{transition:all var(--transition-smooth)}.logo-dot{color:var(--accent-2);font-size:2rem;line-height:0;margin-left:-1px}.nav-menu{display:flex;gap:6px}.nav-link{padding:8px 16px;font-size:.85rem;font-weight:500;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative}.nav-link:after{content:"";position:absolute;bottom:2px;left:16px;right:16px;height:2px;background:var(--gradient-primary);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform var(--transition-smooth)}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{transform:scaleX(1)}.nav-link.active{color:var(--accent-3)}.nav-link.active:after{transform:scaleX(1)}.nav-right{display:flex;align-items:center;gap:16px}.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;font-size:.82rem;font-weight:600;color:#34d399;background:#34d39914;border:1px solid rgba(52,211,153,.2);border-radius:100px;letter-spacing:.3px}.nav-cta-dot{width:7px;height:7px;border-radius:50%;background:#34d399;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 #34d39966}50%{box-shadow:0 0 0 6px #34d39900}}.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:10}.nav-toggle span{width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease;transform-origin:center}.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.hero{min-height:100vh;display:flex;align-items:center;position:relative;z-index:1;overflow:hidden;padding-top:var(--nav-height)}.hero-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(99,102,241,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.03) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black 20%,transparent 100%);z-index:0}.hero-glow{position:absolute;border-radius:50%;filter:blur(120px);z-index:0;pointer-events:none}.hero-glow-1{width:500px;height:500px;background:#6366f11f;top:10%;left:-5%;animation:floatGlow 8s ease-in-out infinite}.hero-glow-2{width:400px;height:400px;background:#8b5cf614;bottom:10%;right:-5%;animation:floatGlow 10s ease-in-out infinite reverse}@keyframes floatGlow{0%,to{transform:translate(0)}33%{transform:translate(30px,-20px)}66%{transform:translate(-20px,20px)}}.hero-container{max-width:var(--container-width);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1;width:100%}.hero-left{display:flex;flex-direction:column;gap:24px}.hero-eyebrow{display:flex;align-items:center;gap:16px}.eyebrow-line{width:40px;height:2px;background:var(--gradient-primary);border-radius:2px}.hero-eyebrow span{font-family:var(--font-mono);font-size:.75rem;font-weight:600;letter-spacing:3px;color:var(--accent-3)}.hero-title{font-weight:700;line-height:1.15;letter-spacing:-.03em;color:var(--text-primary);display:flex;flex-direction:column;gap:4px}.hero-name{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:500;color:var(--text-secondary);letter-spacing:.02em;display:block}.hero-title-highlight{font-size:clamp(3.5rem,7vw,5.5rem);background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;line-height:1;letter-spacing:-.04em}.hero-title-sub{font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--text-muted);font-weight:400;letter-spacing:-.01em;display:block}.hero-typed-line{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:1rem;padding:12px 20px;background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm);width:fit-content}.typed-prefix{color:var(--accent-2);font-weight:600}.hero-typed{color:var(--accent-3)}.typed-cursor{display:inline-block;width:2px;height:1.1em;background:var(--accent-1);animation:blink .8s step-end infinite;vertical-align:middle}@keyframes blink{50%{opacity:0}}.hero-description{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;max-width:480px}.hero-description strong{color:var(--text-primary);font-weight:600}.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;font-family:var(--font-main);font-size:.95rem;font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all var(--transition-smooth);position:relative;overflow:hidden}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 20px var(--accent-glow)}.btn-primary .btn-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#ffffff26;border-radius:50%;font-size:.7rem;transition:transform var(--transition-fast)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.btn-primary:hover .btn-icon{transform:translate(3px)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:14px 8px;font-weight:500;position:relative}.btn-ghost:after{content:"";position:absolute;bottom:10px;left:8px;right:8px;height:1px;background:var(--text-muted);transform:scaleX(0);transform-origin:right;transition:transform var(--transition-smooth)}.btn-ghost:hover{color:var(--text-primary)}.btn-ghost:hover:after{transform:scaleX(1);transform-origin:left}.hero-social{display:flex;gap:12px;padding-top:8px}.hero-social a{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-muted);transition:all var(--transition-fast)}.hero-social a:hover{border-color:var(--accent-1);color:var(--accent-3);background:#6366f114;transform:translateY(-2px)}.hero-right{position:relative}.hero-terminal{background:#111118cc;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 60px #0006,0 0 0 1px #ffffff0d inset;transition:transform var(--transition-smooth),box-shadow var(--transition-smooth)}.hero-terminal:hover{transform:translateY(-4px);box-shadow:0 30px 80px #00000080,0 0 40px #6366f10d,0 0 0 1px #ffffff14 inset}.terminal-header{display:flex;align-items:center;gap:12px;padding:14px 20px;background:#ffffff05;border-bottom:1px solid var(--border)}.terminal-dots{display:flex;gap:6px}.dot{width:10px;height:10px;border-radius:50%}.dot-red{background:#ff5f57}.dot-yellow{background:#febc2e}.dot-green{background:#28c840}.terminal-title{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.terminal-tabs{margin-left:auto}.terminal-tab{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);padding:4px 14px;background:#ffffff0a;border-radius:6px}.terminal-body{padding:24px;overflow-x:auto}.terminal-body pre{margin:0;font-family:var(--font-mono);font-size:.82rem;line-height:1.9}.terminal-body code{font-family:inherit}.t-keyword{color:#c792ea}.t-class{color:#ffcb6b}.t-string{color:#c3e88d}.t-type{color:#82aaff}.t-method{color:#89ddff}.t-bool{color:#f78c6c}.hero-float-card{position:absolute;display:flex;align-items:center;gap:12px;padding:14px 20px;background:#16161fe6;border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 32px #0000004d;z-index:2}.float-icon{width:38px;height:38px;border-radius:var(--radius-sm);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:#fff}.float-number{font-size:1.4rem;font-weight:700;color:var(--text-primary);line-height:1;display:inline}.float-plus{font-size:.9rem;color:var(--accent-2);font-weight:600}.float-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.float-card-1{top:-10px;right:-20px;animation:floatCard 6s ease-in-out infinite}.float-card-2{bottom:-30px;left:-30px;animation:floatCard 7s ease-in-out infinite 1s}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translate(-50%);z-index:2}.scroll-mouse{width:24px;height:38px;border:2px solid var(--text-muted);border-radius:12px;display:flex;justify-content:center;padding-top:6px;opacity:.5;transition:opacity var(--transition-fast)}.scroll-mouse:hover{opacity:1}.scroll-wheel{width:3px;height:8px;background:var(--accent-2);border-radius:3px;animation:scrollWheel 2s ease-in-out infinite}@keyframes scrollWheel{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}.animate-in{opacity:0;transform:translateY(30px);animation:slideUp .8s cubic-bezier(.16,1,.3,1) forwards}.animate-in:nth-child(1){animation-delay:.2s}.animate-in:nth-child(2){animation-delay:.35s}.animate-in:nth-child(3){animation-delay:.5s}.animate-in:nth-child(4){animation-delay:.65s}.animate-in:nth-child(5){animation-delay:.8s}.animate-in:nth-child(6){animation-delay:.95s}.animate-in:nth-child(7){animation-delay:1.1s}@keyframes slideUp{to{opacity:1;transform:translateY(0)}}.loading-dots{display:flex;gap:6px;justify-content:center;align-items:center}.loading-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent-2);animation:loadingBounce 1.4s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.16s}.loading-dots span:nth-child(3){animation-delay:.32s}@keyframes loadingBounce{0%,80%,to{transform:scale(.4);opacity:.4}40%{transform:scale(1);opacity:1}}@keyframes glowPulse{0%,to{box-shadow:0 0 #6366f100}50%{box-shadow:0 0 20px 4px #6366f126}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.count-animate{animation:countUp .6s cubic-bezier(.16,1,.3,1) forwards}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.fade-in-scale{animation:fadeInScale .5s cubic-bezier(.16,1,.3,1) forwards}.stagger-children>*{opacity:0;transform:translateY(16px);animation:staggerIn .5s cubic-bezier(.16,1,.3,1) forwards}.stagger-children>*:nth-child(1){animation-delay:.05s}.stagger-children>*:nth-child(2){animation-delay:.1s}.stagger-children>*:nth-child(3){animation-delay:.15s}.stagger-children>*:nth-child(4){animation-delay:.2s}.stagger-children>*:nth-child(5){animation-delay:.25s}.stagger-children>*:nth-child(6){animation-delay:.3s}.stagger-children>*:nth-child(7){animation-delay:.35s}.stagger-children>*:nth-child(8){animation-delay:.4s}.stagger-children>*:nth-child(9){animation-delay:.45s}.stagger-children>*:nth-child(10){animation-delay:.5s}@keyframes staggerIn{to{opacity:1;transform:translateY(0)}}@keyframes rotateBorder{0%{--angle: 0deg}to{--angle: 360deg}}.page-enter{animation:pageIn .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes pageIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.section-glow-line{height:1px;background:linear-gradient(90deg,transparent,var(--accent-1),var(--accent-2),transparent);opacity:.3;margin:0 auto;max-width:400px}.hover-lift{transition:transform var(--transition-smooth),box-shadow var(--transition-smooth)}.hover-lift:hover{transform:translateY(-3px);box-shadow:0 8px 30px #6366f114}@keyframes tickerIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.ticker-number{display:inline-block;overflow:hidden}.ticker-number span{display:inline-block;animation:tickerIn .6s cubic-bezier(.16,1,.3,1) forwards}@keyframes subtleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.float-subtle{animation:subtleFloat 4s ease-in-out infinite}.about-content{display:grid;grid-template-columns:320px 1fr;gap:60px;align-items:start}.about-photo-frame{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);aspect-ratio:3 / 4;position:relative}.about-photo-frame img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.about-photo:hover .about-photo-frame img{transform:scale(1.03)}.about-info{text-align:center;margin-top:20px}.about-info strong{display:block;font-size:1.15rem;font-weight:700}.about-info span{font-size:.85rem;color:var(--text-muted)}.about-text{display:flex;flex-direction:column;gap:20px}.about-lead{font-size:1.15rem;color:var(--text-primary);line-height:1.8}.about-text p{font-size:.95rem;color:var(--text-secondary);line-height:1.8}.about-text strong{color:var(--text-primary);font-weight:600}.about-highlights{display:flex;gap:16px;padding:8px 0}.about-highlight{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);flex:1;transition:all var(--transition-fast)}.about-highlight:hover{border-color:var(--accent-1);transform:translateY(-2px)}.highlight-icon{width:42px;height:42px;border-radius:var(--radius-sm);background:#6366f11f;color:var(--accent-3);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.about-highlight strong{display:block;font-size:.9rem}.about-highlight span{font-size:.78rem;color:var(--text-muted)}.about-quote{font-size:1rem;color:var(--text-secondary);line-height:1.8;font-style:italic;border-left:3px solid var(--accent-1);padding-left:20px;margin:0}.about-quote strong{color:var(--text-primary);font-weight:600}.skills-tabs{display:flex;justify-content:center;gap:12px;margin-bottom:48px;flex-wrap:wrap}.skill-tab{padding:10px 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;color:var(--text-secondary);font-family:var(--font-main);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px}.skill-tab:hover{border-color:var(--accent-1);color:var(--text-primary)}.skill-tab.active{background:var(--gradient-primary);border-color:transparent;color:#fff}.skill-panel{display:none}.skill-panel.active{display:block;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.skill-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px 20px;text-align:center;transition:all var(--transition-smooth);position:relative;overflow:hidden}.skill-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);transform:scaleX(0);transition:transform var(--transition-smooth)}.skill-card:hover{border-color:var(--accent-1);transform:translateY(-4px);background:var(--bg-card-hover)}.skill-card:hover:before{transform:scaleX(1)}.skill-icon{font-size:2rem;color:var(--accent-2);margin-bottom:14px;height:40px;display:flex;align-items:center;justify-content:center}.skill-name{display:block;font-weight:600;font-size:.95rem;margin-bottom:14px;color:var(--text-primary)}.skill-bar{height:4px;background:#ffffff0f;border-radius:10px;overflow:hidden}.skill-fill{height:100%;width:0;background:var(--gradient-primary);border-radius:10px;transition:width 1.2s cubic-bezier(.16,1,.3,1)}.skill-card.in-view .skill-fill{width:var(--fill)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-smooth);display:flex;flex-direction:column;position:relative}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-md);padding:1px;background:linear-gradient(135deg,transparent 40%,var(--accent-1) 50%,transparent 60%);background-size:300% 300%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s ease;z-index:1;pointer-events:none}.project-card:hover:before{opacity:1;animation:borderShimmer 2s linear infinite}@keyframes borderShimmer{0%{background-position:0% 0%}to{background-position:300% 300%}}.project-card:hover{border-color:#6366f14d;transform:translateY(-4px) scale(1.01);box-shadow:0 12px 40px #6366f114,0 0 0 1px #6366f10d}.project-card.featured{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1.3fr}.project-image{position:relative;overflow:hidden;aspect-ratio:16/9;background:var(--bg-secondary)}.project-card.featured .project-image{aspect-ratio:auto;min-height:240px}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1)}.project-card:hover .project-image img{transform:scale(1.06)}.project-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--accent-1);background:var(--gradient-glow);opacity:.8}.project-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(10,10,15,.85) 0%,transparent 60%);display:flex;align-items:flex-end;padding:14px;opacity:0;transition:opacity var(--transition-smooth)}.project-card:hover .project-overlay{opacity:1}.project-tags{display:flex;gap:6px;flex-wrap:wrap}.tag{padding:3px 10px;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:100px;font-size:.7rem;font-weight:500;color:var(--accent-3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.project-info{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px;flex:1}.project-top{display:flex;align-items:center;justify-content:space-between}.project-label{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;color:#fbbf24;animation:starPulse 2.5s ease-in-out infinite}@keyframes starPulse{0%,to{opacity:1}50%{opacity:.6}}.project-title{font-size:1.1rem;font-weight:700;letter-spacing:-.01em;line-height:1.3}.project-description{color:var(--text-secondary);font-size:.82rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-description strong{color:var(--text-primary);font-weight:600}.project-platforms{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}.platform-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:500;color:var(--text-secondary);padding:2px 8px;border-radius:100px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:all .2s ease;letter-spacing:.2px}.platform-badge:hover{background:#ffffff14;border-color:#ffffff1f;transform:translateY(-1px)}.project-features{display:flex;flex-wrap:wrap;gap:6px}.project-features span{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;color:var(--text-muted);padding:2px 8px;background:#ffffff08;border-radius:4px}.project-links{display:flex;gap:8px;margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.project-link{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#ffffff0a;border:1px solid var(--border);border-radius:100px;font-size:.78rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);position:relative;overflow:hidden}.project-link:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-fast);border-radius:inherit;z-index:-1}.project-link:hover{border-color:var(--accent-1);color:#fff}.project-link:hover:after{opacity:1}.timeline{position:relative;max-width:800px;margin:0 auto;padding-left:40px}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent-1),var(--accent-2),transparent)}.timeline-item{position:relative;margin-bottom:48px;padding-left:40px}.timeline-item:last-child{margin-bottom:0}.timeline-marker{position:absolute;left:-49px;top:4px;width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:2px solid var(--accent-1);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--accent-2);z-index:1;transition:all var(--transition-smooth)}.timeline-item:hover .timeline-marker{background:var(--accent-1);color:#fff;box-shadow:0 0 20px var(--accent-glow)}.timeline-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px;transition:all var(--transition-smooth)}.timeline-item:hover .timeline-content{border-color:var(--accent-1);transform:translate(4px)}.timeline-date{display:inline-block;font-family:var(--font-mono);font-size:.8rem;color:var(--accent-2);margin-bottom:8px;font-weight:500}.timeline-content h3{font-size:1.15rem;font-weight:700;margin-bottom:10px;letter-spacing:-.01em}.timeline-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.7}.hobbies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.hobby-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:32px 28px;text-align:center;transition:all var(--transition-smooth);position:relative;overflow:hidden}.hobby-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--gradient-primary);transform:scaleX(0);transition:transform var(--transition-smooth)}.hobby-card:hover{border-color:var(--accent-1);transform:translateY(-4px);background:var(--bg-card-hover)}.hobby-card:hover:after{transform:scaleX(1)}.hobby-icon{font-size:2rem;color:var(--accent-2);margin-bottom:18px}.hobby-card h3{font-size:1.05rem;font-weight:700;margin-bottom:10px}.hobby-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}.contact-cards{display:flex;flex-direction:column;gap:16px}.contact-card{display:flex;align-items:center;gap:20px;padding:24px 28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-smooth);cursor:pointer}.contact-card:hover{border-color:var(--accent-1);transform:translate(8px);background:var(--bg-card-hover)}.contact-icon{width:52px;height:52px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.contact-icon.linkedin{background:#0a66c226;color:#0a66c2}.contact-icon.github{background:#ffffff1a;color:var(--text-primary)}.contact-icon.instagram{background:#e4405f26;color:#e4405f}.contact-info h3{font-size:1rem;font-weight:700;margin-bottom:2px}.contact-info p{font-size:.85rem;color:var(--text-muted)}.contact-arrow{margin-left:auto;color:var(--text-muted);transition:all var(--transition-fast)}.contact-card:hover .contact-arrow{color:var(--accent-2);transform:translate(4px)}.contact-cta{position:relative}.cta-decoration{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.cta-code{padding:32px;font-family:var(--font-mono);font-size:.9rem;line-height:2}.code-line{display:block}.code-keyword{color:#c792ea}.code-var{color:#82aaff}.code-string{color:#c3e88d}.code-bool{color:#f78c6c}.message-section{width:100%}.message-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);letter-spacing:.3px}.form-input{padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-main);font-size:.95rem;line-height:1.6;transition:all var(--transition-fast);outline:none;resize:none}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--accent-1);box-shadow:0 0 0 3px var(--accent-glow);background:var(--bg-card-hover)}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-textarea{min-height:140px;resize:vertical}.form-actions{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:4px}.btn-clear{background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.btn-clear:hover{color:#fff;border-color:#ef4444;background:#ef444426}.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.form-feedback{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500}.form-success{background:#34d3991a;border:1px solid rgba(52,211,153,.3);color:#34d399}.form-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.form-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.footer{padding:48px 0;border-top:1px solid var(--border);position:relative;z-index:1}.footer-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px}.footer-logo{font-family:var(--font-mono);font-size:1.2rem;font-weight:600}.footer-logo:hover{opacity:1}.logo-bracket{color:var(--accent-2)}.footer-social{display:flex;gap:16px}.footer-social a{width:44px;height:44px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-secondary);transition:all var(--transition-fast)}.footer-social a:hover{background:var(--accent-1);border-color:var(--accent-1);color:#fff;transform:translateY(-2px)}.footer-copy{font-size:.85rem;color:var(--text-muted)}.reveal-left,.reveal-right,.reveal-up{opacity:0;transition:all .8s cubic-bezier(.16,1,.3,1)}.reveal-left{transform:translate(-60px)}.reveal-right{transform:translate(60px)}.reveal-up{transform:translateY(60px)}.reveal-left.revealed,.reveal-right.revealed,.reveal-up.revealed{opacity:1;transform:translate(0)}.project-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}@media (max-width: 1024px){.hero-container{grid-template-columns:1fr;gap:48px;text-align:center}.hero-left{align-items:center}.hero-eyebrow{justify-content:center}.hero-description{margin:0 auto}.hero-actions,.hero-social{justify-content:center}.hero-right{max-width:560px;margin:0 auto}.float-card-1{right:-10px;top:-10px}.float-card-2{left:-10px;bottom:-60px}.about-content{grid-template-columns:1fr;gap:40px}.about-photo{max-width:280px;margin:0 auto}.about-highlights{flex-wrap:wrap}.project-card.featured,.contact-grid,.project-detail-grid{grid-template-columns:1fr}}@media (max-width: 768px){.section{padding:80px 0}.nav-toggle{display:flex}.nav-menu{position:fixed;top:var(--nav-height);left:0;right:0;background:#0a0a0ff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;padding:20px;gap:4px;border-bottom:1px solid var(--border);border-radius:0;transform:translateY(-120%);opacity:0;pointer-events:none;transition:all var(--transition-smooth)}.nav-menu.open{transform:translateY(0);opacity:1;pointer-events:all}.nav-link{padding:14px 20px;font-size:1rem;border-radius:var(--radius-sm)}.nav-cta{display:none}.hero-title-highlight{font-size:clamp(2.5rem,8vw,3.5rem)}.hero-float-card{display:none}.about-content{grid-template-columns:1fr;gap:40px}.about-photo{max-width:320px;margin:0 auto}.about-highlights{flex-direction:column}.projects-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}.timeline,.timeline-item{padding-left:30px}.timeline-marker{left:-39px;width:32px;height:32px;font-size:.75rem}.hobbies-grid{grid-template-columns:1fr}}@media (max-width: 480px){.container{padding:0 16px}.hero-title{font-size:2rem}.hero-typed-line{font-size:.85rem}.hero-actions{flex-direction:column;width:100%}.btn{width:100%;justify-content:center}.btn-ghost{width:auto}.terminal-body pre{font-size:.72rem}.about-highlight{padding:12px 16px}.skills-tabs{gap:8px}.skill-tab{padding:8px 16px;font-size:.8rem}.project-info,.timeline-content{padding:20px}}
