:root{--bg:#060607;--bg-2:#0c0c10;--panel:hsla(0,0%,100%,.024);--panel-hi:hsla(0,0%,100%,.055);--glass:rgba(14,14,18,.62);--ink:#f6f6f7;--ink-dim:#a8a8b0;--ink-faint:#67676f;--line:hsla(0,0%,100%,.085);--line-2:hsla(0,0%,100%,.05);--accent:#fff;--accent-soft:hsla(0,0%,100%,.15);--glow:0.6;--disp:"Raleway",system-ui,sans-serif;--body:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI",system-ui,sans-serif;--mono:"JetBrains Mono",ui-monospace,monospace;--maxw:940px;--status:#34d399}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}a{color:inherit}::selection{background:var(--accent);color:#08080a}.bg{position:fixed;inset:0;z-index:-3;background:radial-gradient(135% 95% at 50% -12%,var(--bg-2),var(--bg) 56%)}.bg-glow{width:64vmax;height:64vmax;left:50%;background:radial-gradient(circle,var(--accent) 0,transparent 62%);opacity:calc(var(--glow) * .1);filter:blur(48px);transform:translate(-50%,-46%);transition:opacity .6s ease}.bg-cursor,.bg-glow{position:fixed;z-index:-2;top:0;border-radius:50%;pointer-events:none}.bg-cursor{width:36vmax;height:36vmax;left:0;background:radial-gradient(circle,var(--accent) 0,transparent 60%);opacity:calc(var(--glow) * .05);filter:blur(34px);transform:translate(-50%,-50%);will-change:transform}.bg-grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E")}body[data-grain="0"] .bg-grain{display:none}.topbar{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px clamp(16px,4vw,34px);pointer-events:none}.topbar>*{pointer-events:auto}.rect{background:var(--glass);border:1px solid var(--line);border-radius:15px;backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);box-shadow:0 8px 30px -16px rgba(0,0,0,.8),inset 0 1px 0 hsla(0,0%,100%,.04)}.brand{display:flex;align-items:center;gap:10px;padding:11px 15px;text-decoration:none;font-family:var(--mono);font-size:13px;letter-spacing:.01em;color:var(--ink)}.bdot{width:8px;height:8px;border-radius:50%;background:var(--status);position:relative;flex:none;box-shadow:0 0 10px var(--status)}.bdot:after{content:"";position:absolute;inset:-3px;border-radius:50%;background:inherit;opacity:.45;animation:ping 2.4s cubic-bezier(0,0,.2,1) infinite}body[data-status=idle] .bdot:after,body[data-status=offline] .bdot:after{animation:none}.brand .bstatus{color:var(--ink-faint);font-size:11px}@keyframes ping{0%{transform:scale(1);opacity:.45}70%,to{transform:scale(2.6);opacity:0}}.navpill{display:flex;gap:3px;padding:6px}.navpill a{font-family:var(--mono);font-size:12px;color:var(--ink-faint);text-decoration:none;padding:8px 13px;border-radius:10px;transition:.25s;letter-spacing:.01em;white-space:nowrap}.navpill a.active,.navpill a:hover{color:var(--ink);background:var(--panel-hi)}.langbox{display:flex;gap:2px;padding:5px}.langbox button{font-family:var(--mono);font-size:12px;color:var(--ink-faint);border:0;background:transparent;padding:7px 10px;border-radius:9px;cursor:pointer;transition:.25s;letter-spacing:.02em}.langbox button:hover{color:var(--ink-dim)}.langbox button.on{color:var(--ink);background:var(--panel-hi)}@media (max-width:780px){.navpill{display:none}.topbar{padding:14px 16px}}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,28px)}.section{padding:12vh 0}.hero,.section{position:relative;isolation:isolate}.hero:before,.section:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:100vw;transform:translateX(-50%);z-index:-1;pointer-events:none;-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 18%,#000 82%,transparent);mask-image:linear-gradient(180deg,transparent 0,#000 18%,#000 82%,transparent)}#friends:before,#projects:before,.hero:before{background-image:radial-gradient(hsla(0,0%,100%,.09) 1.1px,transparent 1.2px);background-size:24px 24px;background-position:50%}#about:before,#skills:before{background-image:linear-gradient(hsla(0,0%,100%,.05) 1px,transparent 0),linear-gradient(90deg,hsla(0,0%,100%,.05) 1px,transparent 0);background-size:46px 46px;background-position:50%}body[data-dots="0"] .hero:before,body[data-dots="0"] .section:before{display:none}.shead{display:flex;align-items:baseline;gap:16px;margin-bottom:40px}.sidx{font-family:var(--mono);font-size:12px;color:var(--accent);border:1px solid var(--accent-soft);border-radius:8px;padding:5px 9px;flex:none;letter-spacing:.04em}.stitle{font-family:var(--disp);font-weight:800;font-size:clamp(32px,6.5vw,56px);letter-spacing:-.02em;line-height:1}.sdesc{color:var(--ink-dim);font-size:16.5px;max-width:56ch;margin-top:-22px;margin-bottom:38px;text-wrap:pretty}.rv{transition:opacity .9s cubic-bezier(.16,.8,.3,1),transform .9s cubic-bezier(.16,.8,.3,1),filter .9s ease}html.js .rv{opacity:0;transform:translateY(34px);filter:blur(7px)}html.js .rv.in{opacity:1;transform:none;filter:blur(0)}html.js .rv-stagger>*{opacity:0;transform:translateY(26px);filter:blur(6px);transition:opacity .75s cubic-bezier(.16,.8,.3,1),transform .75s cubic-bezier(.16,.8,.3,1),filter .75s ease}html.js .rv-stagger.in>*{opacity:1;transform:none;filter:blur(0)}html.js .rv-stagger.in>:nth-child(2){transition-delay:.08s}html.js .rv-stagger.in>:nth-child(3){transition-delay:.16s}html.js .rv-stagger.in>:nth-child(4){transition-delay:.24s}html.js .rv-stagger.in>:nth-child(5){transition-delay:.32s}@media (prefers-reduced-motion:reduce){html.js .rv,html.js .rv-stagger>*{opacity:1!important;transform:none!important;filter:none!important;transition:none}}html.js .hero h1,html.js .stitle{-webkit-clip-path:inset(0 0 -20% 0);clip-path:inset(0 0 -20% 0)}.hero{padding:11vh 0 9vh}.hero .kick{font-family:var(--mono);font-size:13px;color:var(--ink-faint);letter-spacing:.04em;margin-bottom:20px}.hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(52px,12vw,118px);letter-spacing:-.035em;line-height:.88}.hero h1 .mut{color:var(--ink-faint);font-weight:300}.hero .role{font-family:var(--disp);font-weight:600;font-size:clamp(20px,4vw,32px);color:var(--ink-dim);margin-top:16px;letter-spacing:-.01em}.hero .lead{color:var(--ink-dim);font-size:17.5px;max-width:58ch;margin-top:26px;text-wrap:pretty}.hero .lead b{color:var(--ink);font-weight:600}.cta-row{display:flex;gap:11px;flex-wrap:wrap;margin-top:34px}.btn,.cta-row{align-items:center}.btn{display:inline-flex;gap:9px;text-decoration:none;font-size:14.5px;font-weight:600;padding:13px 20px;border-radius:13px;transition:.32s cubic-bezier(.2,.7,.3,1);font-family:var(--body)}.btn-primary{background:var(--accent);color:#08080a}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 44px -14px var(--accent)}.btn:active{transform:translateY(0) scale(.96);transition:transform .12s cubic-bezier(.2,.7,.3,1)}.btn-discord{background:#5865f2;color:#fff}.btn-discord:hover{transform:translateY(-2px);box-shadow:0 16px 44px -14px #5865f2}.btn-ghost{border:1px solid var(--line);color:var(--ink-dim);background:var(--panel)}.btn-ghost:hover{color:var(--ink);border-color:var(--accent-soft);background:var(--panel-hi);transform:translateY(-2px)}.btn svg{width:17px;height:17px}.icons{display:flex;gap:9px;flex-wrap:wrap;margin-top:24px}.ibtn{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:var(--panel);display:grid;place-items:center;color:var(--ink-dim);text-decoration:none;transition:.3s cubic-bezier(.2,.7,.3,1)}.ibtn svg{width:19px;height:19px}.ibtn:hover{color:var(--ink);border-color:var(--accent-soft);background:var(--panel-hi);transform:translateY(-3px)}.ibtn:active{transform:translateY(-1px) scale(.92);transition:transform .12s cubic-bezier(.2,.7,.3,1)}.widgets{display:grid;grid-template-columns:1fr 1fr 1.5fr;grid-gap:12px;gap:12px;margin-top:40px}@media (max-width:760px){.widgets{grid-template-columns:1fr}}.wcard{border:1px solid var(--line);border-radius:16px;padding:18px;background:var(--panel);position:relative;overflow:hidden;transition:.4s cubic-bezier(.2,.7,.3,1)}.wcard:hover{border-color:var(--accent-soft);background:var(--panel-hi)}.wcard .wh{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.wcard .wt{font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase}.wcard .wi,.wcard .wt{color:var(--ink-faint)}.wcard .wi{width:15px;height:15px}.wcard .wi svg{width:100%;height:100%}.clock-time{font-family:var(--disp);font-weight:800;font-size:34px;letter-spacing:-.02em;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;line-height:1}.clock-time .s{color:var(--ink-faint);font-size:19px;font-weight:600}.clock-sub{color:var(--ink-dim);font-size:12.5px;margin-top:8px}.wx{display:flex;align-items:center;gap:13px}.wx-ico{width:34px;height:34px;color:var(--ink);flex:none}.wx-ico svg{width:100%;height:100%}.wx-temp{font-family:var(--disp);font-weight:800;font-size:31px;letter-spacing:-.02em;line-height:1}.wx-desc{color:var(--ink-dim);font-size:12.5px;margin-top:5px;text-transform:capitalize}.np{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;height:100%}.np-art{width:54px;height:54px;border-radius:11px;flex:none;background:var(--bg-2);border:1px solid var(--line);overflow:hidden;position:relative}.np-art img{width:100%;height:100%;object-fit:cover;display:block}.np-art .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-faint)}.np-art .ph svg{width:22px;height:22px}.eq{display:flex;align-items:flex-end;gap:2.5px;height:15px;width:17px}.eq i{flex:1 1;background:var(--accent);border-radius:1.5px;opacity:.9;animation:eq 1.1s ease-in-out infinite}.eq i:nth-child(2){animation-delay:.25s}.eq i:nth-child(3){animation-delay:.5s}.eq i:nth-child(4){animation-delay:.15s}@keyframes eq{0%,to{height:22%}50%{height:100%}}.np[data-playing="0"] .eq i{animation-play-state:paused;height:35%}.np-main{min-width:0;flex:1 1}.np-now{font-family:var(--mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:7px;margin-bottom:5px}.np-t{font-weight:700;font-size:15px;font-family:var(--disp);letter-spacing:-.01em}.np-s,.np-t{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.np-s{color:var(--ink-dim);font-size:12.5px;margin-top:2px}.np .go{margin-left:auto;color:var(--ink-faint);transition:.3s;flex:none}.np:hover .go{color:var(--ink);transform:translate(2px,-2px)}.np .go svg{width:15px;height:15px}.about-grid{display:grid;grid-template-columns:150px 1fr;grid-gap:38px;gap:38px;align-items:start}@media (max-width:640px){.about-grid{grid-template-columns:1fr;gap:26px}}.avatar-wrap{position:relative;width:150px;height:150px}.avatar-wrap:before{content:"";position:absolute;inset:-10px;border-radius:28px;background:radial-gradient(circle,var(--accent) 0,transparent 70%);opacity:calc(var(--glow)*.4);filter:blur(18px);z-index:0}.avatar{position:relative;z-index:1;width:150px;height:150px;border-radius:22px;border:1px solid var(--line);object-fit:cover;background:var(--bg-2);box-shadow:0 20px 55px -22px rgba(0,0,0,.75)}.about-body p{color:var(--ink-dim);font-size:17.5px;max-width:60ch;text-wrap:pretty}.about-body p b{color:var(--ink);font-weight:600}.about-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}.chip{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--ink-dim);font-size:13.5px;font-weight:500;padding:10px 15px;border:1px solid var(--line);border-radius:11px;background:var(--panel);transition:.3s cubic-bezier(.2,.7,.3,1)}.chip svg{width:15px;height:15px;opacity:.85}.chip:hover{color:var(--ink);border-color:var(--accent-soft);background:var(--panel-hi);transform:translateY(-2px)}.proj{display:grid;grid-gap:14px;gap:14px}.pcard{display:block;text-decoration:none;color:inherit;border:1px solid var(--line);border-radius:20px;padding:30px;background:var(--panel);position:relative;overflow:hidden;transition:.45s cubic-bezier(.2,.7,.3,1)}.pcard:before{content:"";position:absolute;inset:0;background:radial-gradient(110% 120% at 100% 0,var(--accent-soft),transparent 55%);opacity:0;transition:.45s;pointer-events:none}.pcard:hover{border-color:var(--accent-soft);transform:translateY(-3px);box-shadow:0 28px 70px -30px var(--accent)}.pcard:active{transform:translateY(1px) scale(.985);transition:transform .13s cubic-bezier(.2,.7,.3,1);box-shadow:0 10px 30px -20px var(--accent)}.pcard:hover:before{opacity:.7}.ptop{display:flex;align-items:center;gap:18px}.pmark{width:62px;height:62px;border-radius:16px;border:1px solid var(--line);display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:22px;letter-spacing:-.04em;background:var(--bg-2);flex:none;overflow:hidden}.pmark img{width:100%;height:100%;object-fit:cover;display:block}.pt{font-family:var(--disp);font-weight:800;font-size:25px;letter-spacing:-.01em}.purl{font-family:var(--mono);font-size:12.5px;color:var(--ink-faint);margin-top:4px;display:flex;align-items:center;gap:6px}.pcard:hover .purl{color:var(--accent)}.parrow{margin-left:auto;color:var(--ink-faint);transition:.45s;flex:none}.pcard:hover .parrow{color:var(--ink);transform:translate(4px,-4px)}.parrow svg{width:22px;height:22px}.pdesc{color:var(--ink-dim);font-size:15.5px;margin-top:20px;max-width:62ch;text-wrap:pretty}.proles{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}.role-tag{font-family:var(--mono);font-size:11.5px;color:var(--ink-dim);background:var(--panel-hi);border:1px solid var(--line);border-radius:8px;padding:6px 11px}.skills{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}@media (max-width:640px){.skills{grid-template-columns:1fr}}.scard{border:1px solid var(--line);border-radius:20px;padding:28px;background:var(--panel);transition:.4s cubic-bezier(.2,.7,.3,1)}.scard:hover{border-color:var(--accent-soft);background:var(--panel-hi)}.scard .sk-h{display:flex;align-items:center;gap:13px;margin-bottom:8px}.sk-ico{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);display:grid;place-items:center;color:var(--accent);background:var(--bg-2);flex:none}.sk-ico svg{width:20px;height:20px}.sk-name{font-family:var(--disp);font-weight:800;font-size:21px;letter-spacing:-.01em}.scard p{color:var(--ink-dim);font-size:14.5px;margin:10px 0 22px;text-wrap:pretty}.tags{display:flex;gap:9px;flex-wrap:wrap}.tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12.5px;color:var(--ink);background:var(--panel-hi);border:1px solid var(--line);border-radius:9px;padding:8px 12px;text-decoration:none;transition:.28s cubic-bezier(.2,.7,.3,1)}.tag .ticon{width:20px;height:20px;border-radius:6px;background:#fff;padding:3px;flex:none;display:grid;place-items:center}.tag .ticon img{width:100%;height:100%;object-fit:contain;display:block}.tag .tdot{width:8px;height:8px;border-radius:2px;flex:none}.tag svg{width:13px;height:13px;opacity:0;margin-left:-4px;transition:.28s}.tag:hover{color:#08080a;background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.tag:hover .tdot{background:#08080a!important}.tag:hover svg{opacity:.7;margin-left:0}.tag:active{transform:translateY(0) scale(.95)}.friends{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px}@media (max-width:760px){.friends{grid-template-columns:1fr}}.fcard{border:1px solid var(--line);border-radius:20px;padding:26px;background:var(--panel);transition:.45s cubic-bezier(.2,.7,.3,1);display:flex;flex-direction:column}.fcard:hover{border-color:var(--accent-soft);background:var(--panel-hi);transform:translateY(-3px)}.fcard:active{transform:scale(.99);transition:transform .13s cubic-bezier(.2,.7,.3,1)}.favatar{width:62px;height:62px;border-radius:16px;border:1px solid var(--line);object-fit:cover;background:var(--bg-2);margin-bottom:16px}.fname{font-family:var(--disp);font-weight:800;font-size:19px;letter-spacing:-.01em}.fbio{font-size:14px;margin-top:8px;flex:1 1;text-wrap:pretty}.fbio,.flink{color:var(--ink-dim)}.flink{display:inline-flex;align-items:center;gap:7px;text-decoration:none;font-family:var(--mono);font-size:12.5px;margin-top:18px;transition:.3s}.flink:hover{color:var(--accent);gap:10px}.flink svg{width:14px;height:14px}footer{padding:8vh 0 7vh;text-align:center;border-top:1px solid var(--line-2)}.views{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;color:var(--ink-dim);border:1px solid var(--line);border-radius:12px;padding:11px 17px;background:var(--panel);margin-bottom:30px}.views svg{width:17px;height:17px;color:var(--ink-faint)}.views b{color:var(--ink);font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:.02em}.views .vlabel{color:var(--ink-faint)}.fmark{font-family:var(--disp);font-weight:800;font-size:18px;letter-spacing:-.02em}.fmeta{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);margin-top:12px;letter-spacing:.03em}.fmeta a{color:var(--ink-dim);text-decoration:none}.fmeta a:hover{color:var(--ink)}.fnote{color:var(--ink-faint);font-size:12px;margin-top:16px;opacity:.7}