@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/55c55f0601d81cf3-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/26a46d62cd723877-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/97e0cb1ae144a2a9-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/581909926a08bbc8-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_e8ce0c{font-family:Inter,Inter Fallback;font-style:normal}.__variable_e8ce0c{--font-inter:"Inter","Inter Fallback"}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/3f69592b2fe603c7-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/6325a8417175c41d-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/021bc4481ed92ece-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/99b7f73d5af7c3e2-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/4f05ba3a6752a328-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Montserrat Fallback;src:local("Arial");ascent-override:85.79%;descent-override:22.25%;line-gap-override:0.00%;size-adjust:112.83%}.__className_4bc053{font-family:Montserrat,Montserrat Fallback;font-style:normal}.__variable_4bc053{--font-montserrat:"Montserrat","Montserrat Fallback"}

/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.relative{position:relative}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}:root{--background:#fff;--foreground:#171717}html.lock--loader,html.lock--mv{overscroll-behavior:none;height:100%;overflow:hidden}body.lock--loader,body.lock--mv{overscroll-behavior:none;width:100%;height:100%;position:fixed;top:0;left:0;right:0;overflow:hidden!important}body{font-family:var(--font-inter),var(--font-montserrat),sans-serif;letter-spacing:.05em;color:#f1f5f9;font-size:15px}a{color:#1ca9e3;text-decoration:none;transition:opacity .3s}img{vertical-align:bottom;border-style:none;max-width:100%;height:auto}.pc-only{display:block}.sp-only{display:none}main{background:#222}.section{padding-top:90px}.section:last-of-type{padding-bottom:90px}.cmn-container{max-width:1280px;margin:0 auto;padding:0 40px}.works.section.is-sub .cmn-container{padding:0}.fade-in{opacity:0;transition:opacity .6s ease-out,transform .6s ease-out;transform:translateY(50px)}.fade-in.active{opacity:1;transform:translateY(0)}.loader__backdrop{z-index:9999;background:#222;place-items:center;animation:loaderFadeIn .3s ease-out;display:grid;position:fixed;inset:0}@keyframes loaderFadeIn{0%{opacity:0}to{opacity:1}}.loader__wrap{place-items:center;gap:16px;display:grid}.loader__ringWrap{width:220px;height:220px;position:relative}.loader__ring{display:block}.loader__char{z-index:2;pointer-events:none;width:100%;height:100%;shape-rendering:geometricPrecision;position:absolute;inset:0}.loader__percent{letter-spacing:1.5px;color:#f1f5f9;-webkit-user-select:none;user-select:none;margin-top:8px;font-size:20px}.title{letter-spacing:.05em;line-height:1}.title-jp{background:linear-gradient(#8e9eab,#eef2f3);-webkit-background-clip:text;margin-bottom:8px;font-size:16px;display:inline-block}.title-en,.title-jp{-webkit-text-fill-color:transparent}.title-en{background:linear-gradient(#eef2f3,#8e9eab 94%);-webkit-background-clip:text;margin-bottom:40px;font-size:48px;font-weight:700;display:block}.lead{text-align:center;margin-bottom:30px;font-size:16px;line-height:1.8}.app-booting .header,.lock--loader .header{display:none}.header{z-index:100;width:100%;transition:background-color .3s;position:fixed;top:0}.header.scrolled{background-color:#21212180}.header .inner{justify-content:space-between;align-items:center;padding:20px 48px;display:flex}.header-logo{letter-spacing:.05em;font-size:24px;font-weight:700;line-height:1.5}.header-logo a{color:#f1f5f9}.header .gnav-list{justify-content:space-between;gap:32px;list-style:none;display:flex}.header .gnav-item a{letter-spacing:.05em;color:#f1f5f9;font-size:16px;transition:all .3s;display:inline-block;position:relative}.header .gnav-item a:after{content:"";background-color:#f1f5f9;width:0;height:1px;transition:all .3s;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.header .gnav-item a:hover:after{width:100%}.hamburger-menu{display:none}.gnav{display:flex}.sp-menu{display:none}.mv{text-align:center;z-index:1;background-color:#222;justify-content:center;align-items:center;height:auto;display:flex;position:relative;overflow:hidden}.mv,.mv .mv-container{background-color:#222;height:100svh}.mv .mv-container{z-index:2;width:100%;height:100%;position:relative}.mv .mv-container .mv-bg{z-index:1;position:absolute;inset:0}.mv .mv-container .mv-bg .mv-container-video{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .9s ease-out;position:absolute;inset:0}.mv .mv-container .mv-bg .mv-container-video.is-visible{opacity:1}.mv .mv-container .mv-title{z-index:5;pointer-events:none;justify-content:center;align-items:center;margin:0;display:flex;position:absolute;inset:0}.mv .mv-container .mv-title .mv-letters{color:#f1f5f9;letter-spacing:.04em;gap:0;font-size:min(80px,6.25vw);font-weight:600;line-height:1;display:inline-flex}.mv .mv-container .mv-title .mv-letters .mv-letter{opacity:0;will-change:transform,opacity;transition:transform .6s cubic-bezier(.2,.65,.2,1),opacity .6s cubic-bezier(.2,.65,.2,1);display:inline-block;transform:translateY(60px)}.mv .mv-container .mv-title .mv-letters.is-on .mv-letter{opacity:1;transform:translateY(0)}.mv .mv-container .mv-title .sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;position:absolute!important}@media (prefers-reduced-motion:reduce){.mv .mv-container .mv-title .mv-letters .mv-letter{opacity:1!important;transition:none!important;transform:none!important}}.mv .mv-container .mv-text{color:#f1f5f9;z-index:3;width:100%;position:absolute;top:58%;left:50%;transform:translate(-50%)}.mv .mv-container .mv-text .mv-sub{color:#f1f5f9;letter-spacing:.1rem;opacity:0;font-size:min(28px,2.2vw);line-height:1.5;transition:opacity .6s ease-out,transform .6s ease-out;transform:translateY(32px)}.mv .mv-container .mv-text .mv-sub.is-visible{opacity:1;transform:translateY(0)}.mv .mv-container .mv-scroll{left:50%;bottom:max(24px,calc(16px + env(safe-area-inset-bottom)));z-index:4;opacity:0;transform-origin:50%;pointer-events:none;flex-direction:column;align-items:center;gap:10px;transition:opacity .6s,transform .6s;display:flex;position:absolute;transform:translate(-50%)}.mv .mv-container .mv-scroll.is-visible{opacity:1}.mv .mv-container .mv-scroll__label{text-transform:lowercase;color:#f1f5f9;-webkit-user-select:none;user-select:none;font-size:16px}.mv .mv-container .mv-scroll__line{--barH:24px;background:#64748b;width:1px;height:100px;position:relative;overflow:hidden}.mv .mv-container .mv-scroll__line:before{content:"";left:0;top:calc(var(--barH)*-1);width:100%;height:var(--barH);background:#f1f5f9;animation:mvScrollRun 1.8s cubic-bezier(.2,.65,.2,1) infinite;position:absolute;box-shadow:0 0 10px #f1f5f98c}@keyframes mvScrollRun{0%{top:calc(var(--barH)*-1);opacity:0}10%{opacity:1}90%{opacity:1}to{opacity:0;top:100%}}.works-list{flex-wrap:wrap;justify-content:space-between;width:100%;margin:0 auto;padding:0;display:flex}.works-list .works-item{flex:0 30%}.works.section.is-sub .works-list .works-item{flex:0 40%}.works-list .works-item .works-img-wrap{width:100%;display:inline-block;overflow:hidden}.works-list .works-item .works-img-wrap .works-img{width:100%;display:block}.works-list .works-item .works-info{color:#f1f5f9;margin-top:12px}.works-list .works-item .works-info .works-meta{align-items:center;gap:12px;font-size:12px;display:flex}.works-list .works-item .works-info .works-meta .badge{border:1px solid #f1f5f9;border-radius:4px;padding:2px 6px;font-size:12px;display:inline-block}.works-list .works-item .works-info .works-title{margin-top:8px;font-size:16px}.skill-content{justify-content:space-between;align-items:flex-start;margin-bottom:120px;display:flex}.skill-content .chart-container{width:50%}.skill-content .skill-rating{width:45%}.skill-content .skill-rating .skill-rating-item{margin-top:32px}.skill-content .skill-rating .skill-rating-item:first-child{margin-top:0}.skill-content .skill-rating .skill-rating-item .skill-rating-heading{align-items:center;gap:12px;margin-bottom:12px;display:flex}.skill-content .skill-rating .skill-rating-item .skill-rating-heading .skill-rating-number{justify-content:center;width:28px;height:28px;display:flex}.skill-content .skill-rating .skill-rating-item .skill-rating-heading img{width:auto;height:28px}.skill-content .skill-rating .skill-rating-item .skill-rating-heading span{color:#efe0ae;font-size:20px;font-weight:600}.skill-content .skill-rating .skill-rating-item p{font-size:16px}.skill-list{flex-wrap:wrap;margin-bottom:-50px}.skill-item,.skill-list{justify-content:space-between;display:flex}.skill-item{align-items:flex-start;width:48%;margin-bottom:48px}.skill-img{justify-content:center;align-items:center;width:60px;height:auto;margin-right:24px;display:flex}.skill-body{flex:1}.skill-name{-webkit-text-fill-color:transparent;background:linear-gradient(#eef2f3,#8e9eab 94%);-webkit-background-clip:text;margin-bottom:12px;font-size:20px;font-weight:700}.skill-text{font-size:16px}.profile{flex-wrap:wrap;margin:0 auto;display:flex}.profile-img{align-items:center;width:300px;height:100%;margin-right:40px;display:flex}.profile-img img{border-radius:50%}.profile-body{flex:1}.profile-body .profile-detail{white-space:pre-line;font-size:16px;line-height:2}.profile-body .profile-detail:not(:last-child){margin-bottom:32px}.profile-body .profile-name{-webkit-text-fill-color:transparent;background:linear-gradient(#eef2f3,#8e9eab 94%);-webkit-background-clip:text;margin-bottom:24px;font-size:24px;font-weight:700}#form{align-items:center;gap:48px}#form,#form .contact-field{flex-direction:column;display:flex}#form .contact-field{gap:16px;width:640px}#form .contact-field .contact-heading{align-items:center;gap:16px;display:flex}#form .contact-field .contact-heading .contact-label{font-size:20px}#form .contact-field .contact-heading .contact-span{color:#efe0ae;border:1px solid #efe0ae;border-radius:4px;justify-content:center;align-items:center;padding:0 8px;font-size:14px;display:inline-flex}#form .contact-field .contact-form .contact-textarea,#form .contact-field .contact-form .contact-textbox{color:#f1f5f9;border:1px solid #f1f5f9;outline:none;width:100%;padding:16px}#form .contact-field .contact-form .contact-textarea{resize:vertical;height:180px}#form .contact-field .contact-form .contact-textarea::placeholder,#form .contact-field .contact-form .contact-textbox::placeholder{color:#f1f5f9cc}#form .contact-field .contact-form .contact-textarea:focus,#form .contact-field .contact-form .contact-textbox:focus{border-color:#efe0ae}#form .contact-btn-wrap{justify-content:center;display:flex}#form .contact-btn-wrap .contact-submit{color:#efe0ae;cursor:not-allowed;letter-spacing:.1em;background:0 0;border:1px solid #efe0ae;align-items:center;gap:48px;padding:12px 48px;font-size:18px;font-weight:600;transition:background-color .25s,color .25s,border-color .25s,transform 40ms;display:inline-flex}#form .contact-btn-wrap .contact-submit:disabled{opacity:1;pointer-events:none}#form .contact-btn-wrap .contact-submit.is-active{color:#222;cursor:pointer;background:#efe0ae}#form .contact-btn-wrap .contact-submit.is-active:hover{opacity:.8}#form .contact-btn-wrap .contact-submit.is-active:active{transform:translateY(4px)}#form .contact-btn-wrap .contact-submit .contact-submit-icon{display:block}.page-top{cursor:pointer;opacity:0;z-index:50;background:#21212180;border:0;border-radius:50%;width:80px;height:80px;transition:opacity .25s,transform .25s;position:fixed;bottom:24px;right:24px;transform:translateY(8px)}.page-top.show{opacity:1;transform:translateY(0)}.page-top__ring{--size:80px;--radius:36px;--start:-90deg;width:var(--size);height:var(--size);border-radius:50%;place-items:center;animation:pageTop-spin 10s linear infinite;display:grid;position:relative}.page-top__center{letter-spacing:.1em;text-transform:uppercase;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:1;font-size:14px;transform:translate(-50%,-50%)}.page-top__center,.page-top__char{color:#f1f5f9;position:absolute;top:50%;left:50%}.page-top__char{transform-origin:0 0;letter-spacing:0;transform:rotate(calc(var(--start,-90deg) + (1turn/var(--count))*var(--i)))translate(var(--radius,50px))rotate(90deg)translateX(-50%)translateY(-50%);font-size:8px;line-height:1;display:inline-block}@keyframes pageTop-spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.page-top__ring{animation:none}}.footer{background-color:#111;width:100%;padding:20px 48px}.footer .copyright{text-align:center;color:#f1f5f9;font-size:12px}.article{padding:100px 0}.article-body img{width:100%;height:auto}.article-body ul li img{width:40px;margin-right:12px}.article-body ul li a{color:#f1f5f9;cursor:pointer;text-decoration:none}.article-body ul li .github-link{color:#f1f5f9;cursor:pointer;text-decoration:underline;display:inline-block;position:relative}.article .article-container{max-width:1040px;margin:0 auto;padding:0 20px}.article .article-container .article-title{-webkit-text-fill-color:transparent;background:linear-gradient(#eef2f3,#8e9eab 94%);-webkit-background-clip:text;margin-bottom:30px;font-size:32px;font-weight:700;display:block}.article .article-container .article-title.fade-in,.article .article-container .article-title.fade-in.active{transform:none}.article .article-container .article-body{margin:0 auto 80px}.article .article-container .article-body .visit-site{color:#efe0ae;cursor:pointer;letter-spacing:.1em;background:0 0;border:1px solid #efe0ae;align-items:center;gap:48px;margin-top:32px;padding:12px 48px;font-size:18px;font-weight:600;transition:opacity .3s;display:inline-flex}.article .article-container .article-body .visit-site:hover{opacity:.7}.article .article-container .article-body .visit-site .visit-site-icon{width:24px;height:24px;display:block}.article .article-container .article-body ul{margin-top:48px}.article .article-container .article-body ul li{align-items:center;margin-top:24px;list-style:none;display:flex}.article .article-container .article-body ul li:first-of-type{margin-top:0}.article .article-container .article-body ul li .arrow-box{color:#e5e7eb;letter-spacing:.06em;place-items:center;width:129px;height:40px;display:inline-grid;position:relative}.article .article-container .article-body ul li .arrow-box:after{content:"";background:url(/img/works-detail/subtitle-part-icon.svg) 0/contain no-repeat;position:absolute;inset:0}.article .article-container .article-body ul li .arrow-box .arrow-box__label{z-index:1;line-height:40px;position:relative}.article .article-container .article-body .article-part{margin-top:120px}.article .article-container .article-body .article-part h2{-webkit-text-fill-color:transparent;background:linear-gradient(#eef2f3,#8e9eab 94%);-webkit-background-clip:text;margin-bottom:24px;padding-left:1em;font-size:24px;font-weight:700;position:relative}.article .article-container .article-body .article-part h2:before{content:"";background:linear-gradient(#eef2f3,#8e9eab 94%);width:5px;height:100%;position:absolute;top:0;left:0}.article .article-container .article-body .article-part p{font-size:16px;line-height:1.8}.article .article-container .article-body .article-part .views-detail{justify-content:space-between;display:flex}.article .article-container .article-body .article-part .views-detail img{border:1px solid #eef2f3;width:45%}.article .article-container .article-body .article-part .detail{white-space:pre-line;width:45%;margin-top:0}.article .article-container .article-body .overview-list{margin-top:64px}.article .article-container .article-body .overview-list li{gap:16px;margin-bottom:24px;font-size:18px;list-style:none}.article .article-container .article-body .overview-list li:hover a{color:#efe0ae}.article .article-container .article-body .overview-list li:hover img{filter:brightness(0)saturate()invert(91%)sepia(32%)saturate(720%)hue-rotate(357deg)brightness(102%)contrast(95%)}.article .article-container .article-body .overview-list li:last-of-type{margin-bottom:0}.article .article-container .article-body .overview-list-img{width:28px;display:inline-block}.overview-item--github img{margin-right:0!important}.inline-tag-icon{vertical-align:-.15em;margin:0 .25em;display:inline-block;border:none!important;width:1em!important;height:1em!important}@media screen and (max-width:768px){body{font-size:14px}.pc-only{display:none}.lead{text-align:center;margin-bottom:20px;font-size:1.7vw;line-height:1.7}.section{padding-top:60px}.section:last-of-type{padding-bottom:60px}.header .inner{padding:16px}.footer-logo,.header-logo{font-size:16px}.hamburger{cursor:pointer;color:#f1f5f9;z-index:200;background:0 0;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:64px;height:48px;display:inline-flex;position:relative}.hamburger__bar{transform-origin:50%;background:#f1f5f9;width:32px;height:1px;transition:transform .25s,opacity .2s;display:block}.hamburger__label{margin-top:2px;font-size:10px;line-height:1;transition:opacity .2s}.hamburger.is-open{gap:0}.hamburger.is-open .hamburger__bar:first-child{transform:translateY(.5px)rotate(45deg)}.hamburger.is-open .hamburger__bar:nth-child(2){transform:translateY(-.5px)rotate(-45deg)}.hamburger.is-open .hamburger__label{margin-top:18px}.sp-menu{z-index:100;pointer-events:none;display:block;position:fixed;inset:0}.sp-menu.is-open{pointer-events:auto}.sp-menu__panel{color:#f1f5f9;opacity:.9;background:#222;flex-direction:column;width:100vw;height:100%;padding:24px;transition:transform .3s;display:flex;position:absolute;top:0;right:0;transform:translate(100%)}.sp-menu.is-open .sp-menu__panel{transform:translate(0)}.sp-menu__list{margin-top:48px}.sp-menu__link{color:#f1f5f9;align-items:center;gap:16px;padding:16px 8px;text-decoration:none;display:flex}.sp-menu__icon{flex:0 0 20px;place-items:center;width:20px;height:20px;display:inline-grid}.sp-menu__iconImg{object-fit:contain;width:100%;height:100%}.sp-menu__text{letter-spacing:.04em;line-height:1}.sp-menu__item{border-bottom:1px solid #f1f5f9}.sp-menu__item a:hover{opacity:.8}.menu-open{overflow:hidden}.mv-container{padding:0 20px}.mv-subtitle{margin-bottom:20px;font-size:16px}.mv-text{font-size:14px;line-height:1.7;top:40%;left:35%}.mv-gears-img{width:18vw}.mv-text p{letter-spacing:.1rem;margin-top:10px;font-size:1.6vw;line-height:1.6}.title-en{font-size:4.3vw}.title-jp{font-size:1.4vw}.works-title{margin-top:16px;font-size:1.6vw}.works-list .works-item{flex:0 40%}.works-list .works-item .works-info{margin-top:3px}.works-item:last-child{margin-bottom:0}.works-item:nth-of-type(3){margin-top:36px}.skill-content .chart-container{width:100%}.skill-list{margin-bottom:0;display:block}.skill-item{width:100%;margin-bottom:35px}.skill-item:last-child{margin-bottom:0}.skill-name{margin-bottom:5px;font-size:2vw}.skill-text{font-size:13px;line-height:1.7}.skill-content{flex-direction:column;margin-bottom:28%;display:flex}.skill-content .skill-rating{width:100%}.skill-rating h3{font-size:2vw}.skill-rating p{font-size:1.6vw}.profile{display:flex}.profile-img{width:50%;margin-bottom:25px}.profile-body{margin:0 auto}.profile-body .profile-name{font-size:2vw}.profile-body .profile-detail{font-size:1.6vw;line-height:1.8}#contact>form>div>div,.profile-body .profile-detail:not(:last-child){margin-bottom:20px}.contact-span-mobile{margin-right:140px}#form .contact-field{width:100%}.footer{padding:20px}.article{padding:100px 0}.article-body h3{margin-top:10%;padding-left:.8em;font-size:3vw}.article-body h3:not(:first-child){margin-top:30px}.article-body ul{margin-top:4%}.article-body p,.article-body ul li .text{font-size:2vw;line-height:1.7}.article .article-container .article-body .article-part .views-detail{flex-direction:column;align-items:center;display:flex}.article .article-container .article-body .article-part .views-detail img{width:100%}.article .article-container .article-body .article-part .detail{width:100%;margin-top:6%}}@media screen and (max-width:500px){.cmn-container{padding:0 24px}.loader__ringWrap{width:160px;height:160px}.footer-logo a,.header-logo a{font-size:4vw}.footer .gnav-item a,.header .gnav-item a{font-size:2.8vw}.mv-text p{margin-top:2%;font-size:2.4vw}.mv .mv-container .mv-title .mv-letters{font-size:7.2vw}.mv .mv-container .mv-text{top:54%}.mv .mv-container .mv-text .mv-sub{letter-spacing:.1rem;margin-top:0;font-size:2.8vw}.mv .mv-container .mv-scroll__label{font-size:2.8vw}.article-title,.title-en{font-size:8vw}.article .article-container .article-title{font-size:6vw}.article .article-container .article-body .visit-site{gap:24px;margin-top:4%;padding:8px 24px;font-size:3.5vw}.article .article-container .article-body .visit-site .visit-site-icon{width:3.5vw;height:3.5vw;margin:0}.article .article-container .article-body .overview-list{margin-top:8%}.article-body ul li img{width:32px}.title-jp{font-size:2.8vw}.works-list{flex-flow:column;justify-content:center;width:100%}.works-list .works-item .works-info .works-meta{font-size:2.8vw}.works-list .works-item .works-info .works-meta .badge{font-size:2vw}.works-list .works-item .works-info .works-title{margin-top:2%;font-size:3.5vw}.works-list .works-item .works-info{margin-top:2%}.works-item{width:100%;margin-bottom:16%}.works-img-wrap img{width:100%}.profile-body .profile-name,.skill-name,.skill-rating h3{margin-bottom:4%;font-size:4.5vw}.profile-body .profile-detail,.skill-rating p,.skill-text{font-size:3.5vw}.skill-content .skill-rating .skill-rating-item .skill-rating-heading{margin-bottom:4%}.skill-content .skill-rating .skill-rating-item .skill-rating-heading span{font-size:4.5vw}.skill-content .skill-rating .skill-rating-item p{font-size:3.5vw}.skill-img{width:48px}.skill-name{margin-bottom:2%}.skill .title-en{margin-bottom:0}.profile{display:block}.profile-img{justify-content:center;width:100%;display:flex}.profile-img img{width:80%}#form .contact-field{gap:4vw}#form .contact-field .contact-heading .contact-label{font-size:4.5vw}#form .contact-field .contact-heading .contact-span{border-radius:4px;padding:2px 6px;font-size:2.8vw;display:inline-block}#form .contact-field .contact-form .contact-textarea,#form .contact-field .contact-form .contact-textbox{padding:12px}#form .contact-btn-wrap .contact-submit{padding:12px 36px;font-size:3.5vw}#form .contact-btn-wrap .contact-submit .contact-submit-icon{width:3.5vw}.lead{font-size:3.5vw}.section{padding-top:28%}.section:last-of-type{padding-bottom:28%}.article .section{padding:0}.sp-only{display:inline-flex}.article-body .visit-site{padding:2% 4%;font-size:3.2vw}.article-body .visit-site .iconify{font-size:5.8vw}.article-body p,.article-body ul li .github-link,.article-body ul li .text{font-size:2.8vw}.article .article-container .article-body{margin-bottom:28%}.article-body p,.article-body ul li .text{font-size:3.5vw}.article-body p,.article-body ul .overview-item .text{font-size:2.8vw}.article .article-container .article-body ul li{align-items:center;gap:16px;font-size:3.5vw;display:flex}.article .article-container .article-body .overview-list li{gap:12px;font-size:3.5vw}.article .article-container .article-body ul li .arrow-box{box-sizing:border-box;flex:0 0 25%;place-items:center;max-width:25%;margin-right:0;display:grid;width:25%!important}.article .article-container .article-body ul li .arrow-box .arrow-box__label{text-align:center;width:100%;font-size:3.5vw}.article .article-container .article-body .article-part{margin-top:28%}.article .article-container .article-body .article-part h2{margin-bottom:4%;padding-left:.8em;font-size:6vw;font-weight:600}.article .article-container .article-body .article-part h2:before{width:4px}.article .article-container .article-body .article-part p{font-size:3.5vw}.article .article-container .article-body .article-part .detail{width:100%;font-size:3.5vw}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}