/* ========= Re:moa Blog — shared styles ========= */
:root{
  --ink:#222222;
  --ink-soft:#3a3a36;
  --accent:#D32F2F;
  --cream:#EDE6DA;
  --paper:#F7F6F3;
  --olive:#7D8451;
  --olive-deep:#5f6640;
  --olive-soft:#A9A48F;
  --line:#d8d4c5;
  --line-soft:#e8e3d3;
  --serif: "Noto Serif JP","游明朝","Yu Mincho","Hiragino Mincho ProN","ヒラギノ明朝 ProN",serif;
  --sans:  "Noto Sans JP","游ゴシック","Yu Gothic","Hiragino Sans","ヒラギノ角ゴ",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);color:var(--ink);background:#fff;
  -webkit-font-smoothing:antialiased;line-height:1.9;
  font-feature-settings:"palt";
}
img{max-width:100%;display:block}
a{color:var(--olive-deep)}

/* ===== Nav ===== */
.nav{
  position:sticky;top:0;z-index:30;background:rgba(255,255,255,.94);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  max-width:1080px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;gap:24px;
}
.logo{display:inline-block;text-decoration:none;color:var(--ink);line-height:0}
.logo img{height:54px;width:auto;display:block}
.nav-links{display:flex;gap:24px;font-size:13px;letter-spacing:.08em;color:var(--ink-soft)}
.nav-links a{color:inherit;text-decoration:none}
.nav-links a:hover{color:var(--olive-deep)}
.nav-cta{
  font-family:var(--serif);font-size:13px;letter-spacing:.14em;
  background:var(--olive);color:#fff;border-radius:999px;
  padding:10px 20px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;
}
.nav-cta:hover{background:var(--olive-deep)}

/* ===== Layout ===== */
.wrap{max-width:1080px;margin:0 auto;padding:0 28px}
.page-head{padding:64px 28px 40px;text-align:center;background:var(--paper);border-bottom:1px solid var(--line-soft)}
.page-head .eyebrow{
  font-family:var(--serif);font-size:12px;letter-spacing:.5em;color:var(--olive-deep);margin-bottom:14px;
}
.page-head h1{
  font-family:var(--serif);font-weight:500;font-size:38px;letter-spacing:.04em;margin:0 0 14px;color:var(--ink);
}
.page-head p{
  font-family:var(--serif);color:var(--ink-soft);margin:0 auto;max-width:560px;font-size:14.5px;letter-spacing:.04em;
}
.crumbs{
  font-size:12px;letter-spacing:.1em;color:var(--olive-deep);margin-bottom:24px;
}
.crumbs a{color:inherit;text-decoration:none;border-bottom:1px solid transparent}
.crumbs a:hover{border-color:var(--olive)}
.crumbs span{margin:0 .5em;opacity:.5}

/* ===== Index list ===== */
.post-list{display:grid;grid-template-columns:repeat(2,1fr);gap:36px;padding:64px 0 96px}
.post-card{
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
  background:#fff;border:1px solid var(--line-soft);border-radius:8px;overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease;
}
.post-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -20px rgba(80,80,40,.22)}
.post-card .thumb{
  aspect-ratio:16/10;background:var(--paper);position:relative;
  display:flex;align-items:center;justify-content:center;color:var(--olive);
  border-bottom:1px solid var(--line-soft);
}
.post-card .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.post-card .thumb image-slot{position:absolute;inset:0;width:100%;height:100%;display:block}
.post-card .thumb svg{width:64px;height:64px;opacity:.7}
.post-card .thumb .tag{
  position:absolute;left:18px;top:18px;background:#fff;z-index:2;
  font-family:var(--serif);font-size:11px;letter-spacing:.18em;color:var(--olive-deep);
  padding:5px 12px;border:1px solid var(--line);border-radius:3px;
}
.post-card .body{padding:26px 28px 30px;display:flex;flex-direction:column;flex:1}
.post-card time{
  font-family:var(--serif);font-size:12px;letter-spacing:.16em;color:var(--olive-deep);
}
.post-card h2{
  font-family:var(--serif);font-weight:500;font-size:20px;line-height:1.6;margin:8px 0 10px;
  letter-spacing:.04em;color:var(--ink);
}
.post-card .excerpt{
  font-size:13.5px;line-height:1.95;color:var(--ink-soft);letter-spacing:.04em;margin:0 0 16px;flex:1;
}
.post-card .more{
  font-family:var(--serif);font-size:13px;letter-spacing:.16em;color:var(--olive-deep);
}
.post-card .more::after{content:" →"}

/* ===== Article ===== */
.article-hero{
  background:var(--paper);padding:0 0 56px;border-bottom:1px solid var(--line-soft);
}
.article-hero-photo{
  width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:var(--cream);
}
.article-hero image-slot.article-hero-photo{
  width:100%;height:auto;aspect-ratio:16/9;display:block;background:var(--cream);
}
.article-hero-inner{max-width:780px;margin:0 auto;padding:48px 28px 0}
.article-meta{
  font-family:var(--serif);font-size:12px;letter-spacing:.18em;color:var(--olive-deep);
  margin-bottom:18px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;
}
.article-meta .cat{background:var(--olive-deep);color:#fff;padding:4px 12px;border-radius:3px;letter-spacing:.2em}
.article-hero h1{
  font-family:var(--serif);font-weight:500;font-size:34px;line-height:1.55;letter-spacing:.04em;margin:0;color:var(--ink);
}
.article{
  max-width:720px;margin:0 auto;padding:64px 28px 80px;
}
.article p{
  font-family:var(--serif);font-size:16px;line-height:2.05;color:var(--ink-soft);
  letter-spacing:.04em;margin:0 0 1.6em;
}
.article p strong{color:var(--ink);font-weight:500}
.article h2{
  font-family:var(--serif);font-weight:500;font-size:24px;letter-spacing:.04em;color:var(--ink);
  margin:3em 0 .9em;padding-bottom:.4em;border-bottom:1px solid var(--ink);
}
.article h3{
  font-family:var(--serif);font-weight:500;font-size:18px;letter-spacing:.04em;color:var(--ink);
  margin:2.4em 0 .7em;
}
.article ul{
  font-family:var(--serif);font-size:15.5px;line-height:2;color:var(--ink-soft);
  padding-left:1.4em;margin:0 0 1.8em;
}
.article ul li{margin:.2em 0;letter-spacing:.04em}
.article hr{
  border:none;height:1px;background:var(--line);margin:3em auto;width:80px;
}
.article .lead{
  font-family:var(--serif);font-size:17px;line-height:2.1;color:var(--ink);margin:0 0 2em;letter-spacing:.04em;
}
.callout{
  margin:2.4em 0;padding:28px 32px;background:var(--paper);border-left:3px solid var(--olive);border-radius:0 6px 6px 0;
}
.callout p{margin:0;font-size:15px;line-height:2}
.callout p+p{margin-top:.8em}

/* CTA at end of article */
.post-cta{
  margin:3em auto 0;max-width:720px;background:var(--paper);
  border:1px solid var(--line-soft);border-radius:8px;padding:40px 36px;text-align:center;
}
.post-cta .small{
  font-family:var(--serif);font-size:11px;letter-spacing:.4em;color:var(--olive-deep);margin-bottom:10px;
}
.post-cta h3{
  font-family:var(--serif);font-weight:500;font-size:22px;line-height:1.7;margin:0 0 14px;color:var(--ink);
}
.post-cta p{
  font-family:var(--serif);font-size:14px;color:var(--ink-soft);line-height:1.95;margin:0 0 22px;letter-spacing:.04em;
}
.btn{
  font-family:var(--serif);font-size:14px;letter-spacing:.18em;
  padding:16px 32px;border-radius:999px;text-decoration:none;
  display:inline-flex;align-items:center;gap:12px;cursor:pointer;border:none;
  transition:all .25s ease;background:var(--olive);color:#fff;
}
.btn:hover{background:var(--olive-deep)}
.btn .arrow{font-family:var(--sans);font-weight:300;font-size:16px}

/* Related */
.related{
  max-width:1080px;margin:0 auto;padding:24px 28px 80px;
}
.related h2{
  font-family:var(--serif);font-weight:500;font-size:18px;letter-spacing:.18em;color:var(--olive-deep);
  text-align:center;margin:0 0 28px;
}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.related .post-card .body{padding:20px 22px 22px}
.related .post-card h2{font-size:16px;margin:6px 0 6px;border:none;padding:0;text-align:left;letter-spacing:.04em}
.related .thumb{aspect-ratio:16/9}
.related .thumb svg{width:48px;height:48px}

/* Footer */
footer{
  background:var(--ink);color:#cfcfc4;padding:60px 28px 28px;font-family:var(--serif);
}
.foot-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px}
footer h4{
  font-family:var(--serif);font-weight:500;font-size:12px;letter-spacing:.4em;color:#fff;margin:0 0 14px;
}
footer ul{list-style:none;padding:0;margin:0;font-size:13px;line-height:2.1;letter-spacing:.04em}
footer a{color:#cfcfc4;text-decoration:none}
footer a:hover{color:#fff}
.foot-brand p{font-size:13px;line-height:2;letter-spacing:.04em;margin:14px 0 0;color:#a8a89a}
.foot-bottom{
  max-width:1080px;margin:48px auto 0;padding-top:22px;border-top:1px solid #333;
  display:flex;justify-content:space-between;font-size:11px;letter-spacing:.2em;color:#888;
}

@media (max-width:760px){
  .post-list,.related-grid{grid-template-columns:1fr;gap:24px}
  .article-hero h1{font-size:26px}
  .page-head h1{font-size:28px}
  .article p,.article ul{font-size:15px}
  .foot-inner{grid-template-columns:1fr;gap:28px}
  .foot-bottom{flex-direction:column;gap:8px}
  .nav-links{display:none}
}
