:root{--bg: #FCFBF9;--ink: #151515;--ink-2: #45423e;--ink-3: #847f79;--blue: #002FA7;--hairline: #e8e5e0;--sans: "Inter", "Noto Sans JP", "Helvetica Neue", sans-serif;--maxw: 1024px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.8;font-feature-settings:"palt";-webkit-font-smoothing:antialiased;text-wrap:pretty}::selection{background:var(--blue);color:#fff}.bg-wash{position:fixed;inset:0;width:100%;height:100%;z-index:-1;pointer-events:none;opacity:.6}.bg-wash--wide{display:none}@media(min-aspect-ratio:8 / 5){.bg-wash--narrow{display:none}.bg-wash--wide{display:block}}a{color:inherit;text-decoration:none}.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}.site-header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--hairline)}.site-header .container{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px}.header-right{display:flex;align-items:center;gap:22px}.brand{font-size:15px;font-weight:600;letter-spacing:-.01em}.brand .dot{color:var(--blue)}.site-nav{display:flex;gap:28px}.site-nav a{font-size:13px;letter-spacing:.04em;color:var(--ink-2);transition:color .2s ease}.site-nav a:hover{color:var(--blue)}.site-nav a[aria-current=page]{color:var(--blue);font-weight:500}.site-nav a[aria-current=page]:after{content:"";display:block;height:1px;background:var(--blue);margin-top:1px}.menu-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:34px;height:30px;padding:6px 7px;background:none;border:none;cursor:pointer}.menu-btn span{display:block;height:1px;background:var(--ink);transition:transform .2s ease}.menu-btn[aria-expanded=true] span:first-child{transform:translateY(3px) rotate(45deg)}.menu-btn[aria-expanded=true] span:last-child{transform:translateY(-3px) rotate(-45deg)}.menu-panel{position:absolute;top:calc(100% + 1px);right:max(20px,calc((100vw - var(--maxw)) / 2));background:var(--bg);border:1px solid var(--hairline);padding:18px 24px;display:flex;flex-direction:column;gap:13px;min-width:220px}.menu-panel[hidden]{display:none}.menu-panel a{display:flex;align-items:baseline;gap:12px;font-size:13px;color:var(--ink-2);transition:color .2s ease}.menu-panel a:hover{color:var(--blue)}.menu-panel .pi-num{font-size:10px;color:var(--blue);font-variant-numeric:tabular-nums;letter-spacing:.1em}@media(min-width:1340px){.menu-btn,.menu-panel{display:none}}.section{display:grid;grid-template-columns:112px 1fr;column-gap:40px;padding:104px 0;border-top:1px solid var(--hairline);scroll-margin-top:64px}.section:first-of-type{border-top:none}.sec-num{font-size:13px;font-weight:500;letter-spacing:.12em;color:var(--blue);font-variant-numeric:tabular-nums;padding-top:10px}.sec-head{margin-bottom:48px}.sec-title{font-size:clamp(28px,4.2vw,44px);font-weight:700;letter-spacing:.01em;line-height:1.3}.sec-title-en{display:block;margin-top:6px;font-size:12px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}.page-index{position:fixed;right:36px;top:50%;transform:translateY(-50%);display:none;flex-direction:column;gap:18px;z-index:5}.page-index a{display:flex;align-items:baseline;gap:10px;font-size:11.5px;letter-spacing:.06em;color:var(--ink-3);transition:color .2s ease}.page-index .pi-num{font-size:10px;font-variant-numeric:tabular-nums;letter-spacing:.1em}.page-index a:hover,.page-index a.active{color:var(--blue)}@media(min-width:1340px){.page-index{display:flex}}.caption-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px 48px}.caption .cap-rule{width:22px;height:1px;background:var(--blue);margin-bottom:14px}.caption .cap-label{font-size:13px;font-weight:600;letter-spacing:.06em;line-height:1.5}.caption .cap-label-en,.tech-group .cap-label-en{display:block;font-size:10.5px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-top:2px;margin-bottom:12px}.caption .cap-value{font-size:14px;color:var(--ink-2);line-height:2}.caption .cap-value strong{color:var(--ink);font-weight:500}.hero{min-height:100vh;min-height:100svh;padding:0;align-content:center}.hero-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:56px}.hero-text{flex:1;min-width:0}.hero-portrait{flex:none;width:clamp(132px,17vw,196px);aspect-ratio:1;border-radius:50%;object-fit:cover;margin-top:34px}.hero-kicker{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-bottom:28px}.hero-name{font-size:clamp(60px,11vw,124px);font-weight:600;letter-spacing:-.035em;line-height:1.02}.hero-name .dot{color:var(--blue)}.hero-role{margin-top:36px;font-size:17px;font-weight:500}.hero-role-en{display:block;font-size:12px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-top:4px}.hero-lead{margin-top:28px;max-width:36em;font-size:15px;color:var(--ink-2)}.hero-lead-en{display:block;font-size:12.5px;color:var(--ink-3);margin-top:4px;letter-spacing:.02em}.hero-links{display:flex;flex-wrap:wrap;gap:10px 28px;margin-top:44px}.ext-link{font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--ink);border-bottom:1px solid var(--hairline);padding-bottom:2px;transition:color .2s ease,border-color .2s ease}.ext-link .arrow{color:var(--ink-3);transition:color .2s ease}.ext-link:hover{color:var(--blue);border-color:var(--blue)}.ext-link:hover .arrow{color:var(--blue)}.caption--wide{grid-column:1 / -1}.cert-list{list-style:none;max-width:520px}.cert-list li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;font-size:14px;color:var(--ink-2);border-bottom:1px solid var(--hairline);padding:9px 0}.cert-list .cert-year{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.06em;white-space:nowrap}.about-note{margin-top:56px;padding-top:32px;border-top:1px solid var(--hairline);max-width:44em;font-size:14px;color:var(--ink-2)}.tech-groups{display:flex;flex-direction:column;gap:40px}.tech-group .cap-rule{width:22px;height:1px;background:var(--blue);margin-bottom:14px}.tech-list{list-style:none;display:flex;flex-wrap:wrap;gap:12px 14px;margin-top:18px}.tech-item{display:inline-flex;align-items:center;gap:9px;padding:8px 14px;border:1px solid var(--hairline);border-radius:3px;transition:border-color .2s ease}.tech-item:hover{border-color:color-mix(in srgb,var(--ink-3) 60%,transparent)}.tech-icon{width:17px;height:17px;color:var(--ink-2);flex:none}.tech-icon--none{display:inline-block;border-radius:50%;background:var(--hairline)}.tech-name{font-size:13px;color:var(--ink-2);letter-spacing:.01em}.year-group{border-top:1px solid var(--hairline)}.year-group:last-of-type{border-bottom:1px solid var(--hairline)}.year-group summary{list-style:none;cursor:pointer;display:flex;align-items:baseline;gap:18px;padding:22px 0;user-select:none}.year-group summary::-webkit-details-marker{display:none}.year-num{font-size:19px;font-weight:600;letter-spacing:.02em;font-variant-numeric:tabular-nums}.year-count{font-size:12px;color:var(--ink-3);letter-spacing:.08em}.year-toggle{margin-left:auto;font-size:15px;font-weight:400;color:var(--ink-3);transition:color .2s ease;line-height:1}.year-group summary:hover .year-toggle,.year-group summary:hover .year-num{color:var(--blue)}.year-group .toggle-close,.year-group[open] .toggle-open{display:none}.year-group[open] .toggle-close{display:inline}.timeline-entries{padding:4px 0 30px}.tl-entry{display:grid;grid-template-columns:76px 1fr;column-gap:46px;align-items:baseline;position:relative;padding:11px 0}.tl-entry:before{content:"";position:absolute;left:92px;top:0;bottom:0;width:1px;background:var(--hairline)}.tl-entry:first-child:before{top:22px}.tl-entry:last-child:before{bottom:auto;height:22px}.tl-entry:only-child:before{display:none}.tl-entry:after{content:"";position:absolute;left:89.5px;top:19px;width:6px;height:6px;border-radius:50%;background:var(--bg);border:1px solid var(--ink-3)}.tl-date{font-size:12.5px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.04em}.tl-body{font-size:14px}.tl-body .tl-sub{display:block;font-size:12px;color:var(--ink-3);margin-top:1px}.tl-body a{border-bottom:1px solid var(--hairline);transition:color .2s ease,border-color .2s ease}.tl-body a:hover{color:var(--blue);border-color:var(--blue)}.contact-mail{font-size:clamp(22px,3.4vw,34px);font-weight:600;letter-spacing:-.01em;border-bottom:1px solid var(--hairline);padding-bottom:4px;transition:color .2s ease,border-color .2s ease}.contact-mail:hover{color:var(--blue);border-color:var(--blue)}.contact-note{margin-top:20px;font-size:13px;color:var(--ink-2)}.contact-links{display:flex;flex-wrap:wrap;gap:10px 28px;margin-top:40px}.work{display:grid;grid-template-columns:88px 1fr 224px;column-gap:40px;padding:44px 0;border-top:1px solid var(--hairline)}.work:last-of-type{border-bottom:1px solid var(--hairline)}.work-media{width:224px;height:140px;align-self:start;margin-top:5px;object-fit:cover;border:1px solid var(--hairline)}.work-media--placeholder{display:flex;align-items:center;justify-content:center;border:1px solid var(--hairline);color:var(--ink-3);font-size:11px;letter-spacing:.08em}.work-no{font-size:12px;font-weight:500;letter-spacing:.12em;color:var(--blue);font-variant-numeric:tabular-nums;padding-top:5px}.work-head{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}.work-title{font-size:21px;font-weight:600;letter-spacing:0}.work-year{font-size:12.5px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.06em}.work-tech{margin-top:8px;font-size:12px;letter-spacing:.05em;color:var(--ink-3)}.work-desc{margin-top:12px;font-size:14px;color:var(--ink-2);max-width:42em}.work-links{display:flex;gap:24px;margin-top:18px}.writing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:52px 44px}.writing-card{display:block}.writing-thumb{display:block;width:100%;aspect-ratio:1.91 / 1;border:1px solid var(--hairline);overflow:hidden}.writing-thumb img{width:100%;height:100%;object-fit:cover;display:block}.writing-meta{display:flex;align-items:baseline;gap:14px;margin-top:16px}.writing-date{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.06em}.badge{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--hairline);border-radius:2px;padding:1px 8px;line-height:1.7}.writing-title{display:block;font-size:14.5px;font-weight:500;line-height:1.7;margin-top:8px;transition:color .2s ease}.writing-title:hover{color:var(--blue)}.writing-title .arrow{color:var(--ink-3);font-size:12px;margin-left:6px}.site-footer{border-top:1px solid var(--hairline);padding:36px 0 48px}.site-footer .container{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap}.footer-copy{font-size:12px;color:var(--ink-3);letter-spacing:.06em}.kari{font-size:.78em;font-weight:400;color:var(--ink-3);letter-spacing:.02em;white-space:nowrap}.kari-note{margin-top:14px;font-size:11.5px;color:var(--ink-3);letter-spacing:.04em}@media(prefers-reduced-motion:no-preference){html.js .fade{opacity:0;transform:translateY(10px);transition:opacity .7s ease,transform .7s ease}html.js .fade.in{opacity:1;transform:none}}@media(max-width:900px){.work{grid-template-columns:88px 1fr;row-gap:16px}.work-media{grid-column:2;width:100%;max-width:400px;height:auto;aspect-ratio:16 / 10;margin-top:6px}}@media(max-width:760px){.section{grid-template-columns:1fr;row-gap:18px;padding:72px 0}.sec-num{padding-top:0}.sec-head{margin-bottom:36px}.hero{padding:88px 0 96px}.hero-inner{flex-direction:column-reverse;gap:32px}.hero-portrait{width:104px;margin-top:0}.tl-entry{grid-template-columns:64px 1fr;column-gap:38px}.tl-entry:before{left:78px}.tl-entry:after{left:75.5px}.work{grid-template-columns:1fr;row-gap:12px;padding:36px 0}.work-media{grid-column:1;margin-top:4px}.writing-grid{grid-template-columns:1fr;gap:44px}}@media(max-width:480px){body{font-size:14px}.container{padding:0 20px}.section{padding:56px 0}.hero{padding:64px 0 72px}.hero-links{gap:10px 20px}.caption-grid{gap:32px}.tl-entry{grid-template-columns:56px 1fr;column-gap:32px}.tl-entry:before{left:68px}.tl-entry:after{left:65.5px}.menu-panel{left:20px;right:20px}}:where([data-astro-image]){object-fit:var(--fit);object-position:var(--pos);height:auto}:where([data-astro-image=full-width]){width:100%}:where([data-astro-image=constrained]){max-width:100%}
