:root{--bg:#FAF7F5;--ink:#1a1a1a;--ink-2:#2a2622;--ink-3:#3c3733;--muted:#685f58;--muted-2:#736a62;--muted-3:#7f756c;--faint:#8b8177;--faint-2:#847a70;--accent:#FF6A2C;--accent-soft:#FCEDE5;--card:#ffffff;--card-warm:#FBF8F6;--line:#ece5e0;--line-warm:#f0e9e3;--line-soft:#efe7e2;--line-2:#ece2dc;--rail:#f3d6c6;--green-bg:#E6F0DD;--green-fg:#5d7d49;--blue-bg:#E4EDF6;--blue-fg:#4d6585;--peach-bg:#FBE7DD;--peach-fg:#b06a47;--serif:'Outfit', 'Zen Maru Gothic', sans-serif;--serif-jp:'Zen Maru Gothic', 'Outfit', sans-serif;--sans:'Inter', 'Noto Sans JP', sans-serif;--sans-jp:'Noto Sans JP', 'Inter', sans-serif;--maxw:1140px;--pad:40px}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}::selection{background:#ffd9c6}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-thumb{background:#e6ddd6;border-radius:10px}::-webkit-scrollbar-track{background:0 0}img{max-width:100%}a{color:inherit}a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}:focus:not(:focus-visible){outline:none}.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}.accent{color:var(--accent)}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}.js [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}.js [data-reveal].is-visible{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.js [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}.floaty{animation:none!important}html{scroll-behavior:auto}}.floaty{animation:float 8s ease-in-out infinite}.nav-shell{position:sticky;top:0;z-index:60;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:rgba(250,247,245,.72);border-bottom:1px solid rgba(0,0,0,4%)}.nav{display:flex;align-items:center;justify-content:space-between;padding-top:20px;padding-bottom:20px}.brand{font-family:quicksand,var(--sans);font-style:italic;font-weight:600;font-size:26px;letter-spacing:0;text-decoration:none;color:var(--ink)}.nav-right{display:flex;align-items:center;gap:30px}.nav-links{display:flex;align-items:center;gap:34px}.nav-link{position:relative;text-decoration:none;padding:4px 0;font-family:var(--sans);font-size:15px;letter-spacing:.2px;color:#3a3631;transition:color .25s}.nav-link:hover{color:var(--accent)}.nav-link::before{content:"";position:absolute;left:0;right:0;bottom:-7px;height:1.5px;background:var(--accent);transform:scaleX(0);transform-origin:center;transition:transform .25s cubic-bezier(.2,.7,.2,1)}.nav-link:hover::before{transform:scaleX(1)}.nav-link.is-active::before{display:none}.nav-link.is-active{color:var(--accent);font-weight:600}.nav-link.is-active::after{content:"";position:absolute;left:50%;bottom:-9px;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--accent)}.nav-icon{display:inline-flex;color:#3a3631;transition:color .25s}.nav-icon:hover{color:var(--accent)}.nav-lang{display:flex;align-items:center;gap:7px;font-family:var(--sans);font-size:13px;letter-spacing:.5px}.nav-lang a{text-decoration:none;color:#b6aca4;font-weight:500;transition:color .2s}.nav-lang a:hover{color:var(--accent)}.nav-lang a.is-active{color:var(--accent);font-weight:600}.nav-lang .sep{color:#d6cdc6}.nav-toggle{display:none;background:0 0;border:none;cursor:pointer;color:var(--ink);padding:4px}.mobile-menu{display:none}main{display:block}.section{max-width:var(--maxw);margin:0 auto;padding:56px var(--pad)}.section-tight{padding-top:46px;padding-bottom:0}.h-section{font-family:var(--serif);font-weight:500;font-size:30px;margin:0 0 24px}.h-section .sub{font-family:var(--sans);font-size:14px;color:var(--faint);margin-left:12px;font-weight:400}.rule{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}.rule>div{border-top:1px solid var(--line-2)}.hero{max-width:var(--maxw);margin:0 auto;padding:48px var(--pad)24px;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}.hero-single{grid-template-columns:1fr;padding-bottom:0}.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,3.6vw,50px);line-height:1.06;letter-spacing:-1px;margin:0 0 16px}.hero-lead{font-family:var(--serif-jp);font-size:19px;line-height:1.95;color:var(--ink-3);margin:0 0 12px;max-width:31ch}.hero-id{margin-top:6px}.hero-meta{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.hero-name{font-family:var(--serif);font-size:20px;font-weight:600;letter-spacing:-.2px;color:var(--ink)}.hero-dot{color:var(--faint-2)}.hero-role{font-family:var(--sans);font-size:14px;color:var(--muted-2);letter-spacing:.2px}.hero-socials{display:flex;gap:11px;margin-top:18px}.hero-socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:transform .2s,border-color .2s,color .2s}.hero-socials a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.hero-socials img{width:18px;height:18px;object-fit:contain}.hero-art-clean{justify-self:end;width:100%;max-width:400px}.hero-art-clean img{width:100%;display:block;height:auto;border-radius:18px}.hero h1.xl,.hero h1.xxl{font-size:clamp(32px,3.6vw,50px);line-height:1.06;letter-spacing:-1px;margin-bottom:16px}.tags{display:flex;gap:10px;flex-wrap:wrap}.tag{font-family:var(--sans);font-size:12.5px;padding:6px 15px;border-radius:999px;background:var(--green-bg);color:var(--green-fg);white-space:nowrap}.tag.cat-product,.tag.cat-プロダクト{background:var(--green-bg);color:var(--green-fg)}.tag.cat-engineering{background:var(--blue-bg);color:var(--blue-fg)}.tag.cat-life,.tag.cat-10x,.tag.cat-aws,.tag.cat-http{background:var(--peach-bg);color:var(--peach-fg)}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 24px;transition:transform .25s,box-shadow .25s}.card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -28px rgba(60,40,20,.3)}.product-card{background:var(--card-warm);border:1px solid var(--line-warm);border-radius:20px;padding:34px 40px;display:grid;grid-template-columns:1fr .72fr;gap:28px;align-items:center;box-shadow:0 30px 60px -50px rgba(60,40,20,.4)}.product-card .wordmark{margin:0 0 16px;display:flex;align-items:center;gap:9px}.product-card .wordmark img{height:30px;width:auto;display:block}.product-card .wordmark span{font-family:var(--sans);font-weight:700;font-size:23px;letter-spacing:-.5px;color:var(--ink)}.product-card .tagline{font-family:var(--serif-jp);font-size:20px;font-weight:500;color:var(--ink);margin:0 0 12px;letter-spacing:.2px}.product-card .desc{font-family:var(--sans-jp);font-size:14px;line-height:1.85;color:var(--muted-2);margin:0 0 16px;max-width:42ch}.product-card .tags{margin-bottom:20px}.product-art{position:relative;justify-self:end}.product-art .glow{position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(253,156,108,.18),rgba(253,156,108,0));top:30px;left:-30px}.product-art .phone{position:relative;width:218px;aspect-ratio:179/307;overflow:hidden;border-radius:30px;filter:drop-shadow(0 24px 40px rgba(40,30,20,.22))}.product-art .phone img{width:100%;display:block}.product-art .phone-img{position:relative;width:196px;filter:drop-shadow(0 24px 44px rgba(40,30,20,.24))}.product-art .phone-img img{width:100%;height:auto;display:block}.link-arrow{display:inline-flex;align-items:center;gap:9px;background:0 0;border:none;cursor:pointer;font-family:var(--sans);font-size:15px;font-weight:600;color:var(--accent);padding:0;text-decoration:none;transition:gap .25s}.link-arrow:hover{gap:15px}.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.project{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 24px;display:flex;flex-direction:column;gap:16px;position:relative;text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s}.project:hover{transform:translateY(-4px);box-shadow:0 22px 44px -28px rgba(60,40,20,.33)}.project.featured{border:1.5px solid var(--accent)}.project.featured .dot{position:absolute;top:18px;right:20px;width:8px;height:8px;border-radius:50%;background:var(--accent)}.project .name{font-family:var(--sans);font-size:18px;font-weight:600;letter-spacing:-.3px}.project .pdesc{font-family:var(--sans-jp);font-size:13px;color:var(--muted-3);line-height:1.6}.project .arr{align-self:flex-end;color:#bdb4ad;transition:transform .25s cubic-bezier(.2,.7,.2,1),color .25s}.project.featured .arr{color:var(--accent)}.project:hover .arr{transform:translateX(5px);color:var(--accent)}.card:hover,.project:not(.featured):hover,.value-card:hover{border-color:#e7d6c9}.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.value-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;transition:transform .25s,box-shadow .25s}.value-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -28px rgba(60,40,20,.3)}.value-card .ic{width:46px;height:46px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--accent)}.value-card .vt{font-family:var(--serif-jp);font-size:17px;font-weight:500;margin-bottom:10px}.value-card .vb{font-family:var(--sans-jp);font-size:13px;line-height:1.85;color:#8a807a}.timeline-row{display:grid;grid-template-columns:104px 30px 1fr;gap:14px;align-items:start;padding:22px 0;border-bottom:1px solid var(--line-soft);text-decoration:none;color:inherit;transition:padding-left .25s}.timeline-row:hover .ttl{color:var(--accent)}.timeline-row:hover .node{background:var(--accent);transform:scale(1.18)}.timeline-row .date{font-family:var(--sans);font-size:14px;color:var(--faint-2);letter-spacing:.5px;padding-top:3px}.timeline-row .rail{position:relative;align-self:stretch;display:flex;justify-content:center}.timeline-row .rail::before{content:"";position:absolute;top:-22px;bottom:-22px;width:1.5px;background:var(--rail)}.timeline-row .node{width:11px;height:11px;border-radius:50%;border:1.6px solid var(--accent);background:var(--bg);margin-top:4px;position:relative;z-index:1;transition:background .2s,transform .2s}.timeline-row .ttl{font-family:var(--serif-jp);font-size:18px;color:var(--ink-2);font-weight:500;transition:color .2s}.timeline-row .titleline{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:7px}.timeline-row .pdesc{font-family:var(--sans-jp);font-size:13.5px;color:var(--muted-3);line-height:1.75}.timeline-row.compact{grid-template-columns:96px 30px 1fr;gap:12px;align-items:center;padding:18px 0}.tl-year{display:flex;align-items:center;gap:16px;font-family:var(--serif);font-size:15px;font-weight:600;letter-spacing:.04em;color:var(--faint);margin:34px 0 8px}.tl-year:first-child{margin-top:0}.tl-year::after{content:"";flex:1;height:1px;background:var(--line-2)}.tl-row{display:grid;grid-template-columns:78px 24px 1fr;gap:14px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line-soft);text-decoration:none;transition:padding-left .2s}.tl-row:hover .tl-title{color:var(--accent)}.tl-date{font-family:var(--sans);font-size:12.5px;color:var(--faint-2);letter-spacing:.3px;white-space:nowrap}.tl-rail{position:relative;align-self:stretch;display:flex;justify-content:center;align-items:center}.tl-rail::before{content:"";position:absolute;top:-13px;bottom:-13px;width:1.5px;background:var(--rail)}.tl-node{width:9px;height:9px;border-radius:50%;border:1.7px solid var(--accent);background:var(--bg);position:relative;z-index:1;transition:background .2s,transform .2s,border-color .2s}.tl-row:hover .tl-node{background:var(--accent);transform:scale(1.25)}.tl-title{font-family:var(--serif-jp);font-size:16px;color:var(--ink-2);line-height:1.5;transition:color .2s}.tl-src{font-family:var(--sans);font-size:10.5px;margin-left:9px;padding:2px 9px;border-radius:999px;white-space:nowrap;vertical-align:middle;color:var(--muted-2);background:var(--card-warm);border:1px solid var(--line)}.src-zenn .tl-node{border-color:#4d6585}.src-zenn:hover .tl-node{background:#4d6585}.src-zenn .tl-src{color:#4d6585;background:#e9f1f9;border-color:transparent}.src-sizu .tl-node{border-color:#5d7d49}.src-sizu:hover .tl-node{background:#5d7d49}.src-sizu .tl-src{color:#5d7d49;background:#eef4e6;border-color:transparent}.src-blog .tl-src{color:var(--peach-fg);background:var(--peach-bg);border-color:transparent}.tl-more-links{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:28px}.tl-more-label{font-family:var(--sans);font-size:13px;color:var(--muted-2);margin-right:2px}.tl-srclink{font-family:var(--sans);font-size:13px;text-decoration:none;padding:7px 16px;border-radius:999px;border:1px solid var(--line);color:var(--ink-2);background:#fff;transition:transform .2s,border-color .2s,color .2s}.tl-srclink:hover{transform:translateY(-2px)}.tl-srclink.src-blog:hover{border-color:var(--peach-fg);color:var(--peach-fg)}.tl-srclink.src-zenn:hover{border-color:#4d6585;color:#4d6585}.tl-srclink.src-sizu:hover{border-color:#5d7d49;color:#5d7d49}.timeline-row.has-thumb{grid-template-columns:100px 30px 1fr 108px;align-items:center}.timeline-row .thumb{width:108px;height:72px;border-radius:10px;overflow:hidden;background:var(--card-warm)}.timeline-row .thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.timeline-row.has-thumb:hover .thumb img{transform:scale(1.05)}.thumb-ph{display:block;width:100%;height:100%;background:linear-gradient(135deg,#efe7e2,#e3d6cc)}.thumb-ph.cat-engineering{background:linear-gradient(135deg,#e9f1f9,#cfdef0)}.thumb-ph.cat-10x,.thumb-ph.cat-aws,.thumb-ph.cat-http{background:linear-gradient(135deg,#fdeae0,#f6d3c2)}.thumb-ph.cat-product{background:linear-gradient(135deg,#ecf4e3,#d4e7c6)}.work-tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:34px}.tab{padding:9px 22px;border-radius:999px;cursor:pointer;font-family:var(--sans);font-size:14px;border:1px solid var(--line);background:#fff;color:#6a6a6a;transition:all .2s}.tab:hover{border-color:#d8c2b6}.tab.is-active{border-color:var(--accent);background:rgba(255,106,44,7%);color:var(--accent);font-weight:600}.work-panel.is-hidden{display:none}.cs-head{margin-bottom:22px}.cs-title{font-family:var(--serif);font-size:clamp(26px,3vw,32px);font-weight:600;display:flex;align-items:center;gap:14px;margin:0 0 10px}.cs-status{font-family:var(--sans);font-size:11.5px;font-weight:500;color:var(--peach-fg);background:var(--peach-bg);padding:4px 12px;border-radius:999px;letter-spacing:.3px;white-space:nowrap}.cs-formerly{font-family:var(--sans);font-size:13px;font-weight:400;color:var(--faint-2);white-space:nowrap}.cs-tagline{font-family:var(--serif-jp);font-size:17px;line-height:1.7;color:var(--muted);margin:0 0 14px;max-width:60ch}.cs-images{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-start;margin:0 0 32px}.cs-images img{max-height:340px;max-width:100%;width:auto;border-radius:14px;border:1px solid var(--line);background:#fff}.cs-release{background:var(--card-warm);border:1px solid var(--line-warm);border-radius:14px;padding:16px 20px;margin:0 0 28px;max-width:520px}.cs-rel-head{display:flex;align-items:baseline;gap:12px;margin-bottom:8px;flex-wrap:wrap}.cs-ver{font-family:var(--sans);font-weight:700;font-size:15px;color:var(--accent)}.cs-rel-date{font-family:var(--sans);font-size:12.5px;color:var(--faint-2)}.cs-rel-notes{font-family:var(--sans-jp);font-size:13px;line-height:1.85;color:var(--ink-3)}.cs-block{margin:0 0 26px}.cs-label{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.cs-text{font-family:var(--sans-jp);font-size:14.5px;line-height:1.95;color:var(--ink-3);margin:0;max-width:64ch}.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px 44px}.cs-list{margin:0;padding:0;list-style:none;max-width:64ch}.cs-list li{position:relative;padding-left:20px;font-family:var(--sans-jp);font-size:14px;line-height:1.75;color:var(--ink-3);margin-bottom:9px}.cs-list li::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.cs-links{display:flex;gap:12px;flex-wrap:wrap;margin:4px 0 28px}.cs-links .btn{display:inline-flex;align-items:center;font-family:var(--sans);font-size:14px;font-weight:600;color:var(--accent);text-decoration:none;padding:10px 20px;border:1px solid var(--accent);border-radius:999px;transition:all .2s}.cs-links .btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}.cs-articles{list-style:none;margin:0;padding:0;max-width:70ch}.cs-articles li{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid var(--line-soft)}.cs-articles .cs-date{font-family:var(--sans);font-size:13px;color:var(--faint-2);white-space:nowrap;padding-top:1px;min-width:76px}.cs-articles a{font-family:var(--sans-jp);font-size:13.5px;line-height:1.6;color:var(--ink-3);text-decoration:none}.cs-articles a:hover{color:var(--accent)}.filterbar{display:flex;gap:12px;flex-wrap:wrap}.chip{padding:9px 22px;border-radius:999px;cursor:pointer;font-family:var(--sans);font-size:14px;border:1px solid var(--line);background:#fff;color:#6a6a6a;transition:all .2s}.chip:hover{border-color:#d8c2b6}.chip.is-active{border-color:var(--accent);background:rgba(255,106,44,7%);color:var(--accent);font-weight:600}.profile{display:block}.profile .id{display:flex;align-items:center;gap:30px}.profile .avatar{width:118px;height:118px;border-radius:50%;background:linear-gradient(135deg,#efe3db,#e3d2c8);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;color:#c3a594}.profile .meta{display:flex;flex-direction:column;gap:16px}.profile .meta .row{display:flex;align-items:center;gap:14px}.profile .meta .ic{color:var(--accent);display:inline-flex}.profile .meta .k{font-family:var(--sans);font-size:13px;color:#a89f99;width:52px}.profile .meta .v{font-family:var(--sans-jp);font-size:14px;color:var(--ink-2)}.profile .bio{font-family:var(--sans-jp);font-size:14.5px;line-height:2.05;color:var(--muted);margin:0;border-left:1px solid var(--line-2);padding-left:38px}.profile-bio{font-family:var(--sans-jp);font-size:15px;line-height:2;color:var(--muted);max-width:760px;margin:24px 0 0}.career{border-top:1px solid var(--line-2)}.career-row{display:grid;grid-template-columns:150px 30px 1fr;gap:16px;align-items:start;padding:22px 0;border-bottom:1px solid var(--line-soft)}.career-row .period{font-family:var(--sans);font-size:13px;color:var(--faint-2);letter-spacing:.3px;padding-top:4px}.career-row .rail{position:relative;align-self:stretch;display:flex;justify-content:center}.career-row .rail::before{content:"";position:absolute;top:-22px;bottom:-22px;width:1.5px;background:var(--rail)}.career-row:first-child .rail::before{top:6px}.career-row:last-child .rail::before{bottom:auto;height:14px}.career-row .node{width:11px;height:11px;border-radius:50%;border:1.6px solid var(--accent);background:var(--bg);margin-top:5px;position:relative;z-index:1}.career-row .org{font-family:var(--serif-jp);font-size:16.5px;font-weight:500;color:var(--ink-2)}.career-row .cbody{font-family:var(--sans-jp);font-size:13.5px;line-height:1.9;color:var(--muted);margin-top:7px;max-width:60ch}.refs{list-style:none;margin:0;padding:0;max-width:760px}.ref-row{display:flex;align-items:center;gap:16px;padding:16px 4px;border-bottom:1px solid var(--line-soft);text-decoration:none;transition:padding-left .25s}.ref-row:hover{padding-left:10px}.ref-row .ref-title{flex:1;font-family:var(--sans-jp);font-size:14.5px;line-height:1.6;color:var(--ink-2);transition:color .2s}.ref-row:hover .ref-title{color:var(--accent)}.ref-row .ref-source{font-family:var(--sans);font-size:11.5px;color:var(--peach-fg);background:var(--peach-bg);padding:4px 11px;border-radius:999px;white-space:nowrap}.ref-row .ref-arrow{color:var(--faint);display:inline-flex;transition:color .2s}.ref-row:hover .ref-arrow{color:var(--accent)}.creds{border-top:1px solid var(--line-2)}.cred-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}.cred-main{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}.cred-org{font-family:var(--serif-jp);font-size:16.5px;font-weight:500;color:var(--ink-2);text-decoration:none;transition:color .2s}a.cred-org:hover{color:var(--accent)}.cred-note{font-family:var(--sans);font-size:12px;color:var(--green-fg);background:var(--green-bg);padding:2px 9px;border-radius:999px}.cred-role{font-family:var(--sans);font-size:13px;color:var(--muted-2)}.cred-period{font-family:var(--sans);font-size:12.5px;color:var(--faint-2);white-space:nowrap}.skills{display:flex;flex-wrap:wrap;gap:11px}.skill{display:inline-flex;align-items:baseline;gap:8px;font-family:var(--sans);font-size:14px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 17px;transition:border-color .2s,transform .2s}.skill:hover{border-color:var(--accent);transform:translateY(-2px)}.skill .yr{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--accent)}.interests{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}.interest{border-top:1px solid var(--line-2);padding-top:20px}.interest .ic{color:#c98a64;margin-bottom:14px;display:inline-flex}.interest .it{font-family:var(--serif);font-size:18px;font-weight:500;margin-bottom:8px}.interest .ib{font-family:var(--sans-jp);font-size:12.5px;line-height:1.8;color:var(--muted-3)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}.contact-list{display:block}.contact-row{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;text-decoration:none;padding:18px 6px;border-bottom:1px solid var(--line-soft);transition:padding-left .25s}.contact-row:hover{padding-left:14px}.contact-row .badge{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink)}.contact-row .label{display:block;font-family:var(--sans);font-size:15px;color:var(--ink);margin-bottom:3px}.contact-row .val{display:block;font-family:var(--sans);font-size:13.5px;color:var(--accent);word-break:break-word}.contact-row .arr{color:var(--accent);display:inline-flex}.open-panel{background:var(--card-warm);border:1px solid var(--line-warm);border-radius:20px;padding:38px;box-shadow:0 30px 60px -50px rgba(60,40,20,.4)}.open-panel .head{display:flex;align-items:center;gap:13px;margin-bottom:18px}.open-panel .head .pip{width:24px;height:24px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center}.open-panel .head .pip span{width:8px;height:8px;border-radius:50%;background:var(--accent)}.open-panel .head .t{font-family:var(--serif);font-size:21px;font-weight:500}.open-panel .body{font-family:var(--sans-jp);font-size:13.5px;line-height:1.95;color:var(--muted-2);margin:0 0 26px}.open-panel .facts{border-top:1px solid var(--line-2);padding-top:24px;display:flex;flex-direction:column;gap:22px}.open-panel .fact{display:flex;gap:16px;align-items:flex-start}.open-panel .fact .fic{width:38px;height:38px;border-radius:50%;background:#f2ece7;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted)}.open-panel .fact .ft{font-family:var(--sans-jp);font-size:14px;color:var(--ink-2);margin-bottom:3px}.open-panel .fact .fs{font-family:var(--sans-jp);font-size:12.5px;color:#a89f99;line-height:1.7}.contact-lead{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-2);margin:0 0 14px}.contact-sub{font-family:var(--serif-jp);font-size:15px;line-height:1.9;color:var(--muted-2);margin:0}.prose{max-width:720px;margin:0 auto;padding:0 var(--pad)}.article-head{max-width:760px;margin:0 auto;padding:60px var(--pad)10px}.article-head h1{font-family:var(--serif-jp);font-weight:600;font-size:clamp(30px,3.6vw,46px);line-height:1.15;letter-spacing:-.6px;margin:0 0 16px}.article-meta{font-family:var(--sans);font-size:13.5px;color:var(--faint);display:flex;gap:14px;flex-wrap:wrap;align-items:center}.article-cover{max-width:860px;margin:24px auto 0;padding:0 var(--pad)}.article-cover img{width:100%;border-radius:16px;display:block}.content{font-family:var(--sans-jp);font-size:16px;line-height:1.95;color:#2d2925}.content h1,.content h2,.content h3,.content h4{font-family:var(--serif-jp);font-weight:600;line-height:1.3;color:var(--ink);margin:2em 0 .7em}.content h1{font-size:1.7em}.content h2{font-size:1.4em;border-bottom:1px solid var(--line-2);padding-bottom:.3em}.content h3{font-size:1.2em}.content h4{font-size:1.05em}.content p{margin:0 0 1.2em}.content a{color:var(--accent);text-decoration:none;background-image:linear-gradient(currentColor,currentColor);background-position:0 100%;background-repeat:no-repeat;background-size:0% 1.5px;transition:background-size .3s cubic-bezier(.2,.7,.2,1)}.content a:hover{background-size:100% 1.5px}@media(prefers-reduced-motion:reduce){.content a{transition:none;background-size:100% 1px}}.content ul,.content ol{padding-left:1.4em;margin:0 0 1.2em}.content li{margin:.4em 0}.content img{border-radius:12px}.content blockquote{margin:1.4em 0;padding:.4em 1.2em;border-left:3px solid var(--accent);color:var(--muted);background:var(--card-warm);border-radius:0 8px 8px 0}.content code{font-family:sfmono-regular,Consolas,monospace;font-size:.9em;background:#f1ebe6;padding:.15em .4em;border-radius:5px}.content pre{background:#1c1a18;color:#eee;padding:18px 20px;border-radius:12px;overflow-x:auto;line-height:1.6}.content pre code{background:0 0;padding:0;color:inherit;font-size:.88em}.content table{border-collapse:collapse;width:100%;margin:1.2em 0;font-size:.92em}.content th,.content td{border:1px solid var(--line-2);padding:8px 12px;text-align:left}.content hr{border:none;border-top:1px solid var(--line-2);margin:2em 0}.post-tags{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 0}.post-tags a{font-family:var(--sans);font-size:12.5px;padding:6px 14px;border-radius:999px;background:var(--card-warm);border:1px solid var(--line);color:var(--muted-2);text-decoration:none;transition:all .2s}.post-tags a:hover{border-color:var(--accent);color:var(--accent)}.post-nav{display:flex;justify-content:space-between;gap:20px;margin-top:8px}.post-nav a{font-family:var(--sans);font-size:14px;color:var(--muted-2);text-decoration:none;max-width:46%;transition:color .2s}.post-nav a:hover{color:var(--accent)}.post-nav .pn-label{font-size:12px;color:var(--faint);display:block;margin-bottom:4px}.list-head{max-width:var(--maxw);margin:0 auto;padding:60px var(--pad)8px}.list-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5vw,64px);line-height:1;letter-spacing:-1.2px;margin:0}.page-header{max-width:var(--maxw);margin:0 auto;padding:60px var(--pad)0}.page-header h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5vw,64px);line-height:1;letter-spacing:-1.2px;margin:0;display:flex;align-items:center;gap:12px;color:var(--ink)}.page-header h1 svg{color:var(--accent)}.page-header .post-meta{font-family:var(--sans);font-size:13px;color:var(--faint);margin-top:16px}.page-header .post-meta ul{list-style:none;padding:0;margin:0;display:flex;gap:14px}.page-header .post-meta a{color:var(--accent);text-decoration:none}#searchbox{max-width:var(--maxw);margin:0 auto;padding:28px var(--pad)80px}#searchInput{width:100%;max-width:520px;font-family:var(--sans);font-size:16px;padding:14px 18px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}#searchInput:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,106,44,.1)}#searchResults{list-style:none;padding:0;margin:22px 0 0;max-width:760px}#searchResults .post-entry{border-bottom:1px solid var(--line-soft);transition:padding-left .25s}#searchResults .post-entry:hover{padding-left:8px}#searchResults .entry-header h2{font-family:var(--serif-jp);font-size:18px;font-weight:500;color:var(--ink-2);margin:0;padding:18px 0}#searchResults .entry-link{position:absolute;inset:0}#searchResults .post-entry{position:relative}.footer{border-top:1px solid var(--line-2);background:rgba(247,242,238,.5);margin-top:30px}.footer-main{max-width:var(--maxw);margin:0 auto;padding:34px var(--pad);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.footer-main .ft{font-family:var(--serif);font-size:24px;font-weight:500}.footer-links{display:flex;align-items:center;gap:30px;flex-wrap:wrap}.footer-links a{display:flex;align-items:center;gap:9px;text-decoration:none;color:#4a443f;font-family:var(--sans);font-size:14px;transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-links a .circle{width:30px;height:30px;border-radius:50%;border:1px solid #e2d9d2;display:flex;align-items:center;justify-content:center}.top-link{width:42px;height:42px;border-radius:50%;border:1px solid #e2d9d2;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .25s,background .25s,color .25s;color:var(--ink)}.top-link:hover{transform:translateY(-3px);background:var(--accent);color:#fff}.footer-copy{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)30px;font-family:var(--sans);font-size:12.5px;color:var(--faint)}@media(max-width:900px){:root{--pad:24px}.nav-links,.nav-lang.desktop{display:none}.nav-toggle{display:inline-flex}.nav-right.open .nav-links{display:flex}.nav-right{position:relative}.mobile-menu{display:none}.mobile-menu.open{display:flex}.mobile-menu{position:absolute;top:100%;right:0;margin-top:14px;flex-direction:column;gap:18px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 26px;box-shadow:0 30px 60px -30px rgba(60,40,20,.3);min-width:200px}.mobile-menu .nav-link{font-size:17px}.mobile-menu .nav-lang{margin-top:6px;padding-top:16px;border-top:1px solid var(--line)}.hero,.product-card,.projects,.values-grid,.contact-grid,.profile,.interests{grid-template-columns:1fr}.hero{padding-top:44px;gap:24px}.hero-art-clean{justify-self:center;max-width:360px;order:-1}.product-card{padding:32px 24px}.product-art{justify-self:center}.projects{gap:14px}.interests{gap:22px}.profile .id{flex-direction:column;align-items:flex-start;gap:20px}.profile .bio{border-left:none;padding-left:0;border-top:1px solid var(--line-2);padding-top:22px}.contact-grid{gap:30px}.timeline-row,.timeline-row.compact,.timeline-row.has-thumb{grid-template-columns:78px 24px 1fr;gap:10px}.timeline-row .thumb{display:none}.career-row{grid-template-columns:92px 24px 1fr;gap:10px}.career-row .period{font-size:12px}.cs-grid{grid-template-columns:1fr;gap:22px}.cs-images img{max-height:260px}.tl-row{grid-template-columns:76px 18px 1fr;gap:9px}.tl-date{font-size:11.5px;letter-spacing:0}.tl-src{display:none}.section{padding-top:40px;padding-bottom:40px}}@media(max-width:560px){.interests{grid-template-columns:1fr 1fr}.footer-main{flex-direction:column;align-items:flex-start;gap:18px}.timeline-row .date{font-size:12.5px}}.brand .accent{display:inline-block;transition:transform .25s cubic-bezier(.2,.7,.2,1)}.brand:hover .accent{transform:scale(1.5)}.contact-row .badge{transition:border-color .2s,color .2s}.contact-row:hover .badge{border-color:var(--accent);color:var(--accent)}.chip:hover,.tab:hover{transform:translateY(-1px)}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.gh-graph{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 24px;max-width:760px}.gh-graph-img{overflow-x:auto}.gh-graph-img img{width:100%;min-width:560px;height:auto;display:block}.gh-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-family:var(--sans);font-size:13.5px;color:var(--muted-2);text-decoration:none;transition:color .2s}.gh-link:hover{color:var(--accent)}.stats{display:flex;flex-wrap:wrap;gap:36px}.stat{display:flex;align-items:baseline;gap:9px}.stat .num{font-family:var(--sans);font-size:19px;font-weight:600;color:var(--ink-2);line-height:1}.stat .num .plus{color:var(--accent)}.stat .label{font-family:var(--sans);font-size:13px;color:var(--faint-2)}.nf{padding-top:80px;padding-bottom:120px}.nf-msg{font-family:var(--serif-jp);font-size:18px;line-height:1.7;color:var(--muted);margin:0 0 26px}.featured{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.feat-card{display:flex;flex-direction:column;gap:12px;min-height:150px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 24px;text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s,border-color .25s}.feat-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -28px rgba(60,40,20,.3);border-color:#e7d6c9}.feat-src{align-self:flex-start;font-family:var(--sans);font-size:11.5px;color:var(--muted-2);background:var(--card-warm);border:1px solid var(--line);padding:3px 11px;border-radius:999px;white-space:nowrap}.feat-title{font-family:var(--serif-jp);font-size:16px;font-weight:500;line-height:1.5;color:var(--ink-2)}.feat-desc{flex:1;font-family:var(--sans-jp);font-size:12.5px;line-height:1.75;color:var(--muted-3)}.feat-arrow{align-self:flex-end;color:var(--faint);display:inline-flex;transition:color .2s}.feat-card:hover .feat-arrow{color:var(--accent)}@media(max-width:900px){.featured{grid-template-columns:1fr}}.hero-greeting{font-family:var(--sans);font-size:13px;color:var(--faint);letter-spacing:.3px;margin:0 0 12px;min-height:1em}.hero-greeting:empty{display:none}.sauna-overlay{position:fixed;inset:0;z-index:200;pointer-events:none;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(circle at 50% 62%,rgba(255,106,44,.1),rgba(250,247,245,0) 62%);animation:saunaFade .4s ease both}.sauna-overlay.out{opacity:0;transition:opacity .6s ease}@keyframes saunaFade{from{opacity:0}to{opacity:1}}.sauna-msg{font-family:var(--serif-jp);font-size:clamp(28px,5vw,52px);font-weight:600;color:var(--ink);background:rgba(255,255,255,.72);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:18px 38px;border-radius:999px;box-shadow:0 30px 60px -30px rgba(60,40,20,.32)}.steam{position:absolute;bottom:-80px;width:16px;height:240px;border-radius:40%;background:linear-gradient(to top,rgba(255,255,255,0),rgba(255,255,255,.6));filter:blur(7px);animation:steamRise 3s ease-in forwards}.steam:nth-child(1){left:38%;animation-delay:0s}.steam:nth-child(2){left:46%;animation-delay:.35s}.steam:nth-child(3){left:54%;animation-delay:.15s}.steam:nth-child(4){left:61%;animation-delay:.5s}.steam:nth-child(5){left:43%;animation-delay:.65s}@keyframes steamRise{0%{transform:translateY(0)scaleX(1);opacity:0}25%{opacity:.85}100%{transform:translateY(-95vh)scaleX(1.7);opacity:0}}@view-transition{navigation: auto; }::view-transition-old(root),::view-transition-new(root){animation-duration:.35s}.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:100;transition:width .08s linear}body::after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}@media(prefers-reduced-motion:reduce){.scroll-progress{transition:none}}.reveal-words .word{display:inline-block;animation:wordIn .65s cubic-bezier(.2,.7,.2,1)both}.reveal-words .word:nth-child(1){animation-delay:.05s}.reveal-words .word:nth-child(2){animation-delay:.15s}.reveal-words .word:nth-child(3){animation-delay:.25s}@keyframes wordIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}.toast{position:fixed;left:50%;bottom:32px;transform:translate(-50%,16px);z-index:300;background:var(--ink);color:#fff;font-family:var(--sans);font-size:13px;padding:10px 20px;border-radius:999px;box-shadow:0 20px 40px -20px rgba(0,0,0,.4);opacity:0;transition:opacity .25s,transform .25s;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%,0)}.to-top-float{position:fixed;right:26px;bottom:26px;z-index:90;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 14px 30px -16px rgba(60,40,20,.4);opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .25s,transform .25s,background .2s,color .2s}.to-top-float.show{opacity:1;transform:translateY(0);pointer-events:auto}.to-top-float:hover{background:var(--accent);color:#fff;border-color:var(--accent)}@media(max-width:560px){.to-top-float{right:16px;bottom:16px}}@keyframes shimmer{100%{transform:translateX(100%)}}.gh-graph-img img{transition:opacity .4s}.gh-graph-img.is-loading{position:relative;min-height:120px;border-radius:10px;overflow:hidden;background:var(--card-warm)}.gh-graph-img.is-loading img{opacity:0}.gh-graph-img.is-loading::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:shimmer 1.3s infinite}.cs-rel-skel{display:none}.cs-release.is-loading .cs-rel-head,.cs-release.is-loading .cs-rel-notes{display:none}.cs-release.is-loading .cs-rel-skel{display:flex;flex-direction:column;gap:10px}.cs-rel-skel span{position:relative;overflow:hidden;height:14px;border-radius:6px;background:rgba(0,0,0,5%)}.cs-rel-skel span:nth-child(1){width:38%}.cs-rel-skel span:nth-child(2){width:88%}.cs-rel-skel span:nth-child(3){width:66%}.cs-rel-skel span::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:shimmer 1.3s infinite}