:root{--text-primary:#f1f5ff;--text-secondary:#a8b3ca;--line:#f1f5ff3d;--panel:#080a1033;--profile-right:clamp(0rem, 1.8vw, 1.6rem);--profile-shift-x:100px;--profile-width:min(44vw, 620px);--profile-top-gap:clamp(1rem, 3.2vh, 2.8rem);--profile-icon-size:clamp(2.2rem, 3.4vw, 3rem);--profile-icon-gap:clamp(.6rem, 1.2vw, 1rem)}*{box-sizing:border-box}html,body{width:100%;height:100%;color:var(--text-primary);background:radial-gradient(circle at 20% 15%,#131a2f 0%,#080b14 45%,#020307 100%);margin:0;font-family:SF Pro Display,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}#scene{z-index:0;width:100%;height:100%;display:block;position:fixed;inset:0}html.mobile-lite,body.mobile-lite{background:#000;height:auto;min-height:100%;overflow:hidden auto}body.mobile-lite #scene,body.mobile-lite .loading-screen,body.mobile-lite .bottom-controls,body.mobile-lite .scroll-hint{display:none!important}body.mobile-lite .overlay{pointer-events:auto;background:#000;justify-content:center;align-items:center;min-height:100dvh;padding:1rem;display:flex;position:relative;inset:auto}body.mobile-lite .top-bar{display:none}body.mobile-lite .mobile-desktop-note{color:#d1dffcdb;letter-spacing:.02em;text-align:center;width:100%;margin:.75rem 0 0;font-size:clamp(.92rem,3.2vw,1.06rem);line-height:1.35;display:block;position:static}.mobile-desktop-note{display:none}body.mobile-lite .profile-panel{text-align:center;background:#060b16d1;border:1px solid #94b4f24d;border-radius:1rem;place-self:auto;width:min(92vw,28rem);margin:0;padding:1.2rem 1rem;transform:none;box-shadow:0 16px 42px #00000080}body.mobile-lite .profile-name{font-size:clamp(2.1rem,12vw,3.35rem)}body.mobile-lite .profile-role{font-size:clamp(1.15rem,6vw,1.7rem)}body.mobile-lite .profile-bio{margin-left:auto;margin-right:auto}body.mobile-lite .profile-links{display:none}body.mobile-lite .action-buttons,body.mobile-lite .action-buttons-secondary{justify-content:center}body.mobile-lite .action-buttons{flex-direction:column;align-items:stretch;gap:.6rem;margin-top:1rem}body.mobile-lite .action-buttons-secondary{margin-top:.6rem}body.mobile-lite .resume-button{width:100%;min-width:0;box-shadow:none}body.mobile-lite .projects-button,body.mobile-lite .secondary-action-button,body.mobile-lite .resume-button:hover,body.mobile-lite .resume-button:focus-visible{box-shadow:none}.loading-screen{--loading-fade-ms:.5s;z-index:20;opacity:1;pointer-events:auto;transition:opacity var(--loading-fade-ms) ease, visibility 0s linear var(--loading-fade-ms);background:radial-gradient(circle at 50% 45%,#0a1224 0%,#050a16 46%,#020307 100%);flex-direction:column;justify-content:center;align-items:center;gap:.7rem;display:flex;position:fixed;inset:0}.loading-screen.is-hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-dial{box-sizing:border-box;will-change:transform;backface-visibility:hidden;border:5px solid #e3ecfdeb;border-bottom-color:#7696d659;border-radius:50%;width:clamp(3.2rem,6.2vw,5rem);height:clamp(3.2rem,6.2vw,5rem);animation:1s linear infinite loading-spin;display:inline-block;transform:translate(0,0);box-shadow:0 0 22px #82a0e047}.loading-label{color:#d2ddf4e6;letter-spacing:.09em;text-transform:lowercase;-webkit-user-select:none;user-select:none;font-size:clamp(.96rem,1.28vw,1.18rem)}@keyframes loading-spin{0%{transform:translate(0,0)rotate(0)}to{transform:translate(0,0)rotate(360deg)}}.bottom-controls{z-index:4;pointer-events:auto;align-items:center;gap:.48rem;display:inline-flex;position:fixed;bottom:clamp(.8rem,2vh,1.6rem);right:clamp(.8rem,1.8vw,1.6rem)}.light-mode-button{min-width:4.65rem;height:clamp(2.1rem,3.6vw,2.5rem);color:var(--text-secondary);letter-spacing:.03em;cursor:pointer;background:#070c188f;border:1px solid #94b4f252;border-radius:999px;font-size:clamp(.74rem,.92vw,.86rem);transition:transform .15s,border-color .15s,background-color .15s,color .15s}.light-mode-button:hover,.light-mode-button:focus-visible{color:var(--text-primary);border-color:#f1f5ff7a;outline:none;transform:translateY(-1px)}.light-mode-button[data-active=true]{color:var(--text-primary);border-color:#f1f5ff85}.light-mode-button[data-light-mode=brake][data-active=true]{background:linear-gradient(#d8404057,#86222257);box-shadow:0 0 14px #cd43435c}.light-mode-button[data-light-mode=reverse][data-active=true]{background:linear-gradient(#afd0f152,#7090c252);box-shadow:0 0 14px #88abe652}.audio-toggle{width:clamp(2.4rem,4.3vw,3rem);height:clamp(2.4rem,4.3vw,3rem);color:var(--text-primary);cursor:pointer;background:#070c1894;border:1px solid #94b4f24d;border-radius:999px;justify-content:center;align-items:center;transition:transform .15s,border-color .15s,background-color .15s;display:inline-flex;position:relative;box-shadow:0 0 20px #6088d647,0 0 36px #587dcd29}.audio-toggle:hover,.audio-toggle:focus-visible{background:#0a1020b8;border-color:#f1f5ff80;outline:none;transform:translateY(-1px)}.audio-toggle svg{fill:currentColor;width:58%;height:58%}.audio-toggle .icon-muted,.audio-toggle[data-muted=true] .icon-unmuted{display:none}.audio-toggle[data-muted=true] .icon-muted{display:block}.scroll-hint{color:#d6e4fec7;opacity:0;visibility:hidden;z-index:4;pointer-events:none;width:clamp(2.35rem,3.6vw,2.8rem);height:clamp(2.35rem,3.6vw,2.8rem);transition:opacity .22s,visibility .22s;position:fixed;bottom:clamp(4.1rem,9vh,5.3rem);right:clamp(.9rem,2vw,1.5rem);transform:translateY(0)}.scroll-hint.is-visible{opacity:1;visibility:visible;animation:1.7s ease-in-out infinite scroll-hint-bounce}.scroll-hint svg{filter:drop-shadow(0 0 10px #6289d347);width:100%;height:100%;display:block}.scroll-hint circle,.scroll-hint path{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.7px}@keyframes scroll-hint-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.overlay{z-index:2;pointer-events:none;background:linear-gradient(90deg,#020409b8 0%,#0204095c 34%,#02040929 58%,#02040914 100%),linear-gradient(#02040914 0%,#02040952 54%,#020409e0 100%);grid-template-rows:auto 1fr;padding:clamp(1rem,2.2vw,2.2rem);display:grid;position:fixed;inset:0}.top-bar{justify-content:space-between;align-items:center;gap:1rem;display:flex}.brand{letter-spacing:.22em;color:var(--text-primary);text-transform:uppercase;font-size:clamp(1.15rem,1.05vw,1.45rem);font-weight:580}.nav{pointer-events:auto;align-items:center;gap:clamp(.9rem,1.8vw,1.6rem);display:flex}.nav a{color:var(--text-secondary);letter-spacing:.06em;border-bottom:1px solid #0000;padding-bottom:.2rem;font-size:clamp(.95rem,1.1vw,1.15rem);text-decoration:none;transition:color .16s,border-color .16s}.nav a:hover,.nav a:focus-visible{color:var(--text-primary);border-color:var(--line);outline:none}.profile-panel{width:var(--profile-width);margin-right:var(--profile-right);margin-top:var(--profile-top-gap);transform:translateX(var(--profile-shift-x));pointer-events:auto;place-self:center end}.profile-intro{letter-spacing:-.01em;margin:0;font-size:clamp(1.2rem,2.2vw,2rem);font-weight:560}.profile-name{letter-spacing:-.02em;text-wrap:balance;margin:clamp(.3rem,1.2vh,.65rem) 0 0;font-size:clamp(2.35rem,6vw,5.1rem);font-weight:650;line-height:.95}.profile-role{color:var(--text-primary);margin:clamp(.45rem,1.6vh,.9rem) 0 0;font-size:clamp(1.5rem,3vw,2.45rem);font-weight:620;line-height:1.02}.profile-bio{color:var(--text-secondary);max-width:42ch;margin:clamp(.7rem,2.1vh,1.4rem) 0 0;font-size:clamp(.95rem,1.35vw,1.3rem);line-height:1.45}.profile-links{gap:var(--profile-icon-gap);flex-wrap:wrap;margin-top:clamp(1rem,2.3vh,1.6rem);display:flex}.icon-link{width:var(--profile-icon-size);height:var(--profile-icon-size);border:1px solid var(--line);color:var(--text-primary);border-radius:999px;justify-content:center;align-items:center;text-decoration:none;transition:transform .16s,border-color .16s,color .16s,background-color .16s;display:inline-flex}.icon-link:hover,.icon-link:focus-visible{border-color:var(--text-primary);background-color:#f1f5ff14;outline:none;transform:translateY(-1px)}.icon-link svg{fill:currentColor;width:52%;height:52%}.action-buttons{flex-flow:wrap;align-items:center;gap:.72rem;margin-top:clamp(1.15rem,2.5vh,1.9rem);display:flex}.action-buttons-secondary{margin-top:.56rem}.resume-button{width:fit-content;min-width:clamp(10rem,20vw,12.8rem);color:var(--text-primary);letter-spacing:.02em;background:linear-gradient(#93b1ec38,#5a76ad38);border:1px solid #f1f5ff40;border-radius:999px;justify-content:center;align-items:center;gap:.45rem;margin-top:0;padding:.7rem 1.2rem;font-size:clamp(.92rem,1.05vw,1.04rem);text-decoration:none;transition:transform .16s,box-shadow .16s,border-color .16s;display:inline-flex;box-shadow:0 0 18px #81a5ec47}.projects-button{background:linear-gradient(#8ca4db2e,#566c9c33);box-shadow:0 0 16px #668bd640}.secondary-action-button{background:linear-gradient(#849bce29,#485e8e2e);box-shadow:0 0 12px #6284c933}.resume-button:hover,.resume-button:focus-visible{border-color:#f1f5ff75;outline:none;transform:translateY(-1px);box-shadow:0 0 28px #81a5ec6b}.resume-icon{font-size:1.02em;line-height:1}@media (width<=980px){.profile-panel{width:min(62vw,560px)}}@media (width<=780px){.overlay{padding:1rem}.top-bar{flex-direction:column;align-items:flex-start;gap:.55rem}.nav{flex-wrap:wrap;gap:.85rem}.profile-panel{place-self:end stretch;width:100%;margin-top:0;margin-bottom:.5rem;margin-right:0}.audio-toggle{width:clamp(2.25rem,9vw,2.6rem);height:clamp(2.25rem,9vw,2.6rem)}.bottom-controls{gap:.38rem;bottom:.7rem;right:.7rem}.light-mode-button{min-width:4.2rem;height:clamp(2.05rem,8vw,2.4rem);font-size:clamp(.7rem,2.4vw,.82rem)}}
