@import"https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400&family=Cormorant+Garamond:ital,wght@0,200;0,300;1,200;1,300&family=Zen+Kaku+Gothic+New:wght@200;300&display=swap";:root{--bg: #070707;--fg: #f5f2ee;--fg-dim: rgba(245, 242, 238, .82);--fg-faint: rgba(245, 242, 238, .5);--accent: #ddd8d0;--line: rgba(245, 242, 238, .14);--hover-glow: rgba(220, 210, 195, .08);--hero-top-padding: 16rem;--page-gutter: clamp(1.6rem, 4.4vw, 5rem);--hero-hint-safe-space: 12rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:10px;scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:Cormorant Garamond,"Noto Serif JP",serif;overflow-x:hidden;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='7' height='7'%3E%3Ccircle cx='3.5' cy='3.5' r='3.5' fill='%23f5f2ee'/%3E%3C/svg%3E") 3 3,none}#cursor{display:none}#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");opacity:.028;pointer-events:none;z-index:1}#app{position:relative;z-index:2;min-height:100vh}header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:flex-start;padding:3.6rem var(--page-gutter) 0;transition:padding .5s ease}header:after{content:"";position:absolute;bottom:0;left:var(--page-gutter);right:var(--page-gutter);height:1px;background:var(--line);transform:scaleX(0);transform-origin:center;transition:transform .5s cubic-bezier(.4,0,.2,1)}header.scrolled{padding-bottom:2rem}header.scrolled:after{transform:scaleX(1)}.logo-block{display:flex;flex-direction:column;gap:.4rem}.logo-jp{font-family:"Noto Serif JP",serif;font-weight:200;font-size:1.8rem;letter-spacing:.3em;color:var(--fg);line-height:1}.logo-en{font-family:Cormorant Garamond,serif;font-weight:200;font-size:1rem;letter-spacing:.4em;color:var(--fg-dim);text-transform:uppercase}nav{display:flex;gap:3.5rem;align-items:center;padding-top:.6rem}nav a{font-family:Cormorant Garamond,serif;font-weight:200;font-size:1.1rem;letter-spacing:.25em;color:var(--fg-dim);text-decoration:none;text-transform:uppercase;position:relative;padding:1rem .2rem;transition:color .4s}nav a:after{content:"";position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--fg);transition:right .4s cubic-bezier(.4,0,.2,1)}nav a:hover,nav a.active{color:var(--fg)}nav a:hover:after,nav a.active:after{right:0}#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:var(--hero-top-padding) var(--page-gutter) max(6rem,var(--hero-hint-safe-space));position:relative;overflow:hidden}.hero-pane--portfolio,.hero-pane--contact{padding-bottom:var(--hero-hint-safe-space)}.hero-text{display:flex;flex-direction:column;align-items:flex-start;gap:1.6rem;max-width:72rem;opacity:0;transform:translate3d(0,30px,0)}.hero-text>*,.hero-text .hero-line-1,.hero-text .hero-title em{transition:none}.hero-label,.hero-contact-label{font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;letter-spacing:.38em;text-transform:uppercase;color:var(--fg-dim);font-size:clamp(1.05rem,1.2vw,1.35rem);transition:none}.hero-title,.hero-contact-title{font-family:"Noto Serif JP",serif;font-style:italic;font-weight:200;font-size:clamp(5.6rem,10vw,11rem);line-height:1.02;letter-spacing:.05em;color:var(--fg)}.hero-line-1,.hero-contact-line-1{white-space:nowrap}.hero-title em,.hero-contact-title em{font-family:Cormorant Garamond,serif;font-style:italic;font-weight:200}.hero-sub,.hero-contact-sub{font-family:Cormorant Garamond,serif;font-weight:200;font-size:clamp(1.5rem,1.8vw,2rem);letter-spacing:.12em;color:#f5f2eebf;max-width:58rem;line-height:1.6}.hero-cta{display:inline-flex;align-items:center;gap:1rem;margin-top:.8rem;align-self:flex-start;font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:1rem;letter-spacing:.35em;text-transform:uppercase;color:var(--fg-dim);text-decoration:none;border:1px solid var(--line);padding:1.3rem 2.8rem;transition:color .3s ease,border-color .3s ease,background .3s ease}.hero-cta:hover{color:var(--fg);border-color:#f5f2ee66;background:#f5f2ee0a}.hero-cta-arrow{display:inline-block;transition:transform .3s ease;letter-spacing:0}.hero-cta:hover .hero-cta-arrow{transform:translateY(3px)}.marquee-section{position:relative;z-index:2;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.6rem 0}.marquee-track{display:flex;width:max-content;animation:marqueeScroll 38s linear infinite}.marquee-content{display:flex;align-items:center;flex-shrink:0}.marquee-item{font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:1.2rem;letter-spacing:.3em;text-transform:uppercase;color:#f5f2ee77;white-space:nowrap;padding:0 2.2rem}.marquee-sep{color:#f5f2ee29;font-size:.75rem;flex-shrink:0}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}.hero-contact{position:absolute;right:var(--page-gutter);top:var(--hero-top-padding);bottom:0;margin-block:auto;height:fit-content;max-height:min(85vh,calc(100vh - 12rem));width:min(56rem,46vw);display:flex;flex-direction:column;align-items:flex-end;text-align:right;gap:2rem;opacity:0;pointer-events:none;transform:translate3d(5rem,0,0)}.hero-contact-list{display:flex;flex-direction:column;gap:.9rem}.hero-contact-list a{width:fit-content;align-self:flex-end;font-family:Zen Kaku Gothic New,sans-serif;font-size:clamp(1.1rem,1.35vw,1.45rem);letter-spacing:.15em;color:#f5f2eee0;text-decoration:none;border-bottom:1px solid rgba(245,242,238,.24);padding-bottom:.35rem;transition:border-color .25s ease,color .25s ease}.hero-contact-list a:hover{color:var(--fg);border-color:var(--fg)}.hero-pane{transition:transform .65s cubic-bezier(.22,1,.36,1),opacity .5s cubic-bezier(.22,1,.36,1)}#hero.show-portfolio .hero-pane--portfolio{pointer-events:auto;animation:heroPanePortfolioEnter 1.15s cubic-bezier(.22,1,.36,1) .55s forwards}#hero.show-portfolio.hero-portfolio-no-boot-anim .hero-pane--portfolio{animation:heroPanePortfolioEnter .72s cubic-bezier(.22,1,.36,1) 0s forwards}#hero.show-contact .hero-pane--portfolio{animation:heroPanePortfolioExit .72s cubic-bezier(.22,1,.36,1) forwards!important;pointer-events:none}#hero.show-contact .hero-pane--contact{opacity:1;transform:translateZ(0);pointer-events:auto}#hero.show-portfolio .hero-pane--contact{opacity:0;transform:translate3d(5rem,0,0);pointer-events:none}.scroll-hint{position:absolute;bottom:clamp(2rem,3.2vh,4rem);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.8rem;opacity:0;animation:fadeIn 1s ease 1.5s forwards;pointer-events:none;z-index:4}.scroll-hint-text{font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:1.2rem;letter-spacing:.45em;color:#f5f2eebf;text-transform:uppercase;white-space:nowrap;top:3rem}.scroll-arrow{display:flex;flex-direction:column;align-items:center;gap:0;animation:scrollBounce 1.8s ease-in-out 1.5s infinite}.scroll-arrow:before,.scroll-arrow:after{content:"";display:block;width:14px;height:14px;border-right:1.5px solid rgba(245,242,238,.75);border-bottom:1.5px solid rgba(245,242,238,.75);transform:rotate(45deg);margin-top:-7px}.scroll-arrow:after{opacity:.5}@keyframes scrollBounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}#projects{padding:5rem var(--page-gutter) 8rem;display:grid;grid-template-columns:auto minmax(0,1fr) auto;grid-template-areas:"header header header" "prev track next" ". index .";align-items:center;gap:2rem}.projects-section-header{grid-area:header;display:flex;align-items:baseline;justify-content:space-between;padding-bottom:2.4rem;border-bottom:1px solid var(--line)}.projects-section-label{font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:1.2rem;letter-spacing:.45em;text-transform:uppercase;color:var(--fg-faint)}#project-slider-track{grid-area:track;position:relative;width:100%;max-width:1000px;margin:0 auto;padding:12px}.project-card{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border:1px solid var(--line);opacity:0;transform-origin:center center;transition:transform .35s ease,box-shadow .35s ease}.project-card.visible{opacity:1;transform:scale(1)}.project-card.visible:hover{transform:scale(1.02);box-shadow:0 24px 48px #00000073}.project-card:after{content:"VER PROYECTO";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) translateY(6px);font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:1rem;letter-spacing:.38em;color:var(--fg);opacity:0;transition:opacity .3s ease,transform .3s ease;pointer-events:none;white-space:nowrap;z-index:2}.project-card.visible:hover:after{opacity:1;transform:translate(-50%,-50%) translateY(0)}.card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:filter .5s ease;filter:brightness(.78) saturate(.85)}.project-card:hover .card-img{filter:brightness(.58) saturate(.65)}.card-exit-left{animation:slideOutLeft .38s ease forwards}.card-exit-right{animation:slideOutRight .38s ease forwards}.card-enter-right{animation:slideInRight .42s ease forwards}.card-enter-left{animation:slideInLeft .42s ease forwards}.card-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:2.5rem;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.18) 50%,transparent 100%)}.card-index{position:absolute;top:2rem;right:2rem;font-family:Cormorant Garamond,serif;font-weight:200;font-size:.9rem;letter-spacing:.3em;color:#f5f2ee59}.card-tech{font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:1.2rem;letter-spacing:.25em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:.8rem}.card-title{font-family:"Noto Serif JP",serif;font-weight:300;font-size:clamp(2.4rem,2.8vw,3.2rem);letter-spacing:.05em;color:var(--fg);line-height:1.3;margin-bottom:.8rem}.card-title-en{font-family:Cormorant Garamond,serif;font-style:italic;font-weight:200;font-size:clamp(1.4rem,1.6vw,1.8rem);letter-spacing:.08em;color:var(--fg-dim)}.card-year{margin-top:1.4rem;font-family:Cormorant Garamond,serif;font-weight:200;font-size:1.1rem;letter-spacing:.3em;color:var(--fg-faint)}.slider-nav{grid-area:prev;width:5.6rem;height:5.6rem;padding:0;border-radius:999px;border:1px solid rgba(245,242,238,.35);background:radial-gradient(circle at 30% 25%,#f5f2ee24,#0c0c0cf2 56%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--fg);display:inline-flex;align-items:center;justify-content:center;line-height:0;box-shadow:0 10px 24px #0000006b;transition:border-color .3s ease,transform .28s ease,background .3s ease,box-shadow .3s ease}.slider-nav#slider-next{grid-area:next}.slider-nav:hover{border-color:#f5f2eebf;transform:translateY(-2px) scale(1.03);background:radial-gradient(circle at 30% 25%,#f5f2ee38,#141414f5 58%);box-shadow:0 16px 32px #0000008c}.slider-nav:active{transform:translateY(0) scale(.98)}.slider-nav:focus-visible{outline:none;border-color:#f5f2eee6;box-shadow:0 0 0 3px #f5f2ee24,0 14px 30px #00000085}.slider-nav-icon{width:2.2rem;height:2.2rem;display:inline-flex;align-items:center;justify-content:center}.slider-nav-icon svg{width:100%;height:100%;stroke:#f5f2eef2;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;fill:none;transition:transform .25s ease,stroke .25s ease}#slider-prev:hover .slider-nav-icon svg{transform:translate(-1px)}#slider-next:hover .slider-nav-icon svg{transform:translate(1px)}#slider-index{grid-area:index;display:flex;justify-content:center;align-items:center;gap:.4rem;margin-top:.5rem;padding-top:.8rem}.slider-index-btn{min-width:4.4rem;height:4.4rem;padding:0 .8rem;border:none;background:transparent;color:#f5f2eeb3;font-family:Zen Kaku Gothic New,sans-serif;font-size:1rem;letter-spacing:.18em;font-weight:300;position:relative;transition:color .25s ease,transform .25s ease}.slider-index-btn:after{content:"";position:absolute;left:0;right:0;bottom:.25rem;height:1px;background:transparent;transition:background .25s ease,transform .25s ease;transform:scaleX(.4)}.slider-index-btn:hover{color:var(--fg);transform:translateY(-1px)}.slider-index-btn.active{color:var(--fg);font-weight:700}.slider-index-btn.active:after{background:var(--fg);transform:scaleX(1)}.card-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#111,#1a1a1a,#0d0d0d);overflow:hidden}.card-placeholder:before{content:"";position:absolute;width:60%;height:60%;border-radius:50%;background:radial-gradient(ellipse at center,rgba(200,180,150,.06) 0%,transparent 70%)}.placeholder-label{font-family:"Noto Serif JP",serif;font-size:4rem;font-weight:200;color:#c8b49614;letter-spacing:.1em;position:relative;z-index:1}footer{border-top:1px solid var(--line);padding:3rem var(--page-gutter);display:flex;justify-content:space-between;align-items:center}.footer-copy{font-family:Zen Kaku Gothic New,sans-serif;font-weight:200;font-size:.85rem;letter-spacing:.3em;color:var(--fg-faint)}#loading{position:fixed;inset:0;background:var(--bg);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3rem;transition:opacity .8s ease,visibility .8s ease}#loading.hidden{opacity:0;visibility:hidden}.loading-jp{font-family:"Noto Serif JP",serif;font-weight:200;font-size:3rem;letter-spacing:.4em;color:var(--fg)}.loading-bar{width:200px;height:1px;background:var(--fg-faint);position:relative;overflow:hidden}.loading-fill{position:absolute;top:0;left:0;height:100%;background:var(--fg);animation:loadFill 1.2s cubic-bezier(.4,0,.2,1) forwards}.loading-num{font-family:Cormorant Garamond,serif;font-weight:200;font-size:1rem;letter-spacing:.4em;color:var(--fg-dim)}html.from-transition #loading{opacity:0!important;visibility:hidden!important;transition:none!important}html.from-transition .page-transition{visibility:visible;pointer-events:none}html.from-transition .page-transition__gate--top,html.from-transition .page-transition__gate--bottom{transform:translateY(0);transition:none}.page-transition{position:fixed;inset:0;z-index:10050;pointer-events:none;visibility:hidden}.page-transition.page-transition--active{pointer-events:auto;visibility:visible}.page-transition__gate{position:absolute;left:0;right:0;height:50.5%;background:var(--bg);transition:transform .85s cubic-bezier(.77,0,.175,1);will-change:transform}.page-transition__gate--top{top:0;transform:translateY(-101%)}.page-transition__gate--bottom{bottom:0;transform:translateY(101%)}.page-transition--active .page-transition__gate--top,.page-transition--active .page-transition__gate--bottom{transform:translateY(0)}.page-transition__content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;opacity:0;transition:opacity .42s ease .26s;z-index:1;pointer-events:none}.page-transition--active .page-transition__content{opacity:1}.page-transition__kicker{font-family:Zen Kaku Gothic New,sans-serif;font-size:1rem;letter-spacing:.45em;color:var(--fg-faint);text-transform:uppercase;margin-bottom:1.2rem}.page-transition__title{font-family:"Noto Serif JP",serif;font-style:italic;font-weight:200;font-size:clamp(2.4rem,5vw,4.5rem);color:var(--fg);line-height:1.15;max-width:90vw}.page-transition__bar{margin-top:2.4rem;width:0;max-width:28rem;height:1px;background:var(--fg);opacity:.85;transition:width .72s cubic-bezier(.33,1,.68,1) .48s}.page-transition--active .page-transition__bar{width:min(28rem,70vw)}@media(prefers-reduced-motion:reduce){.page-transition__gate{transition-duration:.01ms}.page-transition__content,.page-transition__bar{transition-duration:.01ms;transition-delay:0s}#hero.show-contact .hero-pane--portfolio{animation:none!important;opacity:0;transform:translate3d(-1.5rem,0,0) scale(1)}#hero.show-portfolio .hero-pane--portfolio,#hero.show-portfolio.hero-portfolio-no-boot-anim .hero-pane--portfolio{animation:none;opacity:1;transform:translateZ(0) scale(1)}}@keyframes heroPanePortfolioExit{0%{opacity:1;transform:translateZ(0) scale(1)}to{opacity:0;transform:translate3d(-5.5rem,0,0) scale(.96)}}@keyframes heroPanePortfolioEnter{0%{opacity:0;transform:translate3d(-4.25rem,1.25rem,0) scale(.96)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes fadeIn{to{opacity:1}}@keyframes loadFill{0%{width:0}to{width:100%}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(-8%) scale(.985)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(8%) scale(.985)}}@keyframes slideInRight{0%{opacity:0;transform:translate(10%) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-10%) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}.project-detail-page{min-height:100vh;display:flex;flex-direction:column}header.project-detail-header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:flex-start;padding:3.6rem var(--page-gutter) 2rem;background:transparent;border-bottom:none;transition:padding .5s ease}header.project-detail-header:after{content:"";position:absolute;bottom:0;left:var(--page-gutter);right:var(--page-gutter);height:1px;background:var(--line);transform:scaleX(1);transform-origin:center}.project-detail-main{flex:1;padding:12rem var(--page-gutter) 8rem;max-width:148rem;margin:0 auto;width:100%}.project-detail-footer{border-top:1px solid var(--line);padding:2.4rem var(--page-gutter)}.detail-back{display:inline-flex;align-items:center;gap:.9rem;margin-bottom:4rem;font-family:Zen Kaku Gothic New,sans-serif;font-size:1rem;font-weight:200;letter-spacing:.28em;text-transform:uppercase;color:var(--fg-dim);text-decoration:none;transition:color .25s ease,gap .25s ease}.detail-back:hover{color:var(--fg);gap:1.4rem}.detail-back-arrow{font-size:1.1em;transition:transform .25s ease}.detail-back:hover .detail-back-arrow{transform:translate(-3px)}.detail-loading,.detail-error{font-family:Cormorant Garamond,serif;color:#f5f2eee0;font-size:1.8rem}.detail-article{display:grid;gap:0 5rem;grid-template-columns:minmax(28rem,1.2fr) minmax(0,1fr);align-items:start}.detail-media-col{min-width:0;position:sticky;top:11rem;display:flex;align-items:flex-start;justify-content:center}.detail-hero-img-wrap{border:1px solid var(--line);background:#0d0d0d;border-radius:2px;display:flex;align-items:center;justify-content:center;padding:0;max-width:100%}.detail-hero-img{width:auto;height:auto;max-width:100%;display:block}.detail-hero-placeholder{min-height:22rem;aspect-ratio:4 / 5;max-width:28rem;width:100%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#111,#1a1a1a,#0d0d0d)}.detail-hero-placeholder-text{font-family:"Noto Serif JP",serif;font-size:clamp(6rem,14vw,16rem);font-weight:200;color:#f5f2ee14}.detail-body{display:flex;flex-direction:column;gap:1.8rem;padding:.5rem 0 10rem;max-width:62rem;text-shadow:0 .12em 1.8rem rgba(0,0,0,.75)}.detail-proj-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-between;padding:2rem var(--page-gutter);z-index:90;pointer-events:none;background:linear-gradient(to top,rgba(7,7,7,.72) 0%,transparent 100%)}.detail-proj-nav-btn{pointer-events:auto;background:transparent;border:none;color:var(--fg-dim);padding:1.5rem 2rem;display:flex;align-items:center;gap:1.1rem;font-family:Zen Kaku Gothic New,sans-serif;font-size:1.2rem;font-weight:200;letter-spacing:.28em;text-transform:uppercase;transition:color .25s ease,gap .25s ease;max-width:28rem}.detail-proj-nav-btn:hover{color:var(--fg);gap:1.6rem}.detail-proj-nav-label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.detail-proj-nav-arrow{flex-shrink:0;transition:transform .25s ease}.detail-proj-nav-prev:hover .detail-proj-nav-arrow{transform:translate(-4px)}.detail-proj-nav-next:hover .detail-proj-nav-arrow{transform:translate(4px)}.detail-body>*,.detail-section>*,.detail-error>*{transition:none}.detail-meta{font-family:Zen Kaku Gothic New,sans-serif;font-size:1.15rem;letter-spacing:.26em;color:#f5f2ee9e;text-transform:uppercase}.detail-num{color:#f5f2eed1}.detail-title{font-family:"Noto Serif JP",serif;font-style:italic;font-weight:200;font-size:clamp(3.6rem,4.6vw,5.6rem);line-height:1.06;color:#faf8f5}.detail-lead{font-family:Cormorant Garamond,serif;font-size:clamp(2rem,2.2vw,2.75rem);font-style:italic;font-weight:400;color:#f5f2eeeb;line-height:1.42}.detail-role{font-family:Zen Kaku Gothic New,sans-serif;font-size:1.25rem;font-weight:400;letter-spacing:.1em;color:#f5f2eed9}.detail-actions{display:flex;flex-wrap:wrap;gap:1.2rem;margin-top:.4rem}.detail-btn{display:inline-flex;align-items:center;justify-content:center;padding:1.2rem 2.4rem;font-family:Zen Kaku Gothic New,sans-serif;font-size:1.2rem;font-weight:200;letter-spacing:.28em;text-transform:uppercase;text-decoration:none;border:1px solid rgba(245,242,238,.35);background:transparent;color:var(--fg-dim);transition:color .25s ease,border-color .25s ease,background .25s ease;cursor:pointer}.detail-btn:hover{color:var(--fg);border-color:#f5f2eebf;background:#f5f2ee0d}.detail-section{margin-top:2.4rem;padding-top:2.4rem;border-top:1px solid var(--line)}.detail-section-title{font-family:Zen Kaku Gothic New,sans-serif;font-size:1.05rem;font-weight:400;letter-spacing:.32em;color:#f5f2eeb8;text-transform:uppercase;margin-bottom:1.4rem}.detail-p{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:400;line-height:1.68;color:#f5f2eee6;margin-bottom:1.35rem}.detail-p:last-child{margin-bottom:0}.detail-list{margin:0;padding-left:1.8rem;font-family:Cormorant Garamond,serif;font-size:1.9rem;font-weight:400;line-height:1.68;color:#f5f2eee0}.detail-list li{margin-bottom:.8rem}.detail-stack{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.8rem}.detail-stack li{font-family:Zen Kaku Gothic New,sans-serif;font-size:1.05rem;font-weight:400;letter-spacing:.12em;padding:.65rem 1.3rem;border:1px solid rgba(245,242,238,.22);color:#f5f2eee0;background:#07070759}@media(max-width:1024px){:root{--hero-top-padding: 12rem;--page-gutter: 3rem;--hero-hint-safe-space: 10rem}header{align-items:center;gap:1.6rem}nav{gap:2.4rem;flex-wrap:wrap;justify-content:flex-end}.detail-article{grid-template-columns:1fr;gap:3rem;align-items:start}.detail-media-col{position:static;justify-content:center}.detail-hero-placeholder{min-height:18rem;max-width:36rem;margin:0 auto;aspect-ratio:16 / 11}.detail-body{max-width:none;padding-bottom:10rem}.detail-proj-nav{padding:1.5rem 3rem}header.project-detail-header{padding-top:2.5rem;padding-bottom:1.6rem}header{padding:2.5rem var(--page-gutter) 0}#hero{min-height:auto;padding:var(--hero-top-padding) 3rem 5rem}.hero-text,.hero-contact{max-width:100%}.hero-sub,.hero-contact-sub{max-width:65ch}.hero-contact{right:3rem;width:min(52rem,58vw);max-height:min(82vh,calc(100vh - 10rem))}#projects{padding:3rem var(--page-gutter) 6rem}footer{padding:2.5rem var(--page-gutter)}.project-card{aspect-ratio:16/10}}@media(max-width:820px){#hero{min-height:auto}.hero-contact{position:static;top:auto;bottom:auto;margin-block:0;width:100%;max-width:52rem;max-height:none;margin-top:2.4rem;align-items:flex-start;text-align:left;transform:translate3d(0,20px,0)}.hero-contact-list a{align-self:flex-start}#hero.show-contact .hero-pane--contact{transform:translateZ(0)}#hero.show-portfolio .hero-pane--contact{transform:translate3d(0,20px,0)}}@media(max-width:640px){:root{--hero-top-padding: 16rem;--page-gutter: 2rem;--hero-hint-safe-space: 8.6rem}header.project-detail-header{padding-top:2rem;padding-bottom:1.6rem}.project-detail-main{padding-top:9rem}header{align-items:center;gap:1.2rem}nav{gap:1.2rem;padding-top:0;flex-wrap:wrap;justify-content:flex-end}nav a{font-size:.95rem;letter-spacing:.18em}.project-detail-page nav{gap:2rem}header{padding:2rem var(--page-gutter)}#hero{min-height:86svh;padding:var(--hero-top-padding) var(--page-gutter) 2.2rem;align-items:stretch;justify-content:flex-start;overflow:visible}.hero-pane--portfolio,.hero-pane--contact{position:absolute;top:var(--hero-top-padding);left:var(--page-gutter);right:var(--page-gutter);margin:0}.hero-pane--portfolio{align-items:flex-start;text-align:left}.hero-title,.hero-contact-title{font-size:clamp(4.2rem,12vw,6.2rem);line-height:1.08}.hero-line-1,.hero-contact-line-1{white-space:normal}.hero-sub,.hero-contact-sub{font-size:clamp(1.35rem,4.2vw,1.75rem);line-height:1.45;letter-spacing:.08em}.hero-sub br,.hero-contact-sub br{display:none}.scroll-hint{display:flex;left:50%;bottom:clamp(1.6rem,3.2vh,3.2rem);transform:translate(-50%);opacity:1;animation:scrollHintMobileIn .6s ease forwards}.hero-contact{position:absolute;top:var(--hero-top-padding);bottom:auto;left:var(--page-gutter);right:var(--page-gutter);margin-block:0;transform:translateZ(0);width:auto;max-width:100%;max-height:none;margin-top:0;padding-right:.6rem;align-items:flex-end;text-align:right}.hero-contact-title,.hero-contact-sub,.hero-contact-list a{max-inline-size:100%;overflow-wrap:anywhere;word-break:normal}.hero-contact-list a{align-self:flex-end}#hero.show-contact .hero-pane--contact{transform:translateZ(0)}#hero.show-portfolio .hero-pane--contact{transform:translate3d(0,20px,0)}#projects{grid-template-columns:1fr 1fr;grid-template-areas:"header header" "track track" "index index" "prev next";gap:1.5rem;padding:1.5rem var(--page-gutter) 5rem}#project-slider-track{justify-self:center;width:100%}#slider-prev{justify-self:start}#slider-next{justify-self:end}.slider-nav{width:4.9rem;height:4.9rem}.slider-nav-icon{width:1.95rem;height:1.95rem}#slider-index{gap:.15rem}.slider-index-btn{min-width:3.2rem;height:3.2rem;font-size:.9rem;letter-spacing:.12em}.project-card{aspect-ratio:16/12}footer{flex-direction:column;gap:2rem;padding:2rem var(--page-gutter)}.detail-proj-nav{padding:1.2rem var(--page-gutter)}.detail-proj-nav-btn{padding:.9rem 1.2rem;font-size:.78rem;max-width:14rem}.detail-proj-nav-label{max-width:8rem}}@media(max-width:420px){:root{--page-gutter: 1.6rem;--hero-hint-safe-space: 7.2rem}header{padding:1.6rem var(--page-gutter)}.logo-jp{font-size:1.5rem;letter-spacing:.22em}.logo-en{font-size:.9rem;letter-spacing:.24em}#hero{padding:12.2rem var(--page-gutter) 2rem;min-height:82svh}.hero-pane--portfolio,.hero-pane--contact,.hero-contact{left:var(--page-gutter);right:var(--page-gutter)}}@keyframes scrollHintMobileIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(pointer:coarse){body{cursor:auto}#cursor{display:none}a,button,.project-card,.slider-nav,.slider-index-btn,.detail-btn,.detail-proj-nav-btn,.hero-contact-list a,nav a{cursor:auto}}
