*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #cbd5e1;--text: #1e293b;--text-soft: rgba(30, 41, 59, .88);--card-bg-start: rgba(255, 255, 255, .78);--card-bg-end: rgba(255, 255, 255, .42);--card-border: rgba(30, 41, 59, .14);--shadow-a: rgba(15, 23, 42, .62);--shadow-b: rgba(15, 23, 42, .16);--grain-opacity: .04;font-family:Fira Sans,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;background:var(--bg);color:var(--text)}body{min-width:320px;min-height:100vh;background:var(--bg);color:var(--text);transition:background 1.2s ease,color 1.2s ease}#root{min-height:100vh}body:after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:var(--grain-opacity);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)'/%3E%3C/svg%3E");background-size:180px 180px;animation:grain .4s steps(3) infinite}@keyframes grain{0%{background-position:0 0}33%{background-position:-40px -20px}66%{background-position:20px -40px}to{background-position:-20px 20px}}.site{width:100%;min-height:100vh;padding:6vh 0 8vh;padding-left:clamp(2.5rem,10vw,12rem);padding-right:clamp(1.5rem,4vw,4rem)}.central-clock{position:fixed;top:.9rem;right:.9rem;z-index:120;display:inline-flex;flex-direction:column;align-items:flex-end;gap:.28rem;padding:.62rem .72rem .58rem;border-radius:14px;border:1px solid var(--card-border);background:linear-gradient(152deg,var(--card-bg-start),var(--card-bg-end));box-shadow:0 20px 36px -24px var(--shadow-a),0 4px 10px var(--shadow-b);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);opacity:0;transform:translateY(-12px) scale(.96);pointer-events:none}.central-clock.is-visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.central-clock-toggle{display:none}.central-clock-time{display:inline-flex;align-items:center;gap:.22rem;font-size:.92rem;font-weight:700;letter-spacing:.015em;color:var(--text);font-variant-numeric:tabular-nums}.clock-part{display:inline-flex;align-items:center;justify-content:center;min-width:1.7ch;line-height:1;text-align:center;padding:.14rem .22rem;border-radius:7px;background:#fff3;border:1px solid rgba(255,255,255,.24);transform-origin:50% 65%;backface-visibility:hidden}.clock-second-wrap{position:relative;width:calc(1.7ch + .44rem + 2px);height:calc(1em + .28rem + 2px);overflow:hidden;display:inline-flex;align-items:center;justify-content:center;border-radius:7px}.clock-second-layer{position:absolute;inset:0;display:inline-flex;align-items:center;justify-content:center}.clock-second-old{z-index:1;opacity:0}.clock-second-new{z-index:2;opacity:1}.clock-sep{opacity:.72;margin-top:-1px}.clock-ampm{margin-left:.24rem;font-size:.62rem;font-weight:700;letter-spacing:.09em;opacity:.72;text-transform:uppercase}.central-clock-date{font-size:.72rem;font-weight:600;letter-spacing:.01em;color:var(--text-soft);text-align:right}.central-clock-offset{font-size:.66rem;font-weight:500;letter-spacing:.012em;color:var(--text-soft);opacity:.9;text-align:right}.column{max-width:720px;display:flex;flex-direction:column;gap:2.8rem;perspective:800px}.hero-name{font-size:clamp(4.5rem,14vw,12rem);line-height:1;font-weight:900;letter-spacing:-.045em;margin-left:-.06em;padding-bottom:.1em}.name-swap{all:unset;cursor:pointer;display:inline-block;position:relative;overflow:visible;line-height:inherit;font:inherit;letter-spacing:inherit;color:inherit;transform-style:preserve-3d;will-change:transform,text-shadow}.name-sizer{display:block;height:0;overflow:hidden;visibility:hidden;white-space:nowrap;pointer-events:none;font-weight:var(--hero-wght, 900)}.name-line{display:inline-flex;align-items:baseline;position:relative;z-index:1;white-space:nowrap;font-weight:var(--hero-wght, 900)}.name-char{display:inline-block;will-change:transform,opacity;backface-visibility:hidden}.email-line{position:absolute;left:0;top:0;height:100%;display:inline-flex;align-items:center;white-space:nowrap;pointer-events:none;font-weight:var(--hero-wght, 900)}.email-char{display:inline-block;will-change:transform,opacity;backface-visibility:hidden}.bio{font-size:1.15rem;line-height:1.65;max-width:540px;color:var(--text-soft)}.bio-img{display:inline-block;width:28px;height:28px;border-radius:7px;object-fit:cover;vertical-align:-6px;margin:0 3px}.bio strong{color:var(--text);font-weight:600}.section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;font-weight:600;opacity:.55;margin-bottom:.75rem}.tilt-card{transform-style:preserve-3d;will-change:transform}.project-card{display:flex;flex-direction:column;gap:.35rem;max-width:520px;padding:1.1rem 1.25rem;border-radius:16px;border:1px solid var(--card-border);background:linear-gradient(145deg,var(--card-bg-start),var(--card-bg-end));box-shadow:0 18px 36px -26px var(--shadow-a),0 3px 8px var(--shadow-b);transform:rotate(1.2deg);transform-origin:center center;transition:box-shadow .25s ease;text-decoration:none;color:inherit}.project-card-name{font-size:1.2rem;font-weight:700}.project-card-desc{font-size:.95rem;opacity:.65;line-height:1.4}.contact-list{list-style:none;display:flex;flex-direction:row;flex-wrap:wrap;gap:1rem;perspective:800px}.contact-item{display:block;width:fit-content;transform-origin:center center}.contact-chip{all:unset;cursor:pointer;font-family:Fira Sans,sans-serif;font-size:.84rem;color:var(--text);border:2px dashed color-mix(in srgb,var(--text) 26%,rgba(255,255,255,.5));border-radius:999px;width:clamp(136px,17vw,154px);aspect-ratio:1 / 1;display:inline-block;background:radial-gradient(92% 88% at 50% 14%,color-mix(in srgb,var(--card-bg-start) 88%,rgba(255,255,255,.18)),transparent 72%),radial-gradient(130% 120% at 50% 120%,color-mix(in srgb,var(--shadow-a) 26%,transparent),transparent 62%),repeating-linear-gradient(180deg,#ffffff12 0 1px,#00000003 1px 2px),linear-gradient(155deg,color-mix(in srgb,var(--card-bg-start) 90%,var(--bg)),color-mix(in srgb,var(--card-bg-end) 84%,var(--bg)));box-shadow:inset 0 0 0 1px #ffffff29,0 18px 28px -24px var(--shadow-a),0 2px 6px var(--shadow-b);transition:box-shadow .25s ease,color .2s,border-color .2s;text-decoration:none;will-change:transform;transform-style:preserve-3d;transform-origin:center center;position:relative;overflow:hidden;touch-action:manipulation}.contact-chip:before{content:"";position:absolute;inset:9px;border-radius:999px;border:1px solid color-mix(in srgb,var(--text) 20%,transparent);pointer-events:none;background:radial-gradient(120% 75% at 12% 18%,color-mix(in srgb,var(--card-bg-start) 56%,rgba(255,255,255,.2)),transparent 62%),radial-gradient(100% 90% at 85% 100%,color-mix(in srgb,var(--shadow-b) 48%,transparent),transparent 60%)}.contact-chip:after{content:"";position:absolute;inset:12%;border-radius:999px;transform:rotate(-14deg) scale(.9);border:4px solid color-mix(in srgb,var(--text-soft) 30%,transparent);opacity:.28;transition:opacity .2s ease,border-color .2s ease,transform .22s ease}.contact-chip:hover{border-color:color-mix(in srgb,var(--text-soft) 52%,var(--card-border))}.contact-chip:hover:after{opacity:.52;border-color:color-mix(in srgb,var(--text) 42%,transparent);transform:rotate(-11deg) scale(1)}.contact-chip-ring{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}.contact-chip-ring-text{fill:color-mix(in srgb,var(--text) 68%,var(--text-soft));font-size:8px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;opacity:.75}.contact-chip-icon-wrap{position:absolute;left:50%;top:50%;transform:translate(calc(-50% + var(--stamp-icon-x, 0px)),calc(-64% + var(--stamp-icon-y, 0px))) rotate(var(--stamp-icon-rot, 0deg)) scale(var(--stamp-icon-scale, 1));display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid color-mix(in srgb,var(--text) 24%,transparent);background:radial-gradient(circle at 30% 26%,color-mix(in srgb,var(--card-bg-start) 52%,rgba(255,255,255,.24)),color-mix(in srgb,var(--card-bg-end) 70%,transparent));box-shadow:inset 0 1px #ffffff52,0 4px 10px -8px var(--shadow-a);opacity:.95;z-index:2}.contact-chip-main{position:absolute;left:50%;top:62%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.08rem;min-width:0;z-index:1}.contact-chip-value{line-height:1.1;font-size:.69rem;max-width:10ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:700;color:color-mix(in srgb,var(--text-soft) 92%,var(--text));letter-spacing:.01em}.contact-chip-serial{font-size:.45rem;text-transform:uppercase;letter-spacing:.14em;opacity:.72;font-weight:700}.contact-chip--stamp[data-social=email]{transform:rotate(-2.8deg)}.contact-chip--stamp[data-social=discord]{transform:rotate(1.8deg)}.contact-chip--stamp[data-social=lastfm]{transform:rotate(-1.1deg)}.chip-icon{width:20px;height:20px;opacity:.84;flex-shrink:0;color:color-mix(in srgb,var(--text) 88%,var(--text-soft))}.chip-icon--mask{background-color:color-mix(in srgb,var(--text) 88%,var(--text-soft));-webkit-mask-image:var(--chip-icon-url);mask-image:var(--chip-icon-url);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.contact-chip[data-social=email] .chip-icon{transform:translate(.1px,-.1px) scale(.92)}.lastfm-card{display:flex;align-items:center;gap:.82rem;min-height:84px;padding:.78rem .82rem;border-radius:14px;border:1px solid var(--cover-echo-border, var(--card-border));background-color:var(--bg);background-image:linear-gradient(145deg,#ffffff29,#ffffff14),radial-gradient(120% 130% at 10% 10%,var(--cover-echo-wash, transparent),transparent);box-shadow:0 18px 36px -26px var(--shadow-a),0 3px 8px var(--shadow-b),0 0 0 1px var(--cover-echo-glow, transparent);transform:translate(calc(var(--stack-x, 0px) + var(--peek-x, 0px))) translateY(calc(var(--stack-y, 0px) + var(--peek-y, 0px))) rotate(calc(var(--stack-rot, -2deg) + var(--peek-r, 0deg)));transform-origin:center center;transition:box-shadow .25s ease;transform-style:preserve-3d;position:absolute;inset-inline:0;top:0;z-index:var(--stack-z, 1)}.lastfm-stack{position:relative;width:min(460px,100%);min-height:172px}.lastfm-stack.is-scrubbable{cursor:ew-resize;-webkit-user-select:none;user-select:none;touch-action:pan-y}.lastfm-scrub-hint{display:none}.lastfm-stack.is-scrubbable .lastfm-card{pointer-events:none}.lastfm-card.is-active{pointer-events:auto;cursor:auto}.lastfm-card.is-history{pointer-events:none;opacity:1;visibility:visible;filter:saturate(.9)}.lastfm-card.is-active{box-shadow:0 22px 40px -25px var(--shadow-a),0 5px 10px var(--shadow-b),0 0 0 1px var(--cover-echo-glow, transparent)}.lastfm-card-static{position:relative;transform:rotate(-1.8deg)}.lastfm-cover{width:56px;height:56px;border-radius:10px;object-fit:cover;flex-shrink:0}.lastfm-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}.lastfm-track{font-weight:600;font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lastfm-artist{font-size:.88rem;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lastfm-status{font-size:.78rem;opacity:.5;font-weight:500;display:inline-flex;align-items:center;gap:.35rem}.lastfm-status a{color:inherit;text-decoration:underline;text-underline-offset:2px}.waveform{display:flex;align-items:flex-end;gap:2.5px;height:22px;margin-left:auto;flex-shrink:0;padding-right:2px}.wave-bar{width:3px;border-radius:1.5px;background:var(--text-soft);transform-origin:bottom center;animation:wave 1.2s ease-in-out infinite}.wave-bar:nth-child(1){height:40%;animation-delay:0s}.wave-bar:nth-child(2){height:70%;animation-delay:-.4s}.wave-bar:nth-child(3){height:100%;animation-delay:-.8s}.wave-bar:nth-child(4){height:60%;animation-delay:-.2s}.wave-bar:nth-child(5){height:35%;animation-delay:-.6s}@keyframes wave{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}.muted-text{font-size:.92rem;opacity:.5}.is-dragging{z-index:100;cursor:grabbing!important}.drawer-backdrop{position:fixed;inset:0;z-index:200;background:#0000004d;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.drawer-panel{position:fixed;top:1.5rem;bottom:1.5rem;right:1.5rem;z-index:210;width:min(420px,calc(100vw - 3rem));border-radius:20px;border:1px solid var(--card-border);background:linear-gradient(160deg,var(--card-bg-start),var(--card-bg-end));box-shadow:0 32px 64px -20px var(--shadow-a),0 8px 20px var(--shadow-b);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;flex-direction:column;overflow:hidden}.drawer-close{all:unset;cursor:pointer;position:absolute;top:1rem;right:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text);opacity:.5;transition:opacity .2s,background .2s}.drawer-close:hover{opacity:1;background:var(--card-border)}.drawer-close svg{width:18px;height:18px}.drawer-content{padding:2.5rem 1.8rem 2rem;display:flex;flex-direction:column;gap:1rem;flex:1;overflow-y:auto}.drawer-title{font-size:1.65rem;font-weight:800;line-height:1.2;letter-spacing:-.025em;color:var(--text)}.drawer-desc{font-size:1.05rem;line-height:1.6;color:var(--text-soft)}.carousel{display:flex;flex-direction:column;gap:.65rem}.carousel-viewport{position:relative;width:100%;aspect-ratio:3 / 2;border-radius:14px;overflow:hidden;background:#0000000f}.carousel-track{display:flex;height:100%;will-change:transform}.carousel-slide{flex:0 0 100%;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none}.carousel-arrow{all:unset;cursor:pointer;position:absolute;top:50%;transform:translateY(-50%);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--card-bg-start);border:1px solid var(--card-border);color:var(--text);box-shadow:0 2px 8px var(--shadow-b);opacity:.7;transition:opacity .2s,transform .2s;z-index:2}.carousel-arrow:hover{opacity:1;transform:translateY(-50%) scale(1.1)}.carousel-arrow svg{width:16px;height:16px}.carousel-arrow--prev{left:.5rem}.carousel-arrow--next{right:.5rem}.carousel-dots{display:flex;justify-content:center;gap:6px}.carousel-dot{all:unset;cursor:pointer;width:7px;height:7px;border-radius:50%;background:var(--text);opacity:.2;transition:opacity .25s,transform .25s}.carousel-dot--active{opacity:.7;transform:scale(1.35)}.carousel-dot:hover{opacity:.5}.drawer-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;margin-top:auto;padding:.85rem 1.6rem;border-radius:14px;font-family:Fira Sans,sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.01em;color:var(--bg);background:var(--text);box-shadow:0 4px 14px -4px var(--shadow-a),0 1px 3px var(--shadow-b);transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease,opacity .2s;text-decoration:none}.drawer-btn:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 8px 22px -6px var(--shadow-a),0 2px 6px var(--shadow-b)}.drawer-btn:active{transform:translateY(0) scale(.98)}.drawer-btn-label{position:relative;top:.5px}.drawer-btn-arrow{width:18px;height:18px;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.drawer-btn:hover .drawer-btn-arrow{transform:translate(3px)}.social-drawer-panel{width:min(420px,calc(100vw - 3rem))}.social-drawer-content{gap:1.2rem}.social-drawer-kicker{font-size:.64rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;opacity:.55}.social-drawer-plain-row,.social-drawer-playlist-card{border:1px solid var(--card-border);border-radius:14px;background:linear-gradient(148deg,color-mix(in srgb,var(--card-bg-start) 84%,rgba(255,255,255,.12)),color-mix(in srgb,var(--card-bg-end) 88%,rgba(255,255,255,.04)));box-shadow:inset 0 1px #ffffff38}.social-drawer-plain-row{padding:.8rem .92rem;display:flex;align-items:center;justify-content:flex-start;gap:.85rem}.social-drawer-row-copy{display:flex;flex-direction:column;gap:.08rem}.social-drawer-row-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;opacity:.54}.social-drawer-row-value{font-size:.97rem;line-height:1.25;font-weight:700;letter-spacing:.01em}.social-drawer-playlist-card{overflow:hidden;padding:0}.social-drawer-playlist-image{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover;filter:saturate(.88) contrast(1.02)}.social-drawer-playlist-copy{display:flex;flex-direction:column;gap:.48rem;padding:.9rem .95rem 1rem}.social-drawer-card-title{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;opacity:.56}.social-drawer-card-meta{font-size:.86rem;line-height:1.5;opacity:.78}.social-drawer-link{display:inline-flex;align-items:center;width:fit-content;border-radius:999px;padding:.34rem .7rem;border:1px solid var(--card-border);background:color-mix(in srgb,var(--card-bg-start) 76%,transparent);color:var(--text);font-size:.62rem;letter-spacing:.11em;text-transform:uppercase;font-weight:700;text-decoration:none;transition:transform .2s ease,background .2s ease}.social-drawer-link:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--card-bg-start) 92%,transparent)}.social-drawer-btn{margin-top:.35rem}@media(prefers-reduced-motion:reduce){.wave-bar{animation:none}.contact-chip:after{transition:none}}@media(max-width:640px){.central-clock-toggle{all:unset;position:fixed;top:.58rem;right:.58rem;z-index:121;display:inline-flex;align-items:center;gap:.34rem;padding:.42rem .58rem;border-radius:10px;border:1px solid var(--card-border);background:linear-gradient(152deg,var(--card-bg-start),var(--card-bg-end));box-shadow:0 14px 28px -18px var(--shadow-a),0 3px 8px var(--shadow-b);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;color:var(--text)}.central-clock-toggle-kicker{font-size:.56rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;opacity:.7}.central-clock-toggle-time{font-size:.72rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.01em}.central-clock-toggle.is-open{box-shadow:0 18px 30px -16px var(--shadow-a),0 3px 8px var(--shadow-b)}.central-clock{top:.58rem;right:.58rem;padding:.48rem .54rem .46rem;width:min(320px,calc(100vw - 1.16rem));transition:transform .3s ease,opacity .22s ease;transform:translate(calc(100% + .8rem));opacity:0;pointer-events:none}.central-clock.is-visible.is-mobile-open{transform:translate(0);opacity:1;pointer-events:auto}.central-clock-time{font-size:.8rem}.central-clock-date{font-size:.66rem}.central-clock-offset{font-size:.6rem}.site{padding-left:1.5rem;padding-right:1.2rem;padding-top:4vh}.hero-name{font-size:clamp(3.2rem,16vw,6rem)}.email-line,.name-sizer{font-size:.73em}.contact-chip{width:126px}.contact-list{gap:.62rem}.lastfm-stack{min-height:162px}.lastfm-card-static{transform:rotate(-1deg)}.lastfm-scrub-hint{position:absolute;left:50%;bottom:-.95rem;transform:translate(-50%);z-index:12;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.16rem .5rem;border:1px solid color-mix(in srgb,var(--text-soft) 34%,transparent);background:color-mix(in srgb,var(--card-bg-start) 90%,rgba(255,255,255,.08));color:color-mix(in srgb,var(--text-soft) 92%,var(--text));font-size:.56rem;line-height:1;letter-spacing:.08em;text-transform:uppercase;font-weight:700;white-space:nowrap;pointer-events:none;opacity:0;animation:lastfmScrubHint 6s ease forwards}}@keyframes lastfmScrubHint{0%{opacity:0}8.33%{opacity:1}91.66%{opacity:1}to{opacity:0}}
