:root{color-scheme:dark;--ink: #0b0a10;--ink-2: #15101d;--ink-3: #21172b;--silver: #f1edf7;--muted: #b8aec8;--wisteria: #a06bd6;--magenta: #d848a8;--gold: #b99a5a;--line: rgba(185, 154, 90, .34)}*{box-sizing:border-box}html{background:var(--ink);scroll-behavior:smooth}body{margin:0;min-width:320px;background:linear-gradient(90deg,rgba(160,107,214,.06) 1px,transparent 1px),linear-gradient(0deg,rgba(185,154,90,.06) 1px,transparent 1px),var(--ink);background-size:72px 72px,72px 72px,auto;color:var(--silver);font-family:"Noto Serif JP",Yu Mincho,Hiragino Mincho ProN,Times New Roman,serif}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.site-header{position:fixed;z-index:80;top:0;right:0;display:flex;align-items:center;justify-content:center}.menu-toggle{position:relative;z-index:70;display:block;width:68px;height:68px;border:0;border-radius:0;padding:0 18px;background:#5c2f80e6;box-shadow:none;backdrop-filter:none;cursor:pointer}.menu-toggle span{display:block;height:2px;margin:7px 0;background:var(--silver);transform-origin:center;transition:transform .22s ease,opacity .22s ease}.is-menu-open .menu-toggle{background:#5c2f80f5;box-shadow:none}.is-menu-open .menu-toggle span{background:var(--silver)}.is-menu-open .menu-toggle span:nth-child(1){transform:translateY(9px) rotate(45deg)}.is-menu-open .menu-toggle span:nth-child(2){opacity:0}.is-menu-open .menu-toggle span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}.menu-overlay{position:fixed;top:0;right:0;bottom:0;z-index:50;width:min(420px,88vw);display:flex;align-items:center;background:linear-gradient(135deg,#0b0a10f0,#1c1127e0),radial-gradient(circle at 85% 18%,rgba(160,107,214,.22),transparent 32%);border-left:1px solid rgba(185,154,90,.32);box-shadow:-28px 0 80px #00000057;opacity:1;pointer-events:none;transform:translate(100%);transition:transform .34s cubic-bezier(.2,.8,.2,1)}.is-menu-open .menu-overlay{pointer-events:auto;transform:translate(0)}.menu-overlay__inner{width:100%;display:grid;gap:10px;padding:84px 34px 42px}.menu-overlay__label{margin:0 0 18px;color:var(--gold);font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.82rem;font-weight:900;text-transform:uppercase}.menu-overlay a{border-bottom:1px solid rgba(241,237,247,.16);padding:15px 0;color:var(--silver);font-size:2.25rem;line-height:1.08}.menu-overlay__locked{border-bottom:1px solid rgba(241,237,247,.16);padding:15px 0;color:#f1edf76b;font-size:2.25rem;line-height:1.08;cursor:not-allowed;user-select:none}.hero{position:relative;min-height:100vh;overflow:hidden;isolation:isolate;background:var(--ink)}.hero__still,.hero__video{position:absolute;top:0;left:50%;z-index:0;width:100vw;height:100%;max-width:none;object-fit:cover;object-position:center;transform:translate(-50%)}.hero__still--bg{z-index:0;animation:still-bg-intro 2.4s ease-out both}.hero__still--character{z-index:1;transform-origin:50% 72%;animation:character-intro 1.55s cubic-bezier(.2,.8,.2,1) .18s both,character-idle 5.8s ease-in-out 1.9s infinite}.hero__video{z-index:2;opacity:0;transition:opacity 2s ease}.hero__video.is-visible{opacity:1}.hero__inner{position:relative;z-index:3;width:min(1310px,calc(100% - 40px));min-height:100vh;display:flex;align-items:center;justify-content:flex-end;margin:0 auto;padding:112px 0 46px}.hero__copy{position:relative;z-index:2;max-width:560px;padding-right:24px;text-align:right}.hero__copy:after{position:absolute;top:4px;right:0;bottom:4px;width:1px;background:linear-gradient(180deg,transparent,rgba(185,154,90,.76),rgba(160,107,214,.72),transparent);content:"";transform:scaleY(0);transform-origin:top;animation:copy-line-intro 1.2s ease-out .42s both}.hero__copy .eyebrow,.hero__copy h1,.hero__lead{opacity:0;transform:translateY(18px);filter:blur(8px);animation:copy-intro 1s cubic-bezier(.2,.8,.2,1) both}.hero__copy .eyebrow{animation-delay:.45s}.hero__copy h1{animation-delay:.62s}.hero__lead{animation-delay:.8s}.eyebrow{margin:0;color:var(--gold);font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.78rem;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,h3{margin:0;font-weight:700;letter-spacing:0;line-height:1.08}h1{margin-top:18px;font-size:4.9rem}.hero__lead{margin:26px 0 0;color:#f1edf7c7;font-size:1.05rem;line-height:2}.hero__profile-link{min-height:42px;display:inline-flex;align-items:center;border-bottom:1px solid rgba(185,154,90,.78);margin-top:18px;color:var(--silver);font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.86rem;font-weight:800;opacity:0;transform:translateY(18px);filter:blur(8px);animation:copy-intro 1s cubic-bezier(.2,.8,.2,1) .98s both;transition:border-color .2s ease,color .2s ease}.hero__profile-link:hover,.hero__profile-link:focus-visible{border-color:var(--silver);color:var(--silver)}@keyframes still-bg-intro{0%{opacity:.7;transform:translate(-50%) scale(1.035)}to{opacity:1;transform:translate(-50%) scale(1)}}@keyframes character-intro{0%{opacity:0;transform:translate(-50%) translateY(28px) scale(.985);filter:blur(10px)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1);filter:blur(0)}}@keyframes character-idle{0%,to{transform:translate(-50%) translateY(0) scale(1)}50%{transform:translate(-50%) translateY(-7px) scale(1.002)}}@keyframes copy-intro{to{opacity:1;transform:translateY(0);filter:blur(0)}}@keyframes copy-line-intro{to{transform:scaleY(1)}}.button{min-height:46px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 20px;font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.86rem;font-weight:800}.button--primary{background:var(--silver);color:var(--ink)}.section{width:min(1310px,calc(100% - 40px));margin:0 auto;padding:92px 0}.section__heading{display:grid;gap:14px;margin-bottom:30px}h2{font-size:2.45rem}.project-showcase{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.82fr);align-items:start;gap:22px}.project-feature{position:sticky;top:92px;min-height:min(680px,calc(100vh - 118px));display:grid;grid-template-rows:minmax(360px,1fr) auto;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:linear-gradient(160deg,#21172bf0,#0b0a10e0),radial-gradient(circle at 12% 0%,rgba(216,72,168,.16),transparent 38%);box-shadow:0 24px 70px #0000004d;transform:scale(1);transform-origin:center;transition:transform .24s ease}.project-card-link,.project-card[data-href]{cursor:pointer}.project-feature:hover,.project-feature:focus-within{transform:scale(1.012)}.project-feature__media{position:relative;min-height:0;overflow:hidden;background:var(--ink-2)}.project-feature__media img,.project-feature__video{width:100%;height:100%;max-width:none;object-fit:cover;object-position:center}.project-feature__media img{filter:saturate(.92) contrast(1.02);transition:opacity .32s ease,transform .44s ease}.project-feature__video{position:absolute;inset:0;opacity:0;pointer-events:none;transform:scale(1.012);transition:opacity .32s ease}.project-feature.is-video-active .project-feature__media img{transform:scale(1.018)}.project-feature.is-video-active .project-feature__video{opacity:1}.project-feature__body{position:relative;display:grid;gap:0;padding:28px}.project-feature__title{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.project-feature__title .eyebrow{font-size:1rem}.project-feature h3{max-width:12ch;font-size:clamp(1.9rem,2.7vw,3rem)}.project-feature p{max-width:42rem;margin:16px 0 0;color:var(--muted);font-size:1.02rem;line-height:1.9}.project-feature a,.project-card a{width:fit-content;min-height:42px;display:inline-flex;align-items:center;border-bottom:1px solid var(--gold);color:var(--silver);font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.86rem;font-weight:800}.project-feature__external-link,.project-card__detail-link{position:relative;z-index:4}.project-feature a{margin-top:12px;display:inline-flex;align-items:center;gap:6px}.project-feature a svg{width:12px;height:12px;opacity:.7}.project-side-list{display:grid;gap:22px}.project-card{position:relative;min-height:clamp(300px,34vw,390px);display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;border:1px solid var(--line);border-radius:8px;padding:26px;background:linear-gradient(160deg,#21172bf0,#0b0a10db),radial-gradient(circle at top right,rgba(160,107,214,.24),transparent 34%);box-shadow:0 24px 70px #00000047;transform:scale(1);transform-origin:center;transition:transform .24s ease}.project-card[data-href]:hover,.project-card[data-href]:focus-within{transform:scale(1.018)}.project-card:nth-child(2){background:linear-gradient(160deg,#15101df0,#0b0a10e0),radial-gradient(circle at 80% 14%,rgba(185,154,90,.2),transparent 36%)}.project-card__media{position:relative;width:calc(100% + 52px);aspect-ratio:16 / 9;margin:-26px -26px 20px;overflow:hidden;background:var(--ink-2)}.project-card__media img,.project-card__video{width:100%;height:100%;max-width:none;object-fit:cover;object-position:center}.project-card__media img{transition:opacity .28s ease,transform .38s ease}.project-card__video{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .28s ease}.project-card.is-video-active .project-card__media img{transform:scale(1.012)}.project-card.is-video-active .project-card__video{opacity:1}.project-card__body{position:relative;z-index:1}.project-card h3{font-size:2rem}.project-card p{margin:14px 0 0;color:var(--muted);font-size:1rem;line-height:1.8}.news{padding-top:72px}.news-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.news-item{min-height:100%;display:grid;grid-template-rows:auto auto 1fr;align-content:start;gap:12px;border-radius:8px;padding:12px;transition:transform .2s ease}.news-item:hover{transform:translateY(-2px)}.news-item img{width:100%;aspect-ratio:16 / 9;border-radius:6px;object-fit:cover;background:#f1edf714}.news-item span{color:var(--wisteria);font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.82rem;font-weight:800}.news-item strong{color:var(--silver);font-size:1.1rem;font-weight:700;line-height:1.55}.site-footer{border-top:1px solid var(--line);margin-top:24px}.site-footer__inner{width:min(1310px,calc(100% - 40px));margin:0 auto;padding:28px 0 44px;display:flex;flex-direction:column;align-items:center;gap:20px}.footer-links{display:flex;gap:2px}.footer-links a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:6px;color:var(--muted);transition:color .2s ease,background .2s ease}.footer-links a:hover{color:var(--silver);background:#f1edf714}.footer-links a svg{width:18px;height:18px}.footer-copy{margin:0;color:var(--muted);font-family:Inter,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,sans-serif;font-size:.75rem;opacity:.6}@media(max-width:900px){.hero__copy{position:relative;z-index:2}.project-showcase{grid-template-columns:repeat(2,minmax(0,1fr))}.project-feature{position:static;grid-column:1 / -1;min-height:620px}.project-side-list{grid-column:1 / -1;grid-template-columns:repeat(2,minmax(0,1fr))}.news-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.menu-toggle{width:60px;height:60px;padding:0 16px}.menu-overlay{width:min(360px,88vw)}.menu-overlay__inner{padding:76px 26px 34px}.menu-overlay a,.menu-overlay__locked{font-size:1.85rem}.hero__inner,.section{width:100%;padding-right:18px;padding-left:18px}.hero__inner{align-items:flex-end;justify-content:flex-start;padding:120px 0 0}.hero__copy{width:100%;max-width:none;border-top:1px solid rgba(241,237,247,.1);padding:28px 18px 34px 28px;background:linear-gradient(90deg,#03030657,#08060c29),linear-gradient(180deg,transparent,rgba(2,2,4,.28));box-shadow:0 -26px 62px #0000001f;backdrop-filter:blur(3px);text-align:left}.hero__copy:after{inset:24px auto 34px 18px}h1{font-size:3rem}h2{font-size:2rem}.hero__lead{font-size:.98rem}.hero__profile-link{min-height:38px;margin-top:14px}.project-showcase,.project-side-list,.news-list{grid-template-columns:1fr}.project-feature{min-height:0;grid-template-rows:auto auto}.project-feature__media{aspect-ratio:16 / 9}.project-feature__body{padding:22px}.project-feature h3{font-size:2.15rem}.project-card{min-height:220px;padding:22px}.project-card__media{width:calc(100% + 44px);margin:-22px -22px 18px}.site-footer__inner{padding-bottom:36px}}@media(prefers-reduced-motion:reduce){.hero__still--bg,.hero__still--character,.hero__copy:after,.hero__copy .eyebrow,.hero__copy h1,.hero__lead,.hero__profile-link{animation:none}.hero__copy .eyebrow,.hero__copy h1,.hero__lead,.hero__profile-link{opacity:1;transform:none;filter:none}.hero__copy:after{transform:scaleY(1)}}
