@import "https://fonts.googleapis.com/css2?family=Syne+Mono&family=Syne:wght@400;600;700;800&family=Noto+Sans+JP:wght@400;500;700&display=swap";.nav{z-index:100;background:color-mix(in srgb, var(--bg) 95%, transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);align-items:center;height:56px;font-family:Syne,sans-serif;transition:background .25s,border-color .25s;display:flex;position:fixed;top:0;left:0;right:0}.nav-inner{align-items:center;gap:0;width:100%;display:flex}.nav-left{flex-shrink:0;align-items:center;gap:14px;display:flex}.nav-back{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);white-space:nowrap;border-radius:3px;align-items:center;gap:5px;padding:4px 10px;font-family:Syne,sans-serif;font-size:10px;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s;display:flex}.nav-back:hover{color:var(--text-muted);border-color:var(--text-dim)}.nav-sep{background:var(--border);flex-shrink:0;width:1px;height:18px}.nav-sep-mobile{display:none}.nav-logo-btn{color:var(--text);letter-spacing:-.02em;cursor:pointer;text-align:left;background:0 0;border:none;flex-direction:column;padding:0;font-family:Syne,sans-serif;font-size:16px;font-weight:800;line-height:1;text-decoration:none;transition:opacity .15s;display:flex}.nav-logo-btn:hover{opacity:.65}.nav-logo-sub{color:var(--text-dim);letter-spacing:.05em;text-transform:lowercase;margin-top:3px;font-family:Syne,sans-serif;font-size:9px;font-weight:400}.nav-tabs{flex:1;justify-content:center;align-items:stretch;height:56px;display:flex}.nav-tab{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;height:100%;padding:0 22px;font-family:Syne,sans-serif;font-size:11px;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s;display:flex}.nav-tab:hover{color:var(--text)}.nav-tab.active{color:var(--text);border-bottom-color:var(--text)}.nav-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.nav-right-desktop{align-items:center;gap:6px;display:flex}.select-wrap{flex-direction:column;gap:1px;display:flex}.select-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);text-align:center;padding-bottom:2px;font-family:Syne,sans-serif;font-size:8px;font-weight:600;line-height:1}.nav-select{color:var(--text);background:var(--bg-3);border:1px solid var(--border);cursor:pointer;appearance:none;text-align:center;border-radius:4px;outline:none;min-width:80px;padding:5px 10px;font-family:Syne,sans-serif;font-size:11px;font-weight:500;transition:border-color .15s,background .15s}.nav-select:hover{border-color:var(--text-muted)}.nav-select:focus{border-color:var(--text-muted);outline:none}.nav-select option{background:var(--bg-2);color:var(--text)}@media (width<=700px){.nav-tab{padding:0 12px;font-size:10px}.nav-logo-sub{display:none}.nav-select{min-width:64px}}.nav-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:4px;width:28px;height:28px;padding:0;display:none}.nav-hamburger span{background:var(--text);width:18px;height:1.5px;margin:0 auto;transition:transform .2s,opacity .2s;display:block}.nav-hamburger.open span:first-child{transform:translateY(5.5px)rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0}.nav-hamburger.open span:nth-child(3){transform:translateY(-5.5px)rotate(-45deg)}.nav-mobile-menu{z-index:99;background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;max-height:0;transition:max-height .25s;display:flex;position:fixed;top:56px;left:0;right:0;overflow:hidden}.nav-mobile-menu.open{max-height:340px}.nav-mobile-tab{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding:16px 24px;font-family:Syne,sans-serif;font-size:13px;font-weight:600;text-decoration:none;transition:color .15s,background .15s}.nav-mobile-tab:last-child{border-bottom:none}.nav-mobile-tab:hover{color:var(--text);background:var(--bg-2)}.nav-mobile-tab.active{color:var(--text);background:var(--accent-dim)}.nav-mobile-backdrop{z-index:98;background:#0000004d;position:fixed;inset:56px 0 0}@media (width<=640px){.nav-tabs{display:none}.nav-hamburger{display:flex}.nav-sep-mobile{display:block}.nav-back-desktop,.nav-sep-desktop,.nav-right-desktop{display:none}}@media (width<=380px){.nav-logo-sub{display:none}}.nav-mobile-controls{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 24px;display:flex}.nav-mobile-main{letter-spacing:.06em;color:var(--text-muted);align-items:center;gap:6px;font-family:Syne,sans-serif;font-size:11px;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.nav-mobile-main:hover{color:var(--text)}.nav-mobile-selects{flex-shrink:0;gap:8px;display:flex}.nav-mobile-selects .select-label{display:none}.nav-mobile-selects .nav-select{min-width:0;padding:6px 10px}.hero{align-items:center;min-height:100vh;padding-top:56px;display:flex}.hero-content{max-width:720px}.hero-eyebrow{color:var(--text-muted);letter-spacing:.16em;text-transform:uppercase;align-items:center;gap:14px;margin-bottom:28px;font-family:Syne Mono,monospace;font-size:11px;display:flex}.hero-eyebrow:before{content:"";background:var(--text-dim);width:28px;height:1px;display:block}.hero-title{letter-spacing:-.04em;margin-bottom:36px;font-size:clamp(64px,10vw,112px);font-weight:800;line-height:.92;font-family:Syne,sans-serif!important}.hero-the{color:var(--text-muted);display:block}.hero-lab{color:var(--text);display:block}.hero-desc{color:var(--text-muted);max-width:400px;margin-bottom:48px;font-size:16px;line-height:1.65}.hero-cta{letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:var(--text);cursor:pointer;border:none;padding:14px 36px;font-family:Syne,sans-serif;font-size:11px;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-block}.hero-cta:hover{opacity:.7}.hero-stats{text-align:right;flex-direction:column;gap:24px;display:flex;position:absolute;bottom:72px;right:0}.hero-stat-num{color:var(--text-dim);font-family:Syne Mono,monospace;font-size:36px;font-weight:700;line-height:1;display:block}.hero-stat-label{letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);font-family:Syne,sans-serif;font-size:9px;font-weight:600}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fi{opacity:0;animation:.5s forwards fadeUp}.fi-1{animation-delay:50ms}.fi-2{animation-delay:.15s}.fi-3{animation-delay:.27s}.fi-4{animation-delay:.4s}@media (width<=768px){.hero-stats{text-align:left;flex-direction:row;gap:32px;margin-top:56px;position:static}.hero-stat-num{font-size:28px}}.projects-page,.products-page{min-height:100vh;padding-top:56px}.projects-hero,.products-hero{border-bottom:1px solid var(--border);padding:72px 0 56px}.projects-title,.products-title{letter-spacing:-.03em;color:var(--text);margin-bottom:10px;font-family:Syne,sans-serif;font-size:clamp(36px,5vw,56px);font-weight:800}.projects-subtitle,.products-subtitle{color:var(--text-muted);letter-spacing:.1em;font-family:Syne Mono,monospace;font-size:11px}.projects-body,.products-body{padding:56px 0 100px}.filters{flex-wrap:wrap;gap:8px;margin-bottom:40px;display:flex}.filter-btn{letter-spacing:.08em;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:3px;padding:6px 16px;font-family:Syne Mono,monospace;font-size:10px;transition:all .15s}.filter-btn:hover{border-color:var(--text-dim);color:var(--text)}.filter-btn.active{border-color:var(--text);color:var(--text);background:var(--accent-dim)}.projects-grid,.products-grid{background:var(--border);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1px;display:grid}.products-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.project-card,.product-card{background:var(--bg);cursor:pointer;flex-direction:column;gap:14px;padding:28px 32px;text-decoration:none;transition:background .2s;display:flex;position:relative;overflow:hidden}.product-card{gap:18px;padding:32px}.project-card:before,.product-card:before{content:"";background:var(--text);width:2px;height:0;transition:height .3s;position:absolute;top:0;left:0}.project-card:hover:before,.product-card:hover:before{height:100%}.project-card:hover,.product-card:hover{background:var(--bg-2)}.project-card-top,.product-card-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.project-name{color:var(--text);font-family:Syne Mono,monospace;font-size:13px;font-weight:700}.product-name{color:var(--text);font-family:Syne Mono,monospace;font-size:15px;font-weight:700}.project-status,.product-status{letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:2px;flex-shrink:0;padding:3px 7px;font-family:Syne Mono,monospace;font-size:9px}.project-desc{color:var(--text-muted);flex:1;font-size:13px;line-height:1.55}.product-desc{color:var(--text-muted);flex:1;font-size:13px;line-height:1.6}.project-footer,.product-footer{justify-content:space-between;align-items:center;display:flex}.project-private{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);align-items:center;gap:4px;font-family:Syne Mono,monospace;font-size:9px;display:flex}.project-tags,.product-tags{flex-wrap:wrap;gap:6px;display:flex}.project-tag,.product-tag{letter-spacing:.06em;text-transform:uppercase;background:var(--tag);color:var(--tag-text);border-radius:2px;padding:3px 7px;font-family:Syne Mono,monospace;font-size:9px}.project-arrow,.product-arrow{color:var(--text-dim);opacity:0;font-family:Syne Mono,monospace;font-size:11px;transition:opacity .2s}.project-card:hover .project-arrow,.product-card:hover .product-arrow{opacity:1}.project-year,.product-year{color:var(--text-dim);font-family:Syne Mono,monospace;font-size:10px;position:absolute;bottom:12px;right:14px}.product-year{bottom:14px}.projects-empty,.products-empty{color:var(--text-muted);font-family:Syne Mono,monospace;font-size:13px}.pp{min-height:100vh;padding-top:56px}.pp-hero{border-bottom:1px solid var(--border);padding:64px 0 52px}.pp-back{letter-spacing:.06em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:40px;padding:0;font-family:Syne Mono,monospace;font-size:11px;transition:color .15s;display:flex}.pp-back:hover{color:var(--text)}.pp-hero-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.pp-title{letter-spacing:-.03em;color:var(--text);margin-bottom:14px;font-family:Syne,sans-serif;font-size:clamp(32px,5vw,56px);font-weight:800;line-height:1}.pp-status{letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:2px;flex-shrink:0;align-self:flex-start;margin-top:4px;padding:5px 11px;font-family:Syne Mono,monospace;font-size:10px}.pp-meta{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.pp-year{color:var(--text-dim);font-family:Syne Mono,monospace;font-size:11px}.pp-tags{flex-wrap:wrap;gap:6px;display:flex}.pp-tag{letter-spacing:.06em;text-transform:uppercase;background:var(--tag);color:var(--tag-text);border-radius:2px;padding:3px 8px;font-family:Syne Mono,monospace;font-size:9px}.pp-private{letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--border);color:var(--text-dim);border-radius:2px;align-items:center;gap:5px;padding:4px 10px;font-family:Syne Mono,monospace;font-size:9px;display:inline-flex}.pp-links{flex-wrap:wrap;gap:10px;margin-top:36px;display:flex}.pp-btn{letter-spacing:.08em;text-transform:uppercase;cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:3px;align-items:center;gap:9px;padding:10px 18px;font-family:Syne Mono,monospace;font-size:11px;font-weight:600;text-decoration:none;transition:opacity .15s;display:flex}.pp-btn:hover{opacity:.8}.pp-btn-live{background:var(--text);color:var(--bg);border-color:var(--text)}.pp-btn-github{background:var(--gh-bg);color:var(--gh-color);border-color:var(--gh-bg)}.pp-btn-gitlab{color:#fff;background:#fc6d26;border-color:#fc6d26}.pp-body{padding:56px 0 100px}.pp-layout{grid-template-columns:1fr 360px;align-items:start;gap:72px;display:grid}.pp-layout.full{grid-template-columns:1fr;max-width:720px}.pp-desc-short{color:var(--text-muted);margin-bottom:24px;font-size:18px;line-height:1.65}.pp-desc-long{color:var(--text-muted);font-size:15px;line-height:1.8}.pp-media{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.pp-media-item{border:1px solid var(--border);background:var(--bg-3);border-radius:2px;overflow:hidden}.pp-media-img,.pp-media-vid{width:100%;display:block}.pp-info{border:1px solid var(--border)}.pp-info-row{border-bottom:1px solid var(--border);display:flex}.pp-info-row:last-child{border-bottom:none}.pp-info-key{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);border-right:1px solid var(--border);align-items:center;min-width:80px;padding:12px 16px;font-family:Syne Mono,monospace;font-size:9px;display:flex}.pp-info-val{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:4px;padding:12px 16px;font-family:Syne Mono,monospace;font-size:11px;display:flex}.pp-not-found{color:var(--text-muted);font-family:Syne Mono,monospace;font-size:13px}@media (width<=900px){.pp-layout{grid-template-columns:1fr;gap:48px}}.about-page{min-height:100vh;padding-top:56px}.about-hero{border-bottom:1px solid var(--border);padding:72px 0 64px}.about-title{letter-spacing:-.03em;color:var(--text);margin-bottom:16px;font-family:Syne,sans-serif;font-size:clamp(36px,5vw,56px);font-weight:800}.about-lead{color:var(--text-muted);max-width:600px;font-size:18px;line-height:1.65}.about-body{padding:72px 0 100px}.about-grid{background:var(--border);border:1px solid var(--border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.about-fact{background:var(--bg);flex-direction:column;gap:14px;padding:36px 32px;transition:background .2s;display:flex}.about-fact:hover{background:var(--bg-2)}.about-fact-num{color:var(--text-dim);letter-spacing:.1em;font-family:Syne Mono,monospace;font-size:11px}.about-fact-text{color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:600;line-height:1.55}@media (width<=640px){.about-grid{grid-template-columns:1fr}}.footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:28px 0;display:flex}.footer-left{color:var(--text-muted);font-family:Syne Mono,monospace;font-size:11px}.footer-left a{color:var(--text-muted);text-decoration:none;transition:color .15s}.footer-left a:hover{color:var(--text)}.footer-right{align-items:center;gap:20px;display:flex}.footer-legal{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;padding:5px 12px;font-family:Syne Mono,monospace;font-size:11px;text-decoration:none;transition:color .15s,border-color .15s;display:inline-block}.footer-legal:hover{color:var(--text);border-color:var(--text-dim)}.footer-domain{color:var(--text-dim);font-family:Syne Mono,monospace;font-size:10px}@media (width<=520px){.footer{flex-direction:column;align-items:flex-start;gap:12px}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);transition:background .25s,color .25s}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.container{max-width:1280px;margin:0 auto;padding:0 56px}.nav-container{width:100%;max-width:1280px;margin:0 auto;padding:0 40px}.section-header{align-items:baseline;gap:16px;margin-bottom:48px;display:flex}.section-title{letter-spacing:.22em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;font-size:10px;font-weight:600}.section-line{background:var(--border);flex:1;height:1px}@media (width<=900px){.container{padding:0 28px}.nav-container{padding:0 20px}}@media (width<=520px){.container{padding:0 16px}.nav-container{padding:0 12px}}:root{--bg:#fff;--bg-2:#f8f8f8;--bg-3:#f0f0f0;--border:#e8e8e8;--text:#0a0a0a;--text-muted:#767676;--text-dim:#c8c8c8;--accent:#0a0a0a;--accent-dim:#0a0a0a0d;--accent-border:#0a0a0a26;--tag:#f0f0f0;--tag-text:#767676;--font-body:"Syne", sans-serif;--gh-bg:#0a0a0a;--gh-color:#fff}:root[data-lang=jp]{--font-body:"Noto Sans JP", "Syne", sans-serif}
