@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap");:root{--bg:#0a0b0d;--bg-1:#0e0f13;--bg-2:#14161c;--bg-3:#191c23;--line:#1c1f27;--line-2:#2a2e38;--ink:#ececed;--ink-dim:#8b909c;--ink-faint:#565b66;--accent:#c8f24e;--accent-deep:#98b836;--accent-glow:rgba(200,242,78,.16);--font-sans:"Space Grotesk","Segoe UI",system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;--maxw:1180px;--pad:clamp(20px,5vw,64px);--ease:cubic-bezier(0.2,0.7,0.2,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:96px;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:16px;line-height:1.6;font-feature-settings:"ss01","ss02";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}@media (hover:hover){*{cursor:none!important}}body.modal-open{overflow:hidden}a{text-decoration:none}a,button{color:inherit}button{font:inherit;background:none;border:none;cursor:pointer}::selection{background:var(--accent);color:#0a0b0d}img{max-width:100%;display:block}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#23262f;border:3px solid var(--bg);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#313542}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}.marquee-track{animation-duration:90s!important}}.bg-aurora{position:fixed;inset:0;z-index:-2;pointer-events:none;overflow:hidden;background:var(--bg)}.aurora-blob{position:absolute;border-radius:50%;filter:blur(90px);will-change:transform}.aurora-1{width:780px;height:780px;top:-320px;right:-180px;background:radial-gradient(circle,rgba(200,242,78,.09) 0,transparent 68%);animation:aurora-drift-1 28s ease-in-out infinite}.aurora-2{width:700px;height:700px;bottom:-240px;left:-180px;background:radial-gradient(circle,rgba(24,78,200,.07) 0,transparent 68%);animation:aurora-drift-2 34s ease-in-out infinite}.aurora-3{width:560px;height:560px;top:38%;left:35%;background:radial-gradient(circle,rgba(14,140,120,.05) 0,transparent 68%);animation:aurora-drift-3 22s ease-in-out infinite}@keyframes aurora-drift-1{0%,to{transform:translate(0) scale(1)}30%{transform:translate(-70px,80px) scale(1.08)}65%{transform:translate(55px,-55px) scale(.94)}}@keyframes aurora-drift-2{0%,to{transform:translate(0) scale(1)}40%{transform:translate(90px,-70px) scale(1.12)}75%{transform:translate(-40px,50px) scale(.96)}}@keyframes aurora-drift-3{0%,to{transform:translate(0) scale(1)}25%{transform:translate(-55px,45px) scale(1.06)}70%{transform:translate(70px,-35px) scale(.92)}}@media (prefers-reduced-motion:reduce){.aurora-blob{animation:none}}.bg-noise{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.035;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.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}.kicker{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}.kicker .tick{color:var(--accent)}.rule{border:none;border-top:1px solid var(--line)}.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-mono);font-size:.82rem;font-weight:500;letter-spacing:.04em;padding:.85em 1.4em;border:1px solid var(--line-2);border-radius:2px;transition:all .22s var(--ease);white-space:nowrap}.btn .arrow{transition:transform .22s var(--ease)}.btn:hover .arrow{transform:translate(3px,-3px)}.btn-primary{background:var(--accent);color:#0a0b0d;border-color:var(--accent);font-weight:600}.btn-primary:hover{background:#d6fb6b;box-shadow:0 0 0 4px var(--accent-glow)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-cv{padding-left:1rem;padding-right:1rem}.cv-icon{display:inline-block;transition:transform .22s var(--ease)}.btn-cv:hover .cv-icon{transform:translateY(2px)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s var(--ease),transform .75s var(--ease);transition-delay:var(--d,0ms)}.reveal.in{opacity:1;transform:none}.nav{position:fixed;top:0;left:0;right:0;z-index:80;background:rgba(10,11,13,.72);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}.nav-progress{position:absolute;left:0;bottom:-1px;height:2px;background:var(--accent);width:0;box-shadow:0 0 10px var(--accent-glow)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px}.nav-brand{display:flex;align-items:baseline;gap:.55rem;font-weight:600;letter-spacing:-.01em}.nav-brand .mark{font-family:var(--font-mono);font-weight:700;color:#0a0b0d;background:var(--accent);padding:.16em .38em;border-radius:2px;font-size:.86rem}.nav-brand .dot{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:.35rem;list-style:none}.nav-link{display:flex;align-items:baseline;gap:.45em;font-family:var(--font-mono);font-size:.8rem;padding:.5em .7em;color:var(--ink-dim);border-radius:2px;transition:color .18s var(--ease)}.nav-link .idx{font-size:.66rem;color:var(--ink-faint)}.nav-link:hover{color:var(--ink)}.nav-link.active{color:var(--accent)}.nav-link.active .idx{color:var(--accent-deep)}.nav-cta{margin-left:.4rem}.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--line-2);border-radius:3px;position:relative}.nav-toggle span,.nav-toggle span:after,.nav-toggle span:before{content:"";position:absolute;left:50%;width:17px;height:1.6px;background:var(--ink);transform:translateX(-50%);transition:.22s var(--ease)}.nav-toggle span{top:50%}.nav-toggle span:before{top:-6px}.nav-toggle span:after{top:6px}.nav-toggle.open span{background:transparent}.nav-toggle.open span:before{top:0;transform:translateX(-50%) rotate(45deg)}.nav-toggle.open span:after{top:0;transform:translateX(-50%) rotate(-45deg)}.hero{position:relative;padding-top:150px;padding-bottom:clamp(60px,9vh,110px)}.hero-inner{display:grid;grid-template-columns:1.55fr 1fr;grid-gap:clamp(28px,5vw,72px);gap:clamp(28px,5vw,72px);align-items:end}.hero-eyebrow{display:flex;align-items:center;gap:.8rem;margin-bottom:1.7rem}.hero-eyebrow .line{height:1px;width:54px;background:var(--line-2)}.hero-name{font-size:clamp(2.9rem,8.4vw,6.6rem);font-weight:600;line-height:.98;letter-spacing:-.035em;margin-bottom:1.5rem}.hero-name .ln2{display:block;color:var(--ink-faint)}.hero-name .ln2 em{font-style:normal;color:var(--ink)}.hero-statement{font-size:clamp(1.05rem,1.9vw,1.5rem);line-height:1.45;font-weight:400;color:var(--ink-dim);max-width:30ch;margin-bottom:2.4rem}.hero-statement .rotator{display:inline-flex;color:var(--accent);font-weight:600;position:relative}.hero-statement .rotator:after{content:"";display:inline-block;width:9px;height:1.1em;margin-left:2px;background:var(--accent);transform:translateY(.16em);animation:blink 1.1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap}.hero-spec{border:1px solid var(--line);background:linear-gradient(180deg,var(--bg-1),var(--bg));border-radius:3px}.hero-spec-top{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}.hero-spec-top .dots{display:flex;gap:5px}.hero-spec-top .dots i{width:7px;height:7px;border-radius:50%;background:var(--line-2)}.hero-spec-top .dots i:first-child{background:var(--accent-deep)}.spec-row{display:flex;gap:1rem;padding:.72rem 1rem;font-family:var(--font-mono);font-size:.8rem;border-bottom:1px solid var(--line)}.spec-row:last-child{border-bottom:none}.spec-k{color:var(--ink-faint);min-width:76px;flex-shrink:0}.spec-v{color:var(--ink)}.spec-v .on{color:var(--accent)}.spec-v .pulse{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-right:6px;box-shadow:0 0 0 0 var(--accent-glow);animation:pulse 2.4s infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(200,242,78,.4)}70%{box-shadow:0 0 0 9px rgba(200,242,78,0)}to{box-shadow:0 0 0 0 rgba(200,242,78,0)}}.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-1);overflow:hidden;padding:.85rem 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}.marquee-track{display:flex;width:max-content;gap:2.6rem;animation:scroll-x 90s linear infinite}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-item{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.06em;color:var(--ink-dim);display:flex;align-items:center;gap:2.6rem;white-space:nowrap}.marquee-item:after{content:"/";color:var(--accent-deep)}@keyframes scroll-x{to{transform:translateX(-50%)}}.section{padding-block:clamp(76px,11vh,148px);position:relative}.sec-head{display:flex;align-items:baseline;gap:1.1rem;margin-bottom:2.8rem}.sec-index{font-family:var(--font-mono);font-size:.82rem;font-weight:600;color:var(--accent);padding-top:.4rem}.sec-title{font-size:clamp(1.8rem,4.3vw,3rem);font-weight:600;letter-spacing:-.03em;line-height:1}.sec-kicker{margin-left:auto;align-self:center}.sec-head .grow{flex:1 1;height:1px;background:var(--line);align-self:center;margin-inline:.4rem}.work-grid{display:grid;grid-template-columns:.85fr 1.4fr;grid-gap:clamp(20px,4vw,56px);gap:clamp(20px,4vw,56px)}.work-list{border-top:1px solid var(--line)}.work-list,.work-tab{display:flex;flex-direction:column}.work-tab{gap:.2rem;text-align:left;padding:1.15rem 1.1rem;border-bottom:1px solid var(--line);border-left:2px solid transparent;transition:all .2s var(--ease);position:relative}.work-tab.active,.work-tab:hover{background:var(--bg-1)}.work-tab.active{border-left-color:var(--accent)}.work-tab-yr{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint);letter-spacing:.05em}.work-tab.active .work-tab-yr{color:var(--accent-deep)}.work-tab-co{font-size:1.12rem;font-weight:600;letter-spacing:-.01em}.work-tab-role{font-size:.82rem;color:var(--ink-dim)}.work-detail{border:1px solid var(--line);background:linear-gradient(180deg,var(--bg-1),var(--bg));border-radius:3px;padding:clamp(1.4rem,3vw,2.4rem);min-height:320px}.work-detail-top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.3rem}.work-role{font-size:clamp(1.3rem,2.6vw,1.8rem);font-weight:600;letter-spacing:-.02em}.work-role .at{color:var(--accent)}.work-period{font-family:var(--font-mono);font-size:.78rem;color:var(--ink-faint);white-space:nowrap}.work-blurb{color:var(--ink-dim);margin:.9rem 0 1.5rem;max-width:56ch}.work-points{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.6rem}.work-point{display:flex;gap:.7rem;font-size:.93rem;line-height:1.5}.work-point:before{content:"▹";color:var(--accent);flex-shrink:0}.work-stack{display:flex;flex-wrap:wrap;gap:.45rem;padding-top:1.3rem;border-top:1px solid var(--line)}.chip{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.03em;color:var(--ink-dim);padding:.34em .62em;border:1px solid var(--line-2);border-radius:2px;transition:all .18s var(--ease)}.chip:hover{color:var(--accent);border-color:var(--accent-deep)}.projects{display:flex;flex-direction:column;border-top:1px solid var(--line)}.project{display:grid;grid-template-columns:auto 1fr auto;grid-gap:clamp(1rem,4vw,3.2rem);gap:clamp(1rem,4vw,3.2rem);padding:clamp(1.6rem,4vw,2.8rem) .4rem;border-bottom:1px solid var(--line);position:relative;transition:background .25s var(--ease)}.project:hover{background:var(--bg-1)}.project-idx{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-faint);padding-top:.5rem}.project:hover .project-idx{color:var(--accent)}.project-main{min-width:0}.project-head{display:flex;align-items:baseline;gap:.9rem;flex-wrap:wrap;margin-bottom:.7rem}.project-name{font-size:clamp(1.4rem,3vw,2.1rem);font-weight:600;letter-spacing:-.025em}.project-kind{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent-deep);border:1px solid var(--line-2);padding:.28em .55em;border-radius:2px}.project-tagline{font-size:1.04rem;color:var(--ink);margin-bottom:.5rem}.project-desc{color:var(--ink-dim);font-size:.93rem;max-width:64ch;margin-bottom:1.1rem}.project-stack{display:flex;flex-wrap:wrap;gap:.4rem}.project-cta{display:flex;align-items:flex-start;padding-top:.4rem}.project-link{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.78rem;color:var(--ink-dim);border:1px solid var(--line-2);padding:.6em .9em;border-radius:2px;white-space:nowrap;transition:all .2s var(--ease)}.project-link:hover{color:var(--accent);border-color:var(--accent)}.project-link .arrow{transition:transform .2s var(--ease)}.project-link:hover .arrow{transform:translate(2px,-2px)}.project-link.muted{color:var(--ink-faint);cursor:default}.project-link.muted:hover{color:var(--ink-faint);border-color:var(--line-2)}.stack-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);border-radius:3px;overflow:hidden}.stack-group{padding:1.5rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.stack-group-title{display:flex;align-items:center;gap:.55rem;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:1.1rem}.stack-group-title:before{content:"";width:6px;height:6px;background:var(--accent);display:inline-block}.stack-items{display:flex;flex-wrap:wrap;gap:.5rem}.stack-item{font-family:var(--font-mono);font-size:.8rem;color:var(--ink);padding:.4em .7em;background:var(--bg-2);border:1px solid var(--line);border-radius:2px;transition:all .18s var(--ease)}.stack-item:hover{border-color:var(--accent-deep);color:var(--accent);transform:translateY(-2px)}.shelf-category-toggle{display:flex;gap:0;margin-bottom:2rem;border:1px solid var(--line-2);border-radius:3px;overflow:hidden;width:-moz-fit-content;width:fit-content}.shelf-cat-btn{display:flex;align-items:center;gap:.6rem;padding:.75em 1.8em;font-family:var(--font-mono);font-size:.88rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);background:var(--bg-1);border:none;border-right:1px solid var(--line-2);cursor:pointer;transition:all .18s var(--ease)}.shelf-cat-btn:last-child{border-right:none}.shelf-cat-btn:hover{color:var(--ink);background:var(--bg-2)}.shelf-cat-btn.active{background:var(--accent);color:#0a0b0d;border-right-color:var(--accent)}.shelf-cat-btn.active+.shelf-cat-btn{border-left:1px solid var(--accent)}.cat-count{font-size:.72rem;font-weight:500;opacity:.7;background:rgba(0,0,0,.12);padding:.1em .45em;border-radius:2px}.shelf-cat-btn.active .cat-count{background:rgba(0,0,0,.18);opacity:1}.shelf-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}.shelf-count{font-family:var(--font-mono);font-size:.78rem;color:var(--ink-dim)}.shelf-count b{color:var(--accent);font-weight:600}.shelf-filters{display:flex;gap:.4rem;flex-wrap:wrap}.filter-pill{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-dim);padding:.46em .8em;border:1px solid var(--line-2);border-radius:2px;transition:all .18s var(--ease)}.filter-pill:hover{color:var(--ink)}.filter-pill.active{background:var(--accent);color:#0a0b0d;border-color:var(--accent);font-weight:600}.shelf-search{margin-left:auto;position:relative}.shelf-search input{font-family:var(--font-mono);font-size:.78rem;color:var(--ink);background:var(--bg-1);border:1px solid var(--line-2);border-radius:2px;padding:.55em .8em .55em 1.9em;width:200px;outline:none;transition:border-color .18s var(--ease)}.shelf-search input:focus{border-color:var(--accent-deep)}.shelf-search input::placeholder{color:var(--ink-faint)}.shelf-search .ico{position:absolute;left:.6em;top:50%;transform:translateY(-50%);color:var(--ink-faint);font-size:.8rem}.bookcase{display:flex;flex-wrap:wrap;align-content:flex-start;padding-top:6px;border:1px solid var(--line);border-bottom:none;background:linear-gradient(90deg,hsla(0,0%,100%,.012),transparent 8%,transparent 92%,hsla(0,0%,100%,.012)),var(--bg-1)}.book-slot{height:264px;display:flex;align-items:flex-end;justify-content:center;padding:0 7px;border-bottom:3px solid #06070a;box-shadow:inset 0 -15px 22px -18px rgba(0,0,0,.9);position:relative}.book-slot:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:3px;background:linear-gradient(180deg,#2b2f39,#06070a)}.book-spine{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:12px 4px 9px;border-radius:1px 3px 3px 1px;transform-origin:bottom center;transition:transform .26s var(--ease),box-shadow .26s var(--ease),filter .26s var(--ease);cursor:pointer;overflow:hidden;box-shadow:inset 6px 0 9px -6px rgba(0,0,0,.75),inset -3px 0 6px -4px hsla(0,0%,100%,.22),0 8px 14px -8px rgba(0,0,0,.9)}.cover-img{width:100%;max-width:180px;aspect-ratio:2/3;object-fit:cover;border-radius:2px 5px 5px 2px;box-shadow:0 16px 30px -12px rgba(0,0,0,.85),inset 0 0 0 1px hsla(0,0%,100%,.06)}.book-spine:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,.08) 14%,transparent 28%),linear-gradient(90deg,rgba(0,0,0,.42),hsla(0,0%,100%,.09) 13%,transparent 36%,transparent 68%,rgba(0,0,0,.38));pointer-events:none}.book-spine:hover{transform:translateY(-16px) rotate(0deg)!important;box-shadow:inset 6px 0 9px -6px rgba(0,0,0,.7),0 18px 26px -10px rgba(0,0,0,.95),0 0 0 1px var(--accent-deep),0 0 22px -4px var(--accent-glow);filter:brightness(1.12);z-index:5}.book-spine:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.spine-cap{width:14px;height:3px;border-radius:2px;background:hsla(0,0%,100%,.5);flex-shrink:0}.spine-title{-webkit-text-orientation:mixed;text-orientation:mixed;font-size:.6rem;font-weight:600;letter-spacing:.03em;line-height:1.2;color:hsla(0,0%,100%,.96);text-shadow:0 1px 3px rgba(0,0,0,.65);max-height:100%;margin:6px 0}.spine-author,.spine-title{writing-mode:vertical-rl;font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spine-author{font-size:.54rem;letter-spacing:.04em;color:hsla(0,0%,100%,.62);text-transform:uppercase;max-height:84px;flex-shrink:0}.spine-foot{width:100%;height:4px;flex-shrink:0;display:flex;justify-content:center}.spine-foot i{width:60%;height:2px;background:rgba(0,0,0,.4)}.shelf-empty{width:100%;padding:4rem 1rem;text-align:center;font-size:.85rem}.shelf-empty,.shelf-hint{font-family:var(--font-mono);color:var(--ink-faint)}.shelf-hint{margin-top:1.1rem;font-size:.72rem}.shelf-hint code{color:var(--accent-deep);background:var(--bg-2);padding:.15em .45em;border-radius:2px;border:1px solid var(--line)}.heatmap-wrap{margin-top:2.4rem;display:flex;flex-direction:column;gap:.55rem}.heatmap-label{font-family:var(--font-mono);font-size:.68rem;color:var(--ink-faint);letter-spacing:.06em;text-transform:uppercase}.heatmap-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-gap:4px;gap:4px;max-width:600px}.heatmap-cell{aspect-ratio:1;border-radius:3px;border:1px solid var(--line);transition:transform .15s var(--ease);cursor:default}.heatmap-cell,.heatmap-cell[data-intensity="0"]{background:var(--bg-2)}.heatmap-cell[data-intensity="1"]{background:#2d4a10;border-color:#3a5f17}.heatmap-cell[data-intensity="2"]{background:#4d7c1a;border-color:#63991f}.heatmap-cell[data-intensity="3"]{background:#7ab52a;border-color:#91c935}.heatmap-cell[data-intensity="4"]{background:var(--accent);border-color:var(--accent)}.heatmap-cell:hover{transform:scale(1.3);z-index:2;position:relative}.heatmap-legend{display:flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:.62rem;color:var(--ink-faint)}.heatmap-legend .heatmap-cell{width:11px;height:11px;aspect-ratio:1}.globe-stats{display:flex;gap:1.8rem;font-family:var(--font-mono);font-size:.78rem;color:var(--ink-dim);letter-spacing:.04em;text-transform:uppercase;margin-bottom:.6rem}.globe-stats b{color:var(--accent);font-weight:600;margin-right:.35em}.globe-wrap{display:flex;justify-content:center;align-items:center;margin-top:1.4rem;cursor:-webkit-grab;cursor:grab}.globe-wrap:active{cursor:-webkit-grabbing;cursor:grabbing}.globe-loading{padding:5rem 0;text-align:center;color:var(--ink-faint);font-size:.85rem;letter-spacing:.04em}.globe-loading,.globe-tip{font-family:var(--font-mono)}.globe-tip{background:var(--bg-2);border:1px solid var(--line-2);padding:.55rem .75rem;font-size:.72rem;color:var(--ink);border-radius:4px;box-shadow:0 8px 18px rgba(0,0,0,.55)}.globe-tip-name{display:block;color:var(--ink);margin-bottom:.25em}.globe-tip-meta{display:block;color:var(--ink-dim);font-size:.68rem}.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(6,7,9,.78);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px);animation:fade .22s var(--ease)}@keyframes fade{0%{opacity:0}}.modal{position:relative;width:100%;max-width:760px;max-height:88vh;overflow-y:auto;background:var(--bg-1);border:1px solid var(--line-2);border-radius:4px;display:grid;grid-template-columns:248px 1fr;animation:rise .3s var(--ease)}@keyframes rise{0%{opacity:0;transform:translateY(22px) scale(.985)}}.modal-close{position:absolute;top:12px;right:12px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-2);border-radius:2px;color:var(--ink-dim);font-size:1rem;z-index:3;transition:all .18s var(--ease)}.modal-close:hover{color:var(--accent);border-color:var(--accent)}.modal-cover{padding:1.6rem;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--line);background:var(--bg-2)}.cover{width:100%;max-width:180px;aspect-ratio:2/3;border-radius:2px 5px 5px 2px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:1.1rem 1rem 1.1rem 1.4rem;box-shadow:0 16px 30px -12px rgba(0,0,0,.85),inset 0 0 0 1px hsla(0,0%,100%,.06)}.cover:before{left:0;top:0;bottom:0;width:11px;background:rgba(0,0,0,.32);box-shadow:inset -3px 0 5px -3px hsla(0,0%,100%,.3)}.cover:after,.cover:before{content:"";position:absolute}.cover:after{inset:0;background:linear-gradient(135deg,hsla(0,0%,100%,.12),transparent 46%);pointer-events:none}.cover-rule{width:30px;height:3px;background:hsla(0,0%,100%,.85)}.cover-title{font-size:1.02rem;font-weight:600;line-height:1.2;letter-spacing:-.01em;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.cover-author{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:hsla(0,0%,100%,.78)}.cover-foot{display:flex;flex-direction:column;gap:.45rem}.modal-body{padding:clamp(1.5rem,3vw,2.2rem)}.modal-status{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);margin-bottom:.7rem}.modal-title{font-size:clamp(1.3rem,3vw,1.7rem);font-weight:600;letter-spacing:-.02em;line-height:1.15}.modal-author{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-dim);margin-top:.35rem;margin-bottom:1.1rem}.modal-stars{display:flex;align-items:center;gap:.5rem;margin-bottom:1.3rem}.stars{display:inline-flex;gap:2px;font-size:.95rem;letter-spacing:1px}.stars .on{color:var(--accent)}.stars .off{color:var(--line-2)}.stars-label{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint)}.modal-meta{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--line);border-radius:3px;overflow:hidden;margin-bottom:1.4rem}.meta-cell{padding:.7rem .85rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.meta-cell:nth-child(2n){border-right:none}.meta-k{font-size:.63rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.2rem}.meta-k,.meta-v{font-family:var(--font-mono)}.meta-v{font-size:.86rem;color:var(--ink)}.modal-h{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.5rem}.modal-text{color:var(--ink-dim)}.modal-review,.modal-text{font-size:.93rem;line-height:1.6;margin-bottom:1.3rem}.modal-review{color:var(--ink);border-left:2px solid var(--accent);padding-left:.9rem}.modal-genres{display:flex;flex-wrap:wrap;gap:.4rem}.edu-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}.edu-item{display:grid;grid-template-columns:52px 130px 1fr auto;grid-gap:1.4rem;gap:1.4rem;align-items:center;padding:1.2rem .4rem;border-bottom:1px solid var(--line);transition:background .2s var(--ease)}.edu-item:hover{background:var(--bg-1)}.edu-logo-wrap{width:52px;height:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:4px;overflow:hidden;background:#fff;border:1px solid var(--line-2)}.edu-logo{width:100%;height:100%;object-fit:contain;transition:opacity .2s var(--ease)}.edu-logo[data-logo=aalto]{transform:scale(1.75)}.edu-item:hover .edu-logo{opacity:.85}.edu-period{font-family:var(--font-mono);font-size:.8rem;color:var(--accent-deep)}.edu-qual{font-size:1.1rem;font-weight:600}.edu-inst{font-size:.9rem;color:var(--ink-dim);margin-top:.15rem}.edu-loc{font-family:var(--font-mono);font-size:.76rem;color:var(--ink-faint);text-align:right}.contact-grid{display:grid;grid-template-columns:1fr auto;grid-gap:clamp(28px,6vw,72px);gap:clamp(28px,6vw,72px);align-items:center}.contact-lead{font-size:clamp(1.5rem,3.6vw,2.5rem);font-weight:600;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.6rem}.contact-lead .accent{color:var(--accent)}.contact-sub{color:var(--ink-dim);max-width:48ch;margin-bottom:2rem}.contact-email{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--font-mono);font-size:clamp(.95rem,2vw,1.25rem);color:var(--ink);border:1px solid var(--line-2);padding:.9rem 1.2rem;border-radius:3px;transition:all .22s var(--ease)}.contact-email:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.contact-email .arrow{transition:transform .22s var(--ease)}.contact-email:hover .arrow{transform:translate(3px,-3px)}.contact-links{display:flex;gap:.6rem;margin-top:1.6rem;flex-wrap:wrap}.contact-link{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.8rem;color:var(--ink-dim);border:1px solid var(--line);padding:.6em .9em;border-radius:2px;transition:all .2s var(--ease)}.contact-link:hover{color:var(--accent);border-color:var(--accent-deep)}.contact-portrait{width:260px;flex-shrink:0;border:1px solid var(--line-2);border-radius:3px;padding:10px;background:var(--bg-1)}.contact-portrait img{border-radius:2px;width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center 12%;display:block;filter:grayscale(1) contrast(1.05) brightness(.92);transition:filter .4s var(--ease)}.contact-portrait:hover img{filter:grayscale(0) contrast(1) brightness(1)}.contact-portrait .cap{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;color:var(--ink-faint);margin-top:8px;display:flex;justify-content:space-between}.footer{border-top:1px solid var(--line);background:var(--bg-1)}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-block:2rem}.footer-meta{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-faint)}.footer-meta .accent{color:var(--accent-deep)}.back-top{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.76rem;color:var(--ink-dim);border:1px solid var(--line-2);padding:.55em .85em;border-radius:2px;transition:all .2s var(--ease)}.back-top:hover{color:var(--accent);border-color:var(--accent)}@media (max-width:920px){.hero-inner{grid-template-columns:1fr;align-items:start}.hero-spec{max-width:420px}.work-grid{grid-template-columns:1fr}.work-list{flex-direction:row;overflow-x:auto;border-top:none;border-bottom:1px solid var(--line)}.work-tab{border-bottom:none;border-left:none;border-top:2px solid transparent;min-width:165px;flex-shrink:0}.work-tab.active{border-left-color:transparent;border-top-color:var(--accent)}.stack-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{grid-template-columns:1fr}.contact-portrait{order:-1}}@media (max-width:720px){.nav-links{position:fixed;inset:66px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:rgba(10,11,13,.98);border-bottom:1px solid var(--line);padding:.5rem var(--pad) 1.2rem;transform:translateY(-130%);transition:transform .32s var(--ease)}.nav-links.open{transform:translateY(0)}.nav-link{padding:.9em .4em;border-bottom:1px solid var(--line);font-size:.9rem}.nav-cta{margin:.8rem 0 0}.nav-toggle{display:block}.project{grid-template-columns:1fr;gap:.7rem}.project-idx{padding-top:0}.modal,.stack-grid{grid-template-columns:1fr}.modal{max-height:90vh}.modal-cover{border-right:none;border-bottom:1px solid var(--line);padding:1.6rem 1.6rem .4rem}.cover{max-width:140px}.edu-item{grid-template-columns:44px 1fr;gap:.6rem 1rem}.edu-logo-wrap{width:44px;height:44px;grid-row:span 2;align-self:center}.edu-period{align-self:end}.edu-loc{grid-column:2;text-align:left}.modal-meta{grid-template-columns:1fr}.meta-cell{border-right:none}.shelf-search{margin-left:0;width:100%}.shelf-search input{width:100%}}