:root{
  --moss: #2f5d50;
  --moss-ink: #1e2c28;
  --moss-border: #E5EFEA;
  --ivory: #f6f8f4;
}

/* 全体 */
body{ font-family:'Noto Sans JP',sans-serif; line-height:1.8; background:#fff; color:#333; }
h1,h2,h3,h4{ font-weight:700; }

/* 本文デフォルトを .lead 相当に */
p{ font-size:1.25rem; }

/* Hero */
.hero{
  background:url("../images/hero.jpg") center/cover no-repeat;
  height:100vh; position:relative; color:#fff;
}
.hero::before{ content:""; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(0,0,0,.30), rgba(0,0,0,.30)); z-index:0; }
.hero .container{ position:relative; z-index:1; }
.hero-title{ line-height:1.3; }
.hero-title .hero-line{ display:block; white-space:nowrap; font-size:clamp(1.6rem,5.2vw,3rem); }
.hero-title .hero-sub{ display:block; white-space:nowrap; font-size:clamp(1.1rem,3vw,1.6rem); opacity:.95; letter-spacing:.02em; }
.hero h1, .hero .lead{ text-shadow:0 2px 6px rgba(0,0,0,.55), 0 1px 1px rgba(0,0,0,.9); }
.hero .btn{ border-radius:30px; }

/* PCは少し薄め */
@media (min-width: 992px){
  .hero::before{ background:linear-gradient(to bottom, rgba(0,0,0,.30), rgba(0,0,0,.30)); }
}

/* 汎用 */
img.rounded.shadow{ border-radius:15px; box-shadow:0 4px 12px rgba(0,0,0,.2); }
.btn-outline-light{ border-radius:30px; padding:12px 30px; }
footer.bg-dark{}

/* Evidence（背景画像） */
.evidence{ position:relative; background:url("../images/farm.jpg") center/cover no-repeat; color:#fff; }
.evidence::before{ content:""; position:absolute; inset:0; background:rgba(0,0,0,.30); }
.evidence .container{ position:relative; z-index:1; }
.evidence h3, .evidence .li{ text-shadow:0 2px 6px rgba(0,0,0,.55), 0 1px 1px rgba(0,0,0,.9); }
.evidence h3, .evidence p, .evidence li{ color:#fff; }

/* 白背景セクション＋見出し装飾 */
.section-onwhite{ background:#fff; color:var(--moss-ink); }
.section-onwhite .container{ position:relative; z-index:1; }
.section-title .leaf{ width:1.25em; height:1.25em; vertical-align:-.2em; margin-right:.35em; }
.section-title::after{ content:""; display:block; width:88px; height:3px; margin-top:.6rem; background:linear-gradient(90deg, var(--moss), transparent); border-radius:2px; }

/* 可読性（行長制御） */
.measure{ max-width:60ch; }

/* アドレス表示の体裁 */
address{ font-style:normal; }
