*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}:root{--white:#faf9f7;--off-white:#f0eee9;--warm-gray:#c8c2b8;--mid-gray:#4a4540;--dark:#1a1816;--black:#0d0c0b;--accent:#b8a08a;--serif:'Cormorant Garamond', 'BIZ UDPMincho', 'Georgia', serif;--sans:'Outfit', 'Noto Sans JP', 'Helvetica Neue', sans-serif}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--sans);background:var(--white);color:var(--dark);font-weight:500;letter-spacing:.01em;line-height:1.7}::selection{background:var(--dark);color:var(--white)}nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:84px;padding:0 48px;display:flex;align-items:center;gap:48px;background:rgba(250,249,247,.64);backdrop-filter:blur(48px);-webkit-backdrop-filter:blur(48px);transition:height .5s cubic-bezier(.22,1,.36,1),box-shadow .5s ease,background .5s ease,opacity .4s ease,transform .4s ease}nav.nav-hidden{opacity:0;transform:translateY(-100%);pointer-events:none}.nav-spacer{flex:1}nav.scrolled{height:84px}.nav-logo{text-decoration:none;display:flex;align-items:center}.nav-logo-img{height:24px;width:auto}.nav-links{display:flex;gap:40px;list-style:none}.nav-links a{color:var(--dark);text-decoration:none;font-size:14px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;position:relative;padding-bottom:2px}.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--dark);transition:width .4s cubic-bezier(.25,.46,.45,.94)}.nav-links a:hover::after{width:100%}.nav-contact-btn{display:inline-flex;align-items:center;justify-content:center;padding:0 24px;height:48px;gap:16px;border-radius:50px;background-color:var(--dark);text-decoration:none;transition:background-color .4s ease;flex-shrink:0;font-size:14px;font-weight:500;letter-spacing:.03em;line-height:1.2;color:var(--white);white-space:nowrap}.nav-contact-btn:hover{background-color:var(--accent)}.icon-arrow{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1px solid rgba(255,255,255,.2);flex-shrink:0;transition:border-color .3s ease,transform .3s ease}.icon-arrow svg{width:8px;height:10px;fill:var(--warm-gray);transition:fill .3s ease}.project-title-bar{padding:160px 80px 48px;display:flex;align-items:flex-end;gap:40px}.project-back-link{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;border:1px solid rgba(138,130,121,.15);text-decoration:none;transition:border-color .4s ease,background .4s ease,transform .4s cubic-bezier(.22,1,.36,1);flex-shrink:0;margin-bottom:8px}.project-back-link:hover{border-color:var(--accent);background:rgba(184,160,138,6%);transform:translateX(-4px)}.project-back-link svg{width:8px;height:10px;fill:var(--mid-gray);transform:rotate(180deg)}.project-title-text{display:flex;align-items:baseline;gap:24px}.project-title-text h1{font-family:var(--serif);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:300;color:var(--dark);line-height:1.05;letter-spacing:-.01em}.project-title-text .project-year{font-family:var(--sans);font-size:13px;color:var(--warm-gray);letter-spacing:.12em;font-weight:400}.project-hero-img{width:calc(100% - 48px);margin:40px auto 0;aspect-ratio:16/8;overflow:hidden;border-radius:6px;position:relative}.project-hero-img::after{content:'';position:absolute;inset:0;border:1px solid rgba(0,0,0,5%);border-radius:inherit;pointer-events:none;z-index:2}.project-hero-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 6s cubic-bezier(.25,.46,.45,.94)}.project-hero-img.visible img{transform:scale(1.02)}.project-hero-img.reveal{transform:translateY(24px)}.project-overview{padding:0 80px;margin:100px 0 120px}.project-overview-header{display:flex;align-items:center;gap:24px;margin-bottom:64px}.project-overview-label{font-family:var(--sans);font-size:11px;letter-spacing:.2em;color:var(--warm-gray);text-transform:uppercase;font-weight:500;flex-shrink:0}.project-overview-line{flex:1;height:1px;background:rgba(0,0,0,.15)}.project-overview-body{display:grid;grid-template-columns:1fr 1fr;gap:80px}.project-meta-list{display:flex;flex-direction:column;gap:0}.project-meta-item{display:grid;grid-template-columns:120px 1fr;align-items:baseline;padding:20px 0;border-bottom:1px solid rgba(0,0,0,.12)}.project-meta-item:first-child{padding-top:0}.project-meta-item:last-child{border-bottom:none}.project-meta-item dt{font-family:var(--sans);font-size:11px;color:var(--warm-gray);letter-spacing:.1em;text-transform:uppercase;font-weight:500}.project-meta-item dd{font-size:15px;font-weight:500;color:var(--dark);letter-spacing:.02em}.project-meta-item dd a{color:var(--dark);text-decoration:none;border-bottom:1px solid rgba(138,130,121,.2);transition:border-color .3s ease,color .3s ease}.project-meta-item dd a:hover{border-color:var(--accent);color:var(--accent)}.project-description{font-size:15px;font-weight:400;line-height:2.4;color:var(--mid-gray);letter-spacing:.03em}.project-gallery{padding:0 80px 120px;display:grid;grid-template-columns:1fr 1fr;gap:24px}.project-gallery-item{width:100%;aspect-ratio:4/3;border-radius:5px;overflow:hidden;position:relative}.project-gallery-item.is-wide{grid-column:1/-1;aspect-ratio:16/8}.project-gallery-item::after{content:'';position:absolute;inset:0;z-index:10;border:1px solid rgba(0,0,0,4%);border-radius:inherit;pointer-events:none}.project-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}.project-gallery-item:hover img{transform:scale(1.03)}.project-next{position:relative;display:flex;text-decoration:none;overflow:hidden;height:60vh;min-height:400px;align-items:center;justify-content:center}.project-next img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.25,.46,.45,.94),filter .8s ease;filter:grayscale(40%)brightness(.9)}.project-next:hover img{transform:scale(1.05);filter:grayscale(0%)brightness(1)}.project-next-overlay{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.project-next::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,12,11,.3),rgba(13,12,11,.6));z-index:1;transition:opacity .6s ease}.project-next:hover::before{opacity:.7}.project-next-label{font-family:var(--sans);font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.2em;margin-bottom:20px;text-transform:uppercase;font-weight:500}.project-next-title{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,4rem);font-weight:300;color:var(--white);letter-spacing:.02em;margin-bottom:32px;transition:letter-spacing .6s ease}.project-next:hover .project-next-title{letter-spacing:.06em}.project-next-arrow{width:56px;height:56px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;transition:border-color .4s ease,transform .4s cubic-bezier(.22,1,.36,1),background .4s ease}.project-next:hover .project-next-arrow{border-color:var(--accent);background:rgba(184,160,138,.15);transform:translateX(6px)}.project-next-arrow svg{width:10px;height:12px;fill:rgba(255,255,255,.6);transition:fill .4s ease}.project-next:hover .project-next-arrow svg{fill:var(--white)}footer{background:var(--white);overflow:hidden;position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end}.footer-marquee{padding:60px 0;border-top:1px solid rgba(0,0,0,6%);overflow:hidden;position:relative}.footer-marquee::before,.footer-marquee::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}.footer-marquee::before{left:0;background:linear-gradient(to right,var(--white),transparent)}.footer-marquee::after{right:0;background:linear-gradient(to left,var(--white),transparent)}.footer-marquee-track{display:flex;gap:0;animation:footerMarquee 25s linear infinite;width:max-content}.footer-marquee-item{font-family:var(--sans);font-size:clamp(3rem,6vw,5.5rem);font-weight:300;color:rgba(0,0,0,6%);letter-spacing:.04em;line-height:1;white-space:nowrap;user-select:none;padding:0 40px;transition:color .6s ease}.footer-marquee:hover .footer-marquee-item{color:rgba(0,0,0,.12)}.footer-marquee-item .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,6%);margin:0 48px;vertical-align:middle;transition:background .6s ease}.footer-marquee:hover .footer-marquee-item .dot{background:var(--accent);box-shadow:0 0 12px rgba(184,160,138,.3)}@keyframes footerMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}.footer-body{display:grid;grid-template-columns:1.2fr 1fr;gap:0;padding:120px 80px 100px;flex:1;align-content:center}.footer-left{display:flex;flex-direction:column;justify-content:space-between;padding-right:80px;border-right:1px solid rgba(0,0,0,6%);min-height:340px}.footer-brand-block{display:flex;flex-direction:column;gap:32px}.footer-logo-img{height:24px;width:auto;display:block;align-self:flex-start;opacity:.85;transition:opacity .4s ease}.footer-logo-img:hover{opacity:1}.footer-catchphrase{display:flex;flex-direction:column;gap:16px}.footer-catch-main{font-family:biz udpmincho,serif;font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:400;color:var(--dark);letter-spacing:.08em;line-height:1.6}.footer-catch-sub{font-family:biz udpmincho,serif;font-size:14px;font-weight:400;color:var(--warm-gray);line-height:2.2;max-width:320px;letter-spacing:.04em}.footer-social{display:flex;gap:20px;align-items:center}.footer-social a{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid rgba(0,0,0,8%);transition:border-color .4s ease,background .4s ease,transform .4s cubic-bezier(.22,1,.36,1)}.footer-social a:hover{border-color:var(--accent);background:rgba(184,160,138,8%);transform:translateY(-3px)}.footer-social-icon{width:16px;height:16px;opacity:.4;transition:opacity .4s ease}.footer-social a:hover .footer-social-icon{opacity:.8}.footer-right{padding-left:80px;display:flex;flex-direction:column;justify-content:space-between}.footer-nav-cols{display:grid;grid-template-columns:1fr 1fr;gap:48px}.footer-col-title{font-family:biz udpmincho,serif;font-size:13px;letter-spacing:.12em;color:var(--warm-gray);margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,6%)}.footer-col a{display:block;color:var(--mid-gray);text-decoration:none;font-size:14px;font-weight:500;margin-bottom:18px;transition:color .3s ease,transform .3s cubic-bezier(.22,1,.36,1),letter-spacing .3s ease;letter-spacing:.02em;position:relative}.footer-col a::before{content:'';position:absolute;left:-12px;top:50%;width:0;height:1px;background:var(--accent);transition:width .3s cubic-bezier(.22,1,.36,1);transform:translateY(-50%)}.footer-col a:hover{color:var(--dark);transform:translateX(6px);letter-spacing:.04em}.footer-col a:hover::before{width:8px}.footer-contact-block{padding-top:40px;border-top:1px solid rgba(0,0,0,6%)}.footer-contact-label{font-family:biz udpmincho,serif;font-size:12px;letter-spacing:.12em;color:var(--warm-gray);margin-bottom:14px}.footer-contact-email{font-family:var(--sans);font-size:18px;font-weight:400;color:var(--mid-gray);text-decoration:none;letter-spacing:.02em;transition:color .3s ease,letter-spacing .4s ease;position:relative}.footer-contact-email::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:width .5s cubic-bezier(.22,1,.36,1)}.footer-contact-email:hover{color:var(--dark);letter-spacing:.04em}.footer-contact-email:hover::after{width:100%}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:28px 80px;border-top:1px solid rgba(0,0,0,6%)}.footer-copy{font-size:11px;color:var(--warm-gray);letter-spacing:.08em}.footer-back-top{display:inline-flex;align-items:center;gap:8px;color:var(--mid-gray);text-decoration:none;font-size:11px;letter-spacing:.12em;transition:color .3s ease}.footer-back-top:hover{color:var(--dark)}.footer-back-top-arrow{width:28px;height:28px;border-radius:50%;border:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;transition:border-color .3s ease,transform .4s cubic-bezier(.22,1,.36,1)}.footer-back-top:hover .footer-back-top-arrow{border-color:var(--accent);transform:translateY(-3px)}.footer-back-top-arrow svg{width:8px;height:8px;fill:currentColor;transform:rotate(-90deg)}@media(max-width:768px){nav{padding:20px 32px}.nav-links{display:none}.project-title-bar{padding:120px 24px 32px;gap:20px}.project-title-text{flex-direction:column;gap:8px}.project-hero-img{width:calc(100% - 32px);margin-top:24px;aspect-ratio:16/10}.project-overview{padding:0 24px;margin:64px 0 80px}.project-overview-body{grid-template-columns:1fr;gap:48px}.project-meta-item{grid-template-columns:100px 1fr}.project-gallery{padding:0 24px 64px;grid-template-columns:1fr;gap:24px}.project-gallery-item.is-wide{aspect-ratio:16/10}.project-next{height:40vh;min-height:300px}.project-next-arrow{width:44px;height:44px}.footer-marquee-item{font-size:2.2rem;padding:0 24px}.footer-marquee-item .dot{margin:0 20px}.footer-body{grid-template-columns:1fr;padding:60px 24px 48px;gap:60px}.footer-left{padding-right:0;border-right:none;min-height:auto;border-bottom:1px solid rgba(0,0,0,6%);padding-bottom:60px}.footer-right{padding-left:0}.footer-bottom{padding:24px}}.reveal{opacity:0;transform:translateY(32px);transition:opacity 1s cubic-bezier(.25,.46,.45,.94),transform 1s cubic-bezier(.25,.46,.45,.94);transition-delay:var(--delay,0s)}.reveal.visible{opacity:1;transform:translateY(0)}