.orb-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;width:100%;height:100%;scale:1}.glass-surface{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:opacity .26s ease-out}.glass-surface__filter{width:100%;height:100%;pointer-events:none;position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;z-index:-1}.glass-surface__content{display:block;padding:10px 12px;border-radius:inherit;position:relative;z-index:1}.glass-surface--svg{background:light-dark(hsl(0 0% 100% / var(--glass-frost, 0)),hsl(0 0% 0% / var(--glass-frost, 0)));-webkit-backdrop-filter:var(--filter-id, url(#glass-filter)) saturate(var(--glass-saturation, 1));backdrop-filter:var(--filter-id, url(#glass-filter)) saturate(var(--glass-saturation, 1));box-shadow:0 0 2px 1px light-dark(color-mix(in oklch,black,transparent 85%),color-mix(in oklch,white,transparent 65%)) inset,0 0 10px 4px light-dark(color-mix(in oklch,black,transparent 90%),color-mix(in oklch,white,transparent 85%)) inset,0 4px 16px #11111a0d,0 8px 24px #11111a0d,0 16px 56px #11111a0d,0 4px 16px #11111a0d inset,0 8px 24px #11111a0d inset,0 16px 56px #11111a0d inset}.glass-surface--fallback{background:#ffffff40;backdrop-filter:blur(12px) saturate(1.8) brightness(1.1);-webkit-backdrop-filter:blur(12px) saturate(1.8) brightness(1.1);border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #1f268733,0 2px 16px #1f26871a,inset 0 1px #fff6,inset 0 -1px #fff3}@media (prefers-color-scheme: dark){.glass-surface--fallback{background:#ffffff1a;backdrop-filter:blur(12px) saturate(1.8) brightness(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.8) brightness(1.2);border:1px solid rgba(255,255,255,.2);box-shadow:inset 0 1px #fff3,inset 0 -1px #ffffff1a}}@supports not (backdrop-filter: blur(10px)){.glass-surface--fallback{background:#fff6;box-shadow:inset 0 1px #ffffff80,inset 0 -1px #ffffff4d}.glass-surface--fallback:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff26;border-radius:inherit;z-index:-1}}@supports not (backdrop-filter: blur(10px)){@media (prefers-color-scheme: dark){.glass-surface--fallback{background:#0006}.glass-surface--fallback:before{background:#ffffff0d}}}.nav-glass{border-radius:9999px}.nav-row{display:flex;align-items:center;gap:14px;padding:10px 16px}.brand{font-weight:700;font-size:20px;letter-spacing:.2px;white-space:nowrap}.brand-gap{--brand-gap: 128px;width:var(--brand-gap);flex:0 0 var(--brand-gap);height:1px}.nav-right{display:flex;align-items:center;gap:16px}.nav-links{display:flex;gap:16px;white-space:nowrap}.nav-link{text-decoration:none;color:inherit;font-weight:600;font-size:13px;letter-spacing:.2px;opacity:.92;padding:0 6px}.nav-link:hover{opacity:1}.nav-icon{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:inherit;width:36px;height:36px;flex:0 0 16px;display:grid;place-items:center;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}.nav-icon:focus{outline:none}.nav-icon:focus-visible{outline:none;box-shadow:0 0 0 2px currentColor;border-radius:9999px}.hero{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;z-index:10;pointer-events:none;padding:0 16px}.hero .line{display:block}.hero-title{margin:0;font-weight:700;line-height:1.1;letter-spacing:.5px;font-size:clamp(14px,4.6vw,28px)}:root{--font-sans: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif}html,body,#root{height:100%}html,body{margin:0;font-family:var(--font-sans)}.about-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:10;padding:96px 24px 32px;box-sizing:border-box}.about-row{display:grid;grid-template-columns:clamp(260px,42vw,420px) minmax(280px,520px);gap:32px;align-items:center;justify-content:center;justify-items:center;width:min(1100px,92vw);margin:0 auto;pointer-events:auto}.about-text{width:100%;max-width:520px}.about-text h2{margin:0 0 8px;font-weight:700;font-size:clamp(18px,2vw,22px)}.about-text p{margin:0 0 12px;opacity:.9;line-height:1.5;font-size:15px}.about-bullets{margin:8px 0 16px 18px;padding:0;opacity:.9;line-height:1.5;font-size:14px}@media (max-width: 860px){.about-row{grid-template-columns:1fr;gap:20px;width:min(560px,92vw);justify-items:center}}.tilted-card-figure{margin:0}.split-parent{word-break:normal;overflow-wrap:normal;-webkit-hyphens:none;hyphens:none}.split-word{display:inline-block;margin-right:var(--word-gap, 0)}.split-char{display:inline-block;margin-right:var(--letter-gap, 0)}.split-parent a{color:inherit;text-decoration:none;text-underline-offset:2px}.split-parent strong{font-weight:700}.split-parent .proj-title{display:block;margin-bottom:.9em;font-size:clamp(18px,2vw,22px);font-weight:600}.split-parent .proj-desc{display:block}.split-parent .proj-desc:not(:first-of-type){margin-top:.9em}.split-parent .proj-gap{display:block;height:.9em}.proj-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.resume-frame{width:100%;height:clamp(60vh,76vh,86vh);border-radius:16px;border:1px solid rgba(0,0,0,.12);background:#0000000a;box-shadow:0 8px 24px #0000001f;overflow:hidden}html[data-theme=dark] .resume-frame{border-color:#ffffff38;background:#ffffff0f;box-shadow:0 8px 30px #00000059,inset 0 0 0 1px #ffffff0f}.resume-actions{display:flex;justify-content:center;gap:12px;margin-top:12px;flex-wrap:wrap}.site-chip{position:fixed;left:14px;bottom:calc(env(safe-area-inset-bottom) + 14px);z-index:40;font-size:12px;padding:6px 10px;border-radius:999px;backdrop-filter:blur(10px) saturate(1.4);-webkit-backdrop-filter:blur(10px) saturate(1.4);border:1px solid;-webkit-user-select:none;user-select:none}html[data-theme=dark] .site-chip{color:#f5f5f5d1;background:#ffffff0f;border-color:#ffffff29;box-shadow:0 8px 30px #00000059,inset 0 0 0 1px #ffffff0f}html[data-theme=light] .site-chip{color:#141414cc;background:#0000000d;border-color:#00000014;box-shadow:0 8px 24px #0000001a}.tilted-card-figure{position:relative;perspective:800px;display:grid;place-items:center}.tilted-card-mobile-alert{position:absolute;top:1rem;text-align:center;font-size:.875rem;display:none}@media (max-width: 640px){.tilted-card-mobile-alert{display:block}.tilted-card-caption{display:none}}.tilted-card-inner{position:relative;transform-style:preserve-3d}.tilted-card-img{position:absolute;top:0;left:0;object-fit:cover;border-radius:16px;will-change:transform;transform:translateZ(0)}.tilted-card-overlay{position:absolute;top:0;left:0;z-index:2;will-change:transform;transform:translateZ(30px)}.tilted-card-caption{pointer-events:none;position:absolute;left:0;top:0;border-radius:4px;background-color:#fff;padding:4px 10px;font-size:10px;color:#2d2d2d;opacity:0;z-index:3}.dock-outer{margin:0 .5rem;display:flex;max-width:100%;align-items:center}.dock-panel{position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);display:flex;align-items:flex-end;width:fit-content;gap:1rem;border-radius:1rem;background-color:#060010;border:1px solid #222;padding:0 .5rem .5rem}.dock-item{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background-color:#060010;border:1px solid #222;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;cursor:pointer;outline:none}.dock-icon{display:flex;align-items:center;justify-content:center}.dock-label{position:absolute;top:-1.5rem;left:50%;width:fit-content;white-space:pre;border-radius:.375rem;border:1px solid #222;background-color:#060010;padding:.125rem .5rem;font-size:.75rem;color:#fff;transform:translate(-50%)}.dock-panel.embedded{position:static;left:auto;bottom:auto;transform:none;margin:0 auto}.dock-panel.embedded{background:#ffffff0f;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}:root[data-theme=light] .dock-panel.embedded{background:#0000000f;border-color:#0000001f;color:#111;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}:root[data-theme=light] .dock-panel.embedded .dock-item{background-color:#f6e8d5e6;border-color:#00000024;box-shadow:0 4px 16px #00000014,0 2px 8px #0000000f}:root[data-theme=light] .dock-panel.embedded .dock-label{background-color:#f6e8d5e6;border-color:#0000002e;color:#111}:root[data-theme=light] .dock-panel.embedded .dock-icon{color:inherit}.dock-item:focus-visible{outline:2px solid currentColor;outline-offset:2px}.carousel-container{position:relative;overflow:hidden;border-radius:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(12px) saturate(1.6);-webkit-backdrop-filter:blur(12px) saturate(1.6);padding:16px 16px 30px;box-shadow:inset 0 0 0 1px #ffffff0f,0 8px 30px #00000047}:root[data-theme=light] .carousel-container{background:#00000014;border:1px solid rgba(0,0,0,.22);box-shadow:inset 0 0 0 1px #0000000d,0 8px 24px #00000014}.carousel-track{display:flex}.carousel-item{position:relative;display:flex;flex-shrink:0;align-items:center;justify-content:center;border:0;background:transparent;cursor:grab;border-radius:12px}.carousel-item:active{cursor:grabbing}.carousel-media{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}.carousel-indicators-container{position:absolute;left:50%;bottom:8px;transform:translate(-50%);z-index:3;display:flex;justify-content:center}.carousel-indicators{display:flex;gap:10px;align-items:center}.carousel-indicator{height:8px;width:8px;border-radius:50%;cursor:pointer;transition:transform .15s,background-color .15s,opacity .15s;background-color:#555;opacity:.7}.carousel-indicator.active{background-color:#fff;opacity:1;transform:scale(1.15)}:root[data-theme=light] .carousel-indicator{background-color:#bbb}:root[data-theme=light] .carousel-indicator.active{background-color:#111}.shiny-btn{--bg: rgba(255,255,255,.1);--border: rgba(255,255,255,.22);--fg: #fff;position:relative;display:inline-grid;place-items:center;padding:10px 16px;border-radius:999px;border:1px solid var(--border);color:var(--fg);text-decoration:none;overflow:hidden;isolation:isolate;background:var(--bg);box-shadow:inset 0 0 0 1px #ffffff0f,0 8px 30px #00000040;transition:transform .15s ease}.shiny-btn:hover{transform:translateY(-1px)}.shiny-inner{font-weight:600;letter-spacing:.2px;position:relative;z-index:1}.shiny-btn:before{content:"";position:absolute;top:-150%;right:-150%;bottom:-150%;left:-150%;background:conic-gradient(from 0deg at 50% 50%,transparent 0 10%,rgba(255,255,255,.45) 12%,transparent 14% 100%);animation:shiny-spin 5.5s linear infinite;z-index:0;filter:blur(1px)}.shiny-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.55) 50%,transparent 60%);transform:translate(-120%);transition:transform .6s ease;mix-blend-mode:screen;pointer-events:none}.shiny-btn:hover:after{transform:translate(120%)}@keyframes shiny-spin{to{transform:rotate(360deg)}}:root[data-theme=light] .shiny-btn{--bg: rgba(0,0,0,.05);--border: rgba(0,0,0,.18);--fg: #1a1a1a;box-shadow:inset 0 0 0 1px #0000000d,0 8px 24px #00000014}.shiny-btn:before{display:none!important}.text-rotate{display:flex;flex-wrap:wrap;white-space:pre-wrap;position:relative;align-items:center}.text-rotate-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-rotate-word{display:inline-flex;overflow:hidden}.text-rotate-lines{display:flex;flex-direction:column;width:100%}.text-rotate-element{display:inline-block;will-change:transform,opacity}.text-rotate-space{white-space:pre}.rt-pill{display:inline-flex;align-items:center;gap:.5rem;padding:12px 20px;border-radius:999px;line-height:1.2;font-size:clamp(16px,1.35vw,22px);font-weight:600;letter-spacing:.2px;max-width:100%;white-space:nowrap;backdrop-filter:saturate(1.8) blur(10px);-webkit-backdrop-filter:saturate(1.8) blur(10px);position:relative;overflow:hidden;transition:background-color .28s ease,border-color .28s ease,box-shadow .55s ease;will-change:width,height}html[data-theme=dark] .rt-pill{color:#f5f5f5;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px #00000059,inset 0 0 0 1px #ffffff0f}html[data-theme=light] .rt-pill{color:#20150a;background:#20150a14;border:1px solid rgba(32,21,10,.16);box-shadow:0 8px 30px #00000014}.rt-pill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:inherit;background:linear-gradient(to bottom,rgba(255,255,255,.18),transparent 42%);mix-blend-mode:soft-light}.rt-pill:hover{box-shadow:0 10px 40px #00000059,inset 0 0 0 1px #ffffff14}
