:root{--bg:#07080b;--bg-2:#0c0f15;--bg-3:#11151d;--surface:#ffffff08;--surface-2:#ffffff0d;--line:#ffffff14;--line-2:#ffffff24;--fg:#e8ecf3;--fg-dim:#aab1bd;--fg-mute:#6c7382;--silver:#c8cdd6;--accent:#5b8cff;--accent-2:#f56;--accent-glow:#5b8cff59;--radius:14px;--radius-lg:22px;--shadow-soft:0 8px 30px #00000059;--shadow-glow:0 0 40px -10px var(--accent-glow);--maxw:1240px;--grid-line:#ffffff09}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.55;overflow-x:hidden}.skip-link{z-index:1000;background:var(--fg);color:var(--bg);border-radius:10px;padding:10px 14px;font-weight:600;text-decoration:none;transition:top .2s;position:fixed;top:-80px;left:18px}.skip-link:focus-visible{top:18px}:where(a,button,[tabindex]):focus-visible{outline:2px solid var(--accent);outline-offset:3px}.cursor-spotlight{z-index:0;pointer-events:none;background:radial-gradient(550px circle at var(--sx,-100%) var(--sy,-100%), #5b8cff12, transparent 80%);position:fixed;inset:0}@media (hover:none){.cursor-spotlight{display:none}}.bg-field{z-index:-1;pointer-events:none;background:radial-gradient(800px 500px at 12% -10%,#5b8cff1f,#0000 60%),radial-gradient(700px 600px at 100% 10%,#ff55660f,#0000 65%),radial-gradient(900px 700px at 50% 110%,#5b8cff14,#0000 70%),linear-gradient(#07080b,#05060a 60%,#04050a);position:fixed;inset:0}.bg-field:after{content:"";background-image:linear-gradient(var(--grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(100% 70% at 50% 30%,#000 40%,#0000 90%);mask-image:radial-gradient(100% 70% at 50% 30%,#000 40%,#0000 90%)}.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}@media (width<=640px){.container{padding:0 18px}}h1,h2,h3,h4{letter-spacing:-.02em;margin:0;font-family:Space Grotesk,Inter,sans-serif;font-weight:600}.mono{font-feature-settings:"ss01";font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-mute);align-items:center;gap:10px;font-family:JetBrains Mono,monospace;font-size:12px;display:inline-flex}.kicker:before{content:"";background:linear-gradient(90deg, transparent, var(--accent));width:26px;height:1px}.section-title{max-width:22ch;margin-top:14px;font-size:clamp(28px,4vw,44px);line-height:1.1}.section-sub{color:var(--fg-dim);max-width:56ch;margin-top:14px;font-size:16px}section{padding:84px 0;scroll-margin-top:16px;position:relative}@media (width<=720px){section{padding:60px 0;scroll-margin-top:10px}}.header{z-index:50;-webkit-backdrop-filter:blur(18px)saturate(140%);border-bottom:1px solid var(--line);background:linear-gradient(#07080bc7,#07080b8c);position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;gap:24px;padding-block:16px;display:flex}.brand{color:var(--fg);letter-spacing:-.01em;align-items:center;gap:12px;font-family:Space Grotesk,sans-serif;font-size:17px;font-weight:600;text-decoration:none;display:flex}.brand-mark{background:radial-gradient(circle at 30% 30%,#fff 0%,#c8cdd6 35%,#6b7280 70%,#1a1d24 100%);border-radius:10px;width:34px;height:34px;position:relative;box-shadow:inset 0 0 0 1px #ffffff2e,0 4px 16px #5b8cff2e}.brand-mark:after{content:"";background:var(--bg);border-radius:4px;position:absolute;inset:6px;box-shadow:inset 0 0 0 1px #ffffff1f}.brand-mark:before{content:"";background:var(--accent);width:9px;height:9px;box-shadow:0 0 10px var(--accent);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.brand small{color:#8790a1;font-weight:400}.nav{align-items:center;gap:8px;display:flex}.nav a{color:var(--fg-dim);border-radius:10px;padding:9px 15px;font-size:15px;text-decoration:none;transition:color .2s,background .2s;position:relative}.nav a:hover{color:var(--fg);background:var(--surface)}.nav a.active{color:var(--fg)}.nav a.active:after{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);height:1px;position:absolute;bottom:2px;left:14px;right:14px}.header-right{align-items:center;gap:12px;display:flex}.lang-select{position:relative}.lang-btn{background:var(--surface);border:1px solid var(--line);min-height:44px;color:var(--fg-dim);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:9px 14px;font-family:JetBrains Mono,monospace;font-size:12px;transition:all .2s;display:inline-flex}.lang-btn:hover{color:var(--fg);border-color:var(--line-2)}.lang-btn .dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 6px var(--accent);border-radius:50%}.lang-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--line);min-width:180px;box-shadow:var(--shadow-soft);z-index:100;background:#0f121af2;border-radius:12px;padding:6px;display:none;position:absolute;top:calc(100% + 8px);right:0}.lang-menu.open{animation:.15s fadeUp;display:block}.lang-menu button{width:100%;color:var(--fg-dim);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-family:inherit;font-size:13px;display:flex}.lang-menu button:hover{background:var(--surface-2);color:var(--fg)}.lang-menu button.active{color:var(--fg)}.lang-menu button.active .check{color:var(--accent)}.lang-menu .check{opacity:0;font-family:JetBrains Mono,monospace;font-size:11px}.lang-menu button.active .check{opacity:1}.lang-menu .flag{color:var(--fg-mute);font-family:JetBrains Mono,monospace;font-size:11px}.btn{border:1px solid var(--line-2);background:var(--surface);color:var(--fg);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:10px 16px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn:hover{background:var(--surface-2);border-color:#ffffff38;transform:translateY(-1px)}.btn-primary{color:#0a0c11;background:linear-gradient(#f4f6fa,#c8cdd6);border-color:#0000;box-shadow:0 4px 18px #c8cdd626}.btn-primary:hover{color:#0a0c11;background:linear-gradient(#fff,#d8dde6);border-color:#0000;box-shadow:0 6px 24px #c8cdd640}.btn-accent{color:var(--fg);background:linear-gradient(#5b8cff2e,#5b8cff0d);border-color:#5b8cff66}.btn-accent:hover{box-shadow:0 0 0 1px #5b8cff66,0 6px 24px #5b8cff2e}.btn-ghost{border-color:var(--line);color:var(--fg-dim);background:0 0}.btn-ghost:hover{color:var(--fg);border-color:var(--line-2)}.btn-arrow{transition:transform .2s}.btn:hover .btn-arrow{transform:translate(2px)}.menu-toggle{border:1px solid var(--line);background:var(--surface);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:none}.menu-toggle span{background:var(--fg);width:16px;height:1.5px;display:block;position:relative}.menu-toggle span:before,.menu-toggle span:after{content:"";background:var(--fg);width:16px;height:1.5px;transition:transform .2s,top .2s;position:absolute;left:0}.menu-toggle span:before{top:-5px}.menu-toggle span:after{top:5px}.menu-toggle.open span{background:0 0}.menu-toggle.open span:before{top:0;transform:rotate(45deg)}.menu-toggle.open span:after{top:0;transform:rotate(-45deg)}@media (width<=920px){.nav{display:none}.menu-toggle{display:inline-flex}.header-cta{display:none}}@media (width<=420px){.header-inner{gap:14px}.brand{gap:10px;font-size:16px}.brand-mark{width:32px;height:32px}.header-right{gap:8px}.lang-btn{min-height:42px;padding:8px 11px}.menu-toggle{width:42px;height:42px}}.mobile-nav{border-top:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#07080bf5;padding:16px 0 24px;display:none}.mobile-nav.open{animation:.2s fadeUp;display:block}.mobile-nav a{color:var(--fg-dim);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:14px 0;font-size:15px;text-decoration:none;display:flex}.mobile-nav a:last-of-type{border-bottom:none}.mobile-nav a:hover{color:var(--fg)}.mobile-nav a span.num{color:var(--fg-mute);font-family:JetBrains Mono,monospace;font-size:12px}.hero{align-items:center;min-height:calc(100vh - 60px);padding-top:80px;padding-bottom:80px;display:flex}.hero-grid{grid-template-columns:1.3fr .9fr;align-items:center;gap:60px;display:grid}@media (width<=920px){.hero-grid{grid-template-columns:1fr;gap:40px}.hero{min-height:auto;padding-top:50px}}.hero-status{border:1px solid var(--line);background:var(--surface);letter-spacing:.06em;color:var(--fg-dim);border-radius:999px;align-items:center;gap:10px;padding:6px 14px 6px 10px;font-family:JetBrains Mono,monospace;font-size:11px;display:inline-flex}.hero-status .pulse{background:#4ade80;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 8px #4ade80}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.hero-eyebrow{color:var(--fg-mute);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:10px;margin-top:22px;font-family:JetBrains Mono,monospace;font-size:12px;display:flex}.hero-eyebrow:before{content:"";background:var(--line-2);width:28px;height:1px}.hero-title{letter-spacing:-.04em;background:linear-gradient(#fff 30%,#8b93a3);color:#0000;-webkit-background-clip:text;background-clip:text;margin-top:18px;font-size:clamp(54px,9vw,112px);line-height:.95}.hero-subtitle{color:var(--fg);letter-spacing:.02em;margin-top:22px;font-family:JetBrains Mono,monospace;font-size:clamp(15px,1.3vw,18px)}.hero-tagline{max-width:56ch;color:var(--silver);margin-top:22px;font-size:clamp(16px,1.4vw,18px);line-height:1.6}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:36px;display:flex}.hero-meta{border-top:1px solid var(--line);grid-template-columns:repeat(2,1fr);gap:20px 32px;max-width:480px;margin-top:44px;padding-top:28px;display:grid}.hero-meta .k{color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:11px}.hero-meta .v{color:var(--fg);margin-top:4px;font-size:14px}.avatar-wrap{aspect-ratio:1/1.05;width:100%;max-width:460px;margin-left:auto;position:relative}.avatar-card{border-radius:var(--radius-lg);border:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-soft), inset 0 1px 0 #ffffff0d;background:radial-gradient(80% 60% at 50% 110%,#5b8cff2e,#0000 60%),linear-gradient(#0e1219,#07080b);position:absolute;inset:0;overflow:hidden}.avatar-card:before{content:"";background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(100% 80%,#000 30%,#0000 80%);mask-image:radial-gradient(100% 80%,#000 30%,#0000 80%)}.profile-card{flex-direction:column;justify-content:center;align-items:center;gap:18px;padding:56px 28px 72px;display:flex}.profile-photo{z-index:1;aspect-ratio:4/5;background:linear-gradient(#ffffff14,#ffffff05);border:1px solid #ffffff29;border-radius:28px;width:min(76%,300px);position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff14,0 18px 60px #00000059}.profile-photo:before,.profile-photo:after{content:"";pointer-events:none;z-index:2;position:absolute}.profile-photo:before{border:1px solid #5b8cff38;border-radius:22px;inset:12px}.profile-photo:after{background:radial-gradient(70% 52% at 50% 16%,#0000 45%,#07080b14 100%),linear-gradient(#0000 60%,#07080b4d);inset:0}.profile-photo img{object-fit:cover;object-position:50% 44%;width:100%;height:100%;display:block}.profile-chips{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.profile-chips span{border:1px solid var(--line);color:var(--fg-dim);letter-spacing:.06em;text-transform:uppercase;background:#ffffff09;border-radius:999px;padding:6px 10px;font-family:JetBrains Mono,monospace;font-size:10px}@media (width<=420px){.profile-card{padding:48px 22px 68px}.profile-photo{width:min(82%,260px)}}.avatar-meta{color:var(--fg-mute);letter-spacing:.1em;text-transform:uppercase;justify-content:space-between;align-items:end;font-family:JetBrains Mono,monospace;font-size:10px;display:flex;position:absolute;bottom:16px;left:18px;right:18px}.avatar-meta .id{color:var(--fg-dim)}.avatar-meta .id b{color:var(--fg);font-weight:500}.avatar-corner{color:var(--fg-mute);letter-spacing:.1em;font-family:JetBrains Mono,monospace;font-size:10px;position:absolute}.avatar-corner.tl{top:16px;left:18px}.avatar-corner.tr{top:16px;right:18px}.avatar-corners:before,.avatar-corners:after{content:"";border:1px solid var(--accent);width:12px;height:12px;position:absolute}.avatar-corners:before{border-bottom:none;border-right:none;top:10px;left:10px}.avatar-corners:after{border-top:none;border-left:none;bottom:10px;right:10px}.about-stats{background:var(--line);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:repeat(4,1fr);gap:1px;margin-top:48px;display:grid;overflow:hidden}@media (width<=720px){.about-stats{grid-template-columns:repeat(2,1fr)}}.about-stats .stat{background:var(--bg-2);padding:22px 24px}.about-stats .stat .k{color:var(--fg-mute);letter-spacing:.1em;text-transform:uppercase;font-size:11px}.about-stats .stat .v{color:var(--fg);letter-spacing:-.01em;margin-top:8px;font-family:Space Grotesk,sans-serif;font-size:18px}.about-cols{grid-template-columns:1.3fr 1fr;align-items:stretch;gap:60px;margin-top:60px;display:grid}@media (width<=880px){.about-cols{grid-template-columns:1fr;gap:40px}}.about-cols>.reveal{flex-direction:column;display:flex}.col-head{flex-wrap:wrap;align-items:center;gap:8px 14px;margin-bottom:24px;display:flex}.col-num{color:var(--fg-mute);letter-spacing:.12em;font-size:12px}.col-title{letter-spacing:-.01em;font-size:22px}.col-note{border:1px solid var(--line);color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:5px 9px;font-family:JetBrains Mono,monospace;font-size:10px}.pillars{flex-direction:column;flex:1;gap:18px;display:flex}.pillar{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);gap:16px;padding:18px 20px;transition:all .25s;display:flex}.pillar:hover{border-color:var(--line-2);background:var(--surface-2)}.pillar-bullet{background:var(--accent);width:8px;height:8px;box-shadow:0 0 10px var(--accent);border-radius:50%;flex-shrink:0;margin-top:8px}.pillar-t{color:var(--fg);letter-spacing:-.01em;font-family:Space Grotesk,sans-serif;font-size:16px}.pillar-d{color:var(--fg-dim);text-wrap:pretty;margin-top:4px;font-size:14px;line-height:1.55}.interests{flex:1;grid-template-rows:repeat(2,minmax(132px,1fr));grid-template-columns:1fr 1fr;gap:12px;display:grid}.interest{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);flex-direction:column;justify-content:space-between;gap:18px;min-height:132px;padding:20px;transition:all .25s;display:flex}.interest:hover{background:var(--surface-2);border-color:#5b8cff59;transform:translateY(-2px)}.interest-icon{background:var(--bg-2);border:1px solid var(--line);width:38px;height:38px;color:var(--silver);border-radius:10px;justify-content:center;align-items:center;display:flex}.interest:hover .interest-icon{color:var(--accent);border-color:#5b8cff4d}.interest-t{color:var(--fg);letter-spacing:-.01em;font-family:Space Grotesk,sans-serif;font-size:15px}.interest-copy{gap:6px;display:grid}.interest-d{color:var(--fg-dim);text-wrap:pretty;font-size:13px;line-height:1.45}@media (width<=560px){.interests{grid-template-rows:none;grid-template-columns:1fr}.interest{min-height:auto}}.areas-grid{background:var(--line);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:repeat(4,1fr);gap:1px;margin-top:56px;display:grid;overflow:hidden}@media (width<=1024px){.areas-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.areas-grid{grid-template-columns:1fr}.area{min-height:auto}}.area{background:var(--bg-2);flex-direction:column;min-height:245px;padding:28px 24px 32px;transition:background .25s,transform .25s;display:flex;position:relative}.area:hover{background:var(--bg-3);transform:translateY(-1px)}.area:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);opacity:0;height:1px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.area:hover:before{opacity:1}.area-icon{background:var(--surface);border:1px solid var(--line);width:42px;height:42px;color:var(--silver);border-radius:10px;justify-content:center;align-items:center;margin-bottom:22px;transition:all .25s;display:flex}.area:hover .area-icon{color:var(--accent);box-shadow:0 0 18px -6px var(--accent-glow);border-color:#5b8cff59}.area-num{color:var(--fg-mute);letter-spacing:.1em;font-family:JetBrains Mono,monospace;font-size:11px;position:absolute;top:24px;right:24px}.area h3{margin-bottom:8px;font-size:18px}.area p{color:var(--fg-dim);text-wrap:pretty;margin:0;font-size:14px;line-height:1.55}.projects-toolbar{justify-content:space-between;align-items:center;gap:18px;margin-top:34px;display:flex}.project-filters{border:1px solid var(--line);background:#ffffff06;border-radius:999px;flex-wrap:wrap;align-items:center;gap:6px;padding:5px;display:flex}.project-filters button{color:var(--fg-dim);letter-spacing:.04em;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-family:JetBrains Mono,monospace;font-size:11px;transition:color .2s,background .2s,border-color .2s;display:inline-flex}.project-filters button:hover{color:var(--fg);background:var(--surface)}.project-filters button.active{color:var(--fg);background:#5b8cff24;border-color:#5b8cff52}.filter-count{min-width:20px;color:var(--fg-mute);text-align:center;background:#ffffff0f;border-radius:999px;padding:1px 6px;font-size:10px}.project-filters button.active .filter-count{color:var(--silver);background:#5b8cff38}.projects-github{flex-shrink:0}.projects-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;display:grid}.project{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(#ffffff06,#fff0);flex-direction:column;justify-content:space-between;min-height:278px;padding:26px;transition:all .25s;display:flex;position:relative;overflow:hidden}.project:hover{border-color:var(--line-2);transform:translateY(-2px)}.project:after{content:"";border-radius:inherit;pointer-events:none;background:radial-gradient(400px 200px at var(--mx,50%) var(--my,0%), #5b8cff2e, transparent 60%);opacity:0;transition:opacity .3s;position:absolute;inset:-1px}.project:hover:after{opacity:1}.project-tag{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-mute);background:var(--surface);border:1px solid var(--line);border-radius:6px;align-items:center;gap:6px;width:fit-content;padding:4px 8px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.project-dot{background:var(--accent);width:5px;height:5px;box-shadow:0 0 6px var(--accent);border-radius:50%;flex-shrink:0}.project h3{margin-top:18px;font-size:22px;line-height:1.2}.project p{color:var(--fg-dim);text-wrap:pretty;margin-top:10px;font-size:14px;line-height:1.55}.project-cta{color:var(--silver);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:fit-content;margin-top:22px;padding:0;font-family:JetBrains Mono,monospace;font-size:12px;display:inline-flex}.project-cta:hover{color:var(--fg)}.project-cta .arrow{transition:transform .2s}.project-cta:hover .arrow{transform:translate(3px)}.project[data-status=soon] .project-cta{color:var(--fg-mute)}@media (width<=1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=780px){.projects-toolbar{flex-direction:column;align-items:stretch}.project-filters{border-radius:14px;width:100%}.projects-github{width:fit-content}}@media (width<=560px){.projects-grid{grid-template-columns:1fr}.project{min-height:auto}}.skills-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:56px;display:grid}@media (width<=880px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.skills-grid{grid-template-columns:1fr}}.skill-group{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(#ffffff09,#ffffff03);min-height:178px;padding:22px;transition:border-color .2s,background .2s,transform .2s}.skill-group:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-1px)}.skill-group h4{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-mute);justify-content:space-between;align-items:center;margin-bottom:16px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:400;display:flex}.skill-group h4 span{color:var(--fg-mute)}.skill-tags{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{border:1px solid var(--line);background:var(--bg-2);color:var(--fg-dim);cursor:default;border-radius:999px;padding:6px 12px;font-size:13px;transition:all .2s}.skill-tag:hover{color:var(--fg);border-color:var(--line-2);transform:translateY(-1px)}.links-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:56px;display:grid}@media (width<=720px){.links-grid{grid-template-columns:1fr}}.link-card{border:1px solid var(--line);border-radius:var(--radius);color:var(--fg);background:linear-gradient(#ffffff08,#fff0);align-items:center;gap:16px;padding:18px 20px;text-decoration:none;transition:all .25s;display:flex;position:relative;overflow:hidden}.link-card:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-2px)}.link-icon{background:var(--surface);border:1px solid var(--line);width:40px;height:40px;color:var(--silver);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.link-card:hover .link-icon{color:var(--accent);border-color:#5b8cff4d}.link-text{flex-direction:column;flex:1;gap:7px;min-width:0;display:flex}.link-text .label{font-size:15px;font-weight:500;line-height:1.2}.link-text .hint{color:var(--fg-mute);margin-top:0;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.35}.link-arrow{color:var(--fg-mute);transition:all .2s}.link-card:hover .link-arrow{color:var(--fg);transform:translate(3px,-3px)}.contact-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:radial-gradient(700px 300px at 0 0,#5b8cff1f,#0000 60%),linear-gradient(#0d1119,#07080b);margin-top:40px;padding:64px 56px;position:relative;overflow:hidden}.contact-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);height:1px;position:absolute;top:0;left:0;right:0}.contact-title{max-width:18ch;font-size:clamp(32px,5vw,56px);line-height:1.05}.contact-sub{color:var(--fg-dim);max-width:50ch;margin-top:18px;font-size:17px}.contact-actions{flex-wrap:wrap;gap:12px;margin-top:36px;display:flex}@media (width<=640px){.contact-card{padding:40px 28px}.contact-actions .btn{justify-content:center;width:100%}}.footer{border-top:1px solid var(--line);margin-top:60px;padding:40px 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.footer-text{color:var(--fg-mute);font-size:13px}.footer-links{gap:8px;display:flex}.footer-links a{border:1px solid var(--line);background:var(--surface);width:36px;height:36px;color:var(--fg-dim);border-radius:10px;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:inline-flex}.footer-links a:hover{color:var(--fg);border-color:var(--line-2)}.footer-built{opacity:.6}@media (width<=720px){.footer-inner{flex-direction:column;align-items:flex-start}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes revealUp{0%{transform:translateY(14px)}to{transform:translateY(0)}}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(14px)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-stagger>*{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(14px)}.reveal-stagger>.is-visible{opacity:1;transform:translateY(0)}.reveal-stagger>:first-child{transition-delay:0s}.reveal-stagger>:nth-child(2){transition-delay:60ms}.reveal-stagger>:nth-child(3){transition-delay:.12s}.reveal-stagger>:nth-child(4){transition-delay:.18s}.reveal-stagger>:nth-child(5){transition-delay:.24s}.reveal-stagger>:nth-child(6){transition-delay:.3s}.reveal-stagger>:nth-child(7){transition-delay:.36s}.reveal-stagger>:nth-child(8){transition-delay:.42s}.reveal-stagger>:nth-child(9){transition-delay:.48s}.reveal-stagger>:nth-child(10){transition-delay:.54s}.reveal-stagger>:nth-child(11){transition-delay:.6s}.reveal-stagger>:nth-child(12){transition-delay:.66s}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.reveal,.reveal-stagger>*{opacity:1!important;transform:none!important}}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:24px;display:flex}.section-head .right{color:var(--fg-mute);font-family:JetBrains Mono,monospace;font-size:12px}::selection{color:#fff;background:#5b8cff4d}html{scrollbar-color:#ffffff26 transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#fff3}.lang-fade{animation:.35s langFade}@keyframes langFade{0%{transform:translateY(4px)}to{transform:translateY(0)}}.back-to-top{z-index:40;border:1px solid var(--line-2);-webkit-backdrop-filter:blur(12px);width:42px;height:42px;color:var(--fg-dim);cursor:pointer;background:#0c0f15e0;border-radius:12px;justify-content:center;align-items:center;transition:all .2s;animation:.25s fadeUp;display:flex;position:fixed;bottom:28px;right:28px}.back-to-top:hover{color:var(--fg);background:#5b8cff1f;border-color:#5b8cff73;transform:translateY(-2px)}.skill-group-icon{color:var(--fg-mute);transition:color .2s;display:flex}.skill-group:hover .skill-group-icon{color:var(--accent)}
