@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Host+Grotesk:wght@400;500;600;700&display=swap";:root{--bg:#171717;--white:#fff;--gray:#ffffffb3;--gray-soft:#ffffff8c;--blue:#6bcdfe;--blue-soft:#6bcdfecc;--amber:#ffac03;--yellow:#fc0;--maxw:1180px;--content-maxw:920px;--h-pad:clamp(24px,3vw,40px);--gap-section:clamp(48px,6vw,80px);--radius:16px}*{box-sizing:border-box;cursor:url(/assets/cursor.svg) 6 6,auto;margin:0;padding:0}a,button,[role=button],.hero-link,.plearn,.purl,.contact-item{cursor:url(/assets/cursor.svg) 6 6,pointer}html{scroll-behavior:smooth}html,body{background:var(--bg)}body{-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;color:#fff;min-height:100vh;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}.page{width:calc(100% - 40px);max-width:none;margin:20px auto;padding:0 0 clamp(60px,8vw,120px)}.hero{border-radius:var(--radius);isolation:isolate;background:radial-gradient(120% 130% at 30% 0,#f79127 0%,#d8662f 55%,#b0556a 100%);width:100%;min-height:clamp(280px,28vw,400px);display:flex;position:relative;overflow:hidden}.hero canvas{z-index:0;pointer-events:none;width:100%;height:100%;display:block;position:absolute;inset:0}.hero-content{z-index:1;width:100%;max-width:var(--content-maxw);padding:clamp(28px,4vw,56px) var(--h-pad);color:#fff;margin:0 auto;position:relative}.wave{transform-origin:72% 78%;cursor:default;-webkit-user-select:none;user-select:none;font-size:clamp(24px,3vw,32px);line-height:1;display:inline-block}.wave.is-waving{animation:1.25s ease-in-out wave}@keyframes wave{0%{transform:rotate(0)}12%{transform:rotate(16deg)}24%{transform:rotate(-10deg)}36%{transform:rotate(16deg)}48%{transform:rotate(-8deg)}60%{transform:rotate(12deg)}72%{transform:rotate(-4deg)}84%{transform:rotate(6deg)}to{transform:rotate(0)}}.hero-h1{color:#fffffff0;letter-spacing:-.01em;text-wrap:balance;margin-top:clamp(10px,1.2vw,16px);font-size:clamp(18px,2vw,22px);font-weight:500;line-height:1.18}.hero-h1 b{color:#fff;font-weight:800}.hero-p{color:#ffffffd9;text-wrap:pretty;max-width:840px;margin-top:clamp(10px,1.2vw,14px);font-size:clamp(14px,1.4vw,16px);font-weight:400;line-height:1.55}.hero-p b{color:#fff;font-weight:700}.hero-p a,.exp-company a{color:inherit;text-decoration:none}.hero b{position:relative}.hero b:after{content:"";transform-origin:100%;background:currentColor;border-radius:2px;height:2px;transition:transform .42s cubic-bezier(.66,0,.34,1);position:absolute;bottom:-1px;left:0;right:0;transform:scaleX(0)}.hero b:hover:after{transform-origin:0;transform:scaleX(1)}.hero-links{flex-wrap:wrap;align-items:center;gap:clamp(16px,2vw,32px);margin-top:clamp(20px,2.5vw,32px);display:flex}.hero-link{color:#fff;white-space:nowrap;align-items:center;gap:6px;font-size:clamp(13px,1.2vw,15px);font-weight:700;text-decoration:none;transition:opacity .18s,transform .18s;display:inline-flex}.hero-link svg{width:14px;height:14px;transition:transform .22s}.hero-link:hover{opacity:.86}.hero-link:hover svg{transform:translate(2px,-2px)}main{padding:0 var(--h-pad);max-width:var(--content-maxw);margin:0 auto;display:block}.section{margin-top:var(--gap-section)}.label{color:var(--gray);font-size:clamp(13px,1.2vw,14px);font-weight:500;line-height:1}.logos{flex-wrap:wrap;align-items:center;gap:clamp(20px,2.8vw,36px);margin-top:clamp(20px,2.5vw,32px);display:flex}.logos .logo{flex:none;justify-content:center;align-items:center;height:36px;transition:transform .25s,filter .25s;display:flex}.logos .logo:hover{transform:translateY(-4px)scale(1.06)}.logos .logo svg,.logos .logo img{width:auto;height:100%;display:block}.exp-list{flex-direction:column;gap:clamp(32px,4vw,48px);margin-top:clamp(20px,2.5vw,32px);display:flex}.exp-row{grid-template-columns:minmax(220px,260px) 1fr;align-items:stretch;gap:clamp(20px,3vw,40px);display:grid}.exp-left{flex-direction:column;display:flex}.exp-title{color:#fff;letter-spacing:-.01em;width:fit-content;font-size:clamp(18px,2vw,22px);font-weight:800;line-height:1.05;position:relative}.exp-title:after{content:"";transform-origin:100%;background:currentColor;border-radius:2px;height:2px;transition:transform .42s cubic-bezier(.66,0,.34,1);position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.exp-row:hover .exp-title:after{transform-origin:0;transform:scaleX(1)}.exp-company{color:var(--gray);margin-top:8px;font-size:14px;font-weight:500}.exp-date{color:var(--gray-soft);margin-top:7px;font-size:13px;font-weight:400}.exp-sub{color:var(--gray);margin-top:auto;padding-top:16px;font-size:14px;font-weight:400}.exp-right{flex-direction:column;gap:8px;padding-top:4px;display:flex}.exp-bullet{color:var(--gray);max-width:660px;font-size:14px;font-weight:400;line-height:1.5}.exp-bullet b{color:#fff;font-weight:700}@property --bg-angle{syntax:"<angle>";inherits:false;initial-value:90deg}.exp-bullet .amber{background:linear-gradient(90deg,#f2b82e 0%,#fc233f 46%,#998cf9 100%);background:linear-gradient(var(--bg-angle,90deg), #f2b82e 0%, #fc233f 46%, #998cf9 100%);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:700;transition:transform .3s cubic-bezier(.2,.7,.2,1);display:inline-block}.exp-bullet .amber:hover{animation:3s linear infinite spin-grad;transform:scale(1.08)}@keyframes spin-grad{0%{--bg-angle:90deg}to{--bg-angle:450deg}}.proj-grid{grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:clamp(28px,3.5vw,48px) clamp(24px,2.5vw,36px);margin-top:clamp(24px,3vw,36px);display:grid}.card{flex-direction:column;display:flex}.thumb{aspect-ratio:4/3;background:#1f1f1f;border-radius:10px;width:100%;position:relative;overflow:hidden}.thumb img{object-fit:cover;width:100%;height:100%;display:block}.thumb image-slot{width:100%;height:100%;display:block}.ptitle{color:#fff;flex-wrap:wrap;align-items:center;gap:9px;margin-top:16px;font-size:clamp(16px,1.6vw,18px);font-weight:700;line-height:1.1;display:flex}.badge{align-items:center;gap:5px;display:inline-flex}.badge svg{width:15px;height:15px}.badge span{color:var(--gray);white-space:nowrap;font-size:12px;font-weight:600}.pdesc{color:var(--gray);margin-top:12px;font-size:14px;font-weight:400;line-height:1.5}.prow{justify-content:space-between;align-items:center;gap:14px;margin-top:auto;padding-top:22px;display:flex}.purl{color:var(--blue);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:13px;font-weight:700;text-decoration:none;overflow:hidden}.plearn{color:var(--blue-soft);white-space:nowrap;flex:none;font-size:13px;font-weight:700;text-decoration:none;transition:color .18s}.plearn:hover{color:var(--blue)}.purl:hover{text-decoration:underline}.contact h2{color:var(--gray);font-size:clamp(18px,2vw,22px);font-weight:800;line-height:1}.contact-row{flex-direction:column;gap:16px;margin-top:clamp(20px,2.2vw,28px);display:flex}.contact-item{width:fit-content;color:var(--gray);align-items:center;gap:12px;text-decoration:none;transition:color .18s,transform .18s;display:inline-flex}.contact-item svg{color:currentColor;flex:none;width:20px;height:20px}.contact-item span{font-size:clamp(14px,1.4vw,15px);font-weight:500}.contact-item:hover{color:#fff;transform:translate(3px)}.contrib-row{align-items:stretch;gap:clamp(24px,3vw,40px);margin-top:clamp(14px,1.8vw,22px);display:flex}.pinned-col{flex-direction:column;flex-shrink:0;width:40%;display:flex}.contrib-col{flex:1;min-width:0}.repo-carousel{flex-direction:column;flex:1;margin-top:clamp(14px,1.8vw,22px);padding-top:18px;padding-bottom:9px;display:flex}.repo-skeleton{background:#ffffff08;border-radius:10px;height:130px;margin-top:clamp(14px,1.8vw,22px)}@keyframes repoIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.repo-card{height:130px;color:inherit;background:#ffffff08;border:1px solid #ffffff12;border-radius:10px;flex-direction:column;padding:14px 16px 16px;text-decoration:none;transition:background .2s,border-color .2s;animation:.22s both repoIn;display:flex}.repo-card:hover{background:#ffffff0e;border-color:#ffffff21}.repo-card-head{align-items:center;gap:8px;display:flex}.repo-icon{color:#ffffff59;flex-shrink:0;width:15px;height:15px}.repo-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;font-weight:700;overflow:hidden}.repo-visibility{color:#ffffff61;letter-spacing:.01em;border:1px solid #ffffff21;border-radius:999px;flex-shrink:0;padding:1px 7px;font-size:10px;font-weight:400}.repo-desc{color:var(--gray);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:10px;font-size:12px;line-height:1.52;display:-webkit-box;overflow:hidden}.repo-footer{align-items:center;gap:14px;margin-top:auto;padding-top:13px;display:flex}.repo-lang{color:var(--gray-soft);align-items:center;gap:5px;font-size:12px;font-weight:400;display:flex}.repo-lang-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.repo-stars{color:var(--gray-soft);align-items:center;gap:4px;font-size:12px;display:flex}.repo-star-icon{width:12px;height:12px}.repo-dots{align-items:center;gap:5px;margin-top:10px;padding:0 1px;display:flex}.repo-dot{background:#ffffff24;border:none;border-radius:2px;width:14px;height:3px;padding:0;transition:background .2s,width .2s}.repo-dot.active{background:#fff9;width:20px}.repo-dot:hover:not(.active){background:#ffffff47}.snap-cursor{pointer-events:none;z-index:9999;opacity:0;will-change:transform, width, height;background:0 0;border:1.5px solid #ffffffb3;border-radius:4px;transition:opacity 80ms;position:fixed;top:0;left:0}.repo-carousel.is-snapping,.repo-carousel.is-snapping *{cursor:none!important}.repo-dot.snap-active{background:#ffffffbf;width:22px}.gh-pill{pointer-events:none;z-index:9999;color:#111;white-space:nowrap;opacity:0;will-change:transform;background:#fff;border-radius:999px;align-items:center;gap:5px;padding:5px 11px 5px 9px;font-family:Manrope,sans-serif;font-size:11px;font-weight:600;transition:opacity .1s;display:inline-flex;position:fixed;top:0;left:0;transform:translate(0)}.gh-pill svg{flex-shrink:0;width:11px;height:11px}@media (width<=720px){.contrib-row{flex-direction:column}.pinned-col{width:100%}.exp-row{grid-template-columns:1fr;gap:16px}.exp-left{flex-direction:column}.exp-sub{margin-top:6px;padding-top:0}.exp-right{padding-top:4px}}@media (width<=480px){.hero-content{padding:24px 20px}.logos{gap:20px}.logos .logo{height:32px}}.back-link{color:var(--gray);align-items:center;gap:7px;font-size:13px;font-weight:600;text-decoration:none;transition:color .18s,transform .18s;display:inline-flex}.back-link:hover{color:#fff;transform:translate(-2px)}.writing-page{background:var(--bg);min-height:100vh}.writing-main{max-width:var(--content-maxw);padding:clamp(32px,4vw,64px) var(--h-pad) clamp(60px,8vw,120px);margin:0 auto}.writing-title{letter-spacing:-.02em;color:#fff;text-wrap:balance;margin-top:12px;font-size:clamp(22px,2.8vw,32px);font-weight:800;line-height:1.1}.writing-list{flex-direction:column;margin-top:clamp(28px,3.5vw,48px);display:flex}.writing-item{border-top:1px solid #ffffff12}.writing-item:last-child{border-bottom:1px solid #ffffff12}.writing-item-link{color:inherit;padding:clamp(18px,2.5vw,28px) 0;text-decoration:none;display:block}.writing-item-meta{justify-content:space-between;align-items:center;display:flex}.writing-item-date{color:var(--gray-soft);font-size:12px;font-weight:400}.writing-item-arrow{opacity:0;color:var(--blue);transition:opacity .18s,transform .22s}.writing-item-link:hover .writing-item-arrow{opacity:1;transform:translate(2px,-2px)}.writing-item-title{color:#fff;letter-spacing:-.01em;width:fit-content;margin-top:8px;font-size:clamp(15px,1.6vw,18px);font-weight:700;line-height:1.2;position:relative}.writing-item-title:after{content:"";transform-origin:100%;background:currentColor;border-radius:2px;height:1.5px;transition:transform .38s cubic-bezier(.66,0,.34,1);position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.writing-item-link:hover .writing-item-title:after{transform-origin:0;transform:scaleX(1)}.writing-item-excerpt{color:var(--gray-soft);max-width:680px;margin-top:6px;font-size:13px;font-weight:400;line-height:1.5}.writing-section-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.writing-see-all{color:var(--blue);align-items:center;gap:5px;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .18s;display:inline-flex}.writing-see-all svg{transition:transform .22s}.writing-see-all:hover{opacity:.8}.writing-see-all:hover svg{transform:translate(2px,-2px)}.writing-card{color:inherit;background:#ffffff05;border:1px solid #ffffff12;border-radius:10px;flex-direction:column;padding:20px;text-decoration:none;transition:background .2s,border-color .2s;display:flex}.writing-card:hover{background:#ffffff0d;border-color:#ffffff21}.writing-card-title{color:#fff;letter-spacing:-.01em;margin-top:8px;font-size:clamp(14px,1.5vw,16px);font-weight:700;line-height:1.2}.writing-card .pdesc{margin-top:8px}.post-page{background:var(--bg);min-height:100vh}.post-main{max-width:var(--content-maxw);padding:clamp(32px,4vw,64px) var(--h-pad) clamp(60px,8vw,120px);margin:0 auto}.post-header{margin-top:clamp(20px,2.5vw,36px)}.post-date{color:var(--gray-soft);font-size:13px;font-weight:400;display:block}.post-title{letter-spacing:-.02em;color:#fff;text-wrap:balance;margin-top:10px;font-size:clamp(22px,3vw,36px);font-weight:800;line-height:1.1}.post-content{margin-top:clamp(24px,3vw,40px)}.post-content h2{letter-spacing:-.015em;color:#fff;margin-top:clamp(32px,4vw,48px);font-size:clamp(17px,2vw,22px);font-weight:800}.post-content h3{letter-spacing:-.01em;color:#fff;margin-top:clamp(24px,3vw,36px);font-size:clamp(15px,1.6vw,18px);font-weight:700}.post-content p{color:var(--gray);margin-top:16px;font-size:15px;line-height:1.7}.post-content p:first-child{margin-top:0}.post-content strong{color:#fff;font-weight:700}.post-content em{font-style:italic}.post-content a{color:var(--blue);text-underline-offset:3px;text-decoration:underline}.post-content a:hover{opacity:.8}.post-content ul,.post-content ol{flex-direction:column;gap:6px;margin-top:16px;padding-left:24px;display:flex}.post-content li{color:var(--gray);font-size:15px;line-height:1.65}.post-content li strong{color:#fff}.post-content blockquote{color:var(--gray-soft);border-left:3px solid #6bcdfe80;margin-top:20px;padding-left:16px;font-style:italic}.post-content pre{color:#ffffffe0;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;margin-top:20px;padding:16px 20px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.65;overflow-x:auto}.post-content code{color:#ffffffe0;background:#ffffff12;border-radius:4px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.88em}.post-content pre code{font-size:inherit;background:0 0;padding:0}.post-content hr{border:none;border-top:1px solid #ffffff12;margin:clamp(24px,3vw,40px) 0}.post-img-wrapper{margin-top:20px;display:block}.post-img{border-radius:10px;width:100%;height:auto;display:block}.post-table-wrapper{border:1px solid #ffffff14;border-radius:10px;margin-top:20px;overflow-x:auto}.post-table{border-collapse:collapse;width:100%;font-size:14px}.post-th{text-align:left;color:var(--gray-soft);white-space:nowrap;background:#ffffff08;border-bottom:1px solid #ffffff14;padding:10px 14px;font-size:12px;font-weight:600}.post-td{color:var(--gray);border-bottom:1px solid #ffffff0d;padding:10px 14px;font-size:13px;line-height:1.5}.post-table tr:last-child .post-td{border-bottom:none}.btn{border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;height:40px;padding:0 20px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .18s,transform .15s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--blue);color:#111}.btn-primary:hover{opacity:.88}.btn-outline{color:var(--blue);background:0 0;border-color:#6bcdfe80}.btn-outline:hover{border-color:var(--blue);background:#6bcdfe12}.post-btn{margin-top:16px;margin-right:10px;display:inline-flex}.post-content .post-btn+.post-btn{margin-top:0}.post-content .btn-primary{color:#111;text-decoration:none}.post-content .btn-outline{color:var(--blue);text-decoration:none}.collapsible{border:1px solid #ffffff14;border-radius:8px;margin-top:16px;overflow:hidden}.collapsible-trigger{width:100%;color:var(--gray);text-align:left;background:#ffffff08;border:none;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;transition:background .18s;display:flex}.collapsible-trigger:hover{color:#fff;background:#ffffff0f}.collapsible-chevron{color:var(--gray-soft);font-size:10px;transition:transform .22s}.collapsible-chevron[data-open=true]{transform:rotate(90deg)}.collapsible-body{color:var(--gray);border-top:1px solid #ffffff12;padding:14px 16px;font-size:14px;line-height:1.65}.read-next{margin-top:clamp(48px,6vw,72px)}.read-next-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(16px,2vw,24px);margin-top:20px;display:grid}.read-next-card{color:inherit;background:#ffffff05;border:1px solid #ffffff12;border-radius:10px;flex-direction:column;gap:6px;padding:18px 20px;text-decoration:none;transition:background .2s,border-color .2s;display:flex}.read-next-card:hover{background:#ffffff0d;border-color:#ffffff21}.read-next-title{color:#fff;letter-spacing:-.01em;font-size:14px;font-weight:700;line-height:1.3}.read-next-excerpt{color:var(--gray-soft);font-size:12px;line-height:1.5}.resume-page{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.resume-header{z-index:100;-webkit-backdrop-filter:blur(12px);background:#171717e0;border-bottom:1px solid #ffffff12;position:sticky;top:0}.resume-header-inner{max-width:var(--content-maxw);padding:14px var(--h-pad);justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.resume-controls{align-items:center;gap:8px;display:flex}.resume-zoom-btn{width:34px;height:34px;color:var(--gray);background:0 0;border:1px solid #ffffff1a;border-radius:7px;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.resume-zoom-btn:hover{color:#fff;background:#ffffff12}.resume-zoom-level{color:var(--gray);text-align:center;min-width:42px;font-size:13px;font-weight:600}.resume-download{background:var(--blue);color:#111;border-radius:7px;align-items:center;gap:7px;height:34px;padding:0 16px;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .18s;display:inline-flex}.resume-download:hover{opacity:.88}.resume-viewer{padding:clamp(24px,3vw,48px) var(--h-pad) clamp(48px,6vw,80px);flex-direction:column;flex:1;align-items:center;display:flex;overflow-y:auto}.pdf-document{flex-direction:column;gap:16px;display:flex}.pdf-page-wrapper{border-radius:4px;overflow:hidden;box-shadow:0 4px 32px #00000080}.resume-loading{color:var(--gray-soft);text-align:center;padding:40px;font-size:14px}.subtle-footer{border-top:1px solid #ffffff12;margin-top:clamp(48px,6vw,72px);padding:28px 0 40px}.subtle-footer-inner{flex-wrap:wrap;justify-content:center;align-items:center;gap:32px;display:flex}.subtle-footer-left{align-items:center;gap:20px;display:flex}.subtle-footer-socials{gap:14px;display:flex}.subtle-footer-social{opacity:.45;color:#fff;align-items:center;transition:opacity .18s;display:flex}.subtle-footer-social:hover{opacity:1}.subtle-footer-blog{color:var(--gray);align-items:center;gap:6px;font-size:13px;font-weight:600;text-decoration:none;transition:color .18s;display:inline-flex}.subtle-footer-blog:hover{color:#fff}.subtle-footer-contact{color:var(--gray-soft);align-items:center;gap:6px;font-size:13px;display:flex}@media (width<=560px){.subtle-footer-inner{flex-direction:column;align-items:center}}.social-sidebar{z-index:200;flex-direction:column;align-items:center;gap:16px;display:flex;position:fixed;bottom:0;left:20px}.social-sidebar a{color:#ffffff61;transition:color .18s,transform .18s;display:flex}.social-sidebar a:hover{color:#fff;transform:translateY(-2px)}.social-sidebar-line{background:#ffffff26;width:1px;height:72px}@media (width<=900px){.social-sidebar{display:none}}@font-face{font-family:DSEG7;src:url(https://cdn.jsdelivr.net/npm/dseg@0.46.0/fonts/DSEG7-Classic/DSEG7Classic-Bold.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}.seq808{padding:clamp(56px,7vw,88px) 0 clamp(64px,8vw,100px)}.seq808-scroll{width:100%}.seq808-panel{align-items:flex-end;gap:16px;width:100%;padding-bottom:20px;display:flex}.seq808-tempo-section{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.seq808-lcd{letter-spacing:.04em;justify-content:flex-end;align-items:center;width:88px;height:40px;padding:0 4px;font-family:DSEG7,monospace;font-size:1.9rem;font-weight:700;display:flex;position:relative}.seq808-lcd-ghost{color:#ffffff0d;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:inherit;font-size:inherit;justify-content:flex-end;align-items:center;padding:0 4px;display:flex;position:absolute;inset:0}.seq808-lcd-digits{color:#d8d8c8;white-space:pre;position:relative}.seq808-section-label{color:var(--gray-soft);letter-spacing:.05em;font-size:12px}.seq808-knob--big{cursor:ns-resize;touch-action:none;background:#525252;border:6px solid #1a1a1a;border-radius:50%;outline:none;flex-shrink:0;width:88px;height:88px;transition:box-shadow .15s;position:relative;box-shadow:0 0 0 1.5px #484848}.seq808-knob--big:focus-visible{box-shadow:0 0 0 2px #6bcdfe80}.seq808-knob--big .seq808-knob-notch{transform-origin:50% 19px;pointer-events:none;background:#d84820;border-radius:2px;width:3px;height:16px;margin-top:-19px;margin-left:-1.5px;position:absolute;top:50%;left:50%}.seq808-knob--small{cursor:ns-resize;touch-action:none;background:#d8c850;border:2px solid #a89030;border-radius:50%;outline:none;width:44px;height:44px;transition:box-shadow .15s;position:relative;box-shadow:0 2px 6px #0000008c}.seq808-knob--small:hover{box-shadow:0 2px 10px #000000a6}.seq808-knob--small:focus-visible{box-shadow:0 0 0 2px #6bcdfe80}.seq808-knob--small .seq808-knob-notch{transform-origin:50% 13px;pointer-events:none;background:#28200a;border-radius:2px;width:2px;height:11px;margin-top:-13px;margin-left:-1px;transition:background .15s;position:absolute;top:50%;left:50%}.seq808-knob-rz{pointer-events:none;z-index:3;width:52px;height:52px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.seq808-transport{box-sizing:border-box;flex-direction:column;flex-shrink:0;align-items:stretch;gap:7px;width:90px;min-width:90px;max-width:90px;display:flex}.seq808-keybtn{cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;outline:none;width:100%;padding:0 0 6px}.seq808-keybtn-face{box-sizing:border-box;letter-spacing:.06em;border-radius:9px;justify-content:center;align-items:center;width:100%;padding:9px 10px;font-family:inherit;font-size:11px;font-weight:700;transition:top .1s,box-shadow .1s;display:flex;position:relative;top:0}.seq808-keybtn:focus-visible .seq808-keybtn-face{outline-offset:2px;outline:2px solid #6bcdfe80}.seq808-keybtn:active .seq808-keybtn-face{top:4px}.seq808-keybtn--rec .seq808-keybtn-face{color:#f2cece;background:#b03030;box-shadow:0 6px #6a1818}.seq808-keybtn--rec:hover .seq808-keybtn-face{background:#c03838}.seq808-keybtn--rec:active .seq808-keybtn-face{box-shadow:0 2px #6a1818}.seq808-keybtn--active.seq808-keybtn--rec .seq808-keybtn-face{background:#881e1e;top:4px;box-shadow:0 2px #6a1818}.seq808-key-row{gap:6px;width:100%;display:flex;overflow:visible}.seq808-key-row .seq808-keybtn{flex:1;width:0;min-width:0}.seq808-keybtn--clear .seq808-keybtn-face{color:#c8c8c8;background:#525252;font-size:10px;box-shadow:0 6px #282828}.seq808-keybtn--clear:hover .seq808-keybtn-face{background:#5e5e5e}.seq808-keybtn--clear:active .seq808-keybtn-face{box-shadow:0 2px #282828}.seq808-keybtn--all .seq808-keybtn-face{color:#f2cece;background:#b03030;font-size:10px;box-shadow:0 6px #6a1818}.seq808-keybtn--all:hover .seq808-keybtn-face{background:#c03838}.seq808-keybtn--all:active .seq808-keybtn-face{box-shadow:0 2px #6a1818}.seq808-startstop{cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;outline:none;width:100%;padding:0 0 6px}.seq808-ss-front{color:#4a3020;letter-spacing:.04em;box-sizing:border-box;background:#eeddbc;border-radius:9px;flex-direction:column;align-items:center;width:100%;padding:8px 10px;font-family:inherit;font-size:11px;font-weight:700;transition:top .1s,box-shadow .1s;display:flex;position:relative;top:0;box-shadow:0 6px #8a6a40}.seq808-startstop:hover .seq808-ss-front{background:#f5e8ca}.seq808-startstop:focus-visible .seq808-ss-front{outline-offset:2px;outline:2px solid #6bcdfe80}.seq808-startstop--active .seq808-ss-front{top:4px;box-shadow:0 2px #8a6a40}.seq808-ss-rule{background:#0000002e;width:100%;height:1px;margin:5px 0;display:block}.seq808-voices{border-right:2px solid #7a5c28;flex:1;min-width:0;display:flex}.seq808-voice{border-left:2px solid #7a5c28;flex-direction:column;flex:1;align-items:center;gap:8px;min-width:0;padding:0 6px;display:flex}.seq808-knob-slot{flex-direction:column;justify-content:flex-end;align-items:center;gap:5px;min-height:66px;display:flex}.seq808-knob-placeholder{flex-shrink:0;width:44px;height:44px}.seq808-knob-label{color:#ffffff9e;text-align:center;letter-spacing:.02em;font-size:11px}.seq808-voicebtn{color:#5a3a1e;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.02em;text-align:center;background:#f2e4cc;border:1px solid #ffffff1a;border-radius:20px;outline:none;flex-shrink:0;width:62px;padding:5px 8px;font-family:inherit;font-size:12px;font-weight:700;transition:background .14s,color .14s,border-color .14s;overflow:hidden}.seq808-voicebtn:hover{color:#3a2210;background:#faf0dc}.seq808-voicebtn--active{color:#28200a;background:#e8dc68;border-color:#00000014}.seq808-voicebtn:focus-visible{box-shadow:0 0 0 2px #6bcdfe80}.seq808-modeswitch{cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;flex-direction:column;align-items:center;gap:3px;width:100%;padding:3px 0 0;display:flex}.seq808-modeswitch:focus-visible{outline-offset:4px;border-radius:3px;outline:2px solid #6bcdfe80}.seq808-modeswitch-track{cursor:pointer;background:#1c1c1c;border:1px solid #2c2c2c;border-radius:3px;width:68px;height:20px;position:relative;box-shadow:inset 0 2px 4px #000000bf}.seq808-modeswitch-groove{background:#0c0c0c;border-radius:2px;height:5px;position:absolute;top:50%;left:2px;right:2px;transform:translateY(-50%)}.seq808-modeswitch-thumb{z-index:2;pointer-events:none;background:#383838;border:1px solid #484848;border-radius:2px;flex-direction:column;align-items:center;gap:2px;width:17px;height:32px;padding-top:3px;transition:left .2s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:-7px;left:2px;box-shadow:1px 2px 4px #0009}.seq808-modeswitch--a .seq808-modeswitch-thumb{left:2px}.seq808-modeswitch--ab .seq808-modeswitch-thumb{left:26px}.seq808-modeswitch--b .seq808-modeswitch-thumb{left:49px}.seq808-modeswitch-ridge{background:#ffffff29;border-radius:1px;width:11px;height:1.5px}.seq808-modeswitch-labels{letter-spacing:.05em;color:#ffffff40;justify-content:space-between;width:68px;font-size:9px;font-weight:800;transition:color .2s;display:flex}.seq808-modeswitch-labels span{transition:color .2s}.seq808-modeswitch--a .seq808-modeswitch-labels span:first-child,.seq808-modeswitch--ab .seq808-modeswitch-labels span:nth-child(2),.seq808-modeswitch--b .seq808-modeswitch-labels span:nth-child(3){color:#ffffffd9}.seq808-steps{gap:10px;width:100%;display:flex}.seq808-step-group{flex:1;grid-template-columns:repeat(4,1fr);gap:4px;display:grid}.seq808-pad{aspect-ratio:3/4;cursor:pointer;border:none;border-radius:14px;outline:none;position:relative;overflow:hidden}.seq808-pad[data-group="1"]{background:#5a1a16}.seq808-pad[data-group="2"]{background:#5a3c10}.seq808-pad[data-group="3"]{background:#585010}.seq808-pad[data-group="4"]{background:#504c44}.seq808-pad--on[data-group="1"]{background:#360e0c}.seq808-pad--on[data-group="2"]{background:#38220a}.seq808-pad--on[data-group="3"]{background:#362e08}.seq808-pad--on[data-group="4"]{background:#2c2a26}.seq808-pad--play{filter:brightness(1.28)!important}.seq808-pad:hover{filter:brightness(1.1)}.seq808-pad:focus-visible{outline-offset:2px;outline:2px solid #6bcdfe99}.seq808-pad-led{pointer-events:none;z-index:2;background:#0a0604;border-radius:50%;width:7px;height:7px;transition:background .1s;display:block;position:absolute;top:8px;left:50%;transform:translate(-50%)}.seq808-pad--on .seq808-pad-led{background:#ff3820}.seq808-pad-face{pointer-events:none;z-index:1;border-radius:8px;transition:top .1s,background .1s;display:block;position:absolute;inset:22px 0 0}.seq808-pad[data-group="1"] .seq808-pad-face{background:#e83838}.seq808-pad[data-group="2"] .seq808-pad-face{background:#e89020}.seq808-pad[data-group="3"] .seq808-pad-face{background:#dcba28}.seq808-pad[data-group="4"] .seq808-pad-face{background:#e4dcca}.seq808-pad--on .seq808-pad-face{top:30px}.seq808-pad--on[data-group="1"] .seq808-pad-face{background:#8c2020}.seq808-pad--on[data-group="2"] .seq808-pad-face{background:#7a4c10}.seq808-pad--on[data-group="3"] .seq808-pad-face{background:#786018}.seq808-pad--on[data-group="4"] .seq808-pad-face{background:#7a7268}.seq808-homage{color:#ffffff47;letter-spacing:.03em;text-align:center;margin:0 0 18px;font-size:12px}.seq808-playback{background:#1a1410;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:16px;margin-top:18px;padding:10px 14px;display:flex;box-shadow:inset 0 2px 6px #00000080,0 1px #ffffff0a}.seq808-cassette-svg{filter:drop-shadow(0 3px 6px #0009);flex-shrink:0;width:120px;height:auto}.seq808-reel-inner{transform-box:fill-box;transform-origin:50%}.seq808-reel-inner--spin{animation:1.6s linear infinite seq808-spin}@keyframes seq808-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.seq808-tape-controls{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.seq808-tape-lcd{background:#0c0a06;border:1px solid #ffffff0f;border-radius:4px;align-items:baseline;gap:4px;width:fit-content;padding:3px 8px;font-family:Courier New,monospace;display:flex;box-shadow:inset 0 1px 3px #000c}.seq808-tape-time{color:#e8b840;text-shadow:0 0 8px #e8b84099;letter-spacing:.06em;font-size:13px;font-weight:700;line-height:1}.seq808-tape-time--total{color:#e8b84061;text-shadow:none}.seq808-tape-sep{color:#e8b8404d;font-size:10px;line-height:1}.seq808-tape-track{background:#0c0a06;border:1px solid #ffffff0f;border-radius:3px;height:10px;position:relative;overflow:hidden}.seq808-tape-fill{pointer-events:none;background:#b03030;border-radius:3px 0 0 3px;position:absolute;top:0;bottom:0;left:0}.seq808-tape-scrub{opacity:0;cursor:pointer;width:100%;height:100%;margin:0;position:absolute;inset:0}.seq808-tape-btns{flex-direction:column;flex-shrink:0;align-items:center;gap:6px;display:flex}.seq808-tape-play{cursor:pointer;background:#2a201a;border:none;border-radius:6px;outline:none;justify-content:center;align-items:center;width:40px;height:40px;transition:top .1s,box-shadow .1s;display:flex;position:relative;top:0;box-shadow:0 4px #0a0806,inset 0 1px #ffffff14}.seq808-tape-play-face{color:#e0b090;-webkit-user-select:none;user-select:none;font-size:13px;line-height:1}.seq808-tape-play:hover{background:#362820}.seq808-tape-play:active,.seq808-tape-play--active{background:#1a1410;top:3px;box-shadow:0 1px #0a0806,inset 0 1px #ffffff0d}.seq808-tape-play--active .seq808-tape-play-face{color:#ff6040;text-shadow:0 0 6px #ff604080}.seq808-playback-dl{color:#f2cece;cursor:pointer;background:#b03030;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:top .1s,box-shadow .1s,background .1s;display:flex;position:relative;top:0;box-shadow:0 4px #6a1818}.seq808-playback-dl:hover{background:#c03838}.seq808-playback-dl:active{top:3px;box-shadow:0 1px #6a1818}@media (width<=768px){.seq808{display:none}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}._page_znicn_3{--dn-primary:#8f55f9;--dn-primary-strong:#7334dc;--dn-bg:#f8f9fb;--dn-card:#fff;--dn-border:#e2e4e9;--dn-text:#121212;--dn-text-muted:#5a5a66;--dn-purple-bg:#8a50f4;--dn-btn-ghost-bg:#fff;--dn-btn-ghost-hover:#f5f6f8;--dn-field-bg:#fff;--dn-slider-track:#ececef;--dn-cta-bg:#f1f2f5;--dn-slider-thumb:#fff;background:var(--dn-bg);color:var(--dn-text);letter-spacing:-.005em;flex-direction:column;min-height:100vh;font-family:Host Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}._page_znicn_3 *{cursor:default}._page_znicn_3 a,._page_znicn_3 button{cursor:pointer}._container_znicn_33{width:100%;max-width:880px;margin:0 auto;padding:0 32px}._hero_znicn_40{text-align:left;padding:96px 0 72px}._brand_znicn_45{align-items:center;gap:10px;margin-bottom:28px;display:inline-flex}._brandMark_znicn_52{width:28px;height:28px;display:block}._brandWord_znicn_58{letter-spacing:-.01em;color:var(--dn-text);font-size:18px;font-weight:600}._heroTitle_znicn_65{letter-spacing:-.02em;max-width:720px;color:var(--dn-text);margin:0;font-family:Host Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;font-size:50px;font-weight:600;line-height:1.1}._accent_znicn_76{color:var(--dn-primary)}._heroSub_znicn_80{max-width:520px;color:var(--dn-text-muted);margin:20px 0 0;font-size:16px;line-height:1.5}._ctaRow_znicn_88{flex-wrap:wrap;justify-content:flex-start;gap:12px;margin-top:36px;display:flex}._btn_znicn_96{letter-spacing:-.005em;cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;height:48px;padding:0 24px;font-family:inherit;font-size:15px;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,transform 50ms;display:inline-flex}._btnPrimary_znicn_114{background:var(--dn-primary);color:#fff}._btnPrimary_znicn_114:hover{background:var(--dn-primary-strong)}._btnGhost_znicn_123{background:var(--dn-btn-ghost-bg);border-color:var(--dn-border);color:var(--dn-text)}._btnGhost_znicn_123:hover{background:var(--dn-btn-ghost-hover)}._btnSmall_znicn_133{height:40px;padding:0 18px;font-size:14px}._featureGrid_znicn_139{grid-template-columns:1fr 1fr;gap:16px;padding:8px 0 16px;display:grid}._card_znicn_146{background:var(--dn-card);border:1px solid var(--dn-border);border-radius:16px;flex-direction:column;padding:24px;display:flex;overflow:hidden}._cardPurple_znicn_156{background:var(--dn-purple-bg);color:#fff;border-color:#0000}._featureLabel_znicn_162{letter-spacing:-.01em;align-items:center;gap:8px;margin-bottom:10px;font-size:16px;font-weight:600;display:inline-flex}._featureIcon_znicn_172{width:18px;height:18px;color:var(--dn-primary)}._featureIconLight_znicn_178{color:#fff;background:#ffffff2e;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}._featureText_znicn_189{color:var(--dn-text-muted);margin:0 0 18px;font-size:14px;line-height:1.55}._cardPurple_znicn_156 ._featureText_znicn_189{color:#ffffffd9}._cardPurple_znicn_156 ._featureLabel_znicn_162,._cardPurple_znicn_156 ._featureIcon_znicn_172{color:#fff}._mockDark_znicn_208{background:#0b0d12;border-radius:10px;height:180px;margin-top:auto;position:relative;overflow:hidden}._mockImage_znicn_217{object-fit:cover;object-position:top left;width:100%;height:100%;display:block}._codeBlock_znicn_225{box-sizing:border-box;color:#ffffffeb;white-space:pre;background:#0003;border-radius:10px;height:180px;margin-top:auto;padding:14px 16px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.6;overflow:hidden}._codeComment_znicn_240{color:#ffffff8c}._editorCard_znicn_244{grid-template-columns:1.1fr 1fr;align-items:center;gap:32px;display:grid}._editorBody_znicn_251{min-width:0}._fieldRow_znicn_255{grid-template-columns:1fr 1fr;gap:12px;margin-top:20px;display:grid}._field_znicn_255{border:1px solid var(--dn-border);height:40px;color:var(--dn-text);background:var(--dn-field-bg);border-radius:8px;justify-content:space-between;align-items:center;padding:0 14px;font-size:13px;display:flex}._fieldValue_znicn_275{color:var(--dn-primary);font-size:12.5px;font-weight:500}._swatch_znicn_281{background:var(--dn-primary);border:1px solid #0000000f;border-radius:50%;width:14px;height:14px}._editorPreview_znicn_289{background:var(--dn-card);border:1px solid var(--dn-border);border-radius:12px;flex-direction:column;gap:12px;min-height:180px;padding:14px;display:flex}._previewBar_znicn_300{border:1px solid var(--dn-border);height:26px;color:var(--dn-text-muted);border-radius:6px;justify-content:space-between;align-items:center;padding:0 8px;font-size:11px;display:flex}._sliderRow_znicn_312{flex-direction:column;gap:5px;display:flex}._sliderLabel_znicn_318{color:var(--dn-text-muted);letter-spacing:.01em;font-size:10px}._sliderTrack_znicn_324{background:var(--dn-slider-track);border-radius:999px;height:4px;position:relative}._sliderFill_znicn_331{background:var(--dn-primary);border-radius:999px;position:absolute;inset:0 auto 0 0}._sliderThumb_znicn_338{background:var(--dn-slider-thumb);border:1.5px solid var(--dn-primary);border-radius:50%;width:12px;height:12px;position:absolute;top:50%;transform:translate(-50%,-50%)}._cta_znicn_88{background:var(--dn-cta-bg);border:1px solid var(--dn-border);text-align:center;border-radius:16px;margin:56px 0 80px;padding:48px 24px}._ctaTitle_znicn_358{letter-spacing:-.015em;color:var(--dn-text);margin:0;font-family:Host Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;font-size:28px;font-weight:600}._ctaSub_znicn_367{color:var(--dn-text-muted);max-width:520px;margin:12px auto 24px;font-size:14px}._ctaRowSmall_znicn_374{flex-wrap:wrap;justify-content:center;gap:10px;display:inline-flex}._footer_znicn_382{border-top:1px solid var(--dn-border);margin-top:auto;padding:28px 0 40px}._footerInner_znicn_388{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;display:flex}._footerLeft_znicn_396{align-items:center;gap:20px;display:flex}._footerBrand_znicn_402{letter-spacing:-.01em;color:var(--dn-text);align-items:center;gap:8px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}._footerPortfolio_znicn_413{color:var(--dn-text-muted);font-size:13px;text-decoration:none;transition:color .15s}._footerPortfolio_znicn_413:hover{color:var(--dn-primary)}._footerContact_znicn_424{color:var(--dn-text-muted);font-size:13px}@media (width<=720px){._heroTitle_znicn_65{font-size:34px}._featureGrid_znicn_139,._editorCard_znicn_244{grid-template-columns:1fr}._hero_znicn_40{padding:64px 0 48px}._footerInner_znicn_388{flex-direction:column;align-items:flex-start}}
