/* =====================================================================
   ランディングページ専用デザイン（Modern SaaS / Stripe・Linear 系）
   - アプリの狭いコンテナ・下部タブバーから独立した全幅レイアウト
   - .page-lp 配下のみに適用
   ===================================================================== */

:root {
  /* 配色・影・角丸は styles.css :root（全ページ共通）の --brand 系を単一の出どころとし、
     ここでは LP 内の既存 --lp-* 名を保つためのエイリアスに統一（値の二重定義を解消）。 */
  --lp-ink: var(--ink);
  --lp-ink-soft: var(--ink-soft);
  --lp-line: var(--brand-line);
  --lp-bg-alt: var(--brand-bg-alt);
  --lp-accent: var(--brand);
  --lp-accent-2: var(--brand-2);
  --lp-accent-rgb: var(--brand-rgb);
  --lp-gold: var(--gold);
  --lp-gold-rgb: var(--gold-rgb);
  --lp-shadow-sm: var(--elev-sm);
  --lp-shadow-md: var(--elev-md);
  --lp-shadow-lg: var(--elev-lg);
  --lp-radius: var(--r-lg);
  --lp-radius-sm: var(--r-md);
  --lp-maxw: 1120px;          /* LP 専用レイアウト幅（ブランドトークンではない） */
}

/* ---- ページの土台（アプリのコンテナ制約を解除） ---- */
body.page-lp {
  padding: 0 !important;
  background: #ffffff;
  color: var(--lp-ink);
  -webkit-font-smoothing: antialiased;
  /* 共通CSSは body を中央寄せ＆子要素を max-width 制限するため、LPでは全幅に戻す */
  align-items: stretch !important;
}

/* 共通CSS `body > * { width:100%; max-width: var(--content-max) }` を無効化し全幅に */
body.page-lp > .lp {
  width: 100% !important;
  max-width: none !important;
}

.page-lp .lp {
  display: flex;
  flex-direction: column;
}

.page-lp .lp-container {
  width: 100%;
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 40px);
}

/* リンク色をLP側で制御（共通CSSの灰色リンクを上書き） */
.page-lp a {
  color: var(--lp-accent);
  text-decoration: none;
}

/* =========================== Top nav =========================== */
.lp-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--lp-line);
}

.lp-nav-inner {
  height: 64px;
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 40px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.lp-logo {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  font-weight: 800;
  font-size: 1.55rem;
  color: var(--lp-ink) !important;
  letter-spacing: -0.01em;
}

.lp-logo-mark {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 10px rgba(var(--lp-accent-rgb), 0.3);
}

.lp-logo-mark img {
  width: 100%;
  height: 100%;
  display: block;
}

.lp-nav-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.lp-nav-links {
  display: none;
  gap: 22px;
  margin-right: 10px;
}

.lp-nav-links a {
  color: var(--lp-ink-soft) !important;
  font-size: 0.9rem;
  font-weight: 600;
}

.lp-nav-links a:hover {
  color: var(--lp-ink) !important;
}

@media (min-width: 760px) {
  .lp-nav-links {
    display: inline-flex;
  }
}

/* スマホ幅: ロゴ＋ボタンが横にあふれて全体がズームアウトするのを防ぐ。
   px固定ではなく内容を画面幅に収め、ロゴを一回り小さく。 */
@media (max-width: 520px) {
  .lp-nav-inner {
    height: 56px;
    gap: 8px;
    padding: 0 14px;
  }
  .lp-logo {
    font-size: 1.2rem;
    gap: 8px;
    min-width: 0;          /* flex 子が内容幅以下に縮める */
  }
  .lp-logo-mark {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    flex: 0 0 auto;
  }
  .lp-nav-right {
    gap: 6px;
    flex: 0 0 auto;
  }
  .lp-nav-right .lp-btn-sm {
    padding: 7px 12px;
    font-size: 0.82rem;
  }
}

/* =========================== Buttons =========================== */
/* .lp-btn 系の基本定義は styles.css の「ブランド共有コンポーネント」へ昇格
   （.btn-brand と併記）。LP 固有の文脈上書きのみ下方の .lp-cta 等に残す。 */

/* =========================== Hero =========================== */
.lp-hero {
  position: relative;
  width: 100%;
  overflow: hidden;
  background:
    radial-gradient(900px 420px at 78% -8%, rgba(var(--lp-gold-rgb), 0.1), transparent 60%),
    radial-gradient(720px 380px at 10% 6%, rgba(var(--lp-accent-rgb), 0.1), transparent 55%),
    #ffffff;
}

.lp-hero-inner {
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: clamp(56px, 9vw, 104px) clamp(20px, 5vw, 40px) clamp(48px, 7vw, 80px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(36px, 6vw, 56px);
  align-items: center;
}

@media (min-width: 940px) {
  .lp-hero-inner {
    grid-template-columns: 1.05fr 0.95fr;
  }
}

.lp-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 13px;
  border-radius: 999px;
  background: rgba(var(--lp-accent-rgb), 0.08);
  border: 1px solid rgba(var(--lp-accent-rgb), 0.16);
  color: var(--lp-accent);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-bottom: 22px;
}

.lp-eyebrow i {
  min-width: 1em;
  text-align: center;
  font-size: 11px;
}

.lp-h1 {
  margin: 0 0 20px;
  font-size: clamp(2.1rem, 5.4vw, 3.4rem);
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--lp-ink);
}

/* グラデ見出しは“テンプレ臭”の元なのでベタの濃ブルーに。
   グラデはロゴchipと主要CTAボタンだけに限定する。 */
.lp-h1 .lp-h1-grad {
  color: #0c6e50;
}

.lp-sub {
  margin: 0 0 30px;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.75;
  color: var(--lp-ink-soft);
  max-width: 34em;
}

.lp-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

/* 末尾CTAなど中央寄せにしたい行 */
.lp-cta-row--center {
  justify-content: center;
}

.lp-hero-note {
  margin: 16px 0 0;
  font-size: 0.83rem;
  color: #94a3b8;
}

.lp-hero-note i {
  color: #16a34a;
  margin-right: 5px;
}

/* ---- Hero の擬似プロダクトプレビュー（画像不要・CSSで作成） ---- */
.lp-hero-visual {
  position: relative;
}

/* ヒーロー画像に重なる浮遊バッジ（唯一現役の .lp-mock 系） */
.lp-mock-float {
  position: absolute;
  right: -10px;
  bottom: -16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: 12px;
  box-shadow: var(--lp-shadow-md);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--lp-ink);
}

.lp-mock-float i {
  color: #16a34a;
}

@media (max-width: 520px) {
  .lp-mock-float { display: none; }
}

/* =========================== Trust strip =========================== */
.lp-strip {
  border-top: 1px solid var(--lp-line);
  border-bottom: 1px solid var(--lp-line);
  background: var(--lp-bg-alt);
}

.lp-strip-inner {
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: 18px clamp(20px, 5vw, 40px);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 28px;
}

.lp-strip-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--lp-ink-soft);
}

.lp-strip-item i {
  min-width: 1em;
  text-align: center;
  color: var(--lp-accent);
}

/* =========================== Section base =========================== */
.lp-section {
  width: 100%;
  padding: clamp(56px, 8vw, 96px) 0;
}

.lp-section--alt {
  background: var(--lp-bg-alt);
  border-top: 1px solid var(--lp-line);
  border-bottom: 1px solid var(--lp-line);
}

.lp-head {
  text-align: center;
  max-width: 40em;
  margin: 0 auto clamp(32px, 5vw, 52px);
}

/* .lp-kicker / .lp-h2 の基本定義は styles.css の「ブランド共有コンポーネント」へ昇格
   （.brand-kicker / .brand-h2 と併記）。LP 固有の上書きは .lp-founder .lp-h2 等に残す。 */

.lp-lead {
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}

/* =========================== Problems =========================== */
.lp-problems {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 720px) {
  .lp-problems { grid-template-columns: repeat(3, 1fr); }
}

/* アイコン左・テキスト右のメディアオブジェクト型（アイコン行の右余白を作らない） */
.lp-problem {
  display: flex;
  align-items: center;
  gap: 16px;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 22px;
}

.lp-problem-ico {
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #dc2626;
  background: linear-gradient(135deg, rgba(220, 38, 38, 0.1), rgba(234, 88, 12, 0.1));
}

.lp-problem p {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}

/* =========================== Steps =========================== */
.lp-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 760px) {
  .lp-steps { grid-template-columns: repeat(3, 1fr); }
}

/* 数字バッジ左・本文右の2カラムグリッド（数字行の右余白を作らない） */
.lp-step {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 16px;
  align-content: center;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 24px 22px;
}

.lp-step-n {
  grid-row: 1 / span 2;
  align-self: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 1.05rem;
  color: #fff;
  background: var(--lp-accent);
  box-shadow: 0 6px 14px rgba(var(--lp-accent-rgb), 0.28);
}

.lp-step h3 {
  margin: 0 0 6px;
  align-self: end;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--lp-ink);
}

.lp-step p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}

/* =========================== Capabilities =========================== */
.lp-caps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

@media (min-width: 720px) {
  .lp-caps { grid-template-columns: repeat(4, 1fr); }
}

.lp-cap {
  display: flex;
  align-items: center;
  gap: 11px;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius-sm);
  box-shadow: var(--lp-shadow-sm);
  padding: 16px 16px;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--lp-ink);
}

.lp-cap i {
  min-width: 1.2em;
  text-align: center;
  font-size: 17px;
  color: var(--lp-accent);
}

/* =========================== Pricing (3 plans) =========================== */
/* 月額/年額トグル（CSSのみ・チェックボックス連動） */
.lp-bill-input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.lp-bill {
  display: flex;
  width: max-content;
  margin: 0 auto clamp(28px, 4vw, 40px);
  background: #eef1f6;
  border: 1px solid var(--lp-line);
  border-radius: 999px;
  padding: 4px;
  gap: 4px;
}

.lp-bill-seg {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--lp-ink-soft);
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.lp-bill-seg em {
  font-style: normal;
  font-size: 11px;
  font-weight: 800;
  color: #0f9d58;
  background: rgba(22, 163, 74, 0.12);
  padding: 2px 8px;
  border-radius: 999px;
}

/* 既定（未チェック）= 月額がアクティブ */
.lp-bill-seg--m {
  background: #fff;
  color: var(--lp-ink);
  box-shadow: var(--lp-shadow-sm);
}

/* チェック時 = 年額がアクティブ */
.lp-bill-input:checked ~ .lp-bill .lp-bill-seg--m {
  background: transparent;
  color: var(--lp-ink-soft);
  box-shadow: none;
}

.lp-bill-input:checked ~ .lp-bill .lp-bill-seg--y {
  background: #fff;
  color: var(--lp-ink);
  box-shadow: var(--lp-shadow-sm);
}

.lp-bill-input:focus-visible ~ .lp-bill {
  outline: 2px solid var(--lp-accent);
  outline-offset: 3px;
}

.lp-plans {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
}

@media (min-width: 860px) {
  .lp-plans { grid-template-columns: repeat(3, 1fr); }
}

.lp-plan {
  position: relative;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 30px 26px;
}

.lp-plan--featured {
  border: 2px solid var(--lp-accent);
  box-shadow: 0 18px 44px rgba(var(--lp-accent-rgb), 0.18);
}

@media (min-width: 860px) {
  .lp-plan--featured { transform: translateY(-12px); }
}

.lp-plan-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  background: var(--lp-gold);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.02em;
  padding: 5px 14px;
  border-radius: 999px;
  box-shadow: 0 6px 14px rgba(var(--lp-gold-rgb), 0.32);
}

.lp-plan-name {
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: var(--lp-ink);
}

.lp-plan-price {
  margin: 10px 0 4px;
}

.lp-pv {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.lp-pv b {
  font-size: 2.5rem;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--lp-ink);
}

.lp-pv .u {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--lp-ink-soft);
}

/* 既定は月額表示。年額トグル時に切替 */
.lp-pv--y { display: none; }
.lp-bill-input:checked ~ .lp-plans .lp-pv--m { display: none; }
.lp-bill-input:checked ~ .lp-plans .lp-pv--y { display: flex; }

.lp-plan-permonth {
  display: none;
  margin: 0 0 2px;
  font-size: 0.8rem;
  font-weight: 700;
  color: #0f9d58;
}

.lp-bill-input:checked ~ .lp-plans .lp-plan-permonth { display: block; }

.lp-plan-desc {
  margin: 6px 0 20px;
  font-size: 0.86rem;
  color: var(--lp-ink-soft);
}

.lp-plan-cta {
  width: 100%;
  margin-bottom: 22px;
}

/* 機能：値 形式の一覧 */
.lp-plan-feats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.lp-plan-feats li {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 9px;
  font-size: 0.9rem;
  line-height: 1.4;
  color: var(--lp-ink);
}

.lp-plan-feats li > i {
  color: #16a34a;
  min-width: 1.1em;
  text-align: center;
  font-size: 13px;
}

.lp-plan-feats li > b {
  font-weight: 800;
  color: var(--lp-ink);
  white-space: nowrap;
}

.lp-plan-feats li > b::before {
  content: "：";
  font-weight: 400;
  color: var(--lp-ink-soft);
}

.lp-v-hl {
  color: var(--lp-accent) !important;
}

/* ローンチ記念オファー（初月無料 など） */
.lp-promo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  padding: 8px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(22, 163, 74, 0.12), rgba(13, 148, 136, 0.12));
  border: 1px solid rgba(22, 163, 74, 0.25);
  color: #0f7a43;
  font-size: 0.88rem;
  font-weight: 700;
}

.lp-promo i { color: #16a34a; }
.lp-promo strong { color: #0c6b3a; }

.lp-plan-offer {
  margin: -14px 0 18px;
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 0.82rem;
  font-weight: 800;
  color: #0f9d58;
}

.lp-plan-offer i {
  color: #16a34a;
  min-width: 1em;
  text-align: center;
}

.lp-plan-limit {
  margin: 16px 0 0;
  padding-top: 14px;
  border-top: 1px dashed var(--lp-line);
  font-size: 0.8rem;
  color: var(--lp-ink-soft);
  display: flex;
  align-items: center;
  gap: 7px;
}

.lp-plan-limit i {
  min-width: 1em;
  text-align: center;
  color: #94a3b8;
}

.lp-plans-note {
  text-align: center;
  margin: 28px 0 0;
  font-size: 0.9rem;
  color: var(--lp-ink-soft);
}

/* =========================== FAQ =========================== */
.lp-faq {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.lp-faq-item {
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius-sm);
  box-shadow: var(--lp-shadow-sm);
  overflow: hidden;
}

.lp-faq-item summary {
  cursor: pointer;
  list-style: none;
  position: relative;
  padding: 18px 50px 18px 22px;
  font-size: 0.96rem;
  font-weight: 700;
  color: var(--lp-ink);
}

.lp-faq-item summary::-webkit-details-marker { display: none; }

.lp-faq-item summary::after {
  content: "+";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--lp-accent);
  line-height: 1;
}

.lp-faq-item[open] summary::after { content: "\2212"; }

.lp-faq-item p {
  margin: 0;
  padding: 0 22px 20px;
  font-size: 0.92rem;
  line-height: 1.75;
  color: var(--lp-ink-soft);
}

.lp-faq-more {
  text-align: center;
  margin: 26px 0 0;
  font-size: 0.92rem;
  font-weight: 700;
}

/* =========================== Founder note（作り手から） =========================== */
/* 左寄せ・狭めの読み物ブロックで“人が書いた感”を出す（対称グリッドを崩す役割も） */
.lp-founder {
  max-width: 680px;
  margin: 0 auto;
  text-align: left;
  padding-left: clamp(16px, 3vw, 28px);
  border-left: 3px solid var(--lp-accent);
}

.lp-founder .lp-h2 {
  margin-bottom: 18px;
}

.lp-founder-quote {
  margin: 0;
}

.lp-founder-quote p {
  margin: 0 0 18px;
  font-size: clamp(1.05rem, 1.6vw, 1.22rem);
  line-height: 1.95;
  color: var(--lp-ink);
  font-weight: 500;
}

.lp-founder-quote p:last-child {
  margin-bottom: 0;
}

.lp-founder-quote strong {
  font-weight: 800;
  box-shadow: inset 0 -0.5em 0 rgba(var(--lp-gold-rgb), 0.2);
}

.lp-founder-sign {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 28px;
}

.lp-founder-avatar {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  font-weight: 900;
  color: #fff;
  background: var(--lp-accent);
  box-shadow: 0 6px 16px rgba(29, 78, 216, 0.35);
}

.lp-founder-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.45;
}

.lp-founder-meta b {
  font-size: 0.98rem;
  font-weight: 800;
  color: var(--lp-ink);
}

.lp-founder-meta span {
  font-size: 0.84rem;
  color: var(--lp-ink-soft);
}

/* =========================== Final CTA band =========================== */
.lp-cta {
  width: 100%;
  background:
    radial-gradient(700px 300px at 80% 0%, rgba(var(--lp-accent-rgb), 0.5), transparent 60%),
    radial-gradient(500px 260px at 12% 110%, rgba(var(--lp-gold-rgb), 0.18), transparent 60%),
    linear-gradient(135deg, #0c2a20 0%, #0f211a 60%, #10180f 100%);
}

.lp-cta-inner {
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: clamp(56px, 8vw, 88px) clamp(20px, 5vw, 40px);
  text-align: center;
}

.lp-cta h2 {
  margin: 0 0 14px;
  font-size: clamp(1.7rem, 3.6vw, 2.5rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #fff;
}

.lp-cta p {
  margin: 0 0 28px;
  font-size: 1.02rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.66);
}

.lp-cta .lp-btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.22);
  color: #fff !important;
}

.lp-cta .lp-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.16);
}

/* =========================== Footer =========================== */
.lp-footer {
  width: 100%;
  /* 白だとコンテンツとの境界が消えるため、ブランドの深い緑でくっきり区切る
     （彩度を少し抑えた、落ち着きのあるフォレストグリーン） */
  background: linear-gradient(165deg, #1a4d3d 0%, #154033 55%, #11342a 100%);
  border-top: 3px solid #c4a35f;
}

.lp-footer-inner {
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: clamp(40px, 6vw, 64px) clamp(20px, 5vw, 40px) 28px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

@media (min-width: 720px) {
  .lp-footer-inner { grid-template-columns: 1.4fr 1fr 1fr; }
}

.lp-footer-brand .lp-logo { margin-bottom: 12px; }

.lp-footer-brand p {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.74);
  max-width: 26em;
}

.lp-footer-col h4 {
  margin: 0 0 14px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  /* 見出しはブランドゴールドでアクセント（やや沈めた金でトーンを統一） */
  color: #d2ad66;
}

.lp-footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lp-footer-col a {
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 0.9rem;
  font-weight: 600;
}

.lp-footer-col a:hover { color: #ffffff !important; text-decoration: underline; }

.lp-footer-bottom {
  max-width: var(--lp-maxw);
  margin: 0 auto;
  padding: 18px clamp(20px, 5vw, 40px);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.6);
  text-align: center;
}

/* 暗い緑のフッター上ではロゴのワードマーク（暗いグラデ文字）が沈むため明色へ反転 */
.lp-footer .lp-logo { color: #ffffff !important; }

.lp-footer .brand-wordmark__main {
  background: linear-gradient(100deg, #ffffff 0%, #d8f5e8 55%, #7fe3bc 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* =========================== Scroll reveal（出現アニメ） =========================== */
/* JSが .lp-reveal を付けた要素だけ初期非表示 → .is-visible でフワッと表示。
   JS無効時はクラスが付かないため常に表示される（安全側）。 */
.page-lp .lp-reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.page-lp .lp-reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* ヒーローは読み込み時にそのまま出す（スクロール前なので即演出） */
.page-lp .lp-hero-copy > *,
.page-lp .lp-hero-visual {
  animation: lp-rise 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.page-lp .lp-hero-copy > * { animation-delay: calc(var(--i, 0) * 80ms); }
.page-lp .lp-eyebrow { --i: 0; }
.page-lp .lp-h1 { --i: 1; }
.page-lp .lp-sub { --i: 2; }
.page-lp .lp-cta-row { --i: 3; }
.page-lp .lp-hero-note { --i: 4; }
.page-lp .lp-hero-visual { animation-delay: 160ms; }

@keyframes lp-rise {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: none; }
}

@media (prefers-reduced-motion: reduce) {
  .page-lp .lp-reveal,
  .page-lp .lp-hero-copy > *,
  .page-lp .lp-hero-visual {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important;
  }
}

/* =========================== Screenshot frame =========================== */
/* 実スクショ差し替え前提の共通フレーム（ダミー画像もここに収まる） */
.lp-shot {
  margin: 0;
  border-radius: var(--lp-radius);
  border: 1px solid var(--lp-line);
  box-shadow: var(--lp-shadow-lg);
  overflow: hidden;
  background: #fff;
}

.lp-shot img {
  display: block;
  width: 100%;
  height: auto;
}

.lp-shot--hero {
  box-shadow: var(--lp-shadow-lg);
}

/* =========================== Feature rows（左右交互ジグザグ） =========================== */
.lp-rows {
  display: flex;
  flex-direction: column;
  gap: clamp(40px, 7vw, 88px);
}

.lp-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}

@media (min-width: 860px) {
  .lp-row {
    grid-template-columns: 1fr 1fr;
  }
  /* 反転行：コピーを右、画像を左に */
  .lp-row--rev .lp-row-copy { order: 2; }
  .lp-row--rev .lp-row-shot { order: 1; }
}

.lp-row-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(var(--lp-accent-rgb), 0.08);
  color: var(--lp-accent);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  margin-bottom: 16px;
}

.lp-row-tag i { min-width: 1em; text-align: center; }

.lp-row-h3 {
  margin: 0 0 14px;
  font-size: clamp(1.4rem, 2.6vw, 1.85rem);
  line-height: 1.3;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--lp-ink);
}

.lp-row-p {
  margin: 0 0 18px;
  font-size: 1rem;
  line-height: 1.8;
  color: var(--lp-ink-soft);
  max-width: 30em;
}

.lp-row-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lp-row-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.94rem;
  font-weight: 600;
  color: var(--lp-ink);
}

.lp-row-list li i {
  margin-top: 2px;
  min-width: 1.1em;
  text-align: center;
  color: #16a34a;
  font-size: 0.85rem;
}

/* =========================== Voices（お客様の声） =========================== */
.lp-voices {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 760px) {
  .lp-voices { grid-template-columns: repeat(3, 1fr); }
}

.lp-voice {
  margin: 0;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 26px 24px;
}

.lp-voice-stars {
  color: #f59e0b;
  font-size: 0.95rem;
  letter-spacing: 2px;
  margin-bottom: 14px;
}

.lp-voice blockquote {
  margin: 0 0 20px;
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--lp-ink);
  flex: 1;
}

.lp-voice-by {
  display: flex;
  align-items: center;
  gap: 12px;
}

.lp-voice-avatar {
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 900;
  color: #fff;
  background: var(--lp-accent);
}

.lp-voice-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.45;
}

.lp-voice-meta b {
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--lp-ink);
}

.lp-voice-meta span {
  font-size: 0.8rem;
  color: var(--lp-ink-soft);
}

/* =========================== Comparison（比較表） =========================== */
.lp-compare-wrap {
  max-width: 860px;
  margin: 0 auto;
  overflow-x: auto;          /* 狭い画面では横スクロールで崩さない */
  border-radius: var(--lp-radius);
  border: 1px solid var(--lp-line);
  box-shadow: var(--lp-shadow-md);
  background: #fff;
}

.lp-compare {
  width: 100%;
  border-collapse: collapse;
  min-width: 520px;          /* 3カラムが潰れない最小幅 */
}

.lp-compare th,
.lp-compare td {
  padding: 16px 18px;
  text-align: center;
  border-bottom: 1px solid var(--lp-line);
  font-size: 0.92rem;
}

.lp-compare tbody tr:last-child th,
.lp-compare tbody tr:last-child td {
  border-bottom: none;
}

/* 列ヘッダ */
.lp-compare thead th {
  background: var(--lp-bg-alt);
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--lp-ink-soft);
  letter-spacing: 0.01em;
}

/* 行ヘッダ（左端の項目名） */
.lp-compare tbody th {
  text-align: left;
  font-weight: 700;
  color: var(--lp-ink);
}

.lp-compare-rowhead { text-align: left !important; }

/* 自社列を強調 */
.lp-compare thead th.lp-compare-us {
  color: var(--lp-accent);
  background: rgba(var(--lp-accent-rgb), 0.07);
}

.lp-compare tbody td.lp-compare-yes {
  background: rgba(var(--lp-accent-rgb), 0.05);
}

.lp-compare-yes,
.lp-compare-no {
  display: table-cell;
}

.lp-compare-yes span,
.lp-compare-no span {
  display: block;
  margin-top: 4px;
  font-size: 0.78rem;
  font-weight: 700;
}

.lp-compare-yes i { color: #16a34a; font-size: 1.05rem; }
.lp-compare-yes span { color: #0f7a43; }

.lp-compare-no i { color: #cbd5e1; font-size: 1.05rem; }
.lp-compare-no span { color: var(--lp-ink-soft); font-weight: 600; }

/* =========================== Stats showcase（自動で出る数字） =========================== */
.lp-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

@media (min-width: 760px) {
  .lp-stats { grid-template-columns: repeat(3, 1fr); }
}

.lp-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 24px 18px;
}

.lp-stat-label {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--lp-ink-soft);
  letter-spacing: 0.02em;
}

.lp-stat-val {
  margin: 8px 0 6px;
  font-size: clamp(2rem, 4.5vw, 2.6rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--lp-accent);
}

.lp-stat-val small {
  font-size: 0.5em;
  font-weight: 800;
  margin-left: 1px;
}

.lp-stat-val--pos { color: #0f9d58; }

.lp-stat-sub {
  font-size: 0.78rem;
  color: var(--lp-ink-soft);
}

.lp-stats-note {
  margin: 26px auto 0;
  max-width: 40em;
  text-align: center;
  font-size: 0.84rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}

.lp-stats-note i { color: #94a3b8; margin-right: 5px; }

/* =========================== Use cases（こんなグループに） =========================== */
.lp-usecases {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 760px) {
  .lp-usecases { grid-template-columns: repeat(3, 1fr); }
}

.lp-usecase {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 26px 24px;
}

.lp-usecase-ico {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: var(--lp-accent);
  background: rgba(var(--lp-accent-rgb), 0.1);
  margin-bottom: 16px;
}

.lp-usecase h3 {
  margin: 0 0 10px;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--lp-ink);
}

.lp-usecase-scene {
  margin: 0 0 14px;
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}

.lp-usecase-win {
  margin: auto 0 0;
  padding-top: 14px;
  border-top: 1px dashed var(--lp-line);
  font-size: 0.9rem;
  line-height: 1.7;
  font-weight: 700;
  color: var(--lp-ink);
}

.lp-usecase-win i {
  color: var(--lp-accent);
  margin-right: 6px;
}

/* =========================== Glossary（用語解説） =========================== */
.lp-glossary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 720px) {
  .lp-glossary { grid-template-columns: repeat(2, 1fr); }
}

.lp-term {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  gap: 6px 16px;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius-sm);
  box-shadow: var(--lp-shadow-sm);
  padding: 18px 20px;
}

.lp-term dt {
  grid-column: 1;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--lp-accent);
  white-space: nowrap;
}

.lp-term dd {
  grid-column: 2;
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}

/* =========================== Data safety（データの安全性） =========================== */
.lp-safety {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 720px) {
  .lp-safety { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 940px) {
  .lp-safety { grid-template-columns: repeat(4, 1fr); }
}

.lp-safe {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--lp-line);
  border-radius: var(--lp-radius);
  box-shadow: var(--lp-shadow-sm);
  padding: 24px 22px;
}

.lp-safe-ico {
  width: 44px;
  height: 44px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  color: var(--lp-accent);
  background: rgba(var(--lp-accent-rgb), 0.1);
  margin-bottom: 14px;
}

.lp-safe h3 {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 800;
  color: var(--lp-ink);
}

.lp-safe p {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.7;
  color: var(--lp-ink-soft);
}
