:root{--bg:#080808;--surface:#111;--surface2:#161616;--border:#ffffff12;--text:#e8e4dd;--muted:#e8e4dd73;--accent:#42f5a7;--green:#6fcf97;--glow-i:.7;--ff-d:"Syne", sans-serif;--ff-m:"JetBrains Mono", monospace;--ff-b:"DM Sans", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);font-family:var(--ff-b)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}body:after{content:"";pointer-events:none;z-index:9000;opacity:.3;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");background-size:128px;position:fixed;inset:0}.btn-primary{background:var(--accent);color:#111;font-family:var(--ff-d);letter-spacing:.1em;cursor:pointer;border:none;border-radius:2px;padding:13px 26px;font-size:12px;font-weight:700;transition:opacity .15s,transform .15s}.btn-primary:hover{opacity:.82;transform:translateY(-1px)}.btn-ghost{color:var(--text);font-family:var(--ff-d);letter-spacing:.08em;cursor:pointer;background:0 0;border:1px solid #ffffff24;border-radius:2px;padding:13px 26px;font-size:12px;font-weight:600;transition:border-color .2s,background .2s}.btn-ghost:hover{border-color:var(--accent);background:#42f5a70d}.btn-txt{color:var(--muted);font-family:var(--ff-m);letter-spacing:.12em;cursor:pointer;background:0 0;border:none;padding:0;font-size:10px;transition:color .2s}.btn-txt:hover{color:var(--accent)}.pcard{border:1px solid var(--border);cursor:pointer;border-radius:4px;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s,border-color .25s;position:relative;overflow:hidden}.pcard:hover{border-color:#42f5a747;transform:translateY(-3px)scale(1.012);box-shadow:0 18px 44px #0000008c}.pcard .ov{opacity:0;background:#000000b8;justify-content:center;align-items:center;transition:opacity .22s;display:flex;position:absolute;inset:0}.pcard:hover .ov{opacity:1}.tentry{gap:16px;margin-bottom:16px;transition:opacity .4s,transform .4s;display:flex}.picon{cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;transition:background .2s,transform .15s;display:flex}.picon:hover{transform:scale(1.12)}.picon svg{width:15px;height:15px}.slink{border-bottom:1px solid var(--border);cursor:pointer;color:inherit;justify-content:space-between;align-items:center;padding:18px 0;text-decoration:none;transition:padding-left .2s;display:flex}.slink:hover{padding-left:8px}.slink .arrow{color:var(--muted);font-size:18px;transition:color .2s,transform .2s}.slink:hover .arrow{color:var(--accent);transform:translate(2px,-2px)}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes glow{0%,to{box-shadow:0 0 6px var(--green)}50%{box-shadow:0 0 14px var(--green)}}@keyframes ringPulse{0%{opacity:.9;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(2.6)}}@keyframes scan{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes mojiSway{0%,to{transform:rotate(-1.6deg)translateY(0)}50%{transform:rotate(1.6deg)translateY(-5px)}}@keyframes mojiBlink{0%,88%,96%,to{transform:scaleY(1)}91%,94%{transform:scaleY(.06)}}@keyframes caretBlink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes termFlicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.82}94%{opacity:1}}.tcaret{vertical-align:-2px;background:currentColor;width:.55em;height:1em;animation:1.05s step-end infinite caretBlink;display:inline-block}.flip-card{perspective:1400px;cursor:pointer;flex:1;min-height:0}.flip-card-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .75s cubic-bezier(.34,1.2,.64,1);position:relative}.flip-card.is-flipped .flip-card-inner{transform:rotateY(180deg)}.flip-face{backface-visibility:hidden;border-radius:4px;padding:16px 18px;position:absolute;inset:0;overflow:hidden}.flip-face.back{transform:rotateY(180deg)}.ct-node{cursor:pointer}.ct-node .ct-dot{transition:transform .25s cubic-bezier(.34,1.56,.64,1),background .2s,border-color .2s,box-shadow .2s}.ct-node .ct-yr{transition:color .2s,transform .25s cubic-bezier(.34,1.56,.64,1)}.ct-node:hover .ct-dot{transform:scale(1.5)}.ct-node:hover .ct-yr{transform:translateY(-2px)}.ct-node:hover .ct-spike{opacity:1}.ct-spike{pointer-events:none;transition:opacity .2s}.ct-fill{transition:width .6s cubic-bezier(.4,0,.2,1)}.ct-ring{animation:2.2s ease-out infinite ringPulse}.ct-scanline{animation:4.5s linear infinite scan}.aglow{text-shadow:0 0 calc(4px * var(--glow-i,1)) currentColor, 0 0 calc(12px * var(--glow-i,1)) currentColor, 0 0 calc(28px * var(--glow-i,1)) currentColor}.aglow-soft{text-shadow:0 0 calc(3px * var(--glow-i,1)) currentColor, 0 0 calc(10px * var(--glow-i,1)) currentColor}.bglow{box-shadow:0 0 calc(6px * var(--glow-i,1)) currentColor, 0 0 calc(16px * var(--glow-i,1)) currentColor}.mobile-shell{scroll-behavior:smooth;background:linear-gradient(180deg, #ffffff09, transparent 18rem), repeating-linear-gradient(90deg, #ffffff06 0 1px, transparent 1px 4rem), var(--bg);-webkit-overflow-scrolling:touch;height:100dvh;padding-bottom:88px;overflow:hidden auto}.mobile-section{border-bottom:1px solid var(--border);min-height:auto;padding:34px 18px 42px}.mobile-section h2{font-family:var(--ff-d);letter-spacing:0;max-width:11em;margin:14px 0;font-size:31px;line-height:1.04}.mobile-section p{color:var(--muted);font-size:14px;font-weight:300;line-height:1.72}.mobile-hero{flex-direction:column;justify-content:center;gap:18px;min-height:100dvh;padding-top:30px;padding-bottom:106px;display:flex}.mobile-topline{font-family:var(--ff-m);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);justify-content:space-between;gap:12px;font-size:9px;display:flex}.mobile-avatar{border:1px solid color-mix(in oklab, var(--accent) 44%, transparent);background:linear-gradient(145deg,#ffffff14,#0000001a);border-radius:50%;place-items:center;width:122px;height:122px;display:grid;box-shadow:inset 0 0 0 1px #ffffff0d}.mobile-avatar span{font-family:var(--ff-d);color:var(--accent);font-size:35px;font-weight:800}.mobile-hero h1{font-family:var(--ff-d);letter-spacing:0;color:var(--accent);max-width:8em;font-size:48px;line-height:.96}.mobile-hero h1 span{color:var(--text);display:block}.mobile-hero p{max-width:28em}.mobile-actions{flex-wrap:wrap;gap:10px;display:flex}.mobile-actions a,.mobile-contact>a{text-transform:uppercase;text-align:center;text-decoration:none}.mobile-stat-strip,.mobile-metrics{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.mobile-stat-strip div,.mobile-metrics div{border:1px solid var(--border);background:#ffffff09;border-radius:6px;padding:12px 10px}.mobile-stat-strip strong,.mobile-metrics strong{font-family:var(--ff-d);color:var(--accent);font-size:23px;line-height:1;display:block}.mobile-stat-strip span,.mobile-metrics span{font-family:var(--ff-m);letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-top:6px;font-size:8px;display:block}.mobile-kicker{font-family:var(--ff-m);text-transform:uppercase;align-items:center;gap:10px;display:flex}.mobile-kicker span{color:var(--accent);letter-spacing:.15em;font-size:10px}.mobile-kicker i{background:#ffffff29;width:24px;height:1px}.mobile-kicker b{color:var(--muted);letter-spacing:.16em;font-size:10px;font-weight:500}.mobile-skill-list,.mobile-timeline,.mobile-project-list,.mobile-socials{flex-direction:column;gap:12px;margin-top:22px;display:flex}.mobile-skill-list article,.mobile-timeline article,.mobile-project-card,.mobile-socials a{border:1px solid var(--border);background:#111111b8;border-radius:8px}.mobile-skill-list article{gap:14px;padding:15px;display:flex}.mobile-skill-list article>span{height:38px;color:var(--accent);border:1px solid color-mix(in oklab, var(--accent) 32%, transparent);border-radius:6px;flex:0 0 38px;place-items:center;display:grid}.mobile-skill-list h3,.mobile-timeline h3,.mobile-modal-copy h3{font-family:var(--ff-d);letter-spacing:0;font-size:18px;line-height:1.2}.mobile-skill-list small,.mobile-project-body small{font-family:var(--ff-m);letter-spacing:.08em;color:var(--accent);margin-top:10px;font-size:9px;line-height:1.5;display:block}.mobile-timeline article{padding:18px 16px}.mobile-timeline article>span,.mobile-timeline em{font-family:var(--ff-m);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:10px;display:block}.mobile-timeline h3{margin:8px 0 6px}.mobile-timeline ul{margin-top:14px;list-style:none}.mobile-timeline li{color:var(--muted);margin-top:8px;padding-left:16px;font-size:13px;line-height:1.62;position:relative}.mobile-timeline li:before{content:"";background:var(--accent);border-radius:50%;width:5px;height:5px;position:absolute;top:.72em;left:0}.mobile-cat-row{scrollbar-width:none;gap:8px;margin:20px -18px 0;padding:0 18px 4px;display:flex;overflow-x:auto}.mobile-cat-row::-webkit-scrollbar{display:none}.mobile-cat-row button{color:var(--muted);border:1px solid var(--border);font-family:var(--ff-m);letter-spacing:.12em;text-transform:uppercase;background:#ffffff0a;border-radius:999px;flex:none;padding:10px 16px;font-size:10px}.mobile-cat-row button.is-active{background:var(--accent);border-color:var(--accent);color:#111;font-weight:700}.mobile-project-card{width:100%;color:inherit;text-align:left;padding:0;display:block;overflow:hidden}.mobile-project-media{aspect-ratio:16/10;background:#050505;display:block;position:relative}.mobile-project-media img,.mobile-modal-video img,.mobile-modal-video video{object-fit:cover;width:100%;height:100%;display:block}.mobile-project-media i{color:var(--text);font-family:var(--ff-m);background:#000000a8;border:1px solid #ffffff1f;border-radius:4px;padding:4px 7px;font-size:9px;font-style:normal;position:absolute;top:10px;right:10px}.mobile-project-body{justify-content:space-between;gap:14px;padding:14px;display:flex}.mobile-project-body b{font-family:var(--ff-d);font-size:17px;line-height:1.2;display:block}.mobile-project-body em{color:var(--muted);font-family:var(--ff-m);letter-spacing:.09em;text-transform:uppercase;margin-top:4px;font-size:9px;font-style:normal;display:block}.mobile-project-body small{text-align:right;max-width:42%;margin-top:2px}.mobile-contact{padding-bottom:34px}.mobile-contact>a{margin-top:20px;display:inline-block}.mobile-socials a{color:inherit;justify-content:space-between;gap:14px;padding:14px;text-decoration:none;display:flex}.mobile-socials span{font-family:var(--ff-d);font-weight:700}.mobile-socials b{min-width:0;color:var(--accent);font-family:var(--ff-m);letter-spacing:.08em;text-align:right;overflow-wrap:anywhere;font-size:10px;font-weight:500}.mobile-bottom-nav{z-index:4500;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#080808eb;border:1px solid #ffffff1a;border-radius:16px;grid-template-columns:repeat(5,1fr);gap:2px;height:62px;padding:7px;display:grid;position:fixed;bottom:10px;left:10px;right:10px;box-shadow:0 14px 44px #0000008f}.mobile-bottom-nav a{min-width:0;color:var(--muted);border-radius:11px;flex-direction:column;justify-content:center;align-items:center;gap:3px;text-decoration:none;display:flex}.mobile-bottom-nav a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mobile-bottom-nav span{color:var(--accent);font-family:var(--ff-m);font-size:9px}.mobile-bottom-nav b{font-family:var(--ff-m);letter-spacing:.04em;text-transform:uppercase;font-size:8px;font-weight:500}.mobile-modal{z-index:6000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000e6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.mobile-modal-panel{background:var(--surface);border:1px solid #ffffff1f;border-radius:8px;width:min(100%,520px);max-height:calc(100dvh - 32px);position:relative;overflow:auto}.mobile-modal-close{z-index:2;width:34px;height:34px;color:var(--text);font-family:var(--ff-m);background:#000000ad;border:1px solid #ffffff2e;border-radius:50%;font-size:12px;position:absolute;top:10px;right:10px}.mobile-modal-video{aspect-ratio:16/9;background:#000}.mobile-modal-video video{object-fit:contain}.mobile-modal-copy{padding:17px}.mobile-modal-copy p{margin-top:8px}@media (width<=370px){.mobile-section{padding-left:14px;padding-right:14px}.mobile-hero h1{font-size:42px}.mobile-section h2{font-size:28px}.mobile-bottom-nav b{display:none}}
