:root{color-scheme:light;--bg: #fff;--text: #111;--muted: #777;--line: #e5e5e5;--accent: #8421dd;--accent-soft: #f7f7f7}html,body{margin:0;min-height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans JP,Meiryo,sans-serif;font-size:16px;line-height:1.7;text-rendering:optimizeLegibility}*{box-sizing:border-box}::selection{background:#eee}a{color:var(--accent);text-underline-offset:.18em;text-decoration-thickness:1px}a:hover{color:#cc8ef7}p{margin:0 0 1.4rem}ul,ol{margin:0;padding:0}img{display:block;max-width:100%}::view-transition-group(*){animation-duration:.42s;animation-timing-function:cubic-bezier(.22,1,.36,1)}::view-transition-old(*),::view-transition-new(*){animation-duration:inherit;animation-timing-function:inherit;mix-blend-mode:normal}::view-transition-image-pair(*){isolation:isolate}.site-shell{width:min(100% - 2rem,720px);margin:0 auto;padding:3rem 0 3.2rem}.site-shell--top{min-height:100vh;width:min(100% - 2rem,420px);padding-top:clamp(4rem,16vh,9rem)}.site-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:clamp(3.5rem,10vw,7rem);font-size:.82rem;letter-spacing:0}.site-title{color:var(--text);text-decoration:none}.site-header nav{display:flex;gap:1rem}.site-header nav a{color:var(--muted);text-decoration:none}.site-header nav a:hover{color:var(--accent)}.site-header nav a.site-nav-link--current{text-decoration:underline}.hero{max-width:620px}.eyebrow{margin:0 0 .9rem;color:var(--muted);font-size:.78rem}h1,h2{margin:0;font-weight:500;letter-spacing:0}h1{font-size:clamp(2rem,6vw,3rem);line-height:1.1}h2{margin-bottom:2rem;font-size:clamp(1.55rem,4vw,2.35rem);line-height:1.2}.lead{margin-top:2rem;color:#333;font-size:clamp(1.08rem,2.2vw,1.3rem);line-height:2}.home-title{text-align:center;font-size:clamp(1.55rem,4vw,2.15rem)}.home-links{display:grid;gap:0;margin-top:2.4rem;list-style:none}.home-links a{display:block;padding:.62rem 0;border-bottom:1px solid var(--line);color:var(--text);text-decoration:none}.home-links a:hover{color:var(--accent)}.home-links span{color:var(--muted);font-size:.78rem}.external-links{display:flex;flex-wrap:wrap;gap:.45rem 1rem;margin-top:2rem;list-style:none;font-size:.86rem}.external-links a{color:var(--muted);text-decoration:none}.external-links a:hover{color:var(--accent)}.page{max-width:620px}.profile-heading{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.profile-heading img{flex:0 0 auto;border:1px solid var(--line);border-radius:50%}.profile-heading h2{margin-bottom:.2rem}.profile-heading p{margin:0;color:var(--muted);font-size:.88rem}.profile-images{margin:0 0 .8rem}.profile-images img{border:1px solid var(--line);background:#fff}.profile-images img{aspect-ratio:16 / 9;object-fit:cover}.meta-list,.work-list,.thing-grid{list-style:none}.meta-list{margin:0 0 2rem;color:var(--muted);font-size:.88rem}.favorite-section{margin-top:2rem;color:var(--muted);font-size:.88rem}.favorite-section dl{display:grid;gap:.6rem;margin:0}.favorite-section div{display:grid;grid-template-columns:2.6rem minmax(0,1fr);gap:.75rem}.favorite-section dt,.favorite-section dd{margin:0}.favorite-section dt{color:var(--muted)}.work-list{display:grid;gap:0}.work-item{display:flex;align-items:baseline;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line)}.work-year{flex:0 0 4.2rem;color:var(--muted);font-size:1rem;line-height:1.7}.work-content{flex:1 1 auto;min-width:0;font-size:1rem;line-height:1.7}.work-kind{display:inline-block;width:1rem;height:1rem;margin-right:.55rem;color:#aaa;line-height:1;vertical-align:-.12em}.work-kind svg{display:block;width:100%;height:100%;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.work-title{display:inline}.work-note{margin-left:.35rem;color:var(--muted);font-size:.84rem}.work-links{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.18rem;font-size:.84rem}.thing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.7rem;margin-top:2rem}.things-index-page{max-width:none}.thing-thumb{display:block;aspect-ratio:1;overflow:hidden;color:inherit;text-decoration:none}.thing-thumb img{width:100%;height:100%;border:1px solid var(--line);background:var(--accent-soft);object-fit:cover;object-position:center;transition:border-color .16s ease,opacity .16s ease}.thing-thumb:hover img{border-color:#bbb}.thing-transition-loader{position:fixed;top:var(--loader-top);left:var(--loader-left);z-index:1000;display:grid;place-items:center;width:var(--loader-width);height:var(--loader-height);background:#ffffff5c;opacity:0;pointer-events:none;transition:opacity .12s ease;view-transition-name:none}.thing-transition-loader:after{display:block;width:1.8rem;height:1.8rem;border:2px solid rgb(255 255 255 / .78);border-top-color:var(--accent);border-radius:50%;animation:thing-thumb-spinner .72s linear infinite;content:""}.thing-transition-loader.is-visible{opacity:1}@keyframes thing-thumb-spinner{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.thing-transition-loader:after{animation:none}}.back-button{display:inline-flex;align-items:center;gap:.35rem;min-height:2.2rem;margin-bottom:1.4rem;padding:.25rem .7rem .25rem .55rem;border:1px solid var(--line);border-radius:999px;background:var(--bg);color:var(--text);font-size:.86rem;text-decoration:none}.back-button svg{width:1rem;height:1rem;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.back-button:hover{background:var(--accent-soft);color:var(--accent)}.thing-detail-page{max-width:none;margin-right:auto;margin-left:auto}.thing-detail-image-frame{width:min(100%,720px,var(--thing-image-max-width-by-height));aspect-ratio:1;margin:0 auto 2rem;overflow:hidden;transition:aspect-ratio .52s cubic-bezier(.22,1,.36,1)}.thing-detail-image{width:100%;height:100%;object-fit:cover;object-position:center}.thing-detail-image-frame.is-expanded{aspect-ratio:var(--thing-image-aspect)}.thing-detail-image-frame.is-expanded .thing-detail-image{object-fit:cover}.thing-detail-title{margin-bottom:1rem;font-size:clamp(1.45rem,3.2vw,2rem);line-height:1.28}.thing-comment{color:#333;font-size:.94rem}.thing-comment--detail{max-width:42rem}.thing-comment iframe{display:block;width:min(100%,560px);aspect-ratio:16 / 9;height:auto;margin-top:1.4rem}.thing-comment p:last-child{margin-bottom:0}.empty-note{color:var(--muted)}.actions{display:flex;flex-wrap:wrap;gap:.7rem;margin:2rem 0}.button{display:inline-flex;align-items:center;min-height:2.5rem;padding:.4rem .9rem;border:1px solid var(--line);border-radius:999px;background:var(--bg);color:var(--text);font-size:.86rem;text-decoration:none}.button:hover{background:var(--accent-soft);color:var(--accent)}.product-image{margin:2rem 0;border:1px solid var(--line)}.quiet-section{margin-top:2.6rem}.quiet-section h2{margin-bottom:1rem;font-size:.92rem}.quiet-section ul{padding-left:1.3rem}@media (max-width: 560px){body{font-size:15px}.site-shell{width:min(100% - 1.3rem,720px);padding-top:1.4rem}.site-shell--top{width:min(100% - 1.3rem,420px);padding-top:4rem}.home-links{margin-top:2.9rem}.site-header{align-items:flex-start;margin-bottom:3rem}.profile-heading{gap:.8rem}.profile-heading img{width:60px;height:60px}.work-item{gap:.7rem}.work-year{flex-basis:3.4rem}.thing-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
