@import "https://fonts.googleapis.com/css2?family=Caveat:wght@400;500&family=Inter:wght@400;500;600;700&family=Noto+Sans+JP:wght@400;500;600;700&display=swap";:root{--color-bg:#0c0c0c;--color-bg-elevated:#141414;--color-text:#e8e8e8;--color-text-muted:#8a8a8a;--color-text-subtle:#5a5a5a;--color-heading:#fff;--color-accent:#5b8fd4;--color-accent-hover:#7aa8e0;--color-border:#222;--color-border-subtle:#1a1a1a;--font-sans:"Inter", "Noto Sans JP", system-ui, sans-serif;--font-hand:"Caveat", cursive;--text-xs:.6875rem;--text-sm:.75rem;--text-base:.8125rem;--text-md:.875rem;--text-lg:1rem;--text-xl:1.25rem;--text-2xl:1.5rem;--leading-tight:1.3;--leading-normal:1.65;--leading-relaxed:1.8;--tracking-wide:.08em;--tracking-wider:.12em;--max-width:1200px;--grid-columns:12;--grid-gap:1.5rem;--section-gap:6rem;--content-padding:1.5rem;--fade-duration:.6s}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{flex-direction:column;min-height:100svh;display:flex}img{max-width:100%;display:block}a{color:var(--color-accent);text-decoration:none;transition:color .2s}a:hover{color:var(--color-accent-hover)}h1,h2,h3,h4,p{margin:0}h1,h2,h3{color:var(--color-heading);font-weight:600;line-height:var(--leading-tight)}button,input,textarea{font-family:inherit;font-size:inherit}.container{width:100%;max-width:var(--max-width);padding-inline:var(--content-padding);margin-inline:auto}.grid{grid-template-columns:repeat(var(--grid-columns), 1fr);gap:var(--grid-gap);display:grid}.col-12{grid-column:span 12}.col-8{grid-column:span 8}.col-6{grid-column:span 6}.col-4{grid-column:span 4}.col-3{grid-column:span 3}@media (width<=768px){:root{--section-gap:4rem;--content-padding:1.25rem;--grid-gap:1rem}.col-8,.col-6,.col-4,.col-3{grid-column:span 12}}.label{font-size:var(--text-xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);font-weight:500}.label-accent{color:var(--color-accent)}.hand{font-family:var(--font-hand);letter-spacing:.02em;font-weight:400}.text-muted{color:var(--color-text-muted)}.text-subtle{color:var(--color-text-subtle)}.section{padding-block:var(--section-gap)}.section:first-of-type{padding-top:3rem}.section-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.section-title{font-size:var(--text-lg);letter-spacing:var(--tracking-wide);font-weight:600}.section-count{font-size:var(--text-xs);color:var(--color-text-subtle);letter-spacing:var(--tracking-wide)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn var(--fade-duration) ease forwards}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{font-size:var(--text-xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-muted);font-weight:500}.form-input,.form-textarea{border:none;border-bottom:1px solid var(--color-border);width:100%;color:var(--color-text);background:0 0;outline:none;padding:.75rem 0;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--color-accent)}.form-textarea{resize:vertical;min-height:6rem}.form-submit{font-size:var(--text-xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-heading);border:1px solid var(--color-border);cursor:pointer;background:0 0;margin-top:1.5rem;padding:.625rem 1.5rem;font-weight:500;transition:border-color .2s,color .2s}.form-submit:hover{border-color:var(--color-accent);color:var(--color-accent)}.rule{border:none;border-top:1px solid var(--color-border);margin:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.header{z-index:100;background-color:var(--color-bg);border-bottom:1px solid var(--color-border-subtle);position:sticky;top:0}.header__inner{justify-content:space-between;align-items:center;padding-block:1.25rem;display:flex}.logo{color:var(--color-heading);text-decoration:none}.logo__mark{width:3rem;height:1.25rem;display:block}.header__nav{-webkit-overflow-scrolling:touch;overflow-x:auto}.header__list{align-items:center;gap:1.75rem;margin:0;padding:0;list-style:none;display:flex}.header__item{flex-direction:column;gap:.25rem;display:flex;position:relative}.header__link{font-size:var(--text-xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap;font-weight:500;text-decoration:none;transition:color .2s}.header__link:hover{color:var(--color-heading)}.header__sublist{margin:0;padding:0;list-style:none}.header__sublink{font-size:var(--text-xs);color:var(--color-accent);white-space:nowrap;text-decoration:none}.header__sublink:before{content:"└ ";color:var(--color-text-subtle)}@media (width<=768px){.header__inner{flex-direction:column;align-items:flex-start;gap:1rem}.header__list{gap:1.25rem}}.footer{border-top:1px solid var(--color-border-subtle);margin-top:auto;padding-block:3rem 2.5rem}.footer__top{align-items:start}.footer__list{flex-wrap:wrap;justify-content:flex-end;gap:1.5rem 2rem;margin:0;padding:0;list-style:none;display:flex}.footer__link{font-size:var(--text-xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-muted);font-weight:500;text-decoration:none;transition:color .2s}.footer__link:hover{color:var(--color-heading)}.footer__sublist{margin:.375rem 0 0;padding:0;list-style:none}.footer__sublink{font-size:var(--text-xs);color:var(--color-accent);text-decoration:none}.footer__sublink:before{content:"└ ";color:var(--color-text-subtle)}.footer__rule{margin-block:2rem}.footer__copyright{font-size:var(--text-xs);color:var(--color-text-subtle);letter-spacing:.04em}@media (width<=768px){.footer__list{justify-content:flex-start;margin-top:1.5rem}}.hero{padding-top:2rem;padding-bottom:4rem}.hero__grid{align-items:end}.hero__label{margin-bottom:.75rem}.hero__title{font-size:var(--text-2xl);letter-spacing:.06em;margin-bottom:1.25rem;font-weight:700}.hero__sub{font-size:var(--text-md);color:var(--color-text-muted);margin-bottom:.5rem}.hero__works{font-size:var(--text-sm);color:var(--color-text-subtle);line-height:var(--leading-relaxed)}.hero__aside{text-align:right}.hero__year{font-size:var(--text-lg);margin-bottom:1.5rem;font-weight:600}.hero__location-label{margin-bottom:.375rem}.hero__location{font-size:var(--text-sm);color:var(--color-text-muted)}@media (width<=768px){.hero__aside{text-align:left;margin-top:2rem}}.about__grid{align-items:start}.about__profile{flex-direction:column;gap:.375rem;display:flex}.about__name{font-size:var(--text-lg);color:var(--color-heading);margin-top:.5rem;font-weight:600}.about__role{font-size:var(--text-sm)}.about__location{font-size:var(--text-sm);margin-top:.25rem}.about__content{flex-direction:column;gap:1.25rem;display:flex}.about__text{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text-muted)}.about__text--ja{color:var(--color-text-subtle)}.services__list{margin:0;padding:0;list-style:none}.services__item{border-top:1px solid var(--color-border);padding-block:1.25rem}.services__name{font-size:var(--text-sm);color:var(--color-heading);letter-spacing:.02em;font-weight:500}.services__portfolio{border-top:1px solid var(--color-border);margin-top:3rem;padding-top:2rem}.services__portfolio-link{font-size:var(--text-sm);align-items:center;gap:.75rem;margin-top:.75rem;text-decoration:none;display:inline-flex}.services__portfolio-platform{text-transform:lowercase;font-weight:500}.services__portfolio-arrow{color:var(--color-text-subtle);transition:transform .2s}.services__portfolio-link:hover .services__portfolio-arrow{transform:translate(2px)}.projects__grid{align-items:start}.projects__card{padding-bottom:2.5rem}.projects__meta{margin-bottom:.75rem}.projects__title{font-size:var(--text-md);margin-bottom:.625rem;font-weight:600}.projects__link{color:var(--color-heading);text-decoration:none;transition:color .2s}.projects__link:hover{color:var(--color-accent)}.projects__desc{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text-muted)}@media (width<=768px){.projects__card{padding-bottom:2rem}}.contact__grid{align-items:start}.contact__info{flex-direction:column;gap:.5rem;display:flex}.contact__email{font-size:var(--text-sm);margin-top:.25rem}.contact__note{font-size:var(--text-xs);margin-top:.5rem}.contact__form{flex-direction:column;gap:1.5rem;display:flex}.privacy{padding-top:2rem}.privacy__content{max-width:42rem}.privacy__section{margin-bottom:2.5rem}.privacy__heading{font-size:var(--text-sm);letter-spacing:var(--tracking-wide);text-transform:uppercase;margin-bottom:1rem;font-weight:600}.privacy__text{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text-muted);margin-bottom:.75rem}.privacy__list{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text-muted);margin:.5rem 0 0;padding-left:1.25rem}.privacy__list li{margin-bottom:.375rem}
