:root{--bg:#f5f0e8;--surface:#fffaf1;--ink:#101113;--muted:#68635b;--line:#d7cec0;--green:#16a66a;--red:#e34b38;--blue:#2457d6;--focus:#2457d62e;--prose:#292622;--code-bg:#e8dfd0;--max:1180px;color-scheme:light}:root[data-theme=dark]{--bg:#14120f;--surface:#211f1a;--ink:#f4efe6;--muted:#b8b0a4;--line:#3b352d;--green:#48d48d;--red:#ff7a66;--blue:#7aa7ff;--focus:#7aa7ff3d;--prose:#e2d8cb;--code-bg:#302a22;color-scheme:dark}*{box-sizing:border-box}html{background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans JP,sans-serif}body{text-rendering:optimizelegibility;background:var(--bg);margin:0;font-size:16px;line-height:1.7}a{color:inherit;text-underline-offset:.18em;text-decoration-thickness:1px}button{font:inherit}.skip-link{z-index:10;border:1px solid var(--ink);background:var(--surface);color:var(--ink);padding:8px 12px;font-weight:800;position:fixed;top:12px;left:12px;transform:translateY(-160%)}.skip-link:focus{transform:translateY(0)}img{max-width:100%;display:block}h1,h2,h3,p{margin-top:0}h1,h2,h3{letter-spacing:0;line-height:1.12}h1{max-width:10ch;font-size:4rem}h2{font-size:2rem}h3{font-size:1.35rem}.site-header{max-width:var(--max);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:20px;margin:0 auto;padding:20px 24px;display:flex}.brand{align-items:center;gap:12px;text-decoration:none;display:inline-flex}.brand-mark{background:var(--ink);width:44px;height:44px;color:var(--bg);place-items:center;font-weight:900;display:grid}.brand-text{gap:0;display:grid}.brand-text strong,.brand-text small{line-height:1.2}.brand-text small{color:var(--muted)}.site-nav{align-items:center;gap:4px;display:flex}.header-actions{align-items:center;gap:8px;display:flex}.site-nav a{color:var(--muted);border:1px solid #0000;padding:8px 12px;text-decoration:none}.site-nav a:hover,.site-nav a[aria-current=page]{border-color:var(--ink);color:var(--ink)}.theme-toggle{border:1px solid var(--line);background:var(--surface);width:42px;height:42px;color:var(--ink);cursor:pointer;place-items:center;font-size:1.05rem;line-height:1;display:inline-grid}.theme-toggle:hover{border-color:var(--ink);background:var(--ink);color:var(--bg)}.theme-toggle:focus-visible{outline:3px solid var(--focus);outline-offset:2px}.section{width:min(var(--max), calc(100% - 48px));margin:0 auto;padding:56px 0}.home-grid{border-bottom:1px solid var(--line);min-height:62vh;display:block}.intro{padding-bottom:22px}.lead{white-space:pre-line;max-width:660px;font-size:1.25rem}.status-line{max-width:660px;color:var(--muted)}.eyebrow{color:var(--green);text-transform:uppercase;margin-bottom:10px;font-weight:800}.action-row{flex-wrap:wrap;gap:10px;margin-top:28px;display:flex}.button{border:1px solid var(--ink);min-height:44px;color:var(--ink);cursor:pointer;text-align:center;box-shadow:4px 4px 0 var(--line);background:0 0;justify-content:center;align-items:center;padding:8px 16px;font-weight:800;line-height:1.2;text-decoration:none;transition:background .14s,color .14s,border-color .14s,box-shadow .14s,transform .14s;display:inline-flex}.button:hover{background:var(--ink);color:var(--bg);box-shadow:6px 6px 0 var(--ink);transform:translate(-2px,-2px)}.button-primary{background:var(--ink);color:var(--bg)}.button-primary:hover{background:var(--green);color:var(--ink)}.button-small{min-height:38px;padding:7px 12px}.now-panel,.content-band{border:1px solid var(--line);background:var(--surface);padding:24px}.current-text{color:var(--muted);margin:18px 0 0}.now-panel p{margin-bottom:8px}.now-panel a{color:var(--blue)}.focus-list,.plain-list{margin:18px 0 0;padding-left:1.2em}.focus-list li,.plain-list li{margin-bottom:6px}.split-heading{justify-content:space-between;align-items:end;gap:16px;display:flex}.text-link{color:var(--blue);font-weight:800}.post-stack{gap:16px;display:grid}.home-post-list{gap:10px;margin-top:18px;display:grid}.home-post-item{border:1px solid var(--line);background:var(--surface);gap:6px;padding:16px;text-decoration:none;display:grid}.home-post-item:hover{border-color:var(--ink)}.home-post-item strong{font-size:1.08rem;line-height:1.35}.home-post-item>span:last-child{color:var(--muted)}.post-card{border:1px solid var(--line);background:var(--surface);transition:border-color .14s,transform .14s,box-shadow .14s}.post-card:hover{border-color:var(--ink);box-shadow:8px 8px 0 var(--ink);transform:translateY(-2px)}.post-card-link{padding:22px;text-decoration:none;display:block}.post-card h2{margin-bottom:10px}.post-card p{color:var(--muted);margin-bottom:0}.post-card-featured .post-card-link{padding:34px}.post-card-featured h2{font-size:2.6rem}.post-meta{color:var(--red);text-transform:uppercase;flex-wrap:wrap;gap:10px;margin-bottom:12px;font-size:.9rem;font-weight:800;display:flex}.tag-row,.tag-cloud{flex-wrap:wrap;gap:8px;display:flex}.tag-row{padding:0 22px 22px}.tag-row a,.tag-cloud a{border:1px solid var(--line);background:var(--surface);align-items:center;gap:6px;padding:5px 9px;text-decoration:none;display:inline-flex}.tag-row a:hover,.tag-cloud a:hover{border-color:var(--ink);background:var(--ink);color:var(--bg)}.tag-cloud span{color:var(--red);font-weight:800}.compact{display:grid}.blog-layout,.article-layout{grid-template-columns:minmax(0,1fr) 280px;align-items:start;gap:36px;display:grid}.search-panel{border:1px solid var(--line);background:var(--surface);grid-template-columns:96px minmax(0,1fr) auto;align-items:center;gap:12px;margin-bottom:24px;padding:14px;display:grid}.search-panel label{text-transform:uppercase;font-weight:900}.search-panel input{border:1px solid var(--ink);background:var(--bg);width:100%;min-width:0;color:var(--ink);font:inherit;padding:10px 12px}.search-panel input:focus{outline:3px solid var(--focus)}.search-count{color:var(--muted);white-space:nowrap;margin:0}.pagination{flex-wrap:wrap;gap:8px;margin-top:22px;display:flex}.pagination a,.pagination span{border:1px solid var(--line);background:var(--surface);min-width:36px;min-height:36px;color:var(--ink);place-items:center;font-weight:800;text-decoration:none;display:inline-grid}.pagination a:hover,.pagination span[aria-current=page]{border-color:var(--ink);background:var(--ink);color:var(--bg)}[hidden]{display:none!important}@media (prefers-reduced-motion:no-preference){html,body,.post-card,.project-item,.content-band,.empty-state,.site-footer a{transition:background-color .22s,border-color .22s,color .22s,box-shadow .18s,transform .18s}.theme-shifting:before{content:"";z-index:999;pointer-events:none;transform-origin:50%;background:linear-gradient(90deg,#0000,#ffdd8bf2 18%,#ff8453fa 50%,#2a3a5fe0 82%,#0000);width:190vmax;height:2px;animation:.98s cubic-bezier(.16,1,.3,1) both horizon-wiper;position:fixed;bottom:0;left:50%;transform:translate(-50%)rotate(-24deg);box-shadow:0 0 22px #ffb2586b,0 0 2px #ffffffb3}.theme-shifting:after{content:"";aspect-ratio:1;z-index:998;pointer-events:none;transform-origin:50%;background:conic-gradient(from 246deg,#0000 0turn,#ffda7f0f .04turn,#ffc76466 .12turn,#ff845357 .2turn,#f4f0e885 .3turn,#0000 .42turn);border-radius:50%;width:190vmax;animation:.98s cubic-bezier(.16,1,.3,1) both horizon-wiper-wash;position:fixed;bottom:-95vmax;left:50%;transform:translate(-50%)rotate(-24deg)}:root[data-theme=dark].theme-shifting:before{background:linear-gradient(90deg,#0000,#ffc161e6 18%,#80509af0 52%,#070c17fa 82%,#0000);box-shadow:0 0 24px #ff9b5247,0 0 2px #fff6}:root[data-theme=dark].theme-shifting:after{mix-blend-mode:screen;background:conic-gradient(from 246deg,#0000 0turn,#ffb25a0d .04turn,#84529a57 .13turn,#0910209e .28turn,#0910206b .36turn,#0000 .48turn)}body.page-leaving:before{content:"";z-index:998;pointer-events:none;background:linear-gradient(90deg, #ffffff14, transparent 18%), var(--bg);transform-origin:0;animation:.42s cubic-bezier(.65,0,.25,1) both page-cover;position:fixed;inset:0;transform:scaleX(0)}body.page-leaving:after{content:"";z-index:999;pointer-events:none;background:linear-gradient(180deg, transparent, var(--ink) 18%, var(--green) 50%, var(--ink) 82%, transparent);width:2px;animation:.42s cubic-bezier(.65,0,.25,1) both page-edge;position:fixed;top:0;bottom:0;left:0;transform:translate(-2px);box-shadow:0 0 10px #16a66a38}body.page-leaving :is(main,.site-footer){animation:.42s cubic-bezier(.65,0,.25,1) both route-content-out}body.page-leaving[data-route-transition=post]:before,body.page-leaving[data-route-transition=post]:after{display:none}body.page-leaving[data-route-transition=tag]:before{background:radial-gradient(circle at var(--route-x,50vw) var(--route-y,50vh), #16a66a29, transparent 18%), var(--bg);clip-path:circle(0 at var(--route-x,50vw) var(--route-y,50vh));animation:.28s cubic-bezier(.65,0,.25,1) both page-tag-cover;transform:none}body.page-leaving[data-route-transition=tag]:after{display:none}body.page-leaving[data-route-transition=tag] :is(main,.site-footer){animation:.28s cubic-bezier(.65,0,.25,1) both route-content-tag-out}body.page-leaving[data-route-transition=back]:before{transform-origin:100%;animation-name:page-cover-back;transform:scaleX(0)}body.page-leaving[data-route-transition=back]:after{animation-name:page-edge-back;left:auto;right:0;transform:translate(2px)}.route-entering body:before{content:"";z-index:998;pointer-events:none;background:linear-gradient(90deg, transparent 82%, #ffffff14), var(--bg);transform-origin:100%;animation:.42s cubic-bezier(.65,0,.25,1) both page-reveal;position:fixed;inset:0;transform:scaleX(1)}.route-entering body:after{content:"";z-index:999;pointer-events:none;background:linear-gradient(180deg, transparent, var(--ink) 18%, var(--green) 50%, var(--ink) 82%, transparent);width:2px;animation:.42s cubic-bezier(.65,0,.25,1) both page-reveal-edge;position:fixed;top:0;bottom:0;right:0;transform:translate(2px);box-shadow:0 0 10px #16a66a38}.route-entering body :is(main,.site-footer){animation:.42s cubic-bezier(.65,0,.25,1) both route-content-in}.route-entering[data-route-transition=post] body:before,.route-entering[data-route-transition=post] body:after{display:none}body.page-leaving[data-route-transition=post] :is(main,.site-footer){animation:.26s cubic-bezier(.65,0,.25,1) both route-content-out-up}.route-entering[data-route-transition=post] body :is(main,.site-footer){animation:.56s cubic-bezier(.16,1,.3,1) both route-content-in-up}.route-entering[data-route-transition=tag] body:before{background:radial-gradient(circle at var(--route-x,50vw) var(--route-y,50vh), #16a66a29, transparent 18%), var(--bg);transform-origin:50%;clip-path:circle(140% at var(--route-x,50vw) var(--route-y,50vh));animation:.3s cubic-bezier(.65,0,.25,1) both page-tag-reveal;transform:none}.route-entering[data-route-transition=tag] body:after{display:none}.route-entering[data-route-transition=tag] body :is(main,.site-footer){animation:.3s cubic-bezier(.65,0,.25,1) both route-content-tag-in}.route-entering[data-route-transition=back] body:before{transform-origin:0;animation-name:page-reveal-back}.route-entering[data-route-transition=back] body:after{animation-name:page-reveal-edge-back;left:0;right:auto;transform:translate(-2px)}body.page-leaving[data-route-transition=back] :is(main,.site-footer){animation-name:route-content-out-back}.route-entering[data-route-transition=back] body :is(main,.site-footer){animation-name:route-content-in-back}@keyframes horizon-wiper{0%{opacity:0;transform:translate(-50%)rotate(-22deg)}18%,82%{opacity:1}to{opacity:0;transform:translate(-50%)rotate(202deg)}}@keyframes horizon-wiper-wash{0%{opacity:0;transform:translate(-50%)rotate(-22deg)}22%{opacity:.88}82%{opacity:.58}to{opacity:0;transform:translate(-50%)rotate(202deg)}}@keyframes page-cover{to{transform:scaleX(1)}}@keyframes route-content-out{to{transform:translate(-24px)}}@keyframes route-content-in{0%{transform:translate(28px)}to{transform:translate(0)}}@keyframes page-edge{to{transform:translate(100vw)}}@keyframes page-cover-up{to{transform:scaleY(1)}}@keyframes page-edge-up{to{transform:translateY(-100vh)}}@keyframes route-content-out-up{to{transform:translateY(-22px)}}@keyframes route-content-in-up{0%{transform:translateY(84px)}to{transform:translateY(0)}}@keyframes page-tag-cover{to{clip-path:circle(140% at var(--route-x,50vw) var(--route-y,50vh))}}@keyframes route-content-tag-out{to{transform:scale(.992)}}@keyframes route-content-tag-in{0%{transform:scale(.992)}to{transform:scale(1)}}@keyframes page-cover-back{to{transform:scaleX(1)}}@keyframes page-edge-back{to{transform:translate(-100vw)}}@keyframes route-content-out-back{to{transform:translate(24px)}}@keyframes route-content-in-back{0%{transform:translate(-28px)}to{transform:translate(0)}}@keyframes page-reveal{to{transform:scaleX(0)}}@keyframes page-reveal-edge{to{transform:translate(-100vw)}}@keyframes page-reveal-up{to{transform:scaleY(0)}}@keyframes page-reveal-edge-up{to{transform:translateY(100vh)}}@keyframes page-tag-reveal{to{clip-path:circle(0 at var(--route-x,50vw) var(--route-y,50vh))}}@keyframes page-reveal-back{to{transform:scaleX(0)}}@keyframes page-reveal-edge-back{to{transform:translate(100vw)}}}.page-head{max-width:760px;margin-bottom:36px}.profile-intro{white-space:pre-line}.page-head h1{margin-bottom:18px}.side-index,.toc{border-left:1px solid var(--line);padding-left:22px;position:sticky;top:24px}.side-index h2,.toc h2{font-size:1.1rem}.article{min-width:0}.article-head{border-bottom:1px solid var(--line);margin-bottom:36px;padding:26px 0 36px}.article-back{margin-bottom:22px}.article-head h1{max-width:12ch;margin-bottom:18px}.article-head p{max-width:720px;color:var(--muted);font-size:1.15rem}.article-head .tag-row{padding:0}.article-actions{flex-wrap:wrap;align-items:center;gap:12px;margin:18px 0;display:flex}.article-actions button{border:1px solid var(--ink);color:var(--ink);cursor:pointer;background:0 0;padding:6px 10px;font-weight:800}.article-actions button:hover{background:var(--ink);color:var(--bg)}.prose{max-width:760px}.prose h2{margin:2.2em 0 .7em}.prose h3{margin:1.8em 0 .55em}.prose p,.prose li{color:var(--prose)}.prose code{background:var(--code-bg);padding:.1em .25em}.prose pre{background:var(--ink);color:var(--bg);padding:18px;overflow:auto}.prose pre code{background:0 0;padding:0}.prose figure{margin:2rem 0}.prose figcaption{color:var(--muted);margin-top:.5rem;font-size:.92rem}.prose iframe{border:1px solid var(--line);background:var(--surface);width:100%}.slide-deck{margin:2rem 0}.slide-frame{border:1px solid var(--line);background:var(--surface);width:100%;padding-top:56.25%;position:relative}.slide-frame-4x3{padding-top:75%}.slide-frame iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.article-nav{border-top:1px solid var(--line);grid-template-columns:1fr 1fr;gap:14px;margin-top:48px;padding-top:24px;display:grid}.article-nav a,.article-nav-empty{border:1px solid var(--line);background:var(--surface);min-height:110px;padding:16px;text-decoration:none}.article-nav a:hover{border-color:var(--ink)}.article-nav span{color:var(--red);text-transform:uppercase;margin-bottom:8px;font-size:.85rem;font-weight:900;display:block}.article-nav strong{line-height:1.25;display:block}.article-nav-next{text-align:right}.toc ol{margin:0;padding:0;list-style:none}.toc li{margin-bottom:8px}.toc .depth-3{padding-left:14px}.project-list{gap:18px;margin-top:18px;display:grid}.project-item{border:1px solid var(--line);background:var(--surface);color:inherit;grid-template-columns:220px minmax(0,1fr);align-items:stretch;gap:22px;text-decoration:none;display:grid}.project-item:hover{border-color:var(--ink)}.project-item img,.project-placeholder{object-fit:cover;background:var(--ink);width:100%;height:100%;min-height:180px;color:var(--bg)}.project-placeholder{place-items:center;font-weight:900;display:grid}.project-body{padding:22px 22px 22px 0}.project-body p{color:var(--muted);margin-bottom:0}.skill-list{flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none;display:flex}.skill-list li{border:1px solid var(--line);background:var(--surface);padding:6px 10px}.about-layout{gap:18px;display:grid}.profile-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;display:grid}.profile-summary p{margin-bottom:8px}.empty-state{border:1px solid var(--line);background:var(--surface);padding:24px}.not-found{align-content:center;min-height:58vh;display:grid}.not-found p{max-width:640px;color:var(--muted)}.site-footer{width:min(var(--max), calc(100% - 48px));border-top:1px solid var(--line);color:var(--muted);grid-template-columns:minmax(0,1fr) auto auto;align-items:start;gap:24px;margin:24px auto 0;padding:28px 0 40px;display:grid}.site-footer strong{color:var(--ink)}.site-footer p{margin-bottom:0}.site-footer nav{flex-wrap:wrap;gap:8px;display:flex}.site-footer a{border:1px solid var(--line);background:var(--surface);min-height:34px;color:var(--ink);text-align:center;box-shadow:3px 3px 0 var(--line);justify-content:center;align-items:center;padding:5px 10px;font-weight:800;line-height:1.2;text-decoration:none;transition:background .14s,color .14s,border-color .14s,box-shadow .14s,transform .14s;display:inline-flex}.site-footer a:hover{border-color:var(--ink);background:var(--ink);color:var(--bg);box-shadow:5px 5px 0 var(--ink);transform:translate(-2px,-2px)}.site-footer a:focus-visible,.button:focus-visible{outline:3px solid var(--focus);outline-offset:2px}@media (width<=860px){h1{max-width:none;font-size:3rem}h2{font-size:1.6rem}.site-header{flex-direction:column;align-items:flex-start}.site-nav{flex-wrap:wrap;width:100%;overflow:visible}.header-actions{align-items:flex-start;width:100%}.theme-toggle{flex:none}.section{width:min(var(--max), calc(100% - 32px));padding:34px 0}.home-grid,.blog-layout,.article-layout,.project-item,.profile-summary,.search-panel,.article-nav{grid-template-columns:1fr}.split-heading{flex-direction:column;align-items:flex-start;gap:12px}.split-heading .button{width:auto}.site-footer nav{gap:6px;width:100%}.site-footer a{flex:none;min-height:32px;padding:4px 9px;font-size:.92rem}.home-grid{min-height:auto}.lead{font-size:1.1rem}.home-work{padding-top:30px}.home-post-list{gap:8px;margin-top:14px}.home-post-item{padding:14px}.home-post-item strong{font-size:1rem}.pagination{margin-top:18px}.pagination a,.pagination span{min-width:34px;min-height:34px}.side-index,.toc{border-left:none;padding-left:0;position:static}.post-card-featured h2{font-size:1.8rem}.project-body{padding:0 18px 18px}.site-footer{width:min(var(--max), calc(100% - 32px));grid-template-columns:1fr}}
