*{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#f7f4ee;
  --paper2:#fffaf2;
  --ink:#20211f;
  --soft:#6c6a62;
  --line:#ded7cc;
  --green:#4f604a;
  --clay:#b47349;
  --white:#fff;
}
html{scroll-behavior:smooth}
body{font-family:"Noto Sans JP",sans-serif;color:var(--ink);background:var(--paper);line-height:1.9;font-weight:400}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.sample{position:fixed;top:0;left:50%;transform:translateX(-50%);z-index:40;background:rgba(32,33,31,.9);color:#fff;padding:6px 28px;font:700 11px/1 Inter,sans-serif;letter-spacing:.18em}
.site-header{position:fixed;top:26px;left:32px;right:32px;z-index:30;display:flex;align-items:center;gap:32px;padding:16px 22px;background:rgba(247,244,238,.72);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.5)}
.brand{display:flex;align-items:center;gap:12px;min-width:220px}
.brand-mark{width:42px;height:42px;border:1px solid var(--ink);display:grid;place-items:center;font-family:"Noto Serif JP",serif;font-size:20px}
.brand-name strong{display:block;font-size:17px;letter-spacing:.08em;line-height:1.1}
.brand-name span{display:block;font:600 10px/1.4 Inter,sans-serif;letter-spacing:.18em;color:var(--soft);margin-top:4px}
.nav{margin-left:auto;display:flex;align-items:center;gap:24px;font-size:13px;font-weight:600;letter-spacing:.08em}
.nav-cta{border:1px solid var(--ink);border-radius:999px;padding:10px 22px;background:rgba(255,255,255,.5)}
.page-hero{min-height:92svh;display:grid;grid-template-columns:1.02fr .98fr;gap:0;background:var(--paper2);padding-top:0}
.hero-copy{display:flex;flex-direction:column;justify-content:center;padding:120px 7vw 70px}
.kicker{font:700 12px/1 Inter,sans-serif;letter-spacing:.28em;color:var(--clay);margin-bottom:18px}
h1,.h1{font-family:"Noto Serif JP",serif;font-size:clamp(42px,5.7vw,82px);font-weight:500;line-height:1.18;letter-spacing:.04em;word-break:keep-all;overflow-wrap:normal;line-break:strict}
.nowrap{white-space:nowrap}
.hero-copy p{max-width:520px;margin-top:28px;color:var(--soft);font-size:15px;line-height:2.2}
.hero-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:1px solid var(--ink);border-radius:999px;padding:13px 26px;font-weight:700;font-size:14px;min-height:50px}
.btn.dark{background:var(--ink);color:#fff}
.hero-visual{min-height:92svh;background:linear-gradient(180deg,rgba(0,0,0,.02),rgba(0,0,0,.18)),url("https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=1800&q=86") center/cover;position:relative}
.hero-note{position:absolute;left:34px;bottom:34px;background:rgba(255,255,255,.82);backdrop-filter:blur(12px);padding:22px 24px;max-width:330px}
.hero-note b{font-family:"Noto Serif JP",serif;font-size:34px;font-weight:500;color:var(--green)}
.hero-note span{display:block;color:var(--soft);font-size:13px;margin-top:4px}
.section{padding:110px 6vw}
.section.alt{background:#fff}
.inner{max-width:1180px;margin:0 auto}
.section-head{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:end;margin-bottom:58px}
.section-head h2{font-family:"Noto Serif JP",serif;font-size:clamp(32px,4.1vw,56px);line-height:1.34;font-weight:500;letter-spacing:.04em;word-break:keep-all;overflow-wrap:normal;line-break:strict}
.section-head p{color:var(--soft);line-height:2.1}
.story-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:22px}
.story-photo{min-height:520px;background-size:cover;background-position:center}
.story-photo.main{background-image:url("https://images.unsplash.com/photo-1562259949-e8e7689d7828?auto=format&fit=crop&w=1400&q=86")}
.story-photo.sub{background-image:url("https://images.unsplash.com/photo-1518005020951-eccb494ad742?auto=format&fit=crop&w=900&q=86")}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.feature{min-height:300px;padding:34px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.42);display:flex;flex-direction:column;justify-content:space-between}
.feature-num{font-family:"Noto Serif JP",serif;font-size:52px;color:#cec4b6;line-height:1}
.feature h3{font-size:22px;margin-top:22px}
.feature p{font-size:14px;color:var(--soft);margin-top:12px}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case-card{background:var(--paper);transition:transform .25s ease}
.case-card:hover{transform:translateY(-4px)}
.case-card img{width:100%;aspect-ratio:4/5;object-fit:cover}
.case-body{padding:22px}
.case-body small{font:700 11px Inter,sans-serif;letter-spacing:.18em;color:var(--clay)}
.case-body h3{font-size:21px;margin:8px 0 4px}
.case-body p{font-size:14px;color:var(--soft)}
.journal{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.journal a{background:#fff;padding:30px;min-height:190px}
.journal small{font:700 11px Inter,sans-serif;letter-spacing:.2em;color:var(--clay)}
.journal h3{font-size:19px;line-height:1.6;margin-top:16px}
.page-title{padding:170px 6vw 74px;background:var(--paper2)}
.page-title .inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:end}
.page-title h1{font-size:clamp(42px,5vw,74px)}
.page-title p{color:var(--soft);line-height:2.1}
.subnav{display:flex;gap:10px;flex-wrap:wrap;margin-top:28px}
.subnav a{border:1px solid var(--line);border-radius:999px;padding:9px 18px;background:#fff;font-size:13px;font-weight:700}
.service-list{display:grid;gap:22px}
.service-item{display:grid;grid-template-columns:.8fr 1.2fr;gap:40px;padding:42px;background:#fff;border:1px solid var(--line)}
.service-item h2{font-family:"Noto Serif JP",serif;font-size:36px;font-weight:500}
.service-item p{color:var(--soft)}
.price-table{width:100%;border-collapse:collapse;margin-top:24px;background:#fff}
.price-table th,.price-table td{border-bottom:1px solid var(--line);padding:18px;text-align:left}
.price-table td:last-child{text-align:right;font-weight:800;color:var(--green)}
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.flow-step{background:#fff;padding:28px;border:1px solid var(--line);min-height:230px}
.flow-step b{font:700 34px/1 "Noto Serif JP",serif;color:#cec4b6}
.flow-step h3{font-size:20px;margin:18px 0 8px}
.flow-step p{font-size:14px;color:var(--soft)}
.contact-band{background:var(--green);color:#fff;padding:88px 6vw;text-align:center}
.contact-band h2{font-family:"Noto Serif JP",serif;font-size:clamp(30px,4vw,52px);font-weight:500;word-break:keep-all;overflow-wrap:normal;line-break:strict}
.contact-band p{max-width:680px;margin:20px auto 30px;color:rgba(255,255,255,.82)}
.contact-band .btn{border-color:rgba(255,255,255,.7)}
.contact-band .btn.dark{background:#fff;color:var(--green);border-color:#fff}
.footer{padding:36px 6vw;background:#fff;color:var(--soft);font-size:12px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
@media(max-width:900px){
  .site-header{top:18px;left:18px;right:18px;padding:14px;gap:10px}
  .brand{min-width:0}.brand-mark{width:42px;height:42px;flex:0 0 42px}.brand-name strong{font-size:16px}.brand-name span{font-size:10px}
  .nav{gap:0}.nav a:not(.nav-cta){display:none}.nav-cta{white-space:nowrap;padding:10px 14px;font-size:12px}
  h1,.h1,.section-head h2,.contact-band h2{word-break:normal;overflow-wrap:break-word}
  h1,.h1{font-size:clamp(36px,11vw,46px)}
  .nowrap{white-space:normal}
  .page-hero,.section-head,.story-grid,.page-title .inner,.service-item{grid-template-columns:1fr}
  .hero-copy{padding:130px 24px 54px}.hero-visual{min-height:58svh}.hero-note{left:20px;right:20px;bottom:20px}
  .section{padding:72px 24px}.feature-grid,.case-grid,.journal,.flow{grid-template-columns:1fr}
  .story-photo{min-height:360px}.page-title{padding:140px 24px 62px}
}
