*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg);overscroll-behavior:none}:root{--bg: #ffffff;--text: #1a1a1a;--text-secondary: #555;--text-muted: #999;--border: #d4d4d4;--card-bg: #111;--footer-bar-text: #999;--footer-bar-strong: #1a1a1a;--gradient-top: rgba(255, 255, 255, 0);--gradient-bottom: rgba(255, 255, 255, 1)}[data-theme=dark]{--bg: #111111;--text: #fafafa;--text-secondary: #aaa;--text-muted: #666;--border: #333;--card-bg: #1a1a1a;--footer-bar-text: #666;--footer-bar-strong: #fafafa;--gradient-top: rgba(17, 17, 17, 0);--gradient-bottom: rgba(17, 17, 17, 1)}body{font-family:Instrument Sans,sans-serif;font-weight:400;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}ul{list-style:none}.theme-toggle{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center}.toggle-track{width:44px;height:24px;border-radius:12px;background:#e0e0e0;position:relative;transition:background .3s}.toggle-track.dark{background:#333}.toggle-thumb{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .3s;box-shadow:0 1px 3px #00000026;display:flex;align-items:center;justify-content:center;color:#666}.toggle-track.dark .toggle-thumb{transform:translate(20px);background:#555;color:#fff}.navbar{display:flex;justify-content:space-between;align-items:center;padding:28px 56px 20px;position:relative}.navbar-logo{display:flex;align-items:center}[data-theme=dark] .navbar-logo svg{opacity:1}.navbar-right{display:flex;align-items:center;gap:16px}.navbar-links{display:flex;gap:8px}.navbar-link{display:inline-block;padding:6px 16px;border-radius:3px;border:1px solid var(--border);font-size:14px;font-weight:500;color:var(--text);background:#ffffff4d;transition:background .2s,color .2s,border-color .2s}[data-theme=dark] .navbar-link{background:#0000004d}.navbar-link:hover,.navbar-link.active{background:var(--text);color:var(--bg);border-color:var(--text)}.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:28px;height:28px;background:none;border:1px solid var(--border);border-radius:3px;padding:5px;cursor:pointer}.hamburger-line{display:block;width:100%;height:1.5px;background:var(--text);border-radius:1px;transition:transform .3s,opacity .3s}.hamburger.open .hamburger-line:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.hamburger.open .hamburger-line:nth-child(2){opacity:0}.hamburger.open .hamburger-line:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);display:flex;flex-direction:column;padding:8px 24px 16px;z-index:100}.mobile-menu-link{display:block;padding:12px 0;font-size:16px;font-weight:500;color:var(--text);border-bottom:1px solid var(--border)}.mobile-menu-link:last-child{border-bottom:none}.mobile-menu-link:hover,.mobile-menu-link.active{color:var(--text-secondary)}.navbar-mobile{display:none}.navbar-desktop{display:flex}@media (max-width: 768px){.navbar{padding:16px 24px}.navbar-desktop{display:none}.navbar-mobile{display:flex}}.layout{min-height:100vh;background:var(--bg)}.fixed-navbar{position:relative;z-index:4;opacity:0;transform:translateY(-40px);transition:transform .4s ease,opacity .4s ease}.layout:has(.home) .fixed-navbar{position:fixed;top:0;left:0;right:0;z-index:2;background:var(--bg)}.fixed-navbar.menu-open{z-index:10;background:var(--bg)}.page-content{position:relative;pointer-events:none;opacity:0;transition:opacity .4s ease}.phase-enter .fixed-navbar{transform:translateY(-40px);opacity:0}.phase-enter .page-content{opacity:0}.phase-visible .fixed-navbar{transform:none;opacity:1}.phase-visible .page-content{opacity:1;pointer-events:auto}.phase-exit .fixed-navbar{transform:translateY(-40px);opacity:0;transition-duration:.25s}.phase-exit .page-content{opacity:0;transition-duration:.25s}.layout:has(.home).phase-visible .page-content{opacity:1!important;transition:none!important;pointer-events:auto}.layout:has(.home).phase-enter .page-content,.layout:has(.home).phase-exit .page-content{pointer-events:none}.progressive-blur{position:fixed;left:0;right:0;height:40px;pointer-events:none;z-index:50}.progressive-blur.blur-top{top:0}.progressive-blur.blur-bottom{bottom:0}.progressive-blur:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.blur-top:after{background:linear-gradient(to bottom,var(--bg),transparent)}.blur-bottom:after{background:linear-gradient(to top,var(--bg),transparent)}.progressive-blur .blur-layer{position:absolute;left:0;right:0}.blur-top .blur-layer:nth-child(1){top:0;height:25%;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);-webkit-mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-top .blur-layer:nth-child(2){top:0;height:50%;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);-webkit-mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-top .blur-layer:nth-child(3){top:0;height:75%;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);-webkit-mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-top .blur-layer:nth-child(4){top:0;height:100%;backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px);-webkit-mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-bottom .blur-layer:nth-child(1){bottom:0;height:25%;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);-webkit-mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-bottom .blur-layer:nth-child(2){bottom:0;height:50%;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);-webkit-mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-bottom .blur-layer:nth-child(3){bottom:0;height:75%;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);-webkit-mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.blur-bottom .blur-layer:nth-child(4){bottom:0;height:100%;backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px);-webkit-mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);mask:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%)}.project-card-wrapper{display:flex;flex-direction:column}.project-card{display:block;border-radius:15px;overflow:hidden;background:var(--card-bg)}.project-card-image-wrapper{overflow:hidden;aspect-ratio:16 / 10}.project-card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.project-card-gradient{width:100%;height:100%;transition:transform .4s ease}.project-card:hover .project-card-image,.project-card:hover .project-card-gradient{transform:scale(1.05)}.project-card-meta{display:flex;align-items:baseline;gap:8px;padding:12px 4px 0;font-size:13px}.project-card-title{font-weight:600;color:var(--text)}.project-card-year{color:var(--text-muted)}.project-card-tags{font-weight:600;color:var(--text);margin-left:auto}.footer{padding:48px 56px 0;border-top:1px dashed var(--border)}.footer-identity-text{display:flex;flex-direction:column;gap:2px;margin-top:24px}.footer-name{font-size:15px;font-weight:600;color:var(--text)}.footer-role{font-size:15px;color:var(--text)}.footer-email-link{font-size:15px;color:var(--text);text-decoration:underline;text-underline-offset:3px}.footer-columns{display:grid;grid-template-columns:1fr auto auto;gap:80px;margin-bottom:48px}.footer-col{display:flex;flex-direction:column;gap:4px}.footer-col h4{font-size:13px;font-weight:600;letter-spacing:.5px;color:var(--text);margin-bottom:8px}.footer-col a{font-size:15px;color:var(--text-secondary);display:inline-flex;align-items:center;gap:2px}.footer-col a:hover{color:var(--text)}.footer-bar{display:flex;justify-content:space-between;align-items:center;padding:20px 56px 28px;margin:0 -56px;font-size:13px}.footer-copyright,.footer-deploy{color:var(--footer-bar-text)}.footer-deploy strong{color:var(--footer-bar-strong);font-weight:600}@media (max-width: 768px){.footer{padding:48px 24px 0}.footer-columns{grid-template-columns:1fr 1fr;gap:32px}.footer-col:first-child{grid-column:1 / -1}.footer-bar{margin:0 -24px;padding:16px 24px}}.hero-fixed{position:fixed;top:0;left:0;right:0;z-index:1;background:var(--bg);padding-top:76px;min-height:100vh;min-height:100dvh}.hero{padding:100px 56px;max-width:720px}.section-label{font-size:14px;color:var(--text-secondary);padding:56px 56px 0}.hero-spacer{pointer-events:none}.cards-sticky{position:sticky;top:0;z-index:3;background:var(--bg);pointer-events:auto}.cards-sticky:before{content:"";position:absolute;top:-60px;left:0;right:0;height:60px;background:linear-gradient(to bottom,var(--gradient-top),var(--gradient-bottom));pointer-events:none}.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:0 56px 40px}.footer-slide{position:relative;z-index:4;background:var(--bg);border-top:1px dashed var(--border);pointer-events:auto}.anim-hero,.anim-card,.anim-label{opacity:0;transition:opacity .4s ease,transform .4s ease}.anim-card{transform:translateY(40px)}.anim-label{transition-delay:.1s}.home.loaded .anim-hero,.home.loaded .anim-card,.home.loaded .anim-label{opacity:1}.home.loaded .anim-card{transform:translateY(0)}.hero-title{font-size:30px;font-weight:600;line-height:1.1;margin-bottom:16px}.hero-logos-row{display:flex;gap:3px;margin-bottom:16px}.hero-logo-item{width:18px;height:18px}.hero-subtitle{font-size:30px;font-weight:600;line-height:1.1;letter-spacing:-.03em;color:var(--text)}@media (max-width: 768px){.hero-fixed{top:60px}.hero{padding:80px 24px}.hero-title,.hero-subtitle{font-size:24px}.section-label{padding:56px 24px 0}.work-grid{grid-template-columns:1fr;padding:0 24px 60px}}.learn-page{padding-top:76px;pointer-events:auto}.learn-content{max-width:800px;margin:0 auto;padding:80px 56px 100px}.learn-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:56px}.learn-title{font-size:32px;font-weight:600;color:var(--text)}.learn-filters{display:flex;gap:4px}.learn-filter{background:none;border:none;font-size:14px;color:var(--text-secondary);cursor:pointer;padding:4px 10px;border-radius:4px;transition:color .2s,background .2s}.learn-filter:hover{color:var(--text)}.learn-filter.active{color:var(--text);font-weight:600}.learn-section{display:grid;grid-template-columns:100px 1fr;gap:0 32px;margin-bottom:12px}.learn-year-label{font-size:14px;color:var(--text-secondary);padding-top:20px}.learn-list{display:flex;flex-direction:column}.learn-item{display:flex;justify-content:space-between;align-items:center;padding:20px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:opacity .2s}.learn-item:hover{opacity:.6}.learn-item-title{font-size:16px;font-weight:500;color:var(--text)}.learn-item-date{font-size:14px;color:var(--text-secondary);white-space:nowrap;margin-left:24px}@media (max-width: 768px){.learn-content{padding:60px 24px 80px}.learn-header{flex-direction:column;gap:16px;margin-bottom:40px}.learn-section{grid-template-columns:1fr;gap:0}.learn-year-label{padding-top:24px;padding-bottom:4px}}.article-page{position:relative;pointer-events:auto;overscroll-behavior-x:none}.article-layout{max-width:860px;margin:0 auto;padding:80px 56px 100px;box-sizing:border-box}.article-sidebar-col{position:absolute;left:56px;top:80px;bottom:0;width:180px}.article-sidebar{position:sticky;top:40px;display:flex;flex-direction:column;gap:12px}.article-sidebar-back{font-size:13px;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color .2s}.article-sidebar-back:hover{color:var(--text)}.article-sidebar-links{display:flex;flex-direction:column;gap:6px;transition:gap .3s}.article-sidebar.started .article-sidebar-links{gap:0}.article-sidebar-link{background:none;border:none;text-align:left;padding:2px 0;cursor:pointer;display:flex;align-items:center;gap:8px;transition:padding .3s}.article-sidebar.started .article-sidebar-link{padding:0}.article-sidebar.started .article-sidebar-link.active{padding:2px 0}.article-sidebar-line{display:block;width:16px;height:1px;background:var(--border);flex-shrink:0;transition:background .3s,width .3s}.article-sidebar-text{font-size:13px;font-weight:500;color:var(--text-secondary);opacity:0;transition:opacity .3s}.article-sidebar-link.all-visible .article-sidebar-text,.article-sidebar-link:hover .article-sidebar-text{opacity:1}.article-sidebar-link.active{padding:3px 0}.article-sidebar-link.active .article-sidebar-line{background:var(--text);width:24px}.article-sidebar-link.active .article-sidebar-text{opacity:1;color:var(--text)}.article-footer-slide{position:relative;z-index:3;background:var(--bg);border-top:1px dashed var(--border)}.article-title{font-size:32px;font-weight:600;line-height:1.2;color:var(--text);margin-bottom:8px}.article-date{font-size:14px;color:var(--text-secondary);display:block;margin-bottom:24px}.article-divider{border:none;border-top:1px solid var(--border);margin-bottom:48px}.article-body{display:flex;flex-direction:column;gap:24px}.article-heading{font-size:20px;font-weight:600;color:var(--text);margin-top:16px;scroll-margin-top:50px}.article-text{font-size:16px;line-height:1.7;color:var(--text)}.article-code{background:var(--code-bg, rgba(0, 0, 0, .05));border-radius:8px;padding:24px;overflow-x:auto;font-size:14px;line-height:1.6;font-family:SF Mono,Fira Code,Fira Mono,Menlo,monospace;color:var(--text)}[data-theme=dark] .article-code{background:#ffffff0f}@media (max-width: 1100px){.article-sidebar-col{display:none}.article-layout{padding:80px 40px 100px}}@media (max-width: 768px){.article-layout{padding:60px 24px 80px}.article-title{font-size:26px}.article-code{padding:16px;font-size:13px}}.gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center}.gate-form{width:100%;max-width:280px;padding:0 24px}.gate-input{width:100%;padding:12px 16px;font-family:Instrument Sans,sans-serif;font-size:15px;color:var(--text);background:transparent;border:1px solid var(--border);border-radius:8px;outline:none;transition:border-color .2s ease}.gate-input::placeholder{color:var(--text-muted)}.gate-input:focus{border-color:var(--text)}.gate-error{animation:shake .4s ease;border-color:#e74c3c}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}
