: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%}.site-shell{width:min(100% - 2rem,720px);margin:0 auto;padding:3rem 0 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-footer{margin-top:5rem;padding-top:1.4rem;border-top:1px solid var(--line);font-size:.78rem}.site-footer a{color:var(--muted);text-decoration:none}.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.8rem,5vw,3rem);line-height:1.2}.lead{margin-top:2rem;color:#333;font-size:clamp(1.08rem,2.2vw,1.3rem);line-height:2}.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 2rem}.profile-images img{border:1px solid var(--line);background:#fff}.profile-images img{aspect-ratio:16 / 9;object-fit:cover}.meta-list,.work-list{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}.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}.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}}
