/* =========================================================
   障害児通所支援・放課後等デイサービスの選び方 LP
   care002（about）のトンマナ：白 ⇄ 紺 の交互セクション
   iframe 埋め込み用（記事ページのLP枠と一体化）
   ========================================================= */

/* --- reset / base --- */
html, body {
  margin: 0;
  width: 100%;
  overflow-x: hidden;
}
* { box-sizing: border-box; }
img { max-width: 100%; height: auto; display: block; }

:root {
  /* 緑系（ロゴ・見出し・アクセント） */
  --green-900: #2b3e3a;   /* 見出し濃緑（スクショ実測） */
  --green-700: #3f6b5e;
  --green-600: #4f8273;
  --green-500: #5b9182;   /* アクセント */
  --green-300: #9cbfb4;
  --green-100: #e7f0ed;
  --green-050: #f1f6f4;

  /* 紺系（交互背景・実測ベース） */
  --navy-900: #1c3d5e;
  --navy-800: #20446a;
  --navy-700: #23496f;   /* タイル地色 */
  --navy-600: #2e5179;
  --navy-line: #3a5f8a;  /* 紺上の罫 */
  --navy-card: #2c5078;  /* 紺上のカード地 */
  --navy-soft: #b8cbe0;  /* 紺上の淡い文字 */

  --sand-100: #f7f4ec;
  --ink:      #33403c;
  --ink-soft: #5b6b66;
  --line:     #dde7e3;
  --white:    #ffffff;
  --accent:   #d98b5f;   /* テラコッタ差し色（白セクション用） */
  --accent-navy: #e3a479;/* 紺セクション用の差し色 */

  --font-base: "Noto Sans JP", "Hiragino Kaku Gothic ProN",
               "BIZ UDPGothic", "Yu Gothic", "Meiryo", system-ui, sans-serif;
  --maxw: 880px;
}

/* =========================================================
   最外側 — 余白・角丸・最大幅なし（記事枠と一体化）
   ========================================================= */
.lp-root {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  color: var(--ink);
  font-family: var(--font-base);
  font-size: 16px;
  line-height: 1.95;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
  background: var(--white);
  word-break: normal;
  overflow-wrap: anywhere;
}

/* =========================================================
   セクション共通
   ========================================================= */
.lp-section {
  width: 100%;
  padding: clamp(34px, 6vw, 72px) clamp(18px, 4vw, 40px);
}
.lp-section-inner {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
}

/* 白セクション（既定）と 紺セクションの交互 */
.lp-section--light { background: var(--white); }
.lp-section--navy {
  background-color: var(--navy-700);
  background-image: url("../img/navy-pattern.svg?v=2026-06-15T04-20-06.177Z");
  background-repeat: repeat;
  background-size: 160px 160px;
  color: #eaf1f8;
}

/* =========================================================
   見出し・テキスト（白セクション）
   ========================================================= */
.lp-label {
  margin: 0 0 14px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--green-600);
}
.lp-h2 {
  margin: 0 0 22px;
  font-size: clamp(1.3rem, 3.2vw, 1.72rem);
  font-weight: 700;
  line-height: 1.5;
  color: var(--green-900);
  position: relative;
  padding-bottom: 16px;
}
.lp-h2::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 48px; height: 3px;
  background: var(--green-500);
  border-radius: 2px;
}
.lp-text {
  margin: 0 0 1.25em;
  font-size: clamp(0.95rem, 2.2vw, 1.02rem);
}
.lp-text:last-child { margin-bottom: 0; }
.lp-text strong { color: var(--green-700); font-weight: 700; }

/* 紺セクション内の色調整 */
.lp-section--navy .lp-label { color: #9fc6e0; }
.lp-section--navy .lp-h2 { color: #ffffff; }
.lp-section--navy .lp-h2::after { background: #8fb7d6; }
.lp-section--navy .lp-text { color: #e3ecf5; }
.lp-section--navy .lp-text strong { color: #ffffff; }

/* =========================================================
   HERO（白背景・スクショ準拠）
   ========================================================= */
.lp-hero {
  position: relative;
  width: 100%;
  padding: clamp(36px, 7vw, 76px) clamp(20px, 5vw, 56px);
  background: #ffffff;
  overflow: hidden;
}
.lp-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.lp-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.lp-hero-body {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
}
.lp-eyebrow {
  display: inline-block;
  margin: 0 0 22px;
  padding: 7px 16px;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--green-900);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--green-300);
  border-radius: 999px;
}
.lp-hero-title {
  margin: 0 0 22px;
  font-size: clamp(1.55rem, 5.2vw, 2.6rem);
  font-weight: 700;
  line-height: 1.42;
  color: var(--green-900);
  letter-spacing: 0.01em;
}
.lp-hero-title em {
  font-style: normal;
  color: var(--green-500);
}
.lp-hero-lead {
  margin: 0 0 26px;
  max-width: 40em;
  font-size: clamp(0.95rem, 2.4vw, 1.04rem);
  line-height: 1.95;
  color: var(--ink-soft);
}
.lp-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0; padding: 0;
  list-style: none;
}
.lp-hero-meta li {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--green-900);
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 14px;
}

/* INTRO（白・リード） */
.lp-section--intro { padding-top: clamp(28px, 5vw, 56px); padding-bottom: clamp(28px, 5vw, 56px); }
.lp-section--intro .lp-text {
  font-size: clamp(1rem, 2.5vw, 1.08rem);
  line-height: 2.0;
  border-left: 4px solid var(--green-300);
  padding-left: clamp(16px, 3vw, 24px);
  color: var(--ink);
}

/* =========================================================
   サービス種類カード
   ========================================================= */
.lp-services { display: flex; flex-wrap: wrap; gap: 14px; margin: 26px 0; }
.lp-service {
  flex: 1 1 240px; min-width: 0;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 20px 22px;
}
.lp-service--main { border: 1px solid var(--green-300); background: var(--green-050); }
.lp-service-tag {
  display: inline-block; margin: 0 0 10px; padding: 4px 10px;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em;
  color: var(--green-700); background: var(--green-100); border-radius: 999px;
}
.lp-service--main .lp-service-tag { color: #fff; background: var(--green-600); }
.lp-service-name { margin: 0 0 8px; font-size: 1.05rem; font-weight: 700; color: var(--green-900); }
.lp-service-text { margin: 0; font-size: 0.87rem; line-height: 1.75; color: var(--ink-soft); }

/* 紺セクションに置かれた場合のサービスカード */
.lp-section--navy .lp-service { background: var(--navy-card); border-color: var(--navy-line); }
.lp-section--navy .lp-service--main { background: #34608c; border-color: #5a85b3; }
.lp-section--navy .lp-service-tag { color: #dcebf8; background: rgba(255,255,255,0.12); }
.lp-section--navy .lp-service--main .lp-service-tag { color: #1c3d5e; background: #bcd6ee; }
.lp-section--navy .lp-service-name { color: #ffffff; }
.lp-section--navy .lp-service-text { color: var(--navy-soft); }

/* =========================================================
   手続きフロー（縦ステップ）
   ========================================================= */
.lp-flow { list-style: none; margin: 26px 0; padding: 0; counter-reset: flow; }
.lp-flow-step {
  position: relative; margin: 0 0 14px;
  padding: 18px 20px 18px 64px;
  background: var(--white); border: 1px solid var(--line);
  border-radius: 12px; counter-increment: flow;
}
.lp-flow-step:last-child { margin-bottom: 0; }
.lp-flow-step::before {
  content: counter(flow);
  position: absolute; left: 18px; top: 50%; transform: translateY(-50%);
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 800; color: #fff;
  background: var(--green-500); border-radius: 50%;
}
.lp-flow-head { margin: 0 0 4px; font-size: 0.98rem; font-weight: 700; color: var(--green-700); }
.lp-flow-text { margin: 0; font-size: 0.86rem; line-height: 1.7; color: var(--ink-soft); }

/* 紺上のフロー */
.lp-section--navy .lp-flow-step { background: var(--navy-card); border-color: var(--navy-line); }
.lp-section--navy .lp-flow-step::before { background: #8fb7d6; color: var(--navy-900); }
.lp-section--navy .lp-flow-head { color: #ffffff; }
.lp-section--navy .lp-flow-text { color: var(--navy-soft); }

/* =========================================================
   選び方 7ポイント（番号付き）
   ========================================================= */
.lp-points { list-style: none; margin: 26px 0; padding: 0; counter-reset: point; }
.lp-point {
  position: relative; margin: 0 0 14px;
  padding: 20px 22px 20px 70px;
  background: var(--white); border: 1px solid var(--line);
  border-left: 4px solid var(--green-500); border-radius: 12px;
  counter-increment: point;
}
.lp-point:last-child { margin-bottom: 0; }
.lp-point::before {
  content: counter(point, decimal-leading-zero);
  position: absolute; left: 18px; top: 20px;
  font-size: 1.4rem; font-weight: 800; color: var(--green-300); line-height: 1;
}
.lp-point-head { margin: 0 0 6px; font-size: 1.0rem; font-weight: 700; color: var(--green-900); }
.lp-point-text { margin: 0; font-size: 0.88rem; line-height: 1.8; color: var(--ink-soft); }

/* 紺上のポイント */
.lp-section--navy .lp-point { background: var(--navy-card); border-color: var(--navy-line); border-left-color: #8fb7d6; }
.lp-section--navy .lp-point::before { color: #6f9cc4; }
.lp-section--navy .lp-point-head { color: #ffffff; }
.lp-section--navy .lp-point-text { color: var(--navy-soft); }

/* =========================================================
   チェックリスト
   ========================================================= */
.lp-checklist { list-style: none; margin: 22px 0; padding: 0; display: flex; flex-wrap: wrap; gap: 10px; }
.lp-check {
  flex: 1 1 260px; min-width: 0; position: relative;
  padding: 13px 16px 13px 44px;
  background: var(--green-050); border-radius: 10px;
  font-size: 0.88rem; line-height: 1.6;
}
.lp-check::before {
  content: ""; position: absolute; left: 16px; top: 50%;
  width: 14px; height: 9px; margin-top: -7px;
  border-left: 3px solid var(--green-500); border-bottom: 3px solid var(--green-500);
  transform: rotate(-45deg); border-radius: 1px;
}
/* 紺上のチェック */
.lp-section--navy .lp-check { background: rgba(255,255,255,0.08); color: #e3ecf5; }
.lp-section--navy .lp-check::before { border-color: #8fb7d6; }

/* =========================================================
   注記ボックス
   ========================================================= */
.lp-note { margin: 24px 0; background: var(--white); border: 1px dashed var(--green-300); border-radius: 12px; padding: 18px 20px; }
.lp-note-text { margin: 0; font-size: 0.9rem; line-height: 1.8; }
.lp-note-text strong { color: var(--green-700); }
.lp-section--navy .lp-note { background: rgba(255,255,255,0.06); border-color: var(--navy-line); }
.lp-section--navy .lp-note-text { color: #e3ecf5; }
.lp-section--navy .lp-note-text strong { color: #ffffff; }

/* =========================================================
   ハイライト（差し色）
   ========================================================= */
.lp-highlight {
  margin: 24px 0; background: var(--white);
  border: 1px solid var(--green-300); border-radius: 14px;
  padding: 22px 24px; position: relative; overflow: hidden;
}
.lp-highlight::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 6px; background: var(--accent); }
.lp-highlight-label { margin: 0 0 10px; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.12em; color: var(--accent); }
.lp-highlight-text { margin: 0; font-size: 0.95rem; line-height: 1.85; }
.lp-highlight-text strong { color: var(--green-700); }
.lp-section--navy .lp-highlight { background: rgba(255,255,255,0.07); border-color: var(--navy-line); }
.lp-section--navy .lp-highlight::before { background: var(--accent-navy); }
.lp-section--navy .lp-highlight-label { color: var(--accent-navy); }
.lp-section--navy .lp-highlight-text { color: #eaf1f8; }
.lp-section--navy .lp-highlight-text strong { color: #ffffff; }

/* =========================================================
   引用
   ========================================================= */
.lp-quote { margin: 26px 0; background: var(--green-100); border-radius: 14px; padding: clamp(22px, 4vw, 32px); }
.lp-quote-text { margin: 0 0 12px; font-size: clamp(1.02rem, 2.6vw, 1.18rem); font-weight: 700; line-height: 1.8; color: var(--green-900); }
.lp-quote-cite { display: block; font-size: 0.82rem; font-style: normal; color: var(--green-600); text-align: right; }
.lp-section--navy .lp-quote { background: rgba(255,255,255,0.09); }
.lp-section--navy .lp-quote-text { color: #ffffff; }
.lp-section--navy .lp-quote-cite { color: #9fc6e0; }

/* =========================================================
   アクションボックス（CTA）
   白セクション=緑グラデ / 紺セクション=明るい青に反転
   ========================================================= */
.lp-action {
  margin: 26px 0 0;
  background: linear-gradient(150deg, var(--green-600), var(--green-700));
  border-radius: 16px; padding: clamp(24px, 4vw, 34px); color: #eef5f2;
}
.lp-action-title { margin: 0 0 10px; font-size: 1.05rem; font-weight: 700; color: #ffffff; }
.lp-action-text { margin: 0; font-size: 0.92rem; line-height: 1.9; }
.lp-action-text strong { color: #ffffff; }
.lp-section--navy .lp-action { background: linear-gradient(150deg, #3a6794, #2a4f78); }

/* =========================================================
   クロージング・リード
   ========================================================= */
.lp-closing-lead {
  margin: 22px 0 0; font-size: clamp(1.02rem, 2.6vw, 1.16rem);
  font-weight: 700; line-height: 1.95; color: var(--green-900);
  border-top: 1px solid var(--line); padding-top: 22px;
}
.lp-section--navy .lp-closing-lead { color: #ffffff; border-top-color: var(--navy-line); }

/* =========================================================
   注記・出典
   ========================================================= */
.lp-section--disclaimer { padding-top: clamp(24px, 4vw, 40px); padding-bottom: clamp(34px, 6vw, 64px); }
.lp-disclaimer-text {
  margin: 0; font-size: 0.78rem; line-height: 1.85; color: var(--ink-soft);
  background: var(--sand-100); border-radius: 10px; padding: 18px 20px;
}

/* =========================================================
   レスポンシブ（880 / 768 / 620 / 390）
   ========================================================= */
@media (max-width: 620px) {
  .lp-root { font-size: 15.5px; line-height: 1.9; }
  .lp-service { flex-basis: 100%; }
}
@media (max-width: 390px) {
  .lp-hero-meta li { flex: 1 1 100%; text-align: center; }
  .lp-check { flex-basis: 100%; }
  .lp-point { padding-left: 60px; }
}

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