@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root,[data-theme=dark]{--bg-primary: #0a0f1c;--bg-secondary: rgba(15, 22, 41, .4);--bg-card: rgba(20, 27, 45, .8);--bg-card-solid: rgba(20, 27, 45, .95);--card-3d-side: rgba(80, 70, 180, .35);--card-3d-bottom: rgba(60, 50, 150, .2);--card-glass-bg: rgba(18, 22, 40, .75);--card-glass-border: rgba(255, 255, 255, .08);--card-glass-border-hover: rgba(255, 255, 255, .18);--card-glass-shine: rgba(255, 255, 255, .06);--card-shadow-diffuse: rgba(0, 0, 0, .4);--card-glow-primary: rgba(96, 100, 250, .18);--card-glow-secondary: rgba(139, 92, 246, .1);--bg-navbar: rgba(10, 15, 28, .85);--bg-overlay: rgba(10, 15, 28, .95);--bg-code: rgba(15, 23, 42, .9);--bg-code-header: rgba(30, 41, 59, .8);--bg-input: rgba(20, 27, 45, .8);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--text-dim: #475569;--accent: #60a5fa;--accent-secondary: #a78bfa;--accent-on-bg: #0a0f1c;--accent-hover-bg: rgba(96, 165, 250, .15);--accent-tag-bg: rgba(96, 165, 250, .08);--accent-tag-border: rgba(96, 165, 250, .15);--accent-subtle-bg: rgba(96, 165, 250, .1);--accent-subtle-border: rgba(96, 165, 250, .2);--accent-icon-bg: linear-gradient(135deg, rgba(96, 165, 250, .15), rgba(167, 139, 250, .15));--accent-gradient: linear-gradient(135deg, #60a5fa, #a78bfa);--accent-glow: rgba(96, 165, 250, .3);--accent-border: rgba(96, 165, 250, .3);--border: rgba(148, 163, 184, .1);--border-hover: rgba(96, 165, 250, .3);--border-input: rgba(148, 163, 184, .15);--shadow: rgba(0, 0, 0, .3);--shadow-glow: rgba(96, 165, 250, .3);--pillar-color-a: rgba(96, 165, 250, .3);--pillar-color-b: rgba(167, 139, 250, .4);--pillar-color-c: rgba(96, 165, 250, .2);--chroma-glow: rgba(96, 165, 250, .06);--badge-current-bg: rgba(96, 165, 250, .15);--badge-completed-bg: rgba(52, 211, 153, .15);--badge-completed-color: #34d399;--badge-completed-border: rgba(52, 211, 153, .3);--scrollbar-mouse: rgba(148, 163, 184, .3)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: rgba(241, 245, 249, .6);--bg-card: rgba(255, 255, 255, .85);--bg-card-solid: rgba(255, 255, 255, .95);--card-3d-side: rgba(160, 150, 220, .4);--card-3d-bottom: rgba(140, 130, 200, .25);--card-glass-bg: rgba(255, 255, 255, .7);--card-glass-border: rgba(255, 255, 255, .5);--card-glass-border-hover: rgba(59, 130, 246, .3);--card-glass-shine: rgba(255, 255, 255, .5);--card-shadow-diffuse: rgba(0, 0, 0, .08);--card-glow-primary: rgba(59, 130, 246, .1);--card-glow-secondary: rgba(139, 92, 246, .06);--bg-navbar: rgba(248, 250, 252, .88);--bg-overlay: rgba(248, 250, 252, .97);--bg-code: rgba(241, 245, 249, .95);--bg-code-header: rgba(226, 232, 240, .8);--bg-input: rgba(255, 255, 255, .9);--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--text-dim: #94a3b8;--accent: #3b82f6;--accent-secondary: #8b5cf6;--accent-on-bg: #ffffff;--accent-hover-bg: rgba(59, 130, 246, .1);--accent-tag-bg: rgba(59, 130, 246, .06);--accent-tag-border: rgba(59, 130, 246, .15);--accent-subtle-bg: rgba(59, 130, 246, .08);--accent-subtle-border: rgba(59, 130, 246, .2);--accent-icon-bg: linear-gradient(135deg, rgba(59, 130, 246, .1), rgba(139, 92, 246, .1));--accent-gradient: linear-gradient(135deg, #3b82f6, #8b5cf6);--accent-glow: rgba(59, 130, 246, .2);--accent-border: rgba(59, 130, 246, .3);--border: rgba(148, 163, 184, .2);--border-hover: rgba(59, 130, 246, .3);--border-input: rgba(148, 163, 184, .25);--shadow: rgba(0, 0, 0, .08);--shadow-glow: rgba(59, 130, 246, .2);--pillar-color-a: rgba(59, 130, 246, .12);--pillar-color-b: rgba(139, 92, 246, .15);--pillar-color-c: rgba(59, 130, 246, .08);--chroma-glow: rgba(59, 130, 246, .04);--badge-current-bg: rgba(59, 130, 246, .1);--badge-completed-bg: rgba(16, 185, 129, .1);--badge-completed-color: #10b981;--badge-completed-border: rgba(16, 185, 129, .3);--scrollbar-mouse: rgba(100, 116, 139, .3)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:70px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}a{text-decoration:none;color:inherit}ul{list-style:none}img{max-width:100%;display:block}.light-pillar-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:hidden}.light-pillar{position:absolute;bottom:0;background:linear-gradient(to top,transparent 0%,var(--pillar-color-a) 30%,var(--pillar-color-b) 60%,var(--pillar-color-c) 80%,transparent 100%);filter:blur(3px);border-radius:50% 50% 0 0;animation:pillarRise linear infinite;transform-origin:bottom center}@keyframes pillarRise{0%{transform:translateY(100%) scaleY(0);opacity:0}20%{opacity:1}80%{opacity:1}to{transform:translateY(-20%) scaleY(1.2);opacity:0}}.gooey-nav{position:relative;display:flex;align-items:center}.gooey-svg-filter{position:absolute;width:0;height:0;pointer-events:none}.gooey-nav-blob-wrap{position:absolute;top:0;right:0;bottom:0;left:0;filter:url(#gooey-filter);pointer-events:none}.gooey-nav-list{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0;position:relative;z-index:2}.gooey-nav-blob{position:absolute;top:50%;left:0;height:38px;background:var(--accent-gradient);border-radius:19px;z-index:1;transform:translateY(-50%);pointer-events:none;opacity:.9}.gooey-nav-link{position:relative;z-index:3;font-size:.875rem;font-weight:500;color:var(--text-secondary);padding:8px 16px;border-radius:19px;transition:color .3s ease;text-decoration:none;white-space:nowrap}.gooey-nav-link:hover{color:var(--text-primary)}.gooey-nav-link.active{color:var(--accent-on-bg);font-weight:600}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:70px;transition:all .3s ease;background:transparent}.navbar.scrolled{background:var(--bg-navbar);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);box-shadow:0 1px 3px var(--shadow)}.nav-container{max-width:1200px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:16px}.nav-logo{text-decoration:none;z-index:1001;display:flex;align-items:center}.nav-logo-img{height:42px;width:auto;object-fit:contain;display:block;filter:brightness(0) invert(1);transition:filter .3s ease,opacity .3s ease}.nav-logo-img:hover{opacity:.8}[data-theme=light] .nav-logo-img{filter:brightness(0)}.nav-desktop{display:flex;flex:1;justify-content:center}.theme-toggle{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.05rem;transition:all .3s ease;z-index:1001;flex-shrink:0}.theme-toggle:hover{border-color:var(--accent-border);background:var(--accent-hover-bg);transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-glow)}.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px;z-index:1001}.nav-toggle span{display:block;width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.nav-mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.nav-mobile-list{list-style:none;padding:0;margin:0;text-align:center}.nav-mobile-list li{margin:20px 0}.nav-mobile-list a{font-size:1.5rem;font-weight:600;color:var(--text-primary);text-decoration:none;transition:color .3s ease}.nav-mobile-list a:hover{color:var(--accent)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 900px){.nav-desktop{display:none}.nav-toggle{display:flex}}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:70px}.hero-spline-bg{position:absolute;top:0;left:0;width:100%;height:calc(100% + 80px);z-index:0;border:none;pointer-events:none;clip-path:inset(0 0 80px 0)}.hero-container{max-width:1200px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1;width:100%}.hero-greeting{font-family:JetBrains Mono,monospace;font-size:1rem;color:var(--accent);margin-bottom:12px;letter-spacing:1px;opacity:0;transform:translateY(20px);animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) .1s forwards}.hero-name{font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1;margin-bottom:20px;opacity:0;animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) .3s forwards}.name-line{display:block;color:var(--text-primary)}.name-line.accent{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title-wrapper{display:flex;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:1.1rem;margin-bottom:24px;min-height:30px;opacity:0;transform:translateY(20px);animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) .6s forwards}.hero-title-prefix{color:var(--accent);font-weight:600}.hero-title{color:var(--text-secondary)}.cursor{color:var(--accent);animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-description{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:32px;max-width:500px;opacity:0;transform:translateY(20px);animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) .8s forwards}.hero-actions{display:flex;gap:16px;margin-bottom:40px;flex-wrap:wrap;opacity:0;transform:translateY(20px);animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) 1s forwards}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:6px;font-size:.95rem;font-weight:600;transition:all .3s ease;cursor:pointer;border:none;font-family:inherit;text-decoration:none}.btn-primary{background:var(--accent-gradient);color:var(--accent-on-bg)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--shadow-glow)}.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-outline:hover{background:var(--accent-hover-bg);transform:translateY(-2px)}.hero-social{display:flex;gap:12px;opacity:0;transform:translateY(20px);animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) 1.2s forwards}.social-link{width:42px;height:42px;border-radius:6px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .3s ease;font-size:1.1rem;text-decoration:none}.social-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-hover-bg);transform:translateY(-3px)}.hero-visual{width:100%;border-radius:16px;overflow:hidden;opacity:0;transform:translate(40px);animation:heroSlideIn 1s cubic-bezier(.16,1,.3,1) .5s forwards}.code-window{background:var(--bg-code);border-radius:12px;border:1px solid var(--border);overflow:hidden;box-shadow:0 20px 60px var(--shadow)}.code-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-code-header);border-bottom:1px solid var(--border)}.code-dots{display:flex;gap:6px}.dot{width:12px;height:12px;border-radius:50%}.dot.red{background:#ef4444}.dot.yellow{background:#eab308}.dot.green{background:#22c55e}.code-title{font-family:JetBrains Mono,monospace;font-size:.8rem;color:var(--text-muted)}.code-body{padding:20px}.code-body pre{margin:0;font-family:JetBrains Mono,monospace;font-size:.85rem;line-height:1.7;color:var(--text-primary);white-space:pre}.code-body code{font-family:inherit}.code-keyword{color:#c084fc}.code-class{color:#fbbf24}.code-func{color:var(--accent)}.code-param{color:#f97316}.code-string{color:#34d399}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes heroSlideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translate(-50%);z-index:2;text-decoration:none}.mouse{width:26px;height:40px;border:2px solid var(--scrollbar-mouse);border-radius:13px;position:relative}.wheel{width:4px;height:8px;background:var(--accent);border-radius:2px;position:absolute;top:8px;left:50%;transform:translate(-50%);animation:scrollWheel 2s infinite}@keyframes scrollWheel{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(12px)}}@media (max-width: 900px){.hero-container{grid-template-columns:1fr;text-align:center}.hero-description{max-width:100%}.hero-actions,.hero-social{justify-content:center}.hero-visual{height:350px}}.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:start}.about-text p{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:20px}.about-text strong{color:var(--text-primary);font-weight:600}.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:20px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:28px 20px;text-align:center;transition:all .3s ease}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:0 10px 30px var(--shadow)}.stat-number{font-size:2.2rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}.stat-label{font-size:.85rem;color:var(--text-muted);font-weight:500}@media (max-width: 900px){.about-grid{grid-template-columns:1fr;gap:40px}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.skill-category{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px 28px;transition:all .4s cubic-bezier(.23,1,.32,1);opacity:0;transform:translateY(30px)}.skill-category.visible{opacity:1;transform:translateY(0)}.skill-category:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:0 20px 40px var(--shadow)}.skill-category-icon{width:52px;height:52px;border-radius:14px;background:var(--accent-icon-bg);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--accent);margin-bottom:20px;transition:transform .3s ease}.skill-category:hover .skill-category-icon{transform:scale(1.1)}.skill-category h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0 0 16px}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{font-size:.8rem;padding:6px 14px;border-radius:20px;background:var(--accent-tag-bg);color:var(--text-secondary);border:1px solid var(--border);font-weight:500;transition:all .3s ease}.skill-tag:hover{background:var(--accent-hover-bg);color:var(--accent);border-color:var(--border-hover)}.timeline-wrapper{position:relative;padding:0 50px}.timeline-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:var(--bg-card-solid);border:1px solid var(--accent-border);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .3s ease;font-size:.9rem}.timeline-nav:hover:not(:disabled){background:var(--accent-hover-bg);border-color:var(--accent)}.timeline-nav:disabled{opacity:.3;cursor:not-allowed}.timeline-nav-prev{left:0}.timeline-nav-next{right:0}.timeline{display:flex;gap:40px;overflow-x:auto;scroll-behavior:smooth;padding:20px 0;-ms-overflow-style:none;scrollbar-width:none;position:relative}.timeline:before{content:"";position:absolute;top:64px;left:0;height:2px;background:var(--accent);z-index:0;width:calc(var(--timeline-items, 4) * (380px + 40px))}.timeline::-webkit-scrollbar{display:none}.timeline-item{min-width:380px;max-width:380px;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.timeline-date-label{display:block;font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--accent);font-weight:600;margin-bottom:16px;text-align:center}.timeline-marker{width:16px;height:16px;border-radius:50%;background:var(--accent);margin-bottom:0;box-shadow:0 0 12px var(--accent-glow);position:relative;z-index:2;border:3px solid var(--bg-primary);flex-shrink:0}.timeline-marker:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%);width:2px;height:46px;background:var(--accent)}.timeline-content{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:28px;transition:all .3s ease;flex:1;display:flex;flex-direction:column;margin-top:46px;width:100%}.timeline-content:hover{border-color:var(--accent-subtle-border);transform:translateY(-4px);box-shadow:0 10px 30px var(--shadow)}.timeline-header{margin-bottom:16px}.timeline-role{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.timeline-company{font-size:.9rem;color:var(--accent);margin:0 0 12px;display:flex;align-items:center;gap:6px}.timeline-meta{display:flex;flex-direction:column;gap:4px;margin-top:8px}.timeline-date,.timeline-location{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:6px}.timeline-details{list-style:none;padding:0;margin:0 0 16px}.timeline-details li{font-size:.88rem;color:var(--text-secondary);line-height:1.6;padding-left:16px;position:relative;margin-bottom:8px}.timeline-details li:before{content:"▹";color:var(--accent);position:absolute;left:0}.timeline-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.timeline-tags span{font-size:.72rem;padding:3px 10px;border-radius:20px;background:var(--accent-tag-bg);color:var(--accent);border:1px solid var(--accent-tag-border);font-weight:500}@media (max-width: 768px){.timeline-wrapper{padding:0 10px}.timeline-item{min-width:300px;max-width:300px}}.card-swap-container{position:relative;width:100%;max-width:850px;height:420px;margin:40px auto 0;cursor:pointer;perspective:1200px}.card-swap-container:before{content:"";position:absolute;top:-40px;right:-40px;bottom:-40px;left:-40px;background:radial-gradient(ellipse 70% 60% at 60% 40%,var(--card-glow-primary, rgba(96, 100, 250, .18)) 0%,var(--card-glow-secondary, rgba(139, 92, 246, .1)) 40%,transparent 70%);z-index:-1;border-radius:50%;filter:blur(30px);pointer-events:none}.card-swap-card{position:absolute;top:0;left:0;width:100%;display:flex;flex-direction:row;background:var(--card-glass-bg, rgba(18, 22, 40, .75));border:1px solid var(--card-glass-border, rgba(255, 255, 255, .08));border-radius:20px;overflow:hidden;transition:all .6s cubic-bezier(.23,1,.32,1);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-sizing:border-box;box-shadow:0 8px 32px var(--card-shadow-diffuse, rgba(0, 0, 0, .35)),0 2px 8px #0003,inset 0 1px 0 var(--card-glass-shine, rgba(255, 255, 255, .06));transform-style:preserve-3d}.card-swap-content{flex:1;padding:28px 28px 20px;display:flex;flex-direction:column;min-width:0;position:relative}.card-swap-number{position:absolute;top:12px;right:14px;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:500;color:var(--text-muted);letter-spacing:.05em;opacity:.8;pointer-events:none}.card-swap-gallery{flex:0 0 280px;position:relative;overflow:hidden;background:var(--bg-secondary, #111827)}.card-swap-gallery-img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .3s ease}.card-swap-nav{position:absolute;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s ease,background .25s ease;z-index:2}.card-swap-gallery:hover .card-swap-nav{opacity:1}.card-swap-nav:hover{background:var(--accent)}.card-swap-nav-prev{left:6px}.card-swap-nav-next{right:6px}.card-swap-dots{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:5px;z-index:2}.card-swap-dot{width:7px;height:7px;border-radius:50%;background:#fff6;cursor:pointer;transition:background .2s ease,transform .2s ease}.card-swap-dot.active{background:var(--accent);transform:scale(1.3)}.card-swap-card:hover{border-color:var(--card-glass-border-hover, rgba(255, 255, 255, .15));box-shadow:0 12px 40px var(--card-shadow-diffuse, rgba(0, 0, 0, .4)),0 4px 12px #00000040,inset 0 1px 0 var(--card-glass-shine, rgba(255, 255, 255, .1))}.card-swap-exiting{animation:cardSwapExit .6s cubic-bezier(.23,1,.32,1) forwards}@keyframes cardSwapExit{0%{transform:translateY(0) scale(1) rotateX(0);opacity:1}40%{transform:translateY(-80px) scale(.96) rotateX(-4deg);opacity:.6}to{transform:translateY(200px) scale(.88) rotateX(0);opacity:0}}.card-swap-header{margin-bottom:16px}.card-swap-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}.card-swap-subtitle{font-size:.85rem;color:var(--accent);margin:0;font-family:JetBrains Mono,monospace}.card-swap-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.7;margin-bottom:20px}.card-swap-tech{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.card-swap-tag{font-size:.75rem;padding:4px 12px;border-radius:20px;background:var(--accent-subtle-bg);color:var(--accent);border:1px solid var(--accent-subtle-border);font-weight:500}.card-swap-actions{display:flex;gap:12px;margin-top:auto}.card-swap-btn{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;padding:8px 18px;border-radius:8px;background:var(--accent-gradient);color:var(--accent-on-bg);text-decoration:none;transition:all .3s ease}.card-swap-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow-glow)}.card-swap-hint{position:absolute;bottom:-36px;left:50%;transform:translate(-50%);font-size:.75rem;color:var(--text-muted);white-space:nowrap}.card-swap-expand{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:6px;border:none;background:#0000008c;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s ease,background .25s ease;z-index:2}.card-swap-gallery:hover .card-swap-expand{opacity:1}.card-swap-expand:hover{background:var(--accent)}.card-swap-gallery-img{cursor:zoom-in}.card-swap-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000;display:flex;flex-direction:column;cursor:default;animation:lbFadeIn .25s ease}@keyframes lbFadeIn{0%{opacity:0}to{opacity:1}}.card-swap-lightbox-topbar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#111}.card-swap-lightbox-counter{color:#fff9;font-size:.85rem;margin:0}.card-swap-lightbox-close{width:36px;height:36px;border-radius:8px;border:none;background:#dc2626;color:#fff;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.card-swap-lightbox-close:hover{background:#ef4444}.card-swap-lightbox-body{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:16px 60px}.card-swap-lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px;cursor:default;animation:lbZoomIn .3s ease}@keyframes lbZoomIn{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.card-swap-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:none;background:#ffffff1f;color:#fff;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease;z-index:2}.card-swap-lightbox-nav:hover{background:var(--accent)}.card-swap-lightbox-prev{left:10px}.card-swap-lightbox-next{right:10px}.card-swap-lightbox-dots{flex:0 0 auto;display:flex;justify-content:center;gap:8px;padding:10px 0 14px;background:#111}@media (max-width: 768px){.card-swap-container{height:560px;max-width:100%}.card-swap-card{flex-direction:column-reverse}.card-swap-gallery{flex:0 0 180px;width:100%}.card-swap-nav{opacity:1}.card-swap-content{padding:16px}.card-swap-title{font-size:1.1rem}.card-swap-desc{font-size:.85rem}}.projects-cardswap-wrapper{display:flex;justify-content:center;min-height:500px;padding-bottom:40px}@media (max-width: 768px){.projects-cardswap-wrapper{min-height:480px}}.chroma-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px;padding:10px}.chroma-card{position:relative;border-radius:16px;background:var(--bg-card);border:1px solid var(--border);overflow:hidden;transition:all .4s cubic-bezier(.23,1,.32,1);cursor:default}.chroma-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;padding:1px;background:radial-gradient(250px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),var(--accent-glow),var(--accent-subtle-border),transparent 70%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:0;transition:opacity .4s ease}.chroma-card:hover:before{opacity:1}.chroma-card-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;background:radial-gradient(300px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),var(--chroma-glow),transparent 60%);pointer-events:none;opacity:0;transition:opacity .4s ease}.chroma-card:hover .chroma-card-glow{opacity:1}.chroma-card-hovered{transform:translateY(-4px);border-color:var(--accent-subtle-border);box-shadow:0 20px 40px var(--shadow)}.chroma-card-content{position:relative;padding:32px;z-index:1}.chroma-card-icon{width:56px;height:56px;border-radius:14px;background:var(--accent-icon-bg);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--accent);margin-bottom:20px;transition:transform .3s ease}.chroma-card:hover .chroma-card-icon{transform:scale(1.1)}.chroma-card-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}.chroma-card-subtitle{font-size:1rem;font-weight:500;color:var(--text-secondary);margin:0 0 12px}.chroma-card-school{font-size:.9rem;color:var(--accent);margin:0 0 14px;display:flex;align-items:center;gap:8px}.chroma-card-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:.85rem;color:var(--text-muted)}.chroma-card-meta span{display:flex;align-items:center;gap:6px}.chroma-badge{position:absolute;top:24px;right:24px;padding:4px 14px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.chroma-badge.current{background:var(--badge-current-bg);color:var(--accent);border:1px solid var(--accent-border)}.chroma-badge.completed{background:var(--badge-completed-bg);color:var(--badge-completed-color);border:1px solid var(--badge-completed-border)}@media (max-width: 768px){.chroma-grid{grid-template-columns:1fr}}.circular-gallery{width:100%;height:450px;perspective:1200px;overflow:hidden;cursor:grab;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.circular-gallery:active{cursor:grabbing}.circular-gallery-track{position:relative;width:200px;height:280px;transform-style:preserve-3d;transition:transform .05s linear}.circular-gallery-item{position:absolute;top:0;left:0;width:100%;height:100%;backface-visibility:hidden}.circular-gallery-card{width:240px;padding:28px 24px;background:var(--bg-card-solid);border:1px solid var(--accent-tag-border);border-radius:16px;text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .3s ease;transform:translate(-20px)}.circular-gallery-card:hover{border-color:var(--accent-border);box-shadow:0 0 30px var(--accent-subtle-bg)}.circular-card-icon{width:52px;height:52px;margin:0 auto 16px;border-radius:14px;background:var(--accent-icon-bg);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--accent)}.circular-gallery-card h3{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 10px;line-height:1.3}.circular-card-issuer{font-size:.82rem;color:var(--accent);margin:0 0 6px;display:flex;align-items:center;justify-content:center;gap:6px}.circular-card-date{font-size:.78rem;color:var(--text-muted);margin:0 0 14px;display:flex;align-items:center;justify-content:center;gap:6px}.circular-card-link{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--accent);text-decoration:none;padding:6px 16px;border:1px solid var(--accent-border);border-radius:8px;transition:all .3s ease}.circular-card-link:hover{background:var(--accent-hover-bg);border-color:var(--accent)}@media (max-width: 768px){.circular-gallery{height:380px}}.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}.contact-text{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:32px}.contact-cards{display:flex;flex-direction:column;gap:16px}.contact-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;text-decoration:none;transition:all .3s ease}.contact-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 10px 30px var(--shadow)}.contact-card-icon{width:48px;height:48px;border-radius:12px;background:var(--accent-icon-bg);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--accent);flex-shrink:0}.contact-card h4{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 2px}.contact-card p{font-size:.85rem;color:var(--text-muted);margin:0}.contact-form{display:flex;flex-direction:column;gap:20px}.form-group{position:relative}.form-group input,.form-group textarea{width:100%;padding:16px 18px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.95rem;transition:all .3s ease;outline:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle-bg)}.form-group label{position:absolute;left:18px;top:16px;font-size:.95rem;color:var(--text-muted);pointer-events:none;transition:all .3s ease}.form-group input:not(:placeholder-shown)+label,.form-group input:focus+label,.form-group textarea:not(:placeholder-shown)+label,.form-group textarea:focus+label{top:-8px;left:14px;font-size:.75rem;color:var(--accent);background:var(--bg-primary);padding:0 6px}.btn-full{width:100%;justify-content:center}@media (max-width: 900px){.contact-wrapper{grid-template-columns:1fr}}.footer{padding:60px 0;border-top:1px solid var(--border);position:relative;z-index:1}.footer-content{display:flex;flex-direction:column;align-items:center;gap:20px}.footer-logo{font-family:JetBrains Mono,monospace;font-size:1.4rem;font-weight:700;color:var(--text-primary);text-decoration:none}.footer-text{font-size:.9rem;color:var(--text-muted)}.footer-social{display:flex;gap:12px}.footer-copy{font-size:.8rem;color:var(--text-dim);margin-top:10px}.app{position:relative;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{padding:100px 0;position:relative;z-index:1}.section-alt{background:var(--bg-secondary)}.section-title{font-size:clamp(1.8rem,3vw,2.2rem);font-weight:800;color:var(--text-primary);margin-bottom:50px;text-align:center}.section-title:after{display:none}.section-number{font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:500;color:var(--accent)}@media (max-width: 768px){.section{padding:60px 0}.section-title{margin-bottom:36px}}
