:root{
  --bg:#f3f5f2;
  --fg:#16201a;
  --muted:#5d6f64;
  --accent:#16a34a;
  --accent-2:#0f7a3a;
  --card:#ffffff;
  --soft:#fbfcfb;
  --line:#e3e7e3;
  --shadow:0 18px 50px rgba(20,40,28,.06);
  --font-body:"Inter",system-ui,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  color:var(--fg);
  background:var(--bg);
  min-height:100vh;
  line-height:1.7;
}

a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.page{padding:26px 18px 70px}
.main{max-width:1100px;margin:0 auto}

.hero{
  max-width:1100px;
  margin:0 auto 22px;
  border-radius:18px;
  border:1px solid var(--line);
  border-left:5px solid var(--accent);
  background:var(--card);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.hero-inner{padding:30px;text-align:left}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
  font-weight:850;
  color:var(--accent-2);
  margin:0 0 12px;
}

.display{
  font-size:clamp(26px,4vw,44px);
  line-height:1.2;
  letter-spacing:0;
  margin:0 0 12px;
  font-weight:850;
}

h1,h2,h3{letter-spacing:0}
.section-title{font-size:clamp(24px,3vw,36px);line-height:1.2;margin:0;font-weight:850}

.lede{
  max-width:760px;
  margin:0 0 18px;
  color:var(--muted);
  font-size:15px;
}

.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 10px}
.pill{
  border:1px solid var(--line);
  padding:6px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--muted);
  background:#eef2ee;
}

.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 15px;
  border-radius:8px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--fg);
  font-weight:750;
  letter-spacing:0;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent-2)}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(20,40,28,.12);text-decoration:none}

.panel{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  padding:22px;
  margin:24px 0;
}

.panel-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}
.panel-head h1,.panel-head h2{margin:0;font-weight:850}

.grid{display:grid;gap:16px;margin-top:18px}
@media (min-width:860px){.grid{grid-template-columns:repeat(3,1fr)}}

.card{
  background:var(--soft);
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px;
  min-height:190px;
}
.card h3{margin:0 0 8px;font-size:16px}
.card p{margin:0;color:var(--muted)}

.card-link{display:block;transition:transform .2s ease, border-color .2s ease, background .2s ease}
.card-link:hover{color:var(--fg);transform:translateY(-1px);border-color:#bcd8c4;background:#f7faf7;text-decoration:none}

.icon{
  width:44px;
  height:44px;
  border-radius:12px;
  background:#eef2ee;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:12px;
  color:var(--accent);
}
.icon svg{width:26px;height:26px}

.facts{display:grid;gap:12px;margin:18px 0 0;padding:0}
@media (min-width:720px){.facts{grid-template-columns:repeat(2,1fr)}}
.facts div{
  border:1px dashed var(--line);
  border-radius:12px;
  padding:12px 14px;
  background:var(--soft);
}
.facts dt{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}
.facts dd{margin:6px 0 0;font-weight:600}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--line);
  padding:6px 12px;
  border-radius:999px;
  font-size:12px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
  font-weight:800;
  background:#eef2ee;
}

.figure{margin:0}
.figure img{border-radius:14px;border:1px solid var(--line);background:var(--soft)}
.figure figcaption{margin-top:8px;text-align:center;color:var(--muted);font-size:12px}

.notice{
  margin:0 0 14px;
  border-left:4px solid var(--accent);
  background:rgba(22,163,74,.06);
  padding:12px 14px;
  border-radius:10px;
  color:var(--muted);
}

.rules{margin:0;padding-left:18px;color:var(--muted)}
.rules li{margin:6px 0}

.code-block{
  margin:0;
  padding:12px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--soft);
  color:var(--muted);
  font-size:12px;
  white-space:pre-wrap;
  word-break:break-word;
}

.record-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}

.map-embed{
  display:block;
  width:100%;
  min-height:620px;
  height:min(78vh,820px);
  margin-top:18px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#f3f5f2;
}

.stack{display:flex;flex-direction:column;gap:10px}
.muted{color:var(--muted);margin:6px 0 0}

.footer{margin-top:36px;text-align:center;color:var(--muted);font-size:12px}

.hero-inner > *{opacity:0;transform:translateY(12px);animation:rise .6s ease forwards}
.hero-inner > *:nth-child(2){animation-delay:.05s}
.hero-inner > *:nth-child(3){animation-delay:.1s}
.hero-inner > *:nth-child(4){animation-delay:.15s}
.hero-inner > *:nth-child(5){animation-delay:.2s}

@keyframes rise{to{opacity:1;transform:translateY(0)}}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
}
