:root{--color-bg: #EAE6DF;--color-surface: #F5F3EF;--color-primary: #1F1E1D;--color-secondary: #4A4744;--color-accent: #8A7E71;--font-serif: "Cormorant Garamond", "Noto Serif JP", serif;--font-sans: "Montserrat", sans-serif;--font-jp: "Noto Serif JP", serif;--spacing-sm: 1rem;--spacing-md: 2rem;--spacing-lg: 4rem;--spacing-xl: 8rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-jp);color:var(--color-primary);background-color:var(--color-bg);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}li{list-style:none}.container{max-width:1200px;margin:0 auto;padding:0 5%}.loader{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:var(--color-bg);z-index:9999;display:flex;justify-content:center;align-items:center;transition:opacity .8s cubic-bezier(.16,1,.3,1),visibility .8s}.loader.is-hidden{opacity:0;visibility:hidden}.loader-logo{height:40px;animation:pulse 2s infinite ease-in-out;filter:invert(1) brightness(.2)}@keyframes pulse{0%{transform:scale(.95);opacity:.5}50%{transform:scale(1.05);opacity:.9}to{transform:scale(.95);opacity:.5}}.section-title{font-family:var(--font-sans);font-size:1rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--spacing-lg);text-align:center}.navbar{position:fixed;top:0;left:0;width:100%;padding:2rem 5%;z-index:100;transition:transform .35s ease,opacity .25s ease,background-color .5s ease,padding .5s ease,backdrop-filter .5s ease;background-color:transparent;color:#fff;will-change:transform,opacity}.navbar.scrolled{background-color:#f7f5f2f2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:1.2rem 5%;color:var(--color-primary)}.nav-logo{height:40px;width:auto;opacity:.9;transition:transform .4s ease,filter .5s ease}.navbar.scrolled .nav-logo,.navbar.menu-open .nav-logo{filter:invert(1) brightness(.1)}.navbar.hidden{opacity:0;transform:translateY(calc(-100% - 16px));visibility:hidden;pointer-events:none}.nav-container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.nav-brand{font-family:var(--font-sans);font-size:1.2rem;font-weight:400;letter-spacing:.1em}.nav-menu{display:none}.menu-toggle{display:none;flex-direction:column;justify-content:space-between;width:28px;height:10px;cursor:pointer;z-index:1000;position:relative}.menu-toggle .bar{height:1px;width:100%;background-color:currentColor;transition:transform .4s cubic-bezier(.25,1,.5,1),background-color .4s;transform-origin:center}.menu-toggle.is-active .bar:nth-child(1){transform:translateY(4.5px) rotate(45deg)}.menu-toggle.is-active .bar:nth-child(2){transform:translateY(-4.5px) rotate(-45deg)}.nav-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#f5f3effa;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);z-index:99;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease}.nav-overlay.is-active{opacity:1;visibility:visible}.overlay-content{text-align:center}.overlay-content ul li{margin-bottom:2.5rem;overflow:hidden}.overlay-link{font-family:var(--font-sans);font-size:2rem;letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary);display:inline-block;transform:translateY(110%);transition:transform .8s cubic-bezier(.16,1,.3,1)}.nav-overlay.is-active .overlay-link{transform:translateY(0)}.overlay-content ul li:nth-child(1) .overlay-link{transition-delay:.1s}.overlay-content ul li:nth-child(2) .overlay-link{transition-delay:.2s}.overlay-content ul li:nth-child(3) .overlay-link{transition-delay:.3s}@media (min-width: 768px){.nav-menu{display:flex;gap:3rem}.nav-menu a{font-family:var(--font-sans);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;position:relative}.nav-menu a:after{content:"";position:absolute;width:0;height:1px;bottom:-4px;left:0;background-color:currentColor;transition:width .3s ease}.nav-menu a:hover:after{width:100%}}@media (max-width: 767px){.navbar{padding:1.25rem 5%}.nav-logo{height:34px}.menu-toggle{display:flex}}.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-image-wrapper{position:absolute;top:-10vh;left:0;width:100%;height:120vh;z-index:-2}.hero-bg{width:100%;height:100%;object-fit:cover;will-change:transform}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#28262366;z-index:-1}.hero-content{text-align:center;color:#fff;z-index:10;padding:0 2rem}.hero-eyebrow{display:block;font-family:var(--font-sans);font-size:.85rem;letter-spacing:.3em;margin-bottom:2rem;opacity:.8}.hero-title{font-family:var(--font-serif);font-size:clamp(2.5rem,5vw,5rem);font-weight:300;line-height:1.2;margin-bottom:2rem;letter-spacing:.05em}.hero-subtitle{font-family:var(--font-jp);font-size:1rem;letter-spacing:.2em;font-weight:300;opacity:.9}.about{padding:var(--spacing-xl) 0;background-color:var(--color-surface)}.about-wrapper{display:flex;flex-direction:column;gap:4rem;align-items:center;max-width:1000px;margin:0 auto}@media (min-width: 768px){.about-wrapper{flex-direction:row;align-items:flex-start}}.about-image{flex:1;width:100%}.about-image img{display:block;width:100%;height:auto;object-fit:cover;box-shadow:0 10px 30px #00000008}@media (max-width: 767px){.about-wrapper{gap:2rem}.about-image img{aspect-ratio:4 / 3;height:auto;object-position:center 32%}}.about-content{flex:1;text-align:left}.about-lead{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:300;line-height:1.6;margin-bottom:2rem;color:var(--color-primary)}.about-content p{font-size:.95rem;line-height:2.2;color:var(--color-secondary);margin-bottom:1.5rem}.expertise{padding:var(--spacing-xl) 0}.expertise-grid{display:grid;grid-template-columns:1fr;gap:3rem;max-width:1100px;margin:0 auto}@media (min-width: 768px){.expertise-grid{grid-template-columns:repeat(3,1fr);gap:2rem}}.expertise-box{background-color:var(--color-surface);padding:3.5rem 2.5rem;border-top:1px solid var(--color-accent);transition:transform .4s ease;position:relative;overflow:hidden}.expertise-box:hover{transform:translateY(-5px)}.expertise-num{font-family:var(--font-serif);font-size:7.5rem;line-height:.8;color:var(--color-accent);opacity:.1;position:absolute;top:-.5rem;right:.5rem;font-weight:300;pointer-events:none}.expertise-box h4{font-family:var(--font-sans);font-size:1.2rem;font-weight:400;letter-spacing:.05em;margin-bottom:1.5rem;color:var(--color-primary);position:relative;z-index:1}.expertise-box p{font-size:.95rem;line-height:1.9;color:var(--color-secondary);position:relative;z-index:1}.works{padding:var(--spacing-lg) 0 var(--spacing-xl);background-color:var(--color-surface)}.works-intro{text-align:center;margin-bottom:4rem;font-size:1rem;color:var(--color-secondary);letter-spacing:.1em}.work-card{display:flex;flex-direction:column;max-width:1000px;margin:0 auto;background-color:var(--color-bg);overflow:hidden;box-shadow:0 15px 40px #0000000a}@media (min-width: 768px){.work-card{flex-direction:row;align-items:center}}.work-image{flex:1;overflow:hidden}.work-image img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,1,.5,1)}.work-card:hover .work-image img{transform:scale(1.03)}.work-info{flex:1;padding:3rem;display:flex;flex-direction:column;justify-content:center}.work-category{font-family:var(--font-sans);font-size:.75rem;letter-spacing:.15em;color:var(--color-accent);text-transform:uppercase;margin-bottom:1rem}.work-title{font-family:var(--font-serif);font-size:2.5rem;font-weight:300;margin-bottom:1.5rem;color:var(--color-primary)}.work-desc{font-size:.95rem;line-height:2;color:var(--color-secondary);margin-bottom:2rem}.work-link{font-family:var(--font-sans);font-size:.85rem;letter-spacing:.1em;color:var(--color-primary);text-transform:uppercase;display:inline-flex;align-items:center;gap:.5rem;align-self:flex-start;position:relative}.work-link:after{content:"";position:absolute;width:0;height:1px;bottom:-4px;left:0;background-color:currentColor;transition:width .3s ease}.work-card:hover .work-link:after{width:100%}.footer{padding:var(--spacing-xl) 0;text-align:center;background-color:var(--color-primary);color:#eae6df}.footer h2{font-family:var(--font-serif);font-size:clamp(2rem,4vw,3rem);font-weight:300;margin-bottom:2rem}.footer-contact{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:4rem}.footer-email{font-family:var(--font-sans);font-size:1.2rem;letter-spacing:.05em;transition:opacity .3s ease}.status-badge{font-family:var(--font-sans);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;background-color:var(--color-accent);color:#fff;padding:.2rem .6rem;border-radius:20px;opacity:.8}.footer-email:hover{opacity:.7}.footer-copyright{font-family:var(--font-sans);font-size:.8rem;letter-spacing:.1em;color:var(--color-accent)}.reveal-fade{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.25,1,.5,1),transform 1s cubic-bezier(.25,1,.5,1)}.reveal-fade.is-visible{opacity:1;transform:translateY(0)}.delay-1{transition-delay:.2s}.delay-2{transition-delay:.4s}
