/* ===== トンマナ案A クリーン・クール ／ design.md準拠 ===== */
:root{
  --primary:#2B7FB8;        /* CTA・主役の塗り */
  --primary-deep:#226A9C;   /* ホバー */
  --ink:#1A2A33;            /* 本文・見出し */
  --muted:#5A6B75;          /* 注釈・補足のみ */
  --bg:#FFFFFF;
  --soft:#EEF6FA;           /* 淡ブルーの面・帯・ダミー背景 */
  --line:#E3EAEF;           /* 罫線・カード枠 */
  --accent-bg:#E4F2F8;      /* 青ラベル背景・マーカー外周 */
  /* フォントサイズは5段階：40 / 28 / 20 / 16 / 15 */
  --fs-hero:40px; --fs-h2:28px; --fs-h3:20px; --fs-body:16px; --fs-small:15px;
  --maxw:1120px; --radius:12px; --radius-lg:18px;
  --shadow:0 4px 16px rgba(26,42,51,.06);
  --font-head:"Zen Kaku Gothic New",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Noto Sans JP",sans-serif;color:var(--ink);background:var(--bg);line-height:1.75;font-size:var(--fs-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.section{padding:88px 0}
.section--soft{background:var(--soft)}
.eyebrow{display:inline-block;font-size:var(--fs-small);font-weight:700;color:var(--primary-deep);padding-left:14px;border-left:3px solid var(--primary);line-height:1.2;margin-bottom:20px}
h2.sec-title{font-family:var(--font-head);font-weight:700;font-size:var(--fs-h2);line-height:1.4;margin-bottom:14px;letter-spacing:.01em}
.sec-lead{color:var(--muted);font-size:var(--fs-body);margin-bottom:40px;max-width:680px}

/* ボタン */
.btn{display:inline-block;text-decoration:none;font-weight:700;font-size:var(--fs-body);color:#fff;background:var(--primary);padding:16px 40px;border-radius:var(--radius);box-shadow:0 8px 22px rgba(43,127,184,.28);transition:background .2s}
.btn:hover{background:var(--primary-deep)}
.btn--lg{font-size:var(--fs-h3);padding:18px 56px}
.micro{font-size:var(--fs-small);color:var(--muted)}

/* ダミーボックス（色はprimary/inkのアルファで表現＝パレット増やさない） */
.dummy{background:var(--soft);border:1px dashed rgba(43,127,184,.30);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;color:rgba(26,42,51,.55);padding:24px}
.dummy__id{font-size:var(--fs-small);font-weight:700;letter-spacing:.03em;color:var(--primary-deep)}
.dummy__desc{font-size:var(--fs-small);line-height:1.6}

/* ===== ヘッダー ===== */
.header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:12px;height:64px;padding:0 32px;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header__cta{flex:none}
.logo{font-family:var(--font-head);font-weight:700;font-size:var(--fs-h3);color:var(--ink);line-height:1.1;text-decoration:none}
.logo small{display:block;font-size:var(--fs-small);font-weight:500;color:var(--muted);letter-spacing:.02em}
.header__cta{font-size:var(--fs-small);font-weight:700;text-decoration:none;color:#fff;background:var(--primary);padding:10px 18px;border-radius:var(--radius)}
.header__cta .cta-short{display:none}

/* ===== ファーストビュー ===== */
.hero{background:var(--soft);padding:64px 0 72px}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-family:var(--font-head);font-weight:700;font-size:var(--fs-hero);line-height:1.32;letter-spacing:.01em;margin-bottom:24px}
.hero h1 em{font-style:normal;color:var(--primary-deep)}
.hero__bullets{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.hero__bullets li{position:relative;padding-left:28px;font-weight:500}
.hero__bullets li::before{content:"";position:absolute;left:0;top:.6em;width:13px;height:13px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px var(--accent-bg)}
.hero__price{font-size:var(--fs-small);color:var(--muted);margin-bottom:24px}
.hero__price b{color:var(--ink);font-size:var(--fs-body)}
.hero__action{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.hero__visual .dummy{aspect-ratio:4/5}

/* ===== 共感できる課題 ===== */
.problem__list{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:8px}
.problem__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 24px;font-weight:500;line-height:1.7;box-shadow:var(--shadow)}
.problem__card span{display:block;font-size:var(--fs-h3);color:var(--primary);font-weight:700;margin-bottom:10px}

/* ===== 代替手段の否定 ===== */
.alt__list{display:flex;flex-direction:column;gap:14px;max-width:760px}
.alt__item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px}
.alt__x{flex:none;width:26px;height:26px;border-radius:50%;background:var(--accent-bg);color:var(--primary-deep);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:var(--fs-small)}
.alt__item b{font-weight:700}

/* ===== 解決策の特徴 ===== */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:64px}
.feature:nth-child(even) .feature__visual{order:-1}
.feature:last-child{margin-bottom:0}
.feature__num{font-family:var(--font-head);font-size:var(--fs-small);font-weight:700;color:var(--primary);letter-spacing:.08em;margin-bottom:8px}
.feature__title{font-family:var(--font-head);font-size:var(--fs-h3);font-weight:700;line-height:1.5;margin-bottom:14px}
.feature__body{color:var(--muted)}
.feature__visual .dummy{aspect-ratio:4/3}

/* 料金プラン */
.plan{max-width:520px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px;text-align:center;box-shadow:var(--shadow)}
.plan__price{font-family:var(--font-head);font-size:var(--fs-h2);font-weight:700;margin-bottom:6px}
.plan__price small{font-size:var(--fs-small);color:var(--muted);font-weight:500}
.plan__list{list-style:none;text-align:left;display:inline-flex;flex-direction:column;gap:10px;margin:18px 0 14px}
.plan__list li{position:relative;padding-left:24px}
.plan__list li::before{content:"";position:absolute;left:0;top:.7em;width:10px;height:10px;border-radius:50%;background:var(--primary)}
.plan__note{font-size:var(--fs-small);color:var(--muted)}

/* 利用の流れ */
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px;max-width:760px}
.step__visual .dummy{aspect-ratio:4/3;margin-bottom:16px}
.step__no{display:inline-block;font-family:var(--font-head);font-weight:700;color:var(--primary);font-size:var(--fs-small);margin-bottom:6px}
.step__name{font-family:var(--font-head);font-size:var(--fs-h3);font-weight:700;margin-bottom:8px}
.step__desc{color:var(--muted);font-size:var(--fs-small)}

/* ===== 比較表 ===== */
.compare{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:#fff}
.compare th,.compare td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:var(--fs-small);vertical-align:top}
.compare thead th{background:var(--ink);color:#fff;font-weight:700}
.compare thead th.is-ours{background:var(--primary)}
.compare tbody th{font-weight:700;background:var(--soft);width:24%}
.compare td.is-ours{background:var(--accent-bg);font-weight:500}
.compare .mark{font-weight:700;margin-right:6px}
.compare tr:last-child th,.compare tr:last-child td{border-bottom:none}
.compare__note{font-size:var(--fs-small);color:var(--muted);margin-top:12px}

/* ===== 運営者メッセージ ===== */
.owner{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center}
.owner__visual .dummy{aspect-ratio:1/1}
.owner__title{font-family:var(--font-head);font-size:var(--fs-h3);font-weight:700;line-height:1.6;margin-bottom:18px}
.owner__body{color:var(--ink);line-height:1.95}
.owner__name{margin-top:18px;font-size:var(--fs-small);color:var(--muted)}

/* ===== FAQ ===== */
.faq{max-width:780px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 26px;margin-bottom:14px}
.faq__q{font-weight:700;position:relative;padding-left:30px}
.faq__q::before{content:"Q";position:absolute;left:0;top:-1px;color:var(--primary);font-family:var(--font-head);font-weight:700}
.faq__a{color:var(--muted);font-size:var(--fs-small);margin-top:10px;padding-left:30px;position:relative}
.faq__a::before{content:"A";position:absolute;left:0;top:0;color:var(--muted);font-family:var(--font-head);font-weight:700}

/* ===== 最終CTA ===== */
.register{background:var(--primary);color:#fff;text-align:center;padding:80px 0}
.register h2{font-family:var(--font-head);font-size:var(--fs-h2);font-weight:700;line-height:1.5;margin-bottom:16px}
.register p{font-size:var(--fs-body);opacity:.92;margin-bottom:32px}
.register .btn{background:#fff;color:var(--primary-deep);box-shadow:0 10px 30px rgba(0,0,0,.18)}
.register .btn:hover{background:var(--soft)}
.register .micro{color:rgba(255,255,255,.85);margin-top:14px}

/* ===== フッター ===== */
.footer{background:var(--ink);color:rgba(255,255,255,.72);padding:40px 0;font-size:var(--fs-small)}
.footer__inner{display:flex;flex-wrap:wrap;gap:16px 28px;align-items:center;justify-content:space-between}
.footer nav{display:flex;gap:20px;flex-wrap:wrap}
.footer a{color:rgba(255,255,255,.72);text-decoration:none}
.footer a:hover{color:#fff}
.footer__copy{color:rgba(255,255,255,.45)}

/* ===== レスポンシブ ===== */
@media(max-width:760px){
  :root{--fs-hero:28px;--fs-h2:24px;--fs-h3:18px}
  .wrap{padding:0 20px}
  .section{padding:56px 0}
  .header{height:56px;padding:0 14px;overflow:hidden}
  .logo{font-size:var(--fs-small);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .logo small{display:none}
  .header__cta{font-size:var(--fs-small);padding:9px 14px;white-space:nowrap}
  .header__cta .cta-full{display:none}
  .header__cta .cta-short{display:inline}
  .hero{padding:32px 0 48px}
  .hero__inner,.owner{grid-template-columns:1fr;gap:28px}
  .hero__visual{order:-1}
  .hero__visual .dummy{aspect-ratio:16/10}
  .hero__action{align-items:stretch}
  .btn{width:100%;text-align:center;padding:15px 0}
  .problem__list,.steps{grid-template-columns:1fr;gap:14px}
  .feature{grid-template-columns:1fr;gap:20px;margin-bottom:44px}
  .feature__visual{order:-1 !important}
  .owner__visual{order:-1;max-width:260px}
  /* 比較表：横スクロール */
  .compare-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .compare{min-width:560px}
}
