@charset "UTF-8";

/* ====== Tokens / Layout（共通） ====== */
:root{
  --accent:#1f8a3a;
  --text:#1b1b1b;
  --muted:#666;
  --card-bg:#fff;
  --shadow:0 2px 10px rgba(0,0,0,.06);
  --radius:14px;
  --container-w:min(960px,92vw);
}

.section-inner{ width:var(--container-w); margin:0 auto; }
.main-container{ width:var(--container-w)!important; margin:0 auto!important; }

/* ====== Breadcrumbs ====== */
.breadcrumbs{
  width:var(--container-w);
  margin:10px auto 0;
  font-size:.92rem; color:#666;
}
.breadcrumbs a{ color:inherit; text-decoration:underline; text-underline-offset:2px; }

/* ====== Hero（中央寄せ・帯） ====== */
.hero--sub .section-inner{ text-align:center; }
.page-title{ margin:12px 0 6px; }
.page-lead{ margin:0 0 10px; color:#333; }
.page-title-band{
  padding:24px 0 18px;
  background:
    radial-gradient(900px 260px at 50% 0,
      color-mix(in oklab, var(--accent) 9%, transparent) 0%,
      transparent 70%) #f7faf8;
}

/* タグ（チップ） */
.chip-row{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:10px; }
.chip{
  display:inline-block; padding:6px 10px; border-radius:999px;
  background:#eef7f0; color:#217c3b; font-size:.9rem; font-weight:600;
}

/* ボタン（統一） */
.btn-row{ display:flex; justify-content:center; gap:12px; margin-top:12px; }
.btn, .btn-outline{
  display:inline-block; padding:10px 20px; border-radius:999px;
  font-weight:700; text-decoration:none; border:2px solid transparent;
  transition:background .15s, color .15s, border-color .15s, transform .12s;
}
.btn{ background:var(--accent); color:#fff; border-color:var(--accent); }
.btn:hover{ filter:brightness(0.96); transform:translateY(-1px); }
.btn-outline{ background:transparent; color:var(--accent); border-color:var(--accent); }
.btn-outline:hover{ background:color-mix(in oklab, var(--accent) 12%, #fff); }

/* ====== Intro card（ヒーロー下の白カード） ====== */
.lead-intro .section-inner{ width:var(--container-w); margin:0 auto; }
.intro-card{
  background:#fff; border-radius:16px;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  padding:20px 22px;
}

/* ====== 共通 Card / グリッド ====== */
.card, .svc-card{
  background:var(--card-bg); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:20px;
}

.svc-grid{
  display:grid; grid-template-columns:1fr; gap:20px;
  padding:0; margin:32px 0; list-style:none;
}
@media (min-width:900px){ .svc-grid{ grid-template-columns:repeat(3,1fr); } }
.svc-card{ display:flex; flex-direction:column; justify-content:flex-start; min-height:160px; }
.svc-card h3{ margin:0 0 8px; font-size:1.1rem; font-weight:700; }
.svc-card p{ margin:0; line-height:1.7; }

/* ====== 当日の流れ（必要ページで使用） ====== */
.flow-section .section-inner{ width:var(--container-w); margin:0 auto; }
.flow-steps-min{
  display:grid; grid-template-columns:1fr; gap:20px;
  list-style:none; padding:0; margin:24px 0;
}
.flow-steps-min .card{
  display:flex; gap:14px; align-items:flex-start; border-radius:12px;
}
.flow-steps-min .step-badge{
  flex:0 0 auto; width:44px; height:44px; border-radius:50%;
  display:grid; place-items:center; font-weight:700;
  background:#e6f5ea; color:#208a3a;
}
.flow-steps-min .step-body h3{ font-size:1.05rem; margin:2px 0 6px; }
.flow-steps-min .step-body p{ margin:0; line-height:1.6; }

/* ====== 信頼性ブロック / チェックリスト（必要ページで使用） ====== */
.reliability .grid-3{ display:grid; grid-template-columns:1fr; gap:18px; }
@media (min-width:900px){ .reliability .grid-3{ grid-template-columns:repeat(3,1fr); } }
.reliability .card{ text-align:center; }
.reliability .card h3{ margin-bottom:6px; font-size:1.05rem; font-weight:700; }

.check-list{
  list-style:none; padding:0; margin:16px 0;
  display:grid; gap:10px;
}
.check-list li{ position:relative; padding-left:28px; line-height:1.6; }
.check-list li::before{
  content:"\2713"; position:absolute; left:0; top:0; color:var(--accent); font-weight:700;
}

/* === Chips: アウトライン付きに統一 === */
.chip-row{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:10px; }
.chip{
  display:inline-block;
  padding:.45em .9em;
  border-radius:999px;
  border:2px solid var(--accent);
  background:transparent;     /* うっすら塗りにしたければ #f4fbf6 などへ */
  color:var(--accent);
  font-weight:700;
  font-size:.92rem;
}
.chip:hover{
  background:color-mix(in oklab, var(--accent) 12%, #fff);
}
/* === パンくずまわりの余白調整 === */
main.page{ padding-top:0; margin-top:0; }              /* テーマ由来の上余白を無効化 */
.breadcrumbs{ margin:4px auto 0; padding:0; line-height:1.2; }  /* 10px→4pxに圧縮 */
/* svc-grid カード内の段落余白調整 */
.svc-grid .svc-card p {
  margin-top: .4em;
}

.viewer-demo {
  background:#fafafa;
  padding:40px 0;
  text-align:center;
}
.viewer-demo .demo-figure {
  max-width:800px;
  margin:0 auto;
}
.viewer-demo img {
  width:100%;
  height:auto;
  box-shadow:0 4px 16px rgba(0,0,0,0.12);
  border-radius:12px;
}
