@charset "UTF-8";

:root {
  --co-teal-header: #2e9c88;
  --co-teal-deep: #1f7f6f;
  --co-mint-soft: #c8ebe0;
  --co-mint-top: #9fd9c9;
  --co-bg-feature: #e6f6f1;
  --co-bg-faq: #eaf7f3;
  --co-pink: #f15d6e;
  --co-pink-dark: #dd4a5e;
  --co-yellow-btn: #f5c742;
  --co-yellow-hover: #e6b735;
  --co-text: #505050;
  --co-text-muted: #444;
  --co-max: min(1180px, 100%);
  /* SP〜タブレット縦（1023↓）：Pencil は 375 幅での見え方想定／左右ガター */
  --co-sp-inline-pad: clamp(1rem, 0.6875rem + 2.5vw, 1.3125rem);
  /* ヒーロー写真の横幅上限（ビューポート幅の 80%。親は min(100%, …) でゲター内に収める） */
  --co-hero-sp-block-max: 80vw;
  --co-radius: 12px;
  --co-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  --co-sec08-green: #4acbbc;
  /* #08 / #09 デュアル CTA（指示用デザインに合わせたコーラル） */
  --co-sec08-pink: #f05667;
  --co-dual-cta-yellow: #fff461;
  /* LP 主要 CTA の幅（PC 統一 / SP は上限幅として使用） */
  --co-lp-cta-width-pc: 448px;
  --co-lp-cta-width-sp: 288px;
  --co-lp-cta-min-h-sp: 3.25rem;
  /* PC（768px↑）：主要ピンク CTA とヒーローを 66px で揃える */
  --co-lp-cta-min-h-pc: 66px;
  --co-lp-dual-cta-h-pc: 70px;
  /* Hero（Pencil 00_hero） */
  --co-hero-kicker-color: #4acbbc;
  --co-hero-title-brand: #505050;
  --co-hero-title-body: #505050;
  --co-hero-btn-pink: #f15d6e;
  /* Sec01 Our Proposal（Pencil 01_Our Proposal） */
  --co-proposal-teal: #4acbbc;
  --co-proposal-mint: #d1f1ed;
  --co-proposal-fuki-text: #33a194;
  --co-proposal-cta-yellow: #fff461;
  /* Sec03 黄 lead：#03/#04 境に半分はみ出すぶん（padding-top / padding-bottom に加算） */
  --co-feat-lead-bridge: clamp(4.75rem, 11vw, 6.25rem);
  /* Sec04：黄 lead の translateY(50%) ではみ出し＋ Works 直前の最低限のクリア（過大な空きを避ける） */
  --co-works-lead-overlap-clear: clamp(6.25rem, 17vw, 9.25rem);
  /*
   * -------------------------------------------------------------------------
   * ブレークポイント契約（新規 @media は原則ここから選ぶ。並べ替えはカスケード破壊のため不可）
   * -------------------------------------------------------------------------
   * A. LP 2段（タイポ・FAQ・セクション余白の主軸）
   *    - (max-width: 1023px)  … SP＋タブレット縦
   *    - (min-width: 1024px)  … PC
   * B. コンポーネント 2段（デュアル CTA・カード組版・黄 lead など）
   *    - (max-width: 767px)   … スマホ
   *    - (min-width: 768px)   … タブレット横〜（1023 まで含む）
   * C. 中間帯のみ（重なり回避・ヘッダー余白など。必要時だけ追加）
   *    - (min-width: 768px) and (max-width: 1023px)  … タブレット
   *    - (min-width: 1024px) and (max-width: 1199px)  … 狭い PC
   *    - (max-width: 900px) / (min-width: 901px) and (max-width: 1023px) … ヒーロー上余白
   * D. 極窄・個別（該当セクションのみ）
   *    - 719px↓, 640px↑, 480px↓, 320px↓, 1200px↑
   * 注意: 767 と 768、1023 と 1024 は意図的に 1px 隙間なしでペア運用（768px 幅で両方に当たらない）
   * -------------------------------------------------------------------------
   */
}

/*
 * =============================================================================
 * LP セクション索引（`connect_circularoffice/index.html` 想定）
 * -----------------------------------------------------------------------------
 * #00 LP 共通 … `.co-lp-root` 〜 `.co-lp__container` 等（ページ骨格）
 * #00 汎用 … 改行 `co-br-*`（セクション横断）
 * #01 Hero … `#sec-hero`
 * #02 Our Proposal … `#sec01-proposal`
 * #03 Service … `#sec02-service`（白地 `.co-sec--white` を含む）
 * #04 Feature … `#sec03-feature`
 * #05 Works … `#sec04-works`
 * #06 FAQ … `#sec05-faq`
 * #07 Sustainability … `#sec06-sustainability`
 * #08 Contact … `#sec07-contact`
 * #09 デュアル CTA … `#sec08-cta`（Sec08 / Sec09 併記）
 * =============================================================================
 */

/* #00 LP 共通レイアウト（骨格・本文ベース） */
.co-lp-root {
  background: #fff;
  color: var(--co-text);
  font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-feature-settings:'palt';
  letter-spacing: 0.05em;
}

.co-lp {
  overflow-x: hidden;
}

/*
 * sec01 の装飾雲はティール内 clip-path と各ボックスで表現する。
 * .co-lp だけ overflow-x: visible にすると、PC の雲（大きな負の inset）が
 * ドキュメント幅を押し広げ、横スクロール＋背景の「右が欠ける」見え方になる。
 */

/* ページ上部へ（critical-min の display:none を lp-circular.js の .is-visible で表示） */
#page_top {
  position: fixed;
  right: clamp(0.5rem, 2vw, 1.25rem);
  bottom: clamp(0.625rem, 2vw, 1.5rem);
  display: none;
  z-index: 99999;
  width: 70px;
  line-height: 0;
}

#page_top.is-visible {
  display: block;
}

#page_top .page_top_img {
  display: block;
  width: 100%;
  height: auto;
}

.co-lp__container {
  box-sizing: border-box;
  width: var(--co-max);
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2rem);
}

.co-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ---------- #00 汎用：改行制御（<br class="co-br-*"> に付与） ----------
 * - co-br-sp … 767px 以下のみ改行（SP）
 * - co-br-pc … 768px 以上で改行（タブレット横〜PC。SP では非表示）
 * - co-br-pc-only … 1024px 以上のみ改行（LP 内の「PC」ブレークポイントに合わせる）
 * - co-br-tablet-only … 768px〜1023px のみ改行（タブレット帯のみ）
 * - co-br-max600 … 600px 以下のみ改行（狭いスマホ〜小タブレット縦の追加ブレーク）
 */
br.co-br-sp,
br.co-br-pc,
br.co-br-pc-only,
br.co-br-tablet-only,
br.co-br-max600 {
  display: none;
}

@media (max-width: 767px) {
  br.co-br-sp {
    display: inline;
  }
}

@media (min-width: 768px) {
  br.co-br-pc {
    display: inline;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  br.co-br-tablet-only {
    display: inline;
  }
}

@media (min-width: 1024px) {
  br.co-br-pc-only {
    display: inline;
  }
}

@media (max-width: 600px) {
  br.co-br-max600 {
    display: inline;
  }
}

/* SP のみ表示 / PC のみ表示（黄 lead の改行・文末差分など） */
.co-only-sp {
  display: none;
}

@media (max-width: 767px) {
  .co-only-sp {
    display: inline;
  }
}

.co-only-pc {
  display: none;
}

@media (min-width: 768px) {
  .co-only-pc {
    display: inline;
  }
}

/* リード内の部分強調（SP 2rem / PC 60px・ピンク） */
.co-lead-em {
  color: var(--co-pink);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.15;
}

@media (min-width: 768px) {
  .co-lead-em {
    font-size: 60px;
  }
}

/* ドットのアンダーライン（ピンク） */
.co-td-dotted {
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: var(--co-pink);
  text-underline-offset: 0.2em;
}

/* セクション縦余白の基準（#01 proposal 系は .co-sec--proposal-v2 等で上書き） */
.co-sec {
  padding-block: 4.5rem;
}

.co-sec__heading {
  font-size: clamp(1.35rem, 3.5vw, 1.85rem);
  font-weight: 700;
  text-align: center;
  margin: 0 0 1.25rem;
  color: var(--co-text);
}

.co-sec__heading--white {
  color: #fff;
}

.co-sec__heading--underline {
  position: relative;
  display: inline-block;
  width: 100%;
  text-align: center;
}

.co-sec__heading--underline::after {
  content: "";
  display: block;
  width: 3rem;
  height: 3px;
  margin: 0.6rem auto 0;
  background: var(--co-teal-header);
  border-radius: 2px;
}

.co-sec__intro {
  max-width: 42rem;
  margin: 0 auto 2rem;
  text-align: center;
  line-height: 1.85;
  color: var(--co-text-muted);
  font-size: 0.95rem;
}

.co-sec__actions {
  text-align: center;
  margin-top: 2rem;
}

.co-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0.65rem 1.75rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: transform 0.15s ease, filter 0.15s ease, box-shadow 0.15s ease;
}

.co-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.co-btn:active {
  transform: translateY(0);
}

.co-btn--pink {
  background: var(--co-pink);
  color: #fff;
  box-shadow: 0 4px 16px rgba(241, 93, 110, 0.35);
}

.co-btn--pink:hover {
  background: var(--co-pink-dark);
  color: #fff;
}

.co-btn--yellow {
  background: var(--co-yellow-btn);
  color: #222;
}

.co-btn--yellow:hover {
  background: var(--co-yellow-hover);
  color: #111;
}

.co-btn--invert {
  background: #222;
  color: #fff;
}

.co-btn--teal {
  background: var(--co-teal-header);
  color: #fff;
  width: min(var(--co-lp-cta-width-sp), 100%);
}

.co-btn--ghost-light {
  background: transparent;
  color: #fff;
  border: 2px solid #fff;
  box-shadow: none;
}

.co-btn--ghost-light:hover {
  background: rgba(255, 255, 255, 0.12);
}

.co-ph {
  margin: 0;
  border-radius: var(--co-radius);
  background: repeating-linear-gradient(
    -45deg,
    #f0f0f0,
    #f0f0f0 8px,
    #e8eceb 8px,
    #e8eceb 16px
  );
  border: 1px dashed #c8d4cf;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 8rem;
  position: relative;
}

.co-ph__label {
  font-size: 0.8rem;
  color: #666;
  text-align: center;
  padding: 0.5rem;
}

.co-ph--hero {
  aspect-ratio: 16 / 10;
  min-height: 200px;
  width: 100%;
}

.co-ph--card {
  aspect-ratio: 16 / 10;
  margin-bottom: 1rem;
}

.co-ph--thumb {
  aspect-ratio: 4 / 3;
  width: clamp(140px, 28vw, 200px);
  flex-shrink: 0;
}

.co-ph--work {
  aspect-ratio: 3 / 2;
  margin-bottom: 1rem;
}

.co-ph--sustain {
  aspect-ratio: 4 / 3;
  min-height: 200px;
  width: 100%;
}

.co-ph--dual {
  aspect-ratio: 16 / 10;
  min-height: 180px;
}

.co-ph--dual.co-ph--has-photo {
  padding: 0;
  background: none;
  border: none;
  position: relative;
  overflow: hidden;
  min-height: 0;
}

.co-ph--dual.co-ph--has-photo .co-ph__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ---------- #01 Hero（#sec-hero）（00_hero / Desktop・Mobile.png 準拠） ---------- */
.co-sec--hero {
  padding-block: 4.5rem;
  background: #fff;
}

.co-hero__intro .co-hero__title-line--brand,
.co-hero__intro .co-hero__title-line--body {
  color: rgb(80, 80, 80);
}

.co-hero__stack {
  width: 100%;
}

.co-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
  gap: clamp(1.5rem, 4vw, 2.25rem);
  align-items: center;
}

.co-hero__intro {
  width: 100%;
  max-width: 23rem;
}

.co-hero__kicker {
  margin: 0 0 0.75rem;
  font-size: clamp(1rem, 3.4vw, 1.5625rem);
  font-weight: 800;
  line-height: 1.6;
  letter-spacing: 0.05em;
  text-align: left;
  color: var(--co-hero-kicker-color);
  background: none;
}

.co-hero__title {
  margin: 0;
  font-size: clamp(2.0625rem, 8.6vw, 3.4375rem);
  font-weight: 800;
  line-height: 1.27;
  letter-spacing: 0.05em;
}

.co-hero__title-line {
  display: block;
}

.co-hero__title-line--brand {
  color: var(--co-hero-title-brand);
}

.co-hero__title-line--body {
  color: var(--co-hero-title-body);
}

.co-hero__visual {
  box-sizing: border-box;
  width: 100%;
  max-width: min(100%, var(--co-hero-sp-block-max));
  margin-inline: auto;
}

.co-hero__visual-composite {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  margin-inline: 0;
  aspect-ratio: 330 / 227.22;
  overflow: visible;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.16));
}

.co-hero__picture {
  position: absolute;
  inset: 0;
  z-index: 1;
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
}

.co-hero__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.co-hero__cycle-img {
  position: absolute;
  left: 50%;
  top: 50%;
  /* Pencil: 円 274px / 写真ブロック幅 330px — 全幅で写真との比率を共通にする */
  width: calc(100% * 274 / 330);
  max-width: none;
  height: auto;
  transform: translate(-50%, -50%);
  z-index: 2;
  pointer-events: none;
}

.co-hero__cta {
  width: 100%;
  display: flex;
  justify-content: center;
}

.co-btn--hero-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.5rem 1.5rem;
  width: fit-content;
  border-radius: 999px;
  font-weight: 900;
  font-size: clamp(1rem, 3.5vw, 1.5625rem);
  letter-spacing: 0.05em;
  text-decoration: none;
  color: #fff;
  background: var(--co-hero-btn-pink);
  border: 2px solid #fff;
  box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.22);
  transition: transform 0.15s ease, filter 0.15s ease;
}

.co-btn--hero-primary:hover {
  color: #fff;
  filter: brightness(1.03);
  transform: translateY(-1px);
}

.co-btn--hero-primary:focus-visible {
  outline: 2px solid var(--co-text);
  outline-offset: 3px;
}

@media (min-width: 768px) {
  .co-hero__stack {
    display: contents;
  }

  .co-hero__grid {
    grid-template-columns: minmax(0, 503px) minmax(340px, 1.05fr);
    grid-template-rows: auto auto;
    gap: clamp(1.75rem, 3vw, 2.75rem) clamp(2rem, 4vw, 3rem);
    align-items: center;
    justify-items: stretch;
    text-align: left;
  }

  .co-hero__intro {
    grid-column: 1;
    grid-row: 1;
    max-width: none;
    align-self: end;
    padding-right: clamp(0, 2vw, 1rem);
  }

  .co-hero__kicker {
    font-size: 1.5625rem;
    letter-spacing: 0.078125rem;
    line-height: 1.6;
  }

  /* 1240px 付近で上限 55px（3.4375rem）に張り付くよう fluid（旧 3.25vw だと中間項が小さすぎる） */
  .co-hero__title {
    font-size: clamp(2.125rem, calc(1.25rem + 3.05vw), 3.4375rem);
    letter-spacing: 0.171875rem;
    line-height: 1.27;
  }

  .co-hero__visual {
    grid-column: 2;
    grid-row: 1 / span 2;
    max-width: none;
    margin-inline: 0;
    justify-self: end;
    width: min(100%, 36.75rem);
  }

  .co-hero__visual-composite {
    aspect-ratio: 588 / 406;
    max-width: 100%;
    margin-inline: 0;
    filter: drop-shadow(0 4px 14px rgba(0, 0, 0, 0.2));
  }

  /* PC: hero.webp を hero.png（1192×828）相当のトリミングに寄せる（同一シーンの横幅差を等倍ズームで吸収） */
  .co-hero__picture .co-hero__img {
    transform: scale(calc(1900 / 1192));
    transform-origin: 50% 48%;
  }

  .co-hero__picture {
    inset: 0;
    border-radius: 20px;
  }

  .co-hero__cycle-img {
    transform: translate(-50%, -51%);
  }

  .co-hero__cta {
    grid-column: 1;
    grid-row: 2;
    align-self: start;
    justify-content: flex-start;
    padding-top: 0.35rem;
  }

  .co-btn--hero-primary {
    width: min(27.8125rem, 100%);
    box-sizing: border-box;
    min-height: var(--co-lp-cta-min-h-pc);
    padding: 0.5rem 1.75rem;
    font-size: 1.5625rem;
    letter-spacing: 0.078125rem;
  }
}

@media (max-width: 1023px) {
  .co-lp__container {
    padding-inline: 0;
    padding-left: max(var(--co-sp-inline-pad), env(safe-area-inset-left, 0px));
    padding-right: max(var(--co-sp-inline-pad), env(safe-area-inset-right, 0px));
  }
}

/* 768〜1023px：タブレット横〜狭い PC。左右ガターをビューポートの約 7% 相当（各 3.5vw）だけ広げる */
@media (min-width: 768px) and (max-width: 1023px) {
  .co-lp__container {
    padding-left: max(calc(var(--co-sp-inline-pad) + 3.5vw), env(safe-area-inset-left, 0px));
    padding-right: max(calc(var(--co-sp-inline-pad) + 3.5vw), env(safe-area-inset-right, 0px));
  }

  /* ヒーロー：タイポを PC に寄せて一段小さく、右列（写真）の比率と最大幅を少し拡げる */
  #sec-hero .co-hero__grid {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    column-gap: clamp(1.25rem, 2.25vw, 2rem);
  }

  #sec-hero .co-hero__kicker {
    font-size: clamp(1.125rem, 2.1vw, 1.375rem);
    letter-spacing: 0.05em;
    line-height: 1.55;
  }

  #sec-hero .co-hero__title {
    font-size: clamp(1.8125rem, 2.7vw, 2.5rem);
    letter-spacing: 0.1rem;
    line-height: 1.26;
  }

  #sec-hero .co-hero__visual {
    width: min(100%, min(46rem, 72vw));
  }
}

/* ヒーロー 1 列（767px↓）：タブレット 768〜1023 は上の min-width:768px で 2 カラム */
@media (max-width: 767px) {
  #sec-hero .co-lp__container.co-hero__grid {
    position: static;
    left: auto;
    top: auto;
  }

  .co-hero__grid {
    justify-items: stretch;
    align-items: stretch;
    text-align: left;
    gap: 0;
  }

  .co-hero__stack {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: stretch;
    align-items: stretch;
    gap: clamp(1rem, 3.5vw, 1.5rem);
    width: 100%;
    padding-top: clamp(0.375rem, 2vw, 0.75rem);
    padding-bottom: 0;
    box-sizing: border-box;
  }

  /* キッカー・見出し・写真・CTA を main 写真（picture / sp:hero.webp）と同じ列幅に揃える */
  .co-hero__stack > .co-hero__intro,
  .co-hero__stack > .co-hero__visual,
  .co-hero__stack > .co-hero__cta {
    box-sizing: border-box;
    width: 100%;
    max-width: min(100%, var(--co-hero-sp-block-max));
    margin-inline: auto;
    justify-self: center;
  }

  .co-hero__intro {
    text-align: left;
  }

  .co-hero__title {
    text-align: left;
    letter-spacing: 0.103125rem;
    line-height: 1.36;
  }

  .co-hero__title-line {
    text-align: left;
  }

  .co-hero__stack .co-hero__title-line--brand,
  .co-hero__stack .co-hero__title-line--body {
    color: rgb(80, 80, 80);
    text-align: left;
  }

  .co-hero__kicker {
    letter-spacing: 0.05rem;
    margin-bottom: 0.35rem;
    text-align: left;
    color: rgb(74, 203, 188);
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
  }

  .co-hero__cta {
    justify-content: center;
    /* 写真・円形装飾との間を少し広げる（SP のみ） */
    margin-top: clamp(1.5rem, 7vw, 2.75rem);
  }

  .co-hero__visual-composite {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
    margin-bottom: clamp(0.5rem, 2.5vw, 1rem);
    /* img/sp/hero.webp（676×471）に合わせた枠。画角は object-position で微調整 */
    aspect-ratio: 676 / 471;
    filter: none;
  }

  /* 円が写真下にはみ出して CTA と重ならないよう、基準位置を中央寄せに（ベース top:60% は SP では下げ過ぎ） */
  #sec-hero .co-hero__cycle-img {
    top: 55%;
    transform: translate(-50%, -50%);
  }

  .co-hero__picture .co-hero__img {
    object-position: 50% 44%;
  }

  .co-hero__img {
    box-shadow: none;
  }
}

/* 狭い幅では 80vw がガター内より細くなりがちなので、コンテナ幅いっぱいを優先（画像列と文言列を維持） */
@media (max-width: 480px) {
  .co-hero__stack > .co-hero__intro,
  .co-hero__stack > .co-hero__visual,
  .co-hero__stack > .co-hero__cta {
    max-width: 100%;
  }
}

/* 〜900px：固定ヘッダー 57px ＋控えめな上余白（768〜900 のタブレットで以前の +4.5rem は広すぎるため廃止） */
@media (max-width: 900px) {
  .co-sec.co-sec--hero {
    padding-top: calc(57px + 0.875rem + env(safe-area-inset-top, 0px));
    padding-bottom: 4.5rem;
  }
}

/* SP（767px↓）：セクション縦余白 3rem（#01 / #03 外殻 / #08 グリッドは除外し個別指定） */
@media (max-width: 767px) {
  .co-sec:not(.co-sec--proposal):not(.co-sec--proposal-v2):not(.co-sec--feature-v2):not(.co-sec--dual-cta):not(.co-sec--hero) {
    padding-block: 3rem;
  }

  .co-sec.co-sec--hero {
    /* 固定ヘッダー 57px 直下＋ノッチ。追加の空きは stack 側の padding-top で最小化 */
    padding-top: calc(57px + env(safe-area-inset-top, 0px));
    padding-bottom: 3rem;
  }

  .co-feature-v2 {
    padding-top: 3rem;
    padding-bottom: calc(3rem + var(--co-feat-lead-bridge));
  }

  .co-feature-v2__compare-outer {
    margin-bottom: 3rem;
  }

  .co-feature-compare-band {
    padding-block: 3rem;
  }

  .co-dual-block__shell {
    padding-block: 3rem;
  }
}

/* 901〜1023px：#header_sp（固定 57px・disp_pc_miman）が残るため、PC ナビ前でも上余白は 57px 基準に合わせる */
@media (min-width: 901px) and (max-width: 1023px) {
  .co-sec.co-sec--hero {
    padding-top: calc(57px + 0.875rem + env(safe-area-inset-top, 0px));
  }
}

/* LP セクション英字ラベル（Proposal / Service / Feature / Works / FAQ / Sustainability 共通） */
.co-proposal-v2__h4-inner,
.co-service-v2__h4-inner,
.co-feature-v2__h4-inner,
.co-works__h4-inner,
.co-faq__h4-inner,
.co-sustain__h4-inner {
  display: inline-flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.5rem;
}

.co-proposal-v2__h4-text,
.co-service-v2__h4-text,
.co-feature-v2__h4-text,
.co-works__h4-text,
.co-faq__h4-text,
.co-sustain__h4-text {
  margin: 0;
  font-size: clamp(1.0625rem, 2.2vw, 1.75rem);
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.2;
}

@media (max-width: 1023px) {
  .co-proposal-v2__h4-text,
  .co-service-v2__h4-text,
  .co-feature-v2__h4-text,
  .co-works__h4-text,
  .co-faq__h4-text,
  .co-sustain__h4-text {
    font-size: 1.0625rem; /* 17px — Pencil SP */
  }
}

@media (min-width: 1024px) {
  .co-proposal-v2__h4-text,
  .co-service-v2__h4-text,
  .co-feature-v2__h4-text,
  .co-works__h4-text,
  .co-faq__h4-text,
  .co-sustain__h4-text {
    font-size: 1.75rem; /* 28px — Pencil PC */
  }
}

/* LP セクション日本語 h2（#02〜#06 共通。#01 Proposal は別比率） */
.co-service-v2__title,
.co-feature-v2__title,
.co-works__title,
.co-faq__title,
.co-sustain__title {
  font-size: 2rem; /* 32px — Pencil SP */
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.45;
}

@media (min-width: 1024px) {
  .co-service-v2__title,
  .co-feature-v2__title,
  .co-works__title,
  .co-faq__title,
  .co-sustain__title {
    font-size: 2.8125rem; /* 45px — Pencil PC */
    line-height: 1.556;
  }
}

/* ---------- #02 Our Proposal（#sec01-proposal）／旧表記 Sec01 ---------- */
.co-sec--proposal {
  padding-block: 0;
}

/* index+.html: Pencil「01_Our Proposal」レイアウト */
.co-sec--proposal-v2.co-sec {
  padding-block: 0;
}

.co-proposal-v2 {
  position: relative;
}

/* Pencil we72z「catch」内 h4 ＋見出し */
.co-proposal-v2__catch {
  position: relative;
  z-index: 2;
}

.co-proposal-v2__h4 {
  position: relative;
  z-index: 1;
  padding-top: clamp(1.25rem, 4vw, 2.75rem);
  padding-bottom: clamp(0.35rem, 1.5vw, 0.75rem);
  text-align: center;
}

@media (min-width: 1024px) {
  /* キャッチ：上 72px（4.5rem）、左右中央（Figma 由来の微ズレは 8px グリッドに正規化） */
  .co-proposal-v2__catch {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    box-sizing: border-box;
    padding-top: 4.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    z-index: 5;
    pointer-events: none;
  }

  .co-proposal-v2__catch .co-proposal-v2__h4,
  .co-proposal-v2__catch .co-proposal-v2__title {
    pointer-events: auto;
    width: 100%;
    max-width: 40rem;
    margin-left: auto;
    margin-right: auto;
  }

  .co-proposal-v2__h4 {
    padding-top: 0;
    padding-bottom: 0.5rem;
    text-align: center;
  }
}

.co-proposal-v2__h4-inner {
  margin: 0;
}

.co-proposal-v2__h4-text {
  color: #fff;
}

.co-proposal-v2__h4-line {
  display: block;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
  height: 0;
  border: 0;
  border-top: 1px dotted #fff;
  background: transparent;
}

.co-proposal-v2__teal {
  position: relative;
  background: var(--co-proposal-teal);
  color: #fff;
  padding-top: 0;
  /* 雲の左右はみ出しを見せる（overflow-x/y 混在は visible が auto になるため一律 visible） */
  overflow: visible;
}

.co-sec--proposal-v2 {
  overflow-x: visible;
}

/* SP のみ：ステージ全面の雲（Pencil SP 相当のまま） */
.co-proposal-v2__clouds--sp {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.co-proposal-v2__clouds--sp .co-proposal-v2__cloud {
  position: absolute;
  display: block;
  width: auto;
  height: auto;
  max-width: min(46vw, 22rem);
  object-fit: contain;
  opacity: 0.88;
}

.co-proposal-v2__clouds--sp .co-proposal-v2__cloud--1 {
  left: -20%;
  bottom: 60%;
  top: auto;
  max-width: min(52vw, 24rem);
  opacity: 1;
}

.co-proposal-v2__clouds--sp .co-proposal-v2__cloud--2 {
  right: 66%;
  bottom: 10%;
  top: auto;
  max-width: min(58vw, 22rem);
  opacity: 0.72;
/*  transform: rotate(180deg);*/
}

.co-proposal-v2__clouds--sp .co-proposal-v2__cloud--3 {
  right: -34%;
  top: 40%;
  max-width: min(65vw, 20rem);
  opacity: 0.95;
  transform: rotate(180deg);
}

.co-proposal-v2__clouds--sp .co-proposal-v2__cloud--4 {
  left: 98%;
  bottom: auto;
  top: -130px;
  max-width: min(58vw, 26rem);
  opacity: 1;
  transform: translateX(-50%);
}

@media (min-width: 1024px) {
  .co-proposal-v2__clouds--sp {
    display: none;
  }
}

.co-proposal-v2__teal-inner {
  position: static;
  left: auto;
  top: auto;
  z-index: 1;
}

/* #01 見出し：白＋黄の2段サイズ（#02〜#06 の共通 h2 とは別） */
.co-proposal-v2__title {
  margin: 0 auto clamp(1.25rem, 5vw, 2.75rem);
  max-width: 22em;
  text-align: center;
  font-size: 1.25rem; /* SP 白 20px */
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
  color: #fff;
}

.co-proposal-v2__title-accent {
  color: var(--co-proposal-cta-yellow);
  font-weight: 800;
  font-size: 1.6em; /* SP: 20px × 1.6 = 32px */
}

@media (max-width: 320px) {
  #sec01-heading.co-proposal-v2__title,
  .co-proposal-v2__title {
    letter-spacing: 0.05em;
  }
}

/* 768〜1023px：黄白の比率を PC と同じ（30px / 45px） */
@media (min-width: 768px) and (max-width: 1023px) {
  .co-proposal-v2__title {
    font-size: 1.875rem; /* 白 30px */
  }

  .co-proposal-v2__title-accent {
    font-size: 1.5em; /* 30px × 1.5 = 45px */
  }
}

@media (min-width: 1024px) {
  .co-proposal-v2__title {
    max-width: 40rem;
    font-size: 1.875rem; /* 白 30px */
    margin-top: 0.5rem;
    margin-bottom: 1rem;
  }

  .co-proposal-v2__title-accent {
    font-size: 1.5em; /* 黄 45px */
  }

  .co-proposal-v2__title-br {
    display: none;
  }
}

/* Pencil we72z: person_box（左 cloud2→1→fig / 右 cloud3→4→fig）＋ fukidashi */
.co-proposal-v2__person-box {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  box-sizing: border-box;
}

.co-proposal-v2__person-clouds {
  position: absolute;
  /* person_box より広く取り、ウィンドウ拡大時に雲全体が見切れにくい */
  inset: -8% -45% -12% -45%;
  z-index: 0;
  pointer-events: none;
}

.co-proposal-v2__person-cloud {
  position: absolute;
  display: block;
  width: auto;
  height: auto;
  object-fit: contain;
}

.co-proposal-v2__person-cloud--left-1 {
  top: -4%;
  left: -8%;
  width: min(118%, 34rem);
  max-height: 46%;
  opacity: 0.72;
}

.co-proposal-v2__person-cloud--left-2 {
  top: 6%;
  right: -18%;
  left: auto;
  width: min(112%, 30rem);
  max-height: 50%;
  opacity: 1;
}

.co-proposal-v2__person-cloud--right-1 {
  top: -2%;
  right: -8%;
  left: auto;
  width: min(118%, 34rem);
  max-height: 46%;
  opacity: 0.72;
}

.co-proposal-v2__person-cloud--right-2 {
  top: 2%;
  left: -16%;
  width: min(112%, 30rem);
  max-height: 52%;
  opacity: 1;
}

.co-proposal-v2__person-box .co-proposal-v2__figure {
  position: relative;
  z-index: 1;
}

/* 見出し下：ステージ（SP 縦積み / PC 3 列グリッド） */
.co-proposal-v2__stage {
  position: relative;
  z-index: 1;
  display: grid;
  width: 100%;
  gap: clamp(0.65rem, 2.5vw, 1.1rem);
  align-items: end;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  overflow: visible;
}

.co-proposal-v2__clouds--sp {
  grid-column: 1 / -1;
  grid-row: 1 / -1;
}

.co-proposal-v2__person-box--left {
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  width: 100%;
  max-width: min(22rem, 48vw);
  min-height: clamp(11rem, 36vw, 15rem);
}

.co-proposal-v2__person-box--right {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  width: 100%;
  max-width: min(22rem, 48vw);
  min-height: clamp(11rem, 36vw, 15rem);
}

.co-proposal-v2__person-box .co-proposal-v2__figure img {
  display: block;
  width: clamp(5.25rem, 26vw, 8.25rem);
  height: auto;
  margin-inline: auto;
}

@media (max-width: 1023px) {
  .co-proposal-v2__person-clouds {
    display: none;
  }
}

.co-proposal-v2__bubbles {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 4vw, 1.75rem);
  align-items: center;
  width: 100%;
  grid-column: 1 / -1;
  grid-row: 2;
  position: relative;
  z-index: 2;
}

.co-proposal-v2__bubble {
  position: relative;
  width: 100%;
  max-width: min(20.5rem, 100%);
}

@media (min-width: 1024px) {
  /* PC: 下余白を確実にゼロ（.co-sec / テーマCSS より優先） */
  #sec01-proposal.co-sec.co-sec--proposal-v2 {
    padding-bottom: 0;
    padding-block-end: 0;
  }

  #sec01-proposal .co-proposal-v2__teal {
    padding-bottom: 0;
    padding-block-end: 0;
    /* 上方向へはみ出した雲をティール上端でクリップ（左右・下は広げて現行のはみ出しを維持） */
    clip-path: inset(0 -300vw -300vw -300vw);
  }

  #sec01-proposal .co-proposal-v2__teal-inner {
    padding-bottom: 0;
    padding-block-end: 0;
  }

  .co-proposal-v2__teal-inner {
    overflow: visible;
  }

  .co-proposal-v2__stage {
    grid-template-columns: minmax(0, 1fr) minmax(0, 800px) minmax(0, 1fr);
    grid-template-rows: auto;
    gap: 0;
    align-items: end;
    /* 1200px〜は従来どおり。1024〜1199px は下のメディアクエリで約200pxに上書き */
    min-height: clamp(18rem, 30vw, 26rem);
  }

  .co-proposal-v2__person-box--left {
    justify-self: start;
    width: 100%;
    max-width: none;
    min-height: clamp(12rem, 20vw, 16rem);
  }

  .co-proposal-v2__person-box--right {
    grid-column: 3;
    justify-self: end;
    width: 100%;
    max-width: none;
    min-height: clamp(12rem, 20vw, 16rem);
  }

  .co-proposal-v2__person-box--left .co-proposal-v2__person-clouds {
    inset: -20% -82% 14% -58%;
  }

  .co-proposal-v2__person-box--right .co-proposal-v2__person-clouds {
    inset: -20% -58% 14% -82%;
  }

  .co-proposal-v2__person-box--left .co-proposal-v2__person-cloud--left-1 {
    top: -14%;
    left: -24%;
    width: min(122%, 22.5rem);
    max-height: none;
    opacity: 0.92;
  }

  .co-proposal-v2__person-box--left .co-proposal-v2__person-cloud--left-2 {
    top: 67%;
    right: 0%;
    width: min(158%, 28rem);
    max-height: none;
    opacity: 0.7;
  }

  .co-proposal-v2__person-box--right .co-proposal-v2__person-cloud--right-1 {
    top: -50%;
    right: -16%;
    width: min(122%, 22.5rem);
    max-height: none;
    opacity: 0.92;
  }

  .co-proposal-v2__person-box--right .co-proposal-v2__person-cloud--right-2 {
    top: 80%;
    left: 58%;
    width: min(158%, 28rem);
    max-height: none;
    opacity: 0.7;
  }

  .co-proposal-v2__person-box .co-proposal-v2__figure {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 7.5rem;
    max-width: 7.5rem;
    height: clamp(17rem, 21vw, 19rem);
    margin: 0;
    overflow: hidden;
  }

  .co-proposal-v2__person-box--right .co-proposal-v2__figure {
    max-width: 8.25rem;
    width: 8.25rem;
    height: clamp(17.5rem, 22vw, 19.75rem);
  }

  .co-proposal-v2__person-box .co-proposal-v2__figure img {
    width: 100%;
    max-width: none;
    height: 100%;
    max-height: none;
    object-fit: cover;
    object-position: top center;
  }

  /* Pencil PC「fukidashi」: 792×191、グリッド中央列 */
  .co-proposal-v2__bubbles {
    grid-column: 2;
    grid-row: 1;
    align-self: end;
    justify-self: center;
    position: relative;
    z-index: 2;
    display: block;
    width: 100%;
    max-width: 792px;
    aspect-ratio: 792 / 191;
    height: auto;
    margin-inline: auto;
    margin-bottom: 0;
    padding: 0;
    flex-direction: unset;
    flex-wrap: unset;
    justify-content: unset;
    align-items: unset;
    box-sizing: border-box;
  }

  .co-proposal-v2__bubble {
    position: absolute;
    margin: 0;
    box-sizing: border-box;
  }

  .co-proposal-v2__bubble:nth-child(1) {
    left: 0;
    top: 0;
    width: 32.4495%;
    height: 79.0576%;
    z-index: 1;
  }

  .co-proposal-v2__bubble:nth-child(2) {
    left: 30.1768%;
    top: 8.9005%;
    width: 35.7323%;
    height: 91.0995%;
    z-index: 3;
  }

  .co-proposal-v2__bubble:nth-child(3) {
    left: 61.8687%;
    top: 1.5707%;
    width: 38.1313%;
    height: 93.7173%;
    z-index: 2;
  }

  /* Image（Group 内オフセット 12 / 24 / 32px） */
  .co-proposal-v2__bubble:nth-child(1) .co-proposal-v2__bubble-bg {
    position: absolute;
    left: 4.6693%;
    top: 0;
    width: 90.6615%;
    height: auto;
    max-width: none;
  }

  .co-proposal-v2__bubble:nth-child(2) .co-proposal-v2__bubble-bg {
    position: absolute;
    left: 8.4806%;
    top: 0;
    width: 86.5724%;
    height: auto;
    max-width: none;
  }

  .co-proposal-v2__bubble:nth-child(3) .co-proposal-v2__bubble-bg {
    position: absolute;
    left: 10.596%;
    top: 0;
    width: 78.1457%;
    height: auto;
    max-width: none;
  }
}

.co-proposal-v2__bubble-bg {
  display: block;
  width: 100%;
  height: auto;
}

.co-proposal-v2__bubble-text {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  box-sizing: border-box;
  width: 86%;
  margin: 0;
  text-align: center;
  font-size: clamp(0.9rem, 3.2vw, 1rem);
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.03em;
  color: var(--co-proposal-fuki-text);
}

/* SP〜タブレット縦（1023px↓）: 人物＋吹き出し＋人物を 1 段で揃える（769〜1023 もカラム落ちしない） */
@media (max-width: 1023px) {
  .co-proposal-v2__teal-inner {
    padding-inline: clamp(0.75rem, 3.5vw, 1.25rem);
  }

  /* 見出し直下の余白はゼロ。キャッチ〜吹き出しの距離は .co-proposal-v2__bubbles の margin-block で揃える */
  #sec01-heading.co-proposal-v2__title,
  .co-proposal-v2__title {
    margin-bottom: 0;
  }

  .co-proposal-v2__stage {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 0;
    min-height: clamp(16rem, 62vw, 26rem);
    padding-block: 0;
    padding-bottom: 0;
  }

  .co-proposal-v2__person-box--left,
  .co-proposal-v2__person-box--right {
    /* 1 列グリッドなのに右だけ grid-column: 2 のままだと暗黙列が幅 0 になり、
       position:absolute の包含ブロックが潰れて width:16% が 0 相当になる */
    grid-column: 1;
    grid-row: 1;
    position: absolute;
    top: 50%;
    bottom: auto;
    /* ステージ1列目（全幅）を基準にした 16% */
    width: 16%;
    max-width: none;
    min-height: 0;
    z-index: 1;
    transform: translateY(-50%);
  }

  .co-proposal-v2__person-box--left {
    left: clamp(0rem, 2vw, 0.75rem);
  }

  .co-proposal-v2__person-box--right {
    right: clamp(0rem, 2vw, 0.75rem);
  }

  .co-proposal-v2__person-box .co-proposal-v2__figure {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin: 0;
  }

  .co-proposal-v2__person-box .co-proposal-v2__figure img {
    width: 100%;
    height: auto;
    max-width: 100%;
    margin-inline: 0;
  }

  .co-proposal-v2__bubbles {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    justify-self: center;
    width: 58%;
    margin-inline: auto;
    margin-block: clamp(0.75rem, 3vw, 1.25rem);
    padding-inline: clamp(0.5rem, 2.5vw, 1rem);
    gap: clamp(0.8rem, 3.2vw, 1.25rem);
    z-index: 2;
  }
}

/* 768〜1023px: 見出しと吹き出しの重なり回避（契約 B+C） */
@media (min-width: 768px) and (max-width: 1023px) {
  .co-proposal-v2__catch {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    padding-top: clamp(2.75rem, 6vw, 4rem);
    z-index: 3;
    pointer-events: auto;
  }

  .co-proposal-v2__catch .co-proposal-v2__h4,
  .co-proposal-v2__catch .co-proposal-v2__title {
    width: 100%;
    max-width: min(40rem, 92%);
    margin-left: auto;
    margin-right: auto;
  }

}

/* 1024〜1199px: タブレット横〜小さめPCでも重なりを防止 */
@media (min-width: 1024px) and (max-width: 1199px) {
  .co-proposal-v2__catch {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    padding-top: 4.5rem;
    z-index: 3;
    pointer-events: auto;
  }

  .co-proposal-v2__catch .co-proposal-v2__h4,
  .co-proposal-v2__catch .co-proposal-v2__title {
    width: 100%;
    max-width: 40rem;
    margin-left: auto;
    margin-right: auto;
  }

  .co-proposal-v2__stage {
    padding-top: 0;
    /* 狭いPC帯のみステージ高さを抑える（1200px〜は上の clamp のまま） */
    min-height: 12.5rem;
  }
}

/* 1200px〜: catch が再び absolute のため、ステージ上に見出しぶんの余白を確保 */
@media (min-width: 1200px) {
  #sec01-proposal .co-proposal-v2__stage {
    padding-top: clamp(6.75rem, 12.5vw, 9.25rem);
  }
}

@media (min-width: 1024px) {
  .co-proposal-v2__bubble-text {
    left: 50%;
    width: 100%;
    max-width: none;
    padding-inline: 0.35rem;
    box-sizing: border-box;
    font-size: 20px;
    line-height: 28px;
    letter-spacing: 0.05em;
    font-weight: 700;
    transform: translateX(-50%);
  }

  .co-proposal-v2__bubble:nth-child(1) .co-proposal-v2__bubble-text {
    top: 21.192%;
  }

  .co-proposal-v2__bubble:nth-child(2) .co-proposal-v2__bubble-text {
    top: 24.713%;
  }

  .co-proposal-v2__bubble:nth-child(3) .co-proposal-v2__bubble-text {
    top: 24.581%;
  }
}

.co-proposal-v2__mint {
  position: relative;
  background: var(--co-proposal-mint);
  padding-top: clamp(2.35rem, 6vw, 3.65rem);
  padding-bottom: clamp(2rem, 6vw, 3.5rem);
  z-index: 5;
}

.co-proposal-v2__chevron {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  z-index: 1;
  margin-inline: auto;
  /* 上辺＝幅いっぱいの底辺、先端が下＝ティールがミントへ下向きに食い込む */
  width: calc(94/375*100%);
  height: clamp(2.15rem, 5.2vw, 3.85rem);
  transform: translateY(-0.2rem);
  background: var(--co-proposal-teal);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

@media (min-width: 1024px) {
  .co-proposal-v2__chevron {
    width: min(320px, calc(100% - 2rem));
    aspect-ratio: 440 / 126;
    height: auto;
    min-height: 0;
    transform: translateY(-0.35rem);
  }

  .co-proposal-v2__mint {
    padding-top: clamp(2.85rem, 4.5vw, 4rem);
  }
}

.co-proposal-v2__mint-inner {
  position: relative;
  z-index: 2;
  /* 三角（clip-path）がリード文と重ならないよう、三角の高さ相当を確保 */
  padding-top: clamp(1.75rem, 5vw, 3.25rem);
}

@media (min-width: 1024px) {
  .co-proposal-v2__mint-inner {
    padding-top: clamp(3.5rem, 10vw, 5rem);
  }
}

.co-proposal-v2__lead {
  margin: 0 auto;
  max-width: 48rem;
  text-align: center;
  font-size: clamp(0.9375rem, 3.1vw, 1rem);
  font-weight: 700;
  line-height: 1.65;
  letter-spacing: 0.075em;
  color: #505050;
}

@media (min-width: 1024px) {
  .co-proposal-v2__lead {
    font-size: clamp(1.125rem, 1.7vw, 1.6875rem);
    max-width: 56rem;
  }
}


@media (max-width: 767px) {

}

@media (min-width: 1024px) {
  .co-proposal-v2__cta-br {
    display: none;
  }


}

.co-sec--proposal__mint {
  background: linear-gradient(180deg, var(--co-mint-top) 0%, var(--co-mint-soft) 100%);
  padding-block: clamp(2.25rem, 5vw, 3.75rem);
  padding-bottom: clamp(3rem, 7vw, 4rem);
}

.co-sec01-clouds {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
  justify-items: center;
  gap: clamp(0.35rem, 2vw, 1.25rem);
  margin-block: clamp(1rem, 3vw, 1.75rem) 1.25rem;
  width: 100%;
  max-width: min(100%, 960px);
  margin-inline: auto;
}

.co-sec01-cloud {
  display: block;
  width: 100%;
  max-width: min(240px, 100%);
  height: auto;
  object-fit: contain;
}

@media (max-width: 719px) {
  .co-sec01-clouds {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(0.35rem, 4vw, 0.85rem);
  }

  .co-sec01-cloud {
    max-width: min(200px, 100%);
  }
}

.co-proposal-chars {
  display: grid;
  grid-template-columns: 1fr minmax(0, 560px) 1fr;
  gap: 0.75rem;
  align-items: end;
  margin-top: 1.25rem;
}

@media (max-width: 719px) {
  .co-proposal-chars {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .co-proposal-char,
  .co-proposal-char--right {
    display: none;
  }
}

.co-proposal-char {
  min-height: 120px;
  border-radius: 50% 50% 40% 40%;
  background: linear-gradient(180deg, #ffeef0 0%, #ffdde2 100%);
  opacity: 0.95;
}

.co-proposal-char--right {
  background: linear-gradient(180deg, #eaf5ff 0%, #dceeff 100%);
}

.co-proposal-bubbles {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.co-bubble {
  background: #fff;
  border-radius: var(--co-radius);
  padding: 1rem 1.15rem;
  box-shadow: var(--co-shadow);
  border: 1px solid rgba(255, 255, 255, 0.8);
}

.co-bubble p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.65;
}

.co-sec--proposal__teal {
  background: var(--co-teal-header);
  color: #fff;
  padding-block: clamp(2.5rem, 6vw, 4rem);
  position: relative;
  margin-top: 0;
}

.co-sec--proposal__arrow {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -45%);
  width: 0;
  height: 0;
  border-left: clamp(52px, 12vw, 76px) solid transparent;
  border-right: clamp(52px, 12vw, 76px) solid transparent;
  border-top: clamp(38px, 8vw, 52px) solid var(--co-mint-soft);
}

.co-proposal-solution-label {
  text-align: center;
  font-size: 0.85rem;
  opacity: 0.92;
  margin: 1.25rem 0 0.35rem;
}

.co-proposal-solution-title {
  text-align: center;
  font-size: clamp(1.25rem, 3.2vw, 1.75rem);
  font-weight: 700;
  margin: 0;
}

.co-proposal-solution-title strong {
  display: inline-block;
  margin-left: 0.35rem;
  font-weight: 800;
}

/* =============================================================================
 * #03 Service（#sec02-service）— 直下から `.co-sec--white`（白地）→ Service 本体
 * ============================================================================= */
/* ---------- Sec02：白地 .co-sec--white ---------- */
.co-sec--white {
  background: #fff;
}

/* ---------- Sec02 Service（Pencil 02_Service）／#sec02-service ---------- */
.co-sec--service-v2 {
  padding-block: 4.5rem;
}

.co-service-v2 {
  --co-svc-teal: #33a194;
  --co-svc-text: #505050;
  --co-svc-pink: #db437c;
  --co-svc-orange: #ea963b;
  --co-svc-purple: #905e8f;
  --co-svc-grey: #eeeeee;
  --co-svc-cert-yellow: #fff461;
}

.co-service-v2__intro {
  position: static;
  left: auto;
  top: auto;
  text-align: center;
}

.co-service-v2__h4 {
  padding-bottom: clamp(0.5rem, 2vw, 1rem);
}

.co-service-v2__h4-text {
  color: var(--co-svc-teal);
}

.co-service-v2__h4-line {
  display: block;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
  height: 0;
  border: 0;
  border-top: 1px dotted var(--co-svc-teal);
}

.co-service-v2__title {
  margin: 0 0 clamp(1rem, 3vw, 1.5rem);
  letter-spacing: 0.15em;
  color: #33a194;
  background: none;
  background-image: none;
  -webkit-text-fill-color: currentColor;
}

/* 768〜：1行＋半角スペース表示／767以下：改行＋スペース非表示 */
.co-service-v2__title-gap,
.co-service-v2__body-lead-gap {
  display: none;
}

@media (min-width: 768px) {
  .co-service-v2__title-gap,
  .co-service-v2__body-lead-gap {
    display: inline;
  }
}

.co-service-v2__title-br-sp,
.co-service-v2__body-lead-br-sp {
  display: none;
}

@media (max-width: 767px) {
  .co-service-v2__title-br-sp,
  .co-service-v2__body-lead-br-sp {
    display: block;
  }
}

.co-service-v2__lead {
  margin: 0 auto clamp(1.5rem, 3vw, 1.75rem);
  max-width: 62rem;
  font-size: clamp(1.05rem, 2.6vw, 1.6875rem);
  font-weight: 700;
  line-height: 1.85;
  letter-spacing: 0.04em;
  color: var(--co-svc-text);
}

.co-service-v2__body {
  margin: 0 auto;
  max-width: 62rem;
  font-size: clamp(0.9375rem, 2vw, 1.0625rem);
  font-weight: 700;
  line-height: 2.5;
  letter-spacing: 0.05em;
  text-align: center;
  color: var(--co-svc-text);
}

.co-service-v2__lead-br-pc,
.co-service-v2__body-br-pc {
  display: none;
}

.co-service-v2__grey {
  box-sizing: border-box;
  margin-top: clamp(1.75rem, 4vw, 2.5rem);
  /* 証明書 .co-service-v2__cert（.co-lp__container.co-service-v2__cert-outer 内）と同じ左右ガターでグレー帯をインセット */
}

@media (max-width: 1023px) {
  .co-service-v2__grey {
    padding-left: max(var(--co-sp-inline-pad), env(safe-area-inset-left, 0px));
    padding-right: max(var(--co-sp-inline-pad), env(safe-area-inset-right, 0px));
  }
}

@media (min-width: 1024px) {
  .co-service-v2__grey {
    padding-inline: clamp(1rem, 4vw, 2rem);
  }
}

/* 親の横パディング内に100%幅のグレー面。co-lp__container の横ガターは打ち消し、内側だけ余白 */
.co-service-v2__grey .co-service-v2__grey-inner.co-lp__container {
  box-sizing: border-box;
  width: 100%;
  max-width: none;
  margin-inline: 0;
  padding-top: clamp(1.5rem, 4vw, 2.75rem);
  padding-bottom: clamp(2rem, 5vw, 3rem);
  padding-left: clamp(0.9375rem, 3.2vw, 1.875rem);
  padding-right: clamp(0.9375rem, 3.2vw, 1.875rem);
  background: var(--co-svc-grey);
  border-radius: 20px;
}

@media (min-width: 1024px) {
  .co-service-v2__grey .co-service-v2__grey-inner.co-lp__container {
    max-width: min(72.1875rem, 100%);
    margin-inline: auto;
  }
}

.co-service-v2__diagram {
  margin: 0 auto clamp(1.5rem, 4vw, 2.25rem);
  max-width: 33.5625rem;
  text-align: center;
}

.co-service-v2__diagram img {
  display: block;
  width: 100%;
  height: auto;
  margin-inline: auto;
}

.co-service-v2__cards {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(2.625rem, 3vw, 1.7rem);
}

.co-service-v2__card {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  max-width: 20.9375rem;
  margin-top: 1.125rem;
  padding: 2.25rem 1.15rem 1.35rem;
  border-radius: 10px;
  border: 1px solid;
  background: #fff;
}

.co-service-v2__card--now {
  border-color: var(--co-svc-pink);
}

.co-service-v2__card--future {
  border-color: var(--co-svc-orange);
}

.co-service-v2__card--mind {
  border-color: var(--co-svc-purple);
}

.co-service-v2__chip {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 9.0625rem;
  min-height: 2.25rem;
  padding: 0 1rem;
  border-radius: 999px;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  line-height: 1.2;
  color: #fff;
}

.co-service-v2__card--now .co-service-v2__chip {
  background: var(--co-svc-pink);
}

.co-service-v2__card--future .co-service-v2__chip {
  background: var(--co-svc-orange);
}

.co-service-v2__card--mind .co-service-v2__chip {
  background: var(--co-svc-purple);
}

.co-service-v2__card-title {
  margin: 0 0 1rem;
  min-height: 4.9375rem;
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.65;
  letter-spacing: 0.05em;
  text-align: center;
}

.co-service-v2__card--now .co-service-v2__card-title {
  color: var(--co-svc-pink);
}

.co-service-v2__card--future .co-service-v2__card-title {
  color: var(--co-svc-orange);
}

.co-service-v2__card--mind .co-service-v2__card-title {
  color: var(--co-svc-purple);
}

.co-service-v2__card-media {
  margin: 0 auto 1rem;
  max-width: 17rem;
  overflow: hidden;
}

.co-service-v2__card-media picture {
  display: block;
  width: 100%;
}

.co-service-v2__card-media img {
  display: block;
  width: 100%;
  height: auto;
}

.co-service-v2__card-text {
  margin: 0;
  font-size: clamp(0.9375rem, 2.2vw, 1.0625rem);
  font-weight: 500;
  line-height: 1.65;
  letter-spacing: 0.05em;
  text-align: justify;
  color: var(--co-svc-text);
}

.co-service-v2__cta-wrap {
  margin-top: clamp(2rem, 4vw, 2.5rem);
  text-align: center;
}

.co-service-v2__cta {
  min-width: min(100%, 17.5rem);
  min-height: 3.5rem;
  padding: 0.5rem 2rem;
  border: 2px solid #fff;
  border-radius: 999px;
  font-size: clamp(1rem, 2.5vw, 1.5625rem);
  font-weight: 900;
  letter-spacing: 0.05em;
  box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.25);
}

/* グレー帯（.grey-inner）と同じ左右ガター＋同じ max 幅で、緑枠の証明書ブロックを配置 */
.co-service-v2__cert-outer.co-lp__container {
  box-sizing: border-box;
  width: 100%;
  max-width: none;
  margin-inline: 0;
  padding-inline: 0;
  margin-top: clamp(2.5rem, 5vw, 3rem);
}

@media (max-width: 1023px) {
  .co-service-v2__cert-outer.co-lp__container {
    padding-left: max(var(--co-sp-inline-pad), env(safe-area-inset-left, 0px));
    padding-right: max(var(--co-sp-inline-pad), env(safe-area-inset-right, 0px));
  }
}

@media (min-width: 1024px) {
  .co-service-v2__cert-outer.co-lp__container {
    padding-inline: clamp(1rem, 4vw, 2rem);
  }
}

.co-service-v2__cert {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 100%;
  max-width: min(72.1875rem, 100%);
  margin-inline: auto;
  padding: clamp(1.5rem, 4vw, 2.75rem) clamp(0.9375rem, 3.2vw, 1.875rem)
    clamp(2rem, 5vw, 3rem);
  border: 2px solid var(--co-svc-teal);
  background: transparent;
}

.co-service-v2__cert-copy {
  min-width: 0;
}

.co-service-v2__cert-head {
  margin-bottom: 0.75rem;
}

.co-service-v2__cert-line {
  margin: 0;
  font-size: clamp(1.25rem, 3vw, 2.0625rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.35;
  color: var(--co-svc-text);
}

.co-service-v2__cert-line--1 {
  color: var(--co-svc-teal);
}

.co-service-v2__cert-line--2 {
  color: var(--co-svc-teal);
}

.co-service-v2__cert-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0.35rem 0;
  min-height: 3.3125rem;
  padding: 0.25rem 0.75rem;
  background: var(--co-svc-cert-yellow);
  font-size: clamp(1.6875rem, 3.5vw, 2.8125rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.3;
  color: var(--co-svc-teal);
}

.co-service-v2__cert-body {
  margin: 0 0 0.75rem;
  max-width: 32rem;
  font-size: clamp(0.9375rem, 2.2vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.05em;
  text-align: justify;
  color: var(--co-svc-text);
}

.co-service-v2__cert-note {
  margin: 0;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.65;
  letter-spacing: 0.1em;
  color: var(--co-svc-text);
}

/* SP：キャッチ → 証明書画像 → 本文 → 注記（.cert-copy を仮想的に解体して並べ替え） */
@media (max-width: 767px) {
  .co-service-v2__cert-copy {
    display: contents;
  }

  .co-service-v2__cert-head {
    order: 1;
    margin-bottom: 0;
  }

  .co-service-v2__cert-fig {
    order: 2;
  }

  .co-service-v2__cert-body {
    order: 3;
    margin-top: 0;
    margin-bottom: 0;
      max-width: 100%;
  }

  .co-service-v2__cert-note {
    order: 4;
  }
}

.co-service-v2__cert-fig {
  margin: 0;
  padding: 0;
  text-align: center;
  background: none;
  border: 0;
}

.co-service-v2__cert-fig img {
  display: block;
  width: min(13.5rem, 100%);
  height: auto;
  margin-inline: auto;
  border: 0;
}

.co-service-v2__cert-cap {
  margin: 0.5rem 0 0;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.05em;
  color: var(--co-svc-text);
}

/* 768px〜：3カラム横並び（767px 以下はベースの縦積み） */
@media (min-width: 768px) {
  .co-service-v2__cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
    gap: clamp(0.65rem, 1.8vw, 1.375rem);
  }

  .co-service-v2__card {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: none;
    min-width: 0;
  }

  .co-service-v2__card-media {
    max-width: 100%;
  }
}

@media (min-width: 1024px) {
  .co-service-v2__lead-br-pc,
  .co-service-v2__body-br-pc {
    display: block;
  }

  .co-service-v2__cards {
    gap: 1.6875rem;
  }
}

/* 1024px近辺はカード幅がタイトなため、見出しを2行で収める */
@media (min-width: 1024px) and (max-width: 1199px) {
  .co-service-v2__card-title {
    font-size: 1.0625rem;
    line-height: 1.45;
    min-height: calc(1em * 1.45 * 2);
  }
}

@media (min-width: 768px) {
  .co-service-v2__cert {
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
    gap: 3rem;
    padding: clamp(2.5rem, 4vw, 3rem) clamp(2.25rem, 4vw, 2.75rem) clamp(2.25rem, 4vw, 2.75rem);
  }

  .co-service-v2__cert-copy {
    display: block;
  }

  .co-service-v2__cert-fig {
    flex: 0 0 auto;
    align-self: flex-end;
    text-align: right;
  }

  .co-service-v2__cert-fig img {
    width: 13.5rem;
  }

  .co-service-v2__cert-cap {
    text-align: right;
  }
}

.co-cycle {
  position: relative;
  width: min(320px, 80vw);
  aspect-ratio: 1;
  margin: 2rem auto 3rem;
}

.co-cycle__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 14px solid transparent;
}

.co-cycle__ring--a {
  border-color: rgba(241, 93, 110, 0.55);
  transform: scale(1);
}

.co-cycle__ring--b {
  border-color: rgba(247, 160, 0, 0.6);
  transform: scale(0.76);
}

.co-cycle__ring--c {
  border-color: rgba(74, 203, 188, 0.75);
  transform: scale(0.54);
}

.co-cycle__pill {
  position: absolute;
  font-size: 0.68rem;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.95);
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.co-cycle__pill--1 {
  top: 6%;
  right: 4%;
  color: #d0405c;
}

.co-cycle__pill--2 {
  bottom: 8%;
  right: 6%;
  color: #c97400;
}

.co-cycle__pill--3 {
  left: -2%;
  top: 44%;
  color: var(--co-teal-header);
}

.co-cards--three {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .co-cards--three {
    grid-template-columns: repeat(3, 1fr);
  }
}

.co-card {
  background: #fafcfb;
  border-radius: var(--co-radius);
  padding: 0 1.1rem 1.35rem;
  border: 1px solid #e8efec;
  overflow: clip;
}

.co-card__accent {
  height: 6px;
  margin: 0 -1.1rem 1rem -1.1rem;
  border-radius: 0;
}

.co-card__accent--pink {
  background: #f0788c;
}

.co-card__accent--orange {
  background: #f39c4b;
}

.co-card__accent--purple {
  background: #8b76c9;
}

.co-card__title {
  font-size: 1.05rem;
  margin: 0 0 0.5rem;
}

.co-card__text {
  font-size: 0.88rem;
  line-height: 1.85;
  color: var(--co-text-muted);
  margin: 0;
}

.co-notebox {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  align-items: center;
  margin-top: 2.5rem;
  padding: 1.25rem;
  border: 3px solid var(--co-teal-header);
  border-radius: var(--co-radius);
  background: #fbfffd;
}

.co-notebox__title {
  font-size: 1.05rem;
  margin: 0 0 0.35rem;
  color: var(--co-teal-header);
}

.co-notebox__body p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.85;
}

/* ---------- #04 Feature（#sec03-feature）（Pencil 03_Feature） ---------- */
#sec03-feature {
  position: relative;
  z-index: 2;
  overflow: visible;
}

.co-sec--feature-v2 {
  padding-block: 0;
  background: transparent;
  overflow: visible;
}

.co-feature-v2 {
  --co-feat-teal: #4acbbc;
  --co-feat-trad-bg: #d9d9d9;
  --co-feat-circ-bg: #ffd9d7;
  --co-feat-trad-pill: #7b7b7b;
  --co-feat-lead-yellow: #fff461;
  position: relative;
  z-index: 1;
  overflow: visible;
  background: var(--co-feat-teal);
  color: #fff;
  padding-top: 4.5rem;
  padding-bottom: calc(4.5rem + var(--co-feat-lead-bridge));
}

.co-feature-v2__intro {
  text-align: center;
}

/* #02 と同型：ティール帯上は英字＋白の点線（幅は英字に合わせる） */
.co-feature-v2__h4 {
  padding-bottom: clamp(0.5rem, 2vw, 1rem);
}

.co-feature-v2__h4-text {
  color: #fff;
}

.co-feature-v2__h4-line {
  display: block;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
  height: 0;
  border: 0;
  border-top: 1px dotted #fff;
}

.co-feature-v2__title {
  /* #02 h2→lead と同じ下マージン + ピルが上にはみ出す分（高さの約半分） */
  margin: 0 0 calc(clamp(1rem, 3vw, 1.5rem) + clamp(1.0625rem, 2.8vh, 1.4375rem));
  color: #fff;
}

.co-feature-v2__title-br-sp {
  display: none;
}

.co-feature-v2__compare-outer {
  margin-bottom: 4.5rem;
}

.co-feature-v2__compare {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: clamp(1rem, 3vw, 1.5rem);
}

.co-feature-v2__panel {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  max-width: 33.0625rem;
  margin-inline: auto;
  padding: clamp(2.5rem, 6vw, 3.25rem) clamp(1rem, 3vw, 1.875rem) clamp(1.5rem, 3vw, 2rem);
  border-radius: 10px;
}

.co-feature-v2__panel--trad {
  background: var(--co-feat-trad-bg);
  color: #505050;
}

.co-feature-v2__panel--circ {
  background: var(--co-feat-circ-bg);
  color: #505050;
}

/* 親パネル幅の約78%（最大413px付近）・中央・1行（従来／循環とも同ルール） */
.co-feature-v2__pill {
  position: absolute;
  left: 50%;
  right: auto;
  top: 0;
  transform: translate(-50%, -50%);
  box-sizing: border-box;
  width: 78%;
  max-width: min(100%, 25.8125rem);
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  font-size: clamp(0.9375rem, 0.55rem + 1.8vw, 1.875rem);
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1.25;
  text-align: center;
  white-space: nowrap;
  color: #fff;
}

.co-feature-v2__pill--trad {
  background: var(--co-feat-trad-pill);
}

.co-feature-v2__pill--circ {
  background: var(--co-pink);
}

.co-feature-v2__stack {
  display: flex;
  flex-direction: column;
  gap: clamp(1.1rem, 3vw, 1.5rem);
}

.co-feature-v2__subcard {
  margin: 0;
  padding: 2rem;
  border-radius: 10px;
  background: #fff;
  text-align: center;
}

.co-feature-v2__subcard-title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.25rem, 3.2vw, 1.875rem);
  font-weight: 700;
  line-height: 1.35;
  color: #505050;
}

.co-feature-v2__subcard-title--accent {
  color: var(--co-pink);
}

.co-feature-v2__subcard-text {
  margin: 0;
  font-size: clamp(0.93rem, 2.2vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.59;
  color: #505050;
}

/* 矢印：PC は右向き3つ縦、SP は下向き1つ */
.co-feature-v2__arrows {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  gap: 0;
  min-height: 2.5rem;
}

.co-feature-v2__arrow {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0;
  border-left: 24px solid transparent;
  border-right: 24px solid transparent;
  border-top: 22px solid rgba(255, 255, 255, 0.98);
}

.co-feature-v2__arrow--pc-only {
  display: none;
}

/* 黄 lead：親を #03 下端に固定し、子を translateY(50%) で #03/#04 境の中央に */
.co-feature-v2__lead-outer.co-lp__container {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: var(--co-max);
  max-width: 100%;
  margin: 0;
  z-index: 4;
  pointer-events: none;
}

.co-feature-v2__leadbox {
  box-sizing: border-box;
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: min(70.375rem, 100%);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  padding: clamp(1rem, 2.6vw, 1.5rem) clamp(1rem, 3vw, 2rem);
  /* SP（767↓）：カプセルにせず角長方形。768px↑は 150px */
  border-radius: 3.125rem;
  background: var(--co-feat-lead-yellow);
  text-align: center;
  transform: translateY(50%);
  pointer-events: auto;
}

@media (min-width: 768px) {
  .co-feature-v2__leadbox {
    /* PC：カプセル型（両端が半円になる十分大きな radius） */
    border-radius: 9999px;
  }
}

.co-feature-v2__lead {
  margin: 0;
  font-size: clamp(1.15rem, 3.2vw, 2.5rem);
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.02em;
  color: #505050;
}

.co-feature-v2__cta {
  min-width: min(100%, 17.5rem);
  min-height: 3.5rem;
  padding: 0.5rem 2rem;
  border: 2px solid #fff;
  border-radius: 999px;
  font-size: clamp(1rem, 2.5vw, 1.5625rem);
  font-weight: 900;
  letter-spacing: 0.05em;
  box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.25);
}

@media (max-width: 1023px) {
  .co-feature-v2__title-br-sp {
    display: block;
  }

  /* 縦積み：ピル（計測〜44px）が translateY(-50%) で上にはみ出す分、矢印をその半分ほど下げて視覚中央に寄せる */
  .co-feature-v2__arrows {
    margin-bottom: 1.375rem;
  }
}

@media (max-width: 767px) {
  .co-feature-v2__subcard-title {
    font-size: 1.6875rem; /* 27px */
  }
}

@media (min-width: 1024px) {
  .co-feature-v2__leadbox {
    padding: 2rem;
  }

  .co-feature-v2__title {
    /* ピルが translate(-50%, -50%) で上にはみ出す分を含め、h2 とカード列の間を PC で確保 */
    margin-bottom: calc(clamp(1.25rem, 3vw, 1.75rem) + clamp(1.5rem, 2.8vh, 2.125rem));
  }

  .co-feature-v2__compare {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: clamp(0.35rem, 1.2vw, 1rem);
  }

  .co-feature-v2__panel {
    display: flex;
    flex-direction: column;
    flex: 1 1 0;
    min-width: 0;
    max-width: none;
    margin-inline: 0;
    min-height: 28rem;
  }

  /* 左右3行を等高にし、行ごとに矢印をサブカード対の中央へ */
  .co-feature-v2__stack {
    flex: 1 1 auto;
    display: grid;
    grid-template-rows: repeat(3, minmax(0, 1fr));
    min-height: 0;
    align-content: stretch;
  }

  .co-feature-v2__subcard {
    min-height: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-sizing: border-box;
  }

  .co-feature-v2__subcard-title {
    margin-bottom: 0.75rem;
    font-size: clamp(1.125rem, 2.2vw, 1.75rem); /* 18px〜最大 28px（1.75rem）・1行 */
    letter-spacing: 0.04em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .co-feature-v2__arrows {
    display: grid;
    grid-template-rows: repeat(3, minmax(0, 1fr));
    justify-items: center;
    align-items: center;
    align-self: stretch;
   /* width: clamp(3.25rem, 5vw, 5.75rem);*/
    min-height: 0;
    box-sizing: border-box;
    padding-top: clamp(2.5rem, 6vw, 3.25rem);
    padding-bottom: clamp(1.5rem, 3vw, 2rem);
    padding-inline: 0;
  }

  .co-feature-v2__arrow {
    border-top: 24px solid transparent;
    border-bottom: 24px solid transparent;
    border-left: 22px solid rgba(255, 255, 255, 0.98);
    border-right: none;
  }

  .co-feature-v2__arrow--pc-only {
    display: block;
  }
}

/* #04 関連（参考）旧 sec03 用（他ファイル参照用に残す） */
.co-sec--feature {
  background: var(--co-bg-feature);
}

.co-sec__heading--on-teal {
  color: #fff;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.12);
}

.co-sec__sublead--on-teal {
  text-align: center;
  font-size: 0.82rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.9);
  margin: -0.35rem auto 1.75rem;
  max-width: 38rem;
}

/* #04 関連（参考）index++.html 等で使用する旧 compare ブロック */
.co-feature-compare-band {
  width: 100%;
  margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
  padding-block: 4.5rem;
  background: linear-gradient(180deg, #33a08f 0%, #2a8c7d 42%, #217e70 100%);
  color: #fff;
}

.co-compare {
  display: grid;
  gap: 1.25rem;
  margin-top: 0;
}

@media (min-width: 900px) {
  .co-compare {
    grid-template-columns: 1fr auto 1fr;
    gap: clamp(1rem, 2vw, 2rem);
    align-items: start;
  }

  .co-compare__arrows {
    display: flex;
    flex-direction: column;
    gap: clamp(3rem, 8vw, 5rem);
    padding-top: 3.5rem;
    align-self: stretch;
    justify-content: flex-start;
  }

  .co-compare__arrows span {
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 14px solid rgba(255, 255, 255, 0.95);
    opacity: 0.95;
    margin-inline: auto;
  }
}

.co-compare__col {
  padding: 0;
  border-radius: var(--co-radius);
  background: #fff;
  border: none;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12);
  overflow: hidden;
}

.co-compare__head {
  margin: 0;
  padding: 0.95rem 1.2rem;
}

.co-compare__head--trad {
  background: #8b9699;
  color: #fff;
}

.co-compare__head--circ {
  background: var(--co-pink);
  color: #fff;
}

.co-compare__heading {
  margin: 0;
  font-size: clamp(0.95rem, 2.2vw, 1.05rem);
  font-weight: 700;
  line-height: 1.35;
}

.co-compare__body {
  padding: 1.2rem 1.35rem 1.35rem;
}

@media (max-width: 899px) {
  .co-compare__arrows {
    display: none;
  }

  .co-compare__col--circ::before {
    content: "→";
    display: block;
    text-align: center;
    margin-bottom: 0.75rem;
    color: rgba(255, 255, 255, 0.95);
    font-size: 1.25rem;
    font-weight: 700;
  }
}

.co-compare-list {
  margin: 0;
  padding-left: 1.25rem;
  font-size: 0.92rem;
  line-height: 1.85;
}

.co-points {
  margin-top: 2.75rem;
  padding: 1.5rem;
  border-radius: var(--co-radius);
  background: rgba(255, 255, 255, 0.7);
}

.co-points__label {
  text-align: center;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--co-teal-header);
  margin: 0 0 1rem;
}

.co-points-grid {
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: pt;
}

.co-points-grid li {
  counter-increment: pt;
  padding: 1rem 1rem 1rem 0.85rem;
  border-bottom: 1px dashed #bde3d9;
}

.co-points-grid li:last-child {
  border-bottom: none;
}

.co-points__tag {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  background: var(--co-teal-header);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  border-radius: 4px;
}

.co-points__detail {
  margin: 0.5rem 0 0;
  font-size: 0.92rem;
  line-height: 1.8;
}

.co-highlight-strip {
  margin-top: 2rem;
  padding: 1.75rem clamp(1.25rem, 4vw, 2.5rem);
  border-radius: var(--co-radius);
  background: linear-gradient(90deg, #fff389 0%, #ffe749 55%, #ffdd6a 100%);
  box-shadow: var(--co-shadow);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  justify-content: space-between;
}

.co-highlight-strip__lead {
  margin: 0;
  font-weight: 700;
  flex: 1 1 14rem;
}

/* ---------- #05 Works（#sec04-works）（Pencil 04_Works：白地＋緑ドット・Works キッカー・カード枠 #33a194） ---------- */
section#sec04-works.co-sec.co-sec--works {
  position: relative;
  z-index: 1;
  padding-top: 0;
}

/* 黄 lead のはみ出し分を確保しつつ、#04 先頭コンテナは通常フロー（absolute な lead 外と重ならないよう padding で調整） */
#sec04-works.co-sec--works > .co-lp__container {
  position: static;
  left: auto;
  top: auto;
  padding-top: calc(var(--co-feat-lead-bridge) + var(--co-works-lead-overlap-clear));
}

@media (min-width: 768px) {
  #sec04-works.co-sec--works > .co-lp__container {
    padding-top: calc(var(--co-feat-lead-bridge) + var(--co-works-lead-overlap-clear));
  }
}

.co-sec--works {
  --co-works-dot: #33a194;
  background-color: #fff;
  /* ドットは CSS。img/pc/bg.png を置く場合は下の image を先頭に足してもよい */
  background-image: radial-gradient(
    circle at center,
    rgba(51, 161, 148, 0.42) 1px,
    transparent 1.2px
  );
  background-size: 18px 18px;
  color: var(--co-text);
}

/* #02 #03 と同型：英字ラベル＋ライン → h2（セクション内は div、サイト header とは別物） */
.co-works__intro {
  text-align: center;
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
}

.co-works__h4 {
  padding-bottom: clamp(0.5rem, 2vw, 1rem);
}

.co-works__h4-text {
  color: #33a194;
  white-space: nowrap;
}

.co-works__h4-line {
  display: block;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
  height: 0;
  border: 0;
  border-top: 1px dotted #33a194;
}

.co-works__title {
  /* co-sec__heading は付けない（#02 #03 の h2 と同じく専用クラスのみ） */
  display: block;
  max-width: 100%;
  margin: 0;
  box-sizing: border-box;
  text-align: center;
  color: #505050;
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  -webkit-text-fill-color: currentColor;
}

/* Pencil 04_Works：見出しはグレー→ティールのグラデ相当（span で再現、clip 不使用） */
.co-works__title-line {
  display: inline;
  font-weight: inherit;
  letter-spacing: inherit;
}

.co-works__title-line--muted,
.co-works__title-line--accent {
  color: #33a194;
}

@media (max-width: 767px) {
  .co-works__title {
    margin-top: 0.35rem;
    line-height: 1.40625;
  }
}

.co-cards--works {
  display: grid;
  gap: clamp(1.25rem, 3vw, 1.75rem);
}

@media (min-width: 768px) {
  .co-cards--works {
    /*grid-template-columns: repeat(3, 1fr);*/
    display: flex;
    justify-content: center;
  }
}

.co-work-card {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: #fff;
  color: var(--co-text);
  border: 1.5px solid #33a194;
  border-radius: 15px;
  padding: 0;
  width:100%;
}

@media (min-width: 768px) {
  .co-work-card {
    width:33%;
  }
}

.co-work-card > a{
  text-decoration: none;
}

.co-work-card > a > .co-ph {
  margin: 0;
  border-radius: 15px 15px 0 0;
  width: 100%;
  border: none;
}

.co-work-card .co-ph--work {
  margin-bottom: 0;
  aspect-ratio: 352 / 228;
  min-height: 0;
}

.co-work-card .co-ph--work.co-ph--has-photo {
  padding: 0;
  background: none;
  position: relative;
  overflow: hidden;
}

.co-work-card .co-ph--work.co-ph--has-photo .co-ph__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.co-work-card__body {
  padding: clamp(0.85rem, 2vw, 1.15rem) clamp(1rem, 2.5vw, 1.25rem) clamp(1.1rem, 2.5vw, 1.35rem);
}

.co-work-card__name {
  font-size: clamp(1.125rem, 2.2vw, 1.5625rem);
  font-weight: 700;
  margin: 0 0 0.35rem;
  color: #505050;
  letter-spacing: 0.05em;
  line-height: 1.35;
}

.co-work-card__date {
  display: block;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #505050;
  letter-spacing: 0.05em;
  line-height: 1.4;
  margin: 0 0 0.65rem;
}

.co-work-card__desc {
  font-size: clamp(0.9375rem, 1.6vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.76;
  color: #505050;
  margin: 0;
  text-align: justify;
  letter-spacing: 0.05em;
}

@media (max-width: 767px) {
  /* SP でも 3 枚とも表示（縦並び 1 列） */
  .co-cards--works {
    grid-template-columns: 1fr;
  }
}

/* ---------- #06 FAQ（#sec05-faq） ---------- */
.co-sec--faq {
  background: var(--co-proposal-mint);
}

/* #03 と同型：英字ラベル＋ライン → h2（FAQ 背景は明色のためティール） */
.co-faq__intro {
  text-align: center;
}

.co-faq__h4 {
  padding-bottom: clamp(0.5rem, 2vw, 1rem);
}

.co-faq__h4-text {
  color: #33a194;
  background: none;
}

.co-faq__h4-line {
  display: block;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
  height: 0;
  border: 0;
  border-top: 1px dotted #33a194;
}

.co-faq__title {
  margin: 0 0 clamp(1.25rem, 3vw, 1.75rem);
  color: #33a194;
  background: none;
}

.co-faq-item {
  background: #fff;
  border-radius: var(--co-radius);
  margin-bottom: 1.25rem;
  border: 1px solid #d4ebe4;
  overflow: hidden;
  padding: 1rem 0.5rem 0.5rem 0.5rem;
}

/* FAQ リスト：トークンは .co-faq に集約（〜1023 既定 / 1024↑ で上書き） */
.co-faq {
  --co-faq-badge-left: 0.625rem;
  --co-faq-badge-size: 2.25rem;
  --co-faq-badge-gap: 1rem;
  --co-faq-badge-font: 1.25rem;
  --co-faq-content-inset-left: calc(
    var(--co-faq-badge-left) + var(--co-faq-badge-size) + var(--co-faq-badge-gap)
  );
  --co-faq-q-pad-top: 0.5rem;
  --co-faq-q-pad-inline: 1.25rem;
  --co-faq-q-pad-bottom: 0.5rem;
  --co-faq-q-size: 16px;
  --co-faq-q-lh: 1.45;
  --co-faq-q-first-line: calc(var(--co-faq-q-size) * var(--co-faq-q-lh));
  --co-faq-a-pad-top: 0.5rem;
  --co-faq-a-pad-inline: 1.25rem;
  --co-faq-a-pad-bottom: 0.5rem;
  --co-faq-a-size: 14px;
  --co-faq-a-lh: 1.9;
  --co-faq-a-first-line: calc(var(--co-faq-a-size) * var(--co-faq-a-lh));
}

@media (min-width: 1024px) {
  .co-faq {
    --co-faq-badge-left: 1rem;
    --co-faq-badge-size: 3.6rem;
    --co-faq-badge-gap: 1rem;
    --co-faq-badge-font: 1.875rem;
    --co-faq-q-pad-top: 1rem;
    --co-faq-q-pad-inline: 3rem;
    --co-faq-q-pad-bottom: 1rem;
    --co-faq-q-size: 25px;
    --co-faq-a-pad-top: 1rem;
    --co-faq-a-pad-inline: 2rem;
    --co-faq-a-pad-bottom: 1rem;
    --co-faq-a-size: 23px;
  }
}

.co-faq-summary,
.co-faq-panel {
  position: relative;
}

.co-faq-summary,
.co-faq-panel p {
  text-justify: inter-ideograph;
  line-break: strict;
  word-break: normal;
}

.co-faq-summary {
  margin: 0;
  padding: var(--co-faq-q-pad-top) var(--co-faq-q-pad-inline) var(--co-faq-q-pad-bottom)
    var(--co-faq-content-inset-left);
  font-weight: 700;
  font-size: var(--co-faq-q-size);
  line-height: var(--co-faq-q-lh);
  color: var(--co-text);
}

.co-faq-panel {
  padding: var(--co-faq-a-pad-top) var(--co-faq-a-pad-inline) var(--co-faq-a-pad-bottom)
    var(--co-faq-content-inset-left);
}

.co-faq-panel p {
  margin: 0;
  font-size: var(--co-faq-a-size);
  line-height: var(--co-faq-a-lh);
  color: var(--co-text-muted);
}

.co-faq-summary::before,
.co-faq-panel::before {
  position: absolute;
  left: var(--co-faq-badge-left);
  box-sizing: border-box;
  width: var(--co-faq-badge-size);
  height: var(--co-faq-badge-size);
  border-radius: 50%;
  color: #fff;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  font-size: var(--co-faq-badge-font);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  padding: 0;
  margin: 0;
  display: grid;
  place-items: center;
  padding-top: 0.06em;
}

.co-faq-summary::before {
  content: "Q";
  background: var(--co-hero-kicker-color);
  top: calc(
    var(--co-faq-q-pad-top) + (var(--co-faq-q-first-line) - var(--co-faq-badge-size)) / 2
  );
}

.co-faq-panel::before {
  content: "A";
  background: var(--co-pink);
  top: calc(
    var(--co-faq-a-pad-top) + (var(--co-faq-a-first-line) - var(--co-faq-badge-size)) / 2
  );
}

/* ---------- #07 Sustainability（#sec06-sustainability）（Pencil 06_Sustainability：#f0f6f5 背景・Sustainability＋点線・見出し・リード→画像＋本文） ---------- */
.co-sec--sustain {
  background: #f0f6f5;
  color: var(--co-text);
}

.co-sustain__intro {
  text-align: center;
  margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
}

.co-sustain__h4 {
  padding-bottom: clamp(0.5rem, 2vw, 1rem);
}

.co-sustain__h4-text {
  color: #33a194;
  background: none;
}

.co-sustain__h4-line {
  display: block;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
  height: 0;
  border: 0;
  border-top: 1px dotted #33a194;
}

.co-sustain__title {
  margin: 0 0 clamp(0.75rem, 2.2vw, 1.25rem);
  text-align: center;
  color: #33a194;
  background: none;
  -webkit-text-fill-color: currentColor;
}

.co-sustain__title-br-sp {
  display: none;
}

/* Pencil SP：見出しを 2 行に */
@media (max-width: 767px) {
  .co-sustain__title {
    line-height: 1.40625;
  }

  .co-sustain__title-br-sp {
    display: block;
  }
}

/* Pencil PC A1zk6Z：25px / 800 / 行間2・中央。SP CPDPD：16px / 700 / 行間1.875 */
.co-sustain-lead {
  margin: 0 auto;
  max-width: 62.3125rem;
  font-size: clamp(1rem, 2.2vw, 1.5625rem);
  font-weight: 800;
  line-height: 2;
  letter-spacing: 0.05em;
  text-align: center;
  color: #505050;
}

@media (max-width: 767px) {
  .co-sustain-lead {
    max-width: 20.625rem;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.875;
  }
}

.co-sustain {
  display: grid;
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: start;
  margin-top: 0;
}

/* PC：ギャップを除いた残りを 1:1 で分割（画像列／本文＋CTA 列） */
@media (min-width: 768px) {
  .co-sustain {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(1.5rem, 3vw, 2.75rem);
    align-items: flex-start;
  }
}

.co-sustain-frame {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  overflow: hidden;
  background: transparent;
  line-height: 0;
}

.co-sustain-frame__img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .co-sustain-frame {
    max-width: 20.625rem;
    margin-inline: auto;
  }
}

.co-sustain-copy {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  min-width: 0;
  width: 100%;
}

/* Pencil PC xJ7Qw：16px / 700 / 行間2.1875。768px↑は列幅いっぱい */
.co-sustain-copy__text {
  margin: 0;
  width: 100%;
  max-width: 20.625rem;
  margin-inline: auto;
  font-size: 1rem;
  font-weight: 700;
  line-height: 2.1875;
  letter-spacing: 0.05em;
  text-align: justify;
  color: #505050;
}

@media (max-width: 767px) {
  .co-sustain-copy__text {
    line-height: 1.875;
  }
}

@media (min-width: 768px) {
  .co-sustain-copy__text {
    max-width: none;
    margin-inline: 0;
  }
}

.co-link-more {
  color: var(--co-teal-header);
  font-weight: 600;
}

.co-sustain-copy__cta {
  margin-top: clamp(1rem, 2.5vw, 1.5rem);
  width: 100%;
  text-align: center;
}

/* 本文列と同じ幅で、ヒーロー「まずは相談してみる」と同型のピンク CTA */
.co-sustain-copy__cta .co-btn--hero-primary {
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .co-sustain-copy__cta {
    display: flex;
    justify-content: center;
  }
}

@media (min-width: 768px) {
  .co-sustain-copy__cta {
    display: block;
    text-align: left;
  }
}

/* ---------- #08 Contact（#sec07-contact）：白地・本文 #505050／CONTACT ティール／先頭プライバシー（PC はリンクとチェック横並び） ----------
 * 差し替え時に要確認: `.co-sec--contact` 〜 `.co-contact__note` / `.co-form-note`（#sec07 の見出し・導入・
 * 注記まわり）は、本番の文言・DOM 変更に合わせて余白・フォント・色を再調整する必要が出る場合があります。
 * フォーム本体のダミー用スタイルは、直下の「[LP ダミー・差し替え用 CSS]」ブロックを参照してください。
 * ---------- */
.co-sec--contact {
  background: #fff;
  color: #505050;
}

.co-contact__intro {
  text-align: center;
  margin-bottom: clamp(1rem, 2.5vw, 1.75rem);
}

.co-contact__brand {
  margin: 0 0 clamp(0.35rem, 1.2vw, 0.65rem);
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  font-size: clamp(2.1875rem, 10vw, 3.75rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.05;
  color: #33a194;
  text-transform: uppercase;
}

/* SP：各セクション英字ラベルの上下余白を統一（#04 Works の .co-works__h4 は除外で現状維持） */
@media (max-width: 767px) {
  #sec01-proposal .co-proposal-v2__h4,
  .co-service-v2__h4,
  .co-feature-v2__h4,
  .co-faq__h4,
  .co-sustain__h4,
  .co-contact__brand {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .co-contact__brand {
    margin: 0;
  }
}

.co-contact__title {
  margin: 0;
  font-size: clamp(1.0625rem, 2.8vw, 1.25rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.5;
  text-align: center;
  color: #505050;
  background: none;
}

@media (max-width: 767px) {
  .co-contact__title {
    font-size: 1.125rem;
    line-height: 1.667;
  }
}

.co-contact__note {
  margin-top: 0;
  margin-bottom: clamp(1rem, 2.5vw, 1.75rem);
}

.co-sec--contact .co-contact__note,
.co-sec--contact .co-form-note {
  color: #707070;
}

/* =============================================================================
 * [LP ダミー・差し替え用 CSS] #08 Contact — フォーム（#sec07-contact / #co-lp-contact-form）
 * -----------------------------------------------------------------------------
 * `index.html` のプレースホルダー向け。
 * 本番フォームに入れ替える際は、クラス名・DOM 構造の変化に合わせて
 * 下記セレクタ（`.co-contact__form-slot …` / `.co-form…`）を見直すか、このブロックを
 * 丸ごと差し替えてください。
 * 見出し・導入・注記（`.co-contact__intro` 等）は上の「Contact」セクション冒頭コメントの
 * 「差し替え時に要確認」を参照してください。
 * ============================================================================= */

.co-contact__form-slot {
  box-sizing: border-box;
  min-height: clamp(28rem, 52vh, 44rem);
  padding-bottom: clamp(0.75rem, 2vw, 1.5rem);
}

.co-contact__form-slot .co-form {
  max-width: min(68.1875rem, 100%);
  margin-inline: auto;
}

.co-contact__form-slot .co-form__privacy-block {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: clamp(1.35rem, 3.2vw, 2rem);
  padding-block: clamp(0.65rem, 1.6vw, 1rem);
  text-align: left;
}

.co-contact__form-slot .co-form__privacy-col--consent {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  min-width: 0;
}

.co-contact__form-slot .co-form__privacy-lead {
  margin: 0;
  font-size: 1rem;
  line-height: 1.55;
  color: #505050;
}

.co-form__privacy-link {
  color: #4a9eff;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.co-form__privacy-link:hover {
  color: #7ab8ff;
}

.co-contact__form-slot .co-form__privacy-col .co-form__row--privacy-agree {
  margin-bottom: 0;
  align-items: center;
}

.co-contact__form-slot .co-form__check-label {
  color: #505050;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.5;
}

.co-contact__form-slot .co-form__hint {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: #757575;
}

.co-contact__form-slot .co-form__hint--privacy-note {
  font-size: 0.75rem;
  line-height: 1.65;
  color: #757575;
}

.co-contact__form-slot .co-form__hint--warn {
  color: #505050;
}

.co-form__field-stack {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
  width: 100%;
}

.co-contact__form-slot .co-form__label-wrap {
  min-width: 0;
}

.co-contact__form-slot .co-form__row--name .co-form__label-wrap .co-form__label {
  display: inline-block;
}

.co-contact__form-slot .co-form__name-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem 1rem;
  width: 100%;
}

.co-contact__form-slot .co-form__name-part {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  min-width: 0;
}

.co-contact__form-slot .co-form__sublabel {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #505050;
  line-height: 1.4;
}

.co-contact__form-slot .co-form__control {
  border: 1px solid #F15D6E;
  border-radius: 5px;
  min-height: 2.5rem;
  color: #222;
  background: #fff;
}

.co-contact__form-slot .co-form__select {
  appearance: auto;
  cursor: pointer;
}

.co-contact__form-slot .co-form__textarea {
  min-height: 10rem;
}

.co-contact__form-slot .co-form__control:focus-visible {
  outline: 2px solid #33a194;
  outline-offset: 2px;
}

.co-contact__form-slot .co-form__label {
  font-weight: 700;
  color: #505050;
  font-size: 1rem;
}

.co-contact__form-slot .co-form__checkbox {
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 0.15rem;
  accent-color: #33a194;
}

.co-contact__form-slot .co-form__error-msg {
  color: #c62828;
}

.co-contact__form-slot .co-form__error-msg.co-form__error-msg--ok {
  color: #0d7a5f;
}

.co-contact__form-slot .co-form > .co-form__row {
  margin-bottom: 0;
  padding-block: clamp(0.65rem, 1.6vw, 1rem);
}

.co-contact__form-slot .co-form__actions {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-top: clamp(0.75rem, 2vw, 1.25rem);
  padding-block: clamp(0.65rem, 1.8vw, 1.15rem);
  text-align: center;
}

@media (max-width: 767px) {
  .co-contact__form-slot .co-form > .co-form__row:not(.co-form__row--check) {
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 0.4rem;
  }

  .co-contact__form-slot .co-form__label {
    font-size: 1rem;
    line-height: 1.6;
  }
}

@media (min-width: 768px) {
  .co-contact__form-slot .co-form__privacy-block {
    display: grid;
    grid-template-columns: minmax(11.5rem, 15.75rem) minmax(0, 31.5625rem);
    column-gap: 1.5rem;
    align-items: start;
    padding-block: clamp(0.9rem, 2.2vw, 1.35rem);
    margin-bottom: clamp(1.35rem, 3.2vw, 2rem);
    border-bottom: 0.5px solid rgba(80, 80, 80, 0.22);
  }

  .co-contact__form-slot .co-form__label {
    font-size: 1.5625rem;
    line-height: 1.2;
  }

  .co-contact__form-slot .co-form > .co-form__row:not(.co-form__row--check) {
    display: grid;
    grid-template-columns: minmax(11.5rem, 15.75rem) minmax(0, 31.5625rem);
    align-items: start;
    gap: 1rem 1.5rem;
    padding-block: clamp(0.9rem, 2.2vw, 1.35rem);
    padding-left: 2.75rem;
    margin-bottom: 0;
    border-bottom: 0.5px solid rgba(80, 80, 80, 0.22);
  }

  .co-contact__form-slot .co-form > .co-form__row--name {
    align-items: start;
  }

  .co-contact__form-slot .co-form__actions {
    margin-top: clamp(1rem, 2.5vw, 1.75rem);
    padding-block: clamp(0.85rem, 2vw, 1.35rem);
  }
}

.co-form-note {
  max-width: 44rem;
  margin-left: auto;
  margin-right: auto;
  font-size: 0.82rem;
  color: #666;
  line-height: 1.7;
  text-align: center;
}

.co-form {
  max-width: 640px;
  margin-inline: auto;
}

.co-form__row {
  display: grid;
  gap: 0.35rem;
  margin-bottom: 1.1rem;
}

@media (min-width: 640px) {
  .co-form__row:not(.co-form__row--full):not(.co-form__row--check) {
    grid-template-columns: 11rem 1fr;
    align-items: center;
    gap: 1rem;
  }

  .co-form__row--full,
  .co-form__row--check {
    grid-template-columns: 1fr;
  }
}

.co-form__label {
  font-size: 0.9rem;
  font-weight: 600;
}

.co-required {
  color: var(--co-pink);
}

.co-form__control {
  width: 100%;
  padding: 0.65rem 0.85rem;
  border: 1px solid #c5d9d4;
  border-radius: 6px;
  font-family: inherit;
  font-size: 1rem;
  background: #fff;
}

.co-form__control:focus-visible {
  outline: 2px solid var(--co-teal-header);
  outline-offset: 1px;
}

.co-form__textarea {
  resize: vertical;
  min-height: 8rem;
}

.co-form__row--check {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.5rem 0.85rem;
}

.co-form__checkbox {
  margin-top: 0.35rem;
  width: 1.05rem;
  height: 1.05rem;
  flex-shrink: 0;
}

.co-form__actions {
  text-align: center;
  margin-top: 2rem;
}

.co-form__error-msg {
  color: #c00;
  font-size: 0.88rem;
  margin: -0.25rem 0 0.85rem;
  text-align: center;
}

.co-form__error-msg.co-form__error-msg--ok {
  color: var(--co-teal-deep);
}

/* ========= [LP ダミー・差し替え用 CSS] フォームブロックここまで ========= */

/* ---------- #09 デュアル CTA（#sec08-cta）— Sec08 / Sec09（指示用 08_visit / 09_download・SP 09sp 参照） ---------- */
.co-sec--dual-cta {
  padding: 0 !important;
}

.co-dual-grid {
  display: flex;
  flex-direction: column;
}

.co-dual-block {
  display: flex;
  justify-content: center;
  overflow: visible;
}

.co-dual-block--visit {
  position: relative;
  z-index: 1;
  background: var(--co-sec08-green);
}

.co-dual-block--download {
  background: var(--co-sec08-pink);
  margin-bottom: clamp(5rem, 9.6vw, 7.5rem);
}

.co-dual-block__shell {
  box-sizing: border-box;
  width: 100%;
  max-width: var(--co-max);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: clamp(1.35rem, 3.5vw, 2rem);
  padding-left: max(var(--co-sp-inline-pad), env(safe-area-inset-left, 0px));
  padding-right: max(var(--co-sp-inline-pad), env(safe-area-inset-right, 0px));
  padding-bottom: clamp(2.5rem, 6vw, 4rem);
}

.co-dual-block--visit .co-dual-block__shell {
  /* ピルが帯の上辺で半分はみ出す分＋本文開始位置 */
  padding-top: clamp(2.5rem, 6.5vw, 4.5rem);
}

@media (min-width: 768px) {
  .co-dual-block--visit .co-dual-block__shell {
    max-width: min(var(--co-max), 70%);
    margin-inline: auto;
  }

  .co-dual-block--download .co-dual-block__shell {
    max-width: min(var(--co-max), 70%);
    margin-inline: auto;
  }
}

.co-dual-block--download .co-dual-block__shell {
  padding-top: clamp(2.25rem, 5.5vw, 4.5rem);
}

/* #08 上部ピル：#08 上境界の中央で 50% はみ出し（前セクションと跨ぐ） */
.co-dual-block--visit .co-dual-pill {
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 1;
  transform: translate(-50%, -50%);
  box-sizing: border-box;
  width: calc(320/375*100%);
  max-width: min(100%, calc(100vw - 2rem));
  margin: 0;
  padding: clamp(0.5rem, 1.4vw, 1rem) clamp(0.5rem, 3vw, 2rem);
  border-radius: 10px;
  border: 3px solid var(--co-sec08-green);
  background: #fff;
  font-size: 20px; /* SP */
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.05em;
  text-align: center;
  color: #505050;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  white-space: nowrap;
}

@media (min-width: 768px) {
  .co-dual-block--visit .co-dual-pill {
    font-size: 1.875rem; /* 30px PC */
    padding: 8px 48px; /* 左右に余裕 */
    max-width: 630px;
    letter-spacing: 0.1em;
  }
}

.co-dual-block__main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1.15rem, 3vw, 1.75rem);
  width: 100%;
}

@media (min-width: 768px) {
  .co-dual-block__main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 40%);
    align-items: start;
    column-gap: clamp(1.25rem, 3.5vw, 2.25rem);
    row-gap: clamp(1rem, 2.5vw, 1.5rem);
  }

  /* コピーは上、写真は行の下に揃える */
  .co-dual-block__main > .co-ph--dual {
    align-self: end;
  }
}

/* 768–1023px：シェルを広げ、見学は download と同型の可変2カラム＋画像は列内100%（狭いビューでコピー列が潰れないように） */
@media (min-width: 768px) and (max-width: 1023px) {
  .co-dual-block--visit .co-dual-block__shell,
  .co-dual-block--download .co-dual-block__shell {
    max-width: min(var(--co-max), 92%);
  }

  .co-dual-block--visit .co-dual-block__main {
    grid-template-columns: minmax(0, 1fr) minmax(220px, 40%);
    column-gap: clamp(1.25rem, 3vw, 2.25rem);
  }

  .co-dual-block--visit .co-ph--dual {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
    justify-self: end;
  }

  .co-dual-block--visit .co-ph--dual.co-ph--has-photo {
    aspect-ratio: 370 / 260;
  }
}

/* 1024px 以上：見学のみ固定幅カラム・40px ギャップ・写真 370px */
@media (min-width: 1024px) {
  .co-dual-block--visit .co-dual-block__main {
    grid-template-columns: minmax(0, 1fr) 400px;
    column-gap: 40px;
  }

  .co-dual-block--visit .co-ph--dual {
    width: 400px;
    max-width: 400px;
    margin-inline: 0;
    justify-self: end;
  }

  .co-dual-block--visit .co-ph--dual.co-ph--has-photo {
    aspect-ratio: 370 / 260;
  }
}

.co-dual-block__copy {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 28rem;
  margin-inline: auto;
  align-items: center;
  text-align: center;
}

@media (min-width: 768px) {
  .co-dual-block__copy {
    max-width: none;
    margin-inline: 0;
    align-items: flex-start;
    text-align: left;
  }
}

/* アイブロウ＋見出し＋罫線：英字の語間改行防止・見出し1行（幅狭時は横スクロール） */
.co-dual-block__kicker {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  min-width: 0;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}

.co-dual-block__kicker .co-dual-eyebrow {
  flex-shrink: 0;
  white-space: nowrap;
  width: max-content;
  max-width: 100%;
}

.co-dual-block__kicker .co-dual-title {
  flex-shrink: 0;
  white-space: nowrap;
  max-width: 100%;
}

@media (max-width: 767px) {
  .co-dual-block__kicker {
    align-items: center;
  }

  .co-dual-block__kicker .co-dual-title {
    text-align: center;
  }

  .co-dual-block--visit .co-dual-eyebrow,
  .co-dual-block--download .co-dual-eyebrow {
    font-size: 2.5rem; /* 40px */
    line-height: 1.05;
    letter-spacing: 0.05em;
  }

  .co-dual-block--visit .co-dual-title,
  .co-dual-block--download .co-dual-title {
    font-size: 1.125rem; /* 18px */
  }
}

.co-dual-eyebrow {
  margin: 0;
  font-size: clamp(1.65rem, 5vw, 3.75rem);
  font-weight: 800;
  letter-spacing: 0.06em;
  line-height: 1.1;
  text-transform: uppercase;
  color: #fff;
}

@media (min-width: 768px) {
  .co-dual-block--visit .co-dual-eyebrow,
  .co-dual-block--download .co-dual-eyebrow {
    font-size: 3.75rem; /* 60px */
    line-height: 1.05;
    letter-spacing: 0.05em;
  }
}

.co-dual-block--visit .co-dual-title,
.co-dual-block--download .co-dual-title {
  margin: 0.35rem 0 0;
  font-size: clamp(1.05rem, 2.6vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.45;
  color: #fff;
}

@media (min-width: 768px) {
  #cta-visit-title.co-dual-title {
    font-size: 1.5625rem; /* 25px */
  }
}

.co-dual-rule {
  display: block;
  width: 100%;
  max-width: 13rem;
  height: 1px;
  margin: clamp(0.45rem, 1.5vw, 0.65rem) 0 clamp(0.55rem, 1.5vw, 0.85rem);
  background: rgba(255, 255, 255, 0.95);
  border: 0;
  padding: 0;
}

@media (min-width: 768px) {
  .co-dual-rule {
    max-width: none;
    width: 100%;
  }
}

@media (max-width: 767px) {
  .co-dual-rule {
    margin-left: auto;
    margin-right: auto;
  }
}

.co-dual-lead {
  margin: 0;
  font-size: clamp(0.875rem, 2.2vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.05em;
  color: #fff;
}

@media (min-width: 768px) {
  .co-dual-block--visit .co-dual-lead {
    font-size: 1.125rem; /* 18px */
  }
}

.co-dual-lead--dl .co-dual-lead__row {
  display: block;
}

.co-dual-stat {
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: clamp(0.65rem, 2vw, 1.25rem);
  width: 100%;
  max-width: 22rem;
  margin-top: clamp(0.35rem, 1.2vw, 0.5rem);
  padding: clamp(0.85rem, 2.2vw, 1.1rem) clamp(1rem, 2.5vw, 1.35rem);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.06);
}

/*
 * visit リサイクル率
 * - 320px: column・中央
 * - 321–767: row・space-between（max-width 22rem）
 * - 768px〜: width 100%・中央寄せ・wrap 可（狭いと縦積み OK）
 */
.co-dual-block--visit .co-dual-stat {
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: clamp(0.65rem, 2vw, 1.25rem);
  width: 100%;
  max-width: 22rem;
  margin-inline: auto;
}

.co-dual-block--visit .co-dual-stat__label {
  flex: 1;
  min-width: 0;
  text-align: left;
  font-size: 1.125rem; /* 18px */
}

@media (max-width: 320px) {
  .co-dual-block--visit .co-dual-stat {
    flex-direction: column;
    justify-content: center;
    gap: clamp(0.5rem, 2vw, 0.75rem);
  }

  .co-dual-block--visit .co-dual-stat__label {
    flex: 0 1 auto;
    text-align: center;
  }
}

@media (min-width: 768px) {
  .co-dual-block--visit .co-dual-stat {
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: clamp(0.75rem, 2.5vw, 1.5rem);
    width: 100%;
    max-width: none;
    margin-inline: 0;
  }

  .co-dual-block--visit .co-dual-stat__label {
    flex: 0 1 auto;
    min-width: 0;
    text-align: center;
  }
}

.co-dual-stat__label {
  flex: 1;
  min-width: 0;
  font-size: clamp(0.8125rem, 2vw, 0.9375rem);
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.03em;
  text-align: left;
  color: #505050;
}

@media (min-width: 768px) {
  .co-dual-stat {
    max-width: none;
    margin-top: clamp(0.5rem, 1.5vw, 0.75rem);
  }

  .co-dual-stat__label {
    font-size: 1.125rem; /* 18px */
  }
}

/* visit の 96% のみ（index 上は .co-dual-stat が visit 内だけ） */
.co-dual-stat__value {
  flex-shrink: 0;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  font-size: 4.375rem; /* 70px — SP〜1023 */
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--co-sec08-green);
}

@media (min-width: 768px) {
  .co-dual-stat__value {
    font-size: 4.375rem; /* 70px — 1024/1440 でも列内で折り返さない */
  }
}

@media (min-width: 1200px) {
  .co-dual-stat__value {
    font-size: clamp(4.375rem, 4vw, 5rem); /* 広い PC のみ 80px まで */
  }
}

.co-dual-stat__pct {
  font-size: 0.52em;
  font-weight: 800;
  vertical-align: 0.12em;
}

.co-dual-block--visit .co-ph--dual {
  width: 100%;
  max-width: min(26rem, 100%);
  border-radius: 0;
  overflow: hidden;
}

.co-dual-block--visit .co-ph--dual.co-ph--has-photo .co-ph__img {
  border-radius: 0;
}

@media (max-width: 767px) {
  /* 基底の min(26rem) より後で上書き：.co-dual-stat（max-width: 22rem）と同じ幅に */
  .co-dual-block--visit .co-ph--dual {
    max-width: 22rem;
    margin-inline: auto;
  }
}

.co-dual-block--download .co-ph--dual {
  width: 100%;
  max-width: min(24rem, 80%);
}

@media (min-width: 768px) {
  .co-dual-block--download .co-ph--dual {
    max-width: none;
  }
}

.co-dual-block__foot {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  box-sizing: border-box;
  padding-top: clamp(0.15rem, 1vw, 0.35rem);
}

.co-dual-cta {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3.25rem;
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
  padding: 0.8rem clamp(1.75rem, 5vw, 2.75rem);
  border: none;
  border-radius: 9999px;
  background: var(--co-dual-cta-yellow);
  font-family: inherit;
  font-size: clamp(1.25rem, 2.6vw, 1.5625rem); /* 最大 25px */
  font-weight: 800;
  letter-spacing: 0.05em;
  line-height: 1.25;
  text-align: center;
  text-decoration: none;
  color: #505050;
  box-shadow: 4px 6px 0 rgba(0, 0, 0, 0.14);
  transition: transform 0.15s ease, filter 0.15s ease;
}

@media (min-width: 768px) {
  .co-dual-cta {
    max-width: none;
    width: 100%;
    margin-inline: 0;
    height: var(--co-lp-dual-cta-h-pc);
    min-height: var(--co-lp-dual-cta-h-pc);
    font-size: 1.5625rem; /* 25px */
    padding-block: 0;
    padding-inline: clamp(2rem, 4vw, 3rem);
  }
}

.co-dual-cta:hover {
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.co-dual-cta:active {
  transform: translateY(0);
}

.co-dual-cta:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.95);
  outline-offset: 3px;
}

/* LP 主要 CTA：PC は幅 448px・高さ 66px（デュアル帯のみ 70px）／SP は幅・最小高さを揃える */
@media (min-width: 768px) {
  .co-service-v2__cta,
  .co-feature-v2__cta,
  .co-contact__form-slot .co-btn--teal {
    width: var(--co-lp-cta-width-pc);
    max-width: 100%;
    box-sizing: border-box;
    margin-inline: auto;
    min-height: var(--co-lp-cta-min-h-pc);
  }

  .co-service-v2__cta,
  .co-feature-v2__cta {
    min-width: 0;
  }
}

@media (max-width: 767px) {
  .co-btn--hero-primary,
  .co-service-v2__cta,
  .co-feature-v2__cta,
  .co-sustain-copy__cta .co-btn--hero-primary,
  .co-contact__form-slot .co-btn--teal,
  .co-dual-cta {
    width: min(100%, var(--co-lp-cta-width-sp));
    max-width: 100%;
    box-sizing: border-box;
    margin-inline: auto;
    min-height: var(--co-lp-cta-min-h-sp);
  }

  .co-dual-block__foot .co-dual-cta {
    align-self: center;
  }

  .co-service-v2__cta,
  .co-feature-v2__cta {
    min-width: 0;
  }
}
