*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--clay:#8b7355;--sand:#f4e8d0;--terracotta:#a0522d;--cream:#faf6f0;--ink:#3d3229;--font:'Shippori Mincho','Noto Serif JP',serif;--sans:'Noto Sans JP',sans-serif}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.75}
img{max-width:100%;display:block;object-fit:cover}
a{color:var(--terracotta)}
.ca-head{display:flex;align-items:center;padding:1rem 2rem;background:var(--sand);border-bottom:3px solid var(--clay);flex-wrap:wrap;position:sticky;top:0;z-index:50}
.logo{font-family:var(--font);font-size:1.5rem;text-decoration:none;color:var(--ink)}
.ca-head nav{display:flex;gap:1.25rem;margin-left:auto;flex-wrap:wrap}
.ca-head nav a{text-decoration:none;color:var(--ink);font-size:.9rem}
.menu{display:none;border:2px solid var(--clay);background:var(--cream);padding:.3rem .6rem;cursor:pointer;margin-left:1rem}
.hero-gallery{display:grid;grid-template-columns:1.1fr 1fr;min-height:65vh;gap:0}
.hero-text{padding:4rem 3rem;display:flex;flex-direction:column;justify-content:center;background:var(--sand)}
.hero-text h1{font-family:var(--font);font-size:clamp(1.9rem,4vw,2.8rem);line-height:1.4;margin:.75rem 0}
.hero-text .eyebrow{font-size:.8rem;letter-spacing:.2em;color:var(--clay)}
.hero-text p{margin-bottom:1.5rem}
.cta{display:inline-block;background:var(--terracotta);color:#fff;padding:.85rem 2rem;text-decoration:none;border-radius:2px}
.hero-visual img{width:100%;height:100%;min-height:400px}
.masonry-section{padding:4rem 2rem;max-width:1100px;margin:0 auto}
.masonry-section h2{font-family:var(--font);text-align:center;font-size:1.9rem;margin-bottom:.5rem}
.masonry-lead{text-align:center;margin-bottom:2.5rem;opacity:.85}
.masonry-grid{columns:2;column-gap:1.5rem}
.masonry-grid article{break-inside:avoid;margin-bottom:1.5rem;background:#fff;border:1px solid rgba(139,115,85,.35);padding:1rem;border-radius:4px}
.masonry-grid article.tall img{aspect-ratio:3/4}
.masonry-grid article.wide img{aspect-ratio:4/3}
.masonry-grid article img{width:100%;margin-bottom:.75rem;border-radius:2px}
.masonry-grid h3{font-family:var(--font);font-size:1.05rem}
.masonry-grid .price{font-weight:700;color:var(--terracotta);margin:.4rem 0}
.masonry-grid button{width:100%;border:1px solid var(--clay);background:var(--sand);padding:.55rem;cursor:pointer;font-family:inherit}
.masonry-grid button:hover{background:var(--clay);color:#fff}
.features{padding:4rem 2rem;background:var(--sand)}
.features h2{font-family:var(--font);text-align:center;margin-bottom:2rem}
.earth-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;max-width:1000px;margin:0 auto 2rem}
.earth-feats div{text-align:center;padding:1.25rem;background:var(--cream);border-radius:50% 50% 4px 4px / 20% 20% 4px 4px}
.earth-feats strong{display:block;font-size:1.8rem;color:var(--clay);font-family:var(--font)}
.studio-img{max-width:900px;margin:0 auto;display:block;border-radius:4px;box-shadow:8px 8px 0 var(--clay)}
.voices{padding:4rem 2rem;max-width:900px;margin:0 auto}
.voices h2{font-family:var(--font);text-align:center;margin-bottom:2rem}
.voices blockquote{margin-bottom:1.5rem;padding:1.5rem;border-left:5px solid var(--terracotta);background:#fff}
.voices cite{font-size:.85rem;opacity:.75}
.faq{padding:3rem 2rem 4rem;max-width:700px;margin:0 auto}
.faq h2{font-family:var(--font);margin-bottom:1.5rem}
.faq details{margin-bottom:1rem;padding:1rem;background:#fff;border:1px solid var(--clay)}
.faq summary{cursor:pointer;font-weight:600}
.legal{padding:3rem 2rem;background:var(--ink);color:var(--sand);font-size:.87rem}
.legal h3,.legal h4{color:#e8d4b8;margin:1.25rem 0 .5rem;font-family:var(--font)}
.legal dl{display:grid;grid-template-columns:8.5em 1fr;gap:.35rem .7rem}
.legal a{color:#e8d4b8}
.copy{margin-top:2rem;opacity:.6}
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(150%);background:var(--ink);color:var(--sand);padding:1rem 1.75rem;border-radius:4px;transition:transform .3s;z-index:99}
.toast.show{transform:translateX(-50%) translateY(0)}
@media(max-width:768px){
  .menu{display:block}
  .ca-head nav{display:none;width:100%;flex-direction:column}
  .ca-head nav.open{display:flex}
  .hero-gallery,.earth-feats{grid-template-columns:1fr}
  .masonry-grid{columns:1}
}
