/* 議員チェッカー LP — ブランドトンマナ */

:root {
  --brand: #ff7a2f;
  --brand-strong: #fb5b01;
  --brand-dark: #c44e00;
  --brand-light: #fff6f1;
  --brand-border: #e8b794;
  --brand-soft: #f4c4a8;
  --cream: #f8edea;
  --cream-light: #fdf5f2;
  --surface: #ffffff;
  --surface-muted: #faf7f5;
  --surface-tint: #f8edea;
  --surface-card: #ffead8;
  --surface-card-strong: #ffd4b0;
  --border: #efe6e1;
  --text: #1f1f1f;
  --text-body: #262626;
  --text-muted: #766c69;
  --text-sub: #555555;
  --shadow-sm: 0 2px 12px rgba(255, 122, 47, 0.08);
  --shadow-md: 0 8px 28px rgba(31, 31, 31, 0.08);
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-pill: 999px;
  --section-x: clamp(16px, 4vw, 32px);
  --content-max: 1100px;
  --mobile-header-bar: 3px;
  --mobile-header-inner: 56px;
  --mobile-header-total: calc(var(--mobile-header-bar) + var(--mobile-header-inner));
}

/* ── Global layout / typography ── */
#wrapper {
  overflow-x: hidden;
}

main {
  line-height: 1.75;
  letter-spacing: 0.02em;
  font-family: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", Meiryo, sans-serif;
  padding-bottom: 72px;
}

.lp-container {
  width: min(var(--content-max), calc(100% - var(--section-x) * 2));
  margin-inline: auto;
}

h2,
h3,
h4 {
  line-height: 1.45;
}

/* OCL animation: show content when visible */
.animation.is-visible,
.animation.show,
.commonIssues01_title.is-visible,
.commonIssues01_title.show {
  opacity: 1 !important;
  transform: none !important;
}

.commonIssues01 > .animation.is-visible .commonIssues01_sec > .commonIssues01_card,
.commonIssues01 > .animation.show .commonIssues01_sec > .commonIssues01_card {
  opacity: 1 !important;
  transform: none !important;
}

.mainvisual.show .mainvisual_txt01,
.mainvisual.show .mainvisual_txt02,
.mainvisual.show .mainvisual_txt03 {
  clip-path: none !important;
  opacity: 1 !important;
  transform: none !important;
}

.mainvisual_txt01 {
  opacity: 1 !important;
  transform: none !important;
  margin-bottom: 20px !important;
}

.mainvisual_txt02 {
  clip-path: none !important;
  margin-bottom: 12px !important;
}

.mainvisual_txt03 {
  clip-path: none !important;
  margin-top: 8px;
  line-height: 1.6 !important;
  display: inline-block;
  width: fit-content;
  max-width: 100%;
  padding: 10px 16px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: 0 2px 12px rgba(31, 31, 31, 0.06);
}

.header_logo img {
  display: block;
  width: min(160px, 40vw);
  height: auto;
}

.header_inner {
  align-items: center;
}

.header {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  box-shadow: none;
}

.header::before {
  content: "";
  display: block;
  height: 3px;
  background: linear-gradient(90deg, var(--brand-strong), var(--brand));
}

.header_nav_main a {
  color: var(--text-sub);
  font-weight: 700;
}

.header_nav_main a:hover {
  color: var(--brand);
}

.btn_signup {
  background: var(--brand) !important;
  color: #fff !important;
  border: 2px solid var(--brand) !important;
  border-radius: var(--radius-pill) !important;
  font-weight: 700 !important;
}

.btn_signup:hover {
  background: var(--brand-dark) !important;
  border-color: var(--brand-dark) !important;
}

.btn_download {
  background: var(--surface) !important;
  color: var(--brand) !important;
  border: 2px solid var(--brand-border) !important;
  border-radius: var(--radius-pill) !important;
  font-weight: 700 !important;
}

.btn_download:hover {
  background: var(--brand-light) !important;
}

/* ── Hero ── */
.mainvisual {
  background: linear-gradient(180deg, var(--cream) 0%, var(--cream-light) 100%) !important;
  min-height: auto !important;
  position: relative;
  overflow: hidden;
  padding-bottom: 48px;
}

.mainvisual_badges {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 20px var(--section-x) 0;
  max-width: var(--content-max);
  margin: 0 auto;
}

.mainvisual_badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 16px;
  border-radius: 999px;
  font-size: clamp(1.2rem, 2.5vw, 1.4rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.mainvisual_badge--free {
  background: var(--brand);
  color: #fff;
}

.mainvisual_badge--register {
  background: var(--surface);
  color: var(--brand-dark);
  border: 1px solid var(--brand-border);
}

.mainvisual::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: url("../assets/images/hero.jpg") center bottom / cover no-repeat;
  pointer-events: none;
}

.mainvisual::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: 4px;
  background: linear-gradient(90deg, var(--brand-strong), var(--brand-soft));
  border-radius: 0;
}

.mainvisual_txt01 img,
.mainvisual_txt02 img {
  display: none;
}

.mainvisual_inner {
  position: relative;
  z-index: 1;
  width: min(1200px, 100%) !important;
  margin: 0 auto !important;
  padding: 28px var(--section-x) 0 !important;
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
  box-sizing: border-box;
}

.mainvisual_inner > div:first-child {
  width: auto !important;
  padding-top: 0 !important;
  text-align: center;
}

.mainvisual_txt01::after {
  content: "あなたの街の\A議員をチェックしましょう";
  white-space: pre-line;
  display: block;
  font-size: clamp(2.2rem, 5.5vw, 4rem);
  font-weight: 900;
  line-height: 1.35;
  color: var(--text);
  text-shadow: none;
  text-align: center;
}

.mainvisual_txt02::after {
  content: "公式議事録 × AI｜選ぶ前に、確認から。";
  display: block;
  margin-top: 1.2rem;
  font-size: clamp(1.3rem, 2.6vw, 1.8rem);
  font-weight: 700;
  color: var(--brand);
  text-align: center;
}

.mainvisual_txt03 {
  color: var(--text-body) !important;
  font-weight: 600 !important;
  font-size: clamp(1.4rem, 2.5vw, 1.7rem) !important;
  text-align: center;
  margin-inline: auto;
}

.mainvisual_inner > div:last-child {
  width: min(520px, 100%) !important;
  margin: 0 auto !important;
  justify-self: center;
}

.mainvisual_img01,
.mainvisual_img02,
.mainvisual_chara {
  display: none !important;
}

/* ── CTA band ── */
.contactArea01 {
  background: var(--surface) !important;
  background-image: none !important;
  margin-top: 0;
  position: relative;
  z-index: 2;
  border-radius: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  text-align: center;
}

.contactArea01_inner {
  width: min(1200px, 100%) !important;
  height: auto !important;
  margin: 0 auto !important;
  padding: 40px var(--section-x) 48px !important;
  box-sizing: border-box;
}

.contactArea01_txt {
  color: var(--text) !important;
  font-weight: 800 !important;
  font-size: clamp(1.6rem, 3.5vw, 2.2rem) !important;
  line-height: 1.6 !important;
  margin-bottom: 28px !important;
}

.contactArea01_btn {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
}

.contactArea01_btn01,
.contactArea01_btn02 {
  width: 100% !important;
  margin: 0 !important;
}

.contactArea01_btn01 {
  padding-top: 14px;
}

.contactArea01_btn01 a,
.contactArea01_btn02 a {
  display: flex !important;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100% !important;
  height: 56px !important;
  min-height: 56px !important;
  max-height: 56px !important;
  line-height: 1.3 !important;
  padding: 0 48px 0 24px !important;
  font-size: clamp(1.4rem, 3vw, 1.8rem) !important;
  box-sizing: border-box;
  white-space: nowrap;
  text-align: center;
  border-radius: var(--radius-pill) !important;
  font-weight: 800 !important;
}

.contactArea01_btn01 a {
  background: var(--brand) !important;
  color: #fff !important;
  box-shadow: var(--shadow-sm);
}

.contactArea01_btn01 a .shape {
  position: absolute !important;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 4px 12px !important;
  background: var(--brand-dark) !important;
  color: #fff !important;
  border-radius: 999px;
  font-size: 1.1rem !important;
  line-height: 1.3;
  white-space: nowrap;
  z-index: 1;
  background-image: none !important;
}

.contactArea01_btn01 a .arrow {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.contactArea01_chara {
  display: none;
}

.contactArea01_btn02 a {
  background: var(--surface) !important;
  color: var(--brand) !important;
  border: 2px solid var(--brand-border) !important;
  font-weight: 700 !important;
}

/* ── Pain points (hibou checklist style) ── */
.commonIssues01 {
  background: var(--surface);
  padding: 72px var(--section-x) 56px;
  text-align: center;
}

.commonIssues01_title {
  color: var(--text) !important;
  font-weight: 900 !important;
  font-size: clamp(2.4rem, 5vw, 3.6rem) !important;
  line-height: 1.45 !important;
  margin: 0 auto 40px !important;
  max-width: 720px;
  text-align: center;
}

.commonIssues01_title span {
  display: block;
  width: fit-content;
  margin: 0 auto 10px;
  padding: 4px 14px;
  background: var(--brand-light);
  color: var(--brand-dark);
  border-radius: var(--radius-pill);
  font-size: 0.45em;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.commonIssues01 > .animation {
  max-width: var(--content-max);
  margin: 0 auto;
}

.commonIssues01_sec {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  justify-content: stretch !important;
  padding: 0 !important;
  background: none !important;
}

.commonIssues01_sec > .commonIssues01_card {
  position: relative;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 28px 24px 130px !important;
  background: var(--surface) !important;
  background-image: none !important;
  border-radius: var(--radius-md);
  border: none;
  box-shadow: 0 4px 24px rgba(31, 31, 31, 0.08);
  text-align: left;
  color: var(--text) !important;
  box-sizing: border-box;
  min-height: 320px;
  overflow: hidden;
}

.commonIssues01_card-illust {
  position: absolute;
  right: 0;
  bottom: 0;
  width: min(200px, 58%);
  height: auto;
  display: block;
  pointer-events: none;
}

.commonIssues01_sec > .commonIssues01_card:nth-child(1),
.commonIssues01_sec > .commonIssues01_card:nth-child(2),
.commonIssues01_sec > .commonIssues01_card:nth-child(3) {
  margin: 0 !important;
  padding-top: 28px !important;
  width: auto !important;
  height: auto !important;
  opacity: 1;
  transform: none;
}

.commonIssues01_sec h3 {
  color: var(--text) !important;
  font-weight: 800 !important;
  font-size: clamp(1.6rem, 3vw, 2rem) !important;
  margin-bottom: 12px !important;
  line-height: 1.4;
}

.commonIssues01_sec h3::before {
  content: none;
}

.commonIssues01_sec p {
  font-size: clamp(1.4rem, 2.5vw, 1.6rem) !important;
  line-height: 1.75 !important;
  color: var(--text-muted);
}

.commonIssues01_sec > .commonIssues01_card {
  border-left: none;
}

.commonIssues01_img {
  display: none !important;
}

/* ── Why section ── */
.commonIssues02 {
  background: var(--cream);
  padding: 64px var(--section-x);
}

.commonIssues02_inner {
  background: var(--surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 5vw, 48px) clamp(20px, 4vw, 40px) !important;
  max-width: var(--content-max);
  margin: 0 auto;
  box-shadow: var(--shadow-md);
  display: flex !important;
  align-items: center;
  gap: clamp(24px, 4vw, 48px);
}

.commonIssues02_body {
  flex: 1;
  min-width: 0;
}

.commonIssues02_title {
  color: var(--text) !important;
  font-weight: 900 !important;
  font-size: clamp(2rem, 4.5vw, 3.2rem) !important;
  line-height: 1.45 !important;
  margin-bottom: 24px !important;
  text-align: left;
}

.commonIssues02_list {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
}

.commonIssues02_list li {
  position: relative;
  padding-left: 1.6em;
  margin-bottom: 1.4em;
  color: var(--text) !important;
  font-weight: 600 !important;
  font-size: clamp(1.4rem, 2.5vw, 1.7rem) !important;
  line-height: 1.75 !important;
}

.commonIssues02_list li:last-child {
  margin-bottom: 0;
}

.commonIssues02_list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand);
}

.commonIssues02_img {
  flex-shrink: 0;
  width: min(400px, 44%);
  margin: 0;
  line-height: 0;
}

.commonIssues02_img img {
  display: block;
  width: 100%;
  height: auto;
}

/* ── Features ── */
.features {
  overflow-x: clip;
}

.features_header {
  display: none !important;
}

.features_body {
  background: var(--surface);
  width: 100% !important;
  max-width: none;
  margin-inline: auto;
  padding: 0 !important;
  box-sizing: border-box;
}

.features_intro {
  width: 100% !important;
  max-width: var(--content-max);
  margin-inline: auto;
  padding: 56px var(--section-x) 40px;
  box-sizing: border-box;
}

.features_title {
  opacity: 1 !important;
  transform: none !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
  font-size: clamp(2.4rem, 5vw, 3.6rem) !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  padding: 0 0 12px !important;
  margin: 0 auto 8px !important;
  line-height: 1.4 !important;
  text-align: center !important;
}

.features_lead {
  text-align: center !important;
  max-width: 720px;
  margin: 0 auto !important;
  line-height: 1.85 !important;
  font-size: clamp(1.4rem, 2.5vw, 1.7rem) !important;
  color: var(--text-muted);
}

.features_lead span {
  display: inline !important;
  clip-path: none !important;
  opacity: 1 !important;
}

.features_box01 {
  display: flex !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 56px var(--section-x) !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 32px !important;
  box-sizing: border-box;
}

.features_box01_01,
.features_box01_03 {
  background: var(--cream-light) !important;
}

.features_box01_02,
.features_box01_04 {
  background: var(--surface) !important;
}

.features_box01 > div {
  flex: 1 1 auto;
  width: 100% !important;
  max-width: 520px !important;
  box-sizing: border-box;
}

.features_box01 > p.features_box01_img {
  flex: 1 1 auto;
  width: 100% !important;
  max-width: 520px !important;
  box-sizing: border-box;
  position: relative !important;
  opacity: 1 !important;
  transform: none !important;
  margin: 0 !important;
}

.features_box01 > p img {
  position: static !important;
  left: auto !important;
  transform: none !important;
  max-width: 100% !important;
  width: 100% !important;
  height: auto !important;
  border-radius: var(--radius-md);
  box-shadow: 0 8px 28px rgba(31, 31, 31, 0.08);
}

@media (min-width: 768px) {
  .features_box01 {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 48px !important;
    padding: 64px max(var(--section-x), calc((100% - var(--content-max)) / 2 + var(--section-x))) !important;
  }

  .features_box01_02,
  .features_box01_04 {
    flex-direction: row-reverse !important;
  }

  .features_box01 > div,
  .features_box01 > p.features_box01_img {
    flex: 0 1 calc((var(--content-max) - 48px) / 2) !important;
    width: calc((var(--content-max) - 48px) / 2) !important;
    max-width: 520px !important;
    min-width: 0 !important;
  }
}

.features_box01_label {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  position: relative !important;
  left: auto !important;
  top: auto !important;
  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 6px 16px !important;
  margin: 0 0 16px !important;
  border-radius: var(--radius-pill) !important;
  background: var(--brand) !important;
  color: #fff !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  text-align: center;
  opacity: 1 !important;
  transform: none !important;
}

.features_box01_title {
  opacity: 1 !important;
  transform: none !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  font-size: clamp(2rem, 4vw, 2.8rem) !important;
  line-height: 1.45 !important;
  margin-bottom: 16px !important;
}

.features_box01_txt {
  line-height: 1.85 !important;
  margin-bottom: 0 !important;
  font-size: clamp(1.4rem, 2.5vw, 1.7rem) !important;
  color: var(--text-muted) !important;
}

.features_box01_txt,
.features_box01_point {
  clip-path: none !important;
  opacity: 1 !important;
}

.features_box01_title,
.features_box01_txt,
.features_box01_point {
  text-align: left;
}

.features_box01_point {
  margin: 24px 0 0 !important;
  padding: 0 !important;
  list-style: none;
}

.features_box01_point li {
  display: flex !important;
  align-items: center;
  gap: 10px;
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  background: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  line-height: 1.5 !important;
}

.features_box01_point li + li {
  margin-top: 12px !important;
}

.features_box01_point li img {
  flex-shrink: 0;
  width: 24px !important;
  height: 24px !important;
  margin: 0 !important;
}

/* top.css 上書き（特徴セクション） */
#features .features_box01 {
  width: 100% !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  flex-wrap: nowrap !important;
  position: static !important;
}

#features .features_box01_02,
#features .features_box01_03,
#features .features_box01_04 {
  margin-top: 0 !important;
}

#features .features_box01 > div {
  position: relative !important;
  width: auto !important;
}

#features .features_box01 > p {
  width: auto !important;
  text-align: left !important;
  margin-bottom: 0 !important;
}

#features .features_box01_01 .features_box01_img img,
#features .features_box01_02 .features_box01_img img,
#features .features_box01_03 .features_box01_img img,
#features .features_box01_04 .features_box01_img img {
  width: 100% !important;
  max-width: 100% !important;
}

#features .features_box01_point li {
  background: none !important;
  background-color: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  line-height: 1.5 !important;
  color: var(--text) !important;
  white-space: normal !important;
}

#features .features_box01_title {
  color: var(--text) !important;
  text-align: left !important;
}

#features .features_intro .features_title {
  text-align: center !important;
}

.introduction_lead,
.introduction_subTitle {
  text-align: center !important;
  max-width: 720px;
  margin-inline: auto !important;
  line-height: 1.75 !important;
}

.introduction_inner,
.allInOneManagement_inner,
.price_availablePlans,
.qa {
  padding-inline: var(--section-x);
  box-sizing: border-box;
}

.price_availablePlans_box_planDetails div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  text-align: left;
  line-height: 1.5;
}

.price_availablePlans_box_planDetails div p:last-child {
  text-align: right;
  flex-shrink: 0;
}

.price_availablePlans_note {
  text-align: center !important;
  max-width: 720px;
  margin-inline: auto !important;
  line-height: 1.85 !important;
}

.accordion_head a span {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  line-height: 1.6;
  text-align: left;
}

.accordion_inner p {
  display: flex;
  gap: 12px;
  line-height: 1.85;
  text-align: left;
  padding: 16px 20px;
}

.footer_inner {
  padding-inline: var(--section-x);
}

.footer_dataProtectionPrivacy_txt {
  line-height: 1.85 !important;
  text-align: left;
  color: rgba(255, 255, 255, 0.88) !important;
}

.features_box01_title,
.features_box01_txt,
.features_box01_point {
  text-align: left;
}

.features_box01_txt {
  line-height: 1.85 !important;
  margin-bottom: 16px;
}

.features_box01_label {
  background: var(--brand) !important;
  color: #fff !important;
}

.features_box01_title {
  color: var(--text) !important;
  font-weight: 800 !important;
}

.features_box02 {
  background: var(--brand-light) !important;
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-md);
}

.features_box02_title {
  color: var(--text) !important;
  font-weight: 900 !important;
}

/* ── Before/After ── */
.postImplementationChanges {
  background: linear-gradient(135deg, var(--brand-strong) 0%, var(--brand) 100%) !important;
}

.postImplementationChanges_title {
  color: #fff !important;
}

.postImplementationChanges ul li {
  background: #fff !important;
  color: var(--brand-dark) !important;
  border: none !important;
  border-radius: 16px;
  font-weight: 700;
}

.postImplementationChanges_txt {
  color: #fff !important;
  font-weight: 900 !important;
}

/* ── How-to / management ── */
.introduction {
  background: #fff;
}

.introduction_title,
.allInOneManagement_title {
  color: var(--text) !important;
  font-weight: 900 !important;
}

.introduction_box_label {
  background: var(--brand) !important;
}

.allInOneManagement_box {
  background: var(--cream-light) !important;
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-md);
}

.allInOneManagement_box_title {
  color: var(--brand) !important;
  font-weight: 800 !important;
}

/* ── Support / price ── */
.price {
  background: #fff !important;
}

.price_title {
  color: var(--text) !important;
  font-weight: 900 !important;
}

.price_availablePlans_box {
  border: 2px solid var(--brand-border) !important;
  border-radius: var(--radius-md) !important;
  background: var(--surface) !important;
}

.price_availablePlans_box_label {
  background: var(--brand) !important;
}

.price_contractFlow_box {
  background: var(--surface) !important;
  border-left: 4px solid var(--brand) !important;
  border: 1px solid var(--brand-border);
  border-left-width: 4px;
  border-radius: var(--radius-md);
}

/* ── FAQ ── */
.qa {
  background: #fff;
}

.qa_ttl {
  color: var(--text) !important;
  font-weight: 900 !important;
}

.accordion_head {
  background: var(--cream-light) !important;
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-md) !important;
}

.accordion_head_q {
  color: var(--brand) !important;
}

.accordion.is-open .accordion_head {
  background: var(--brand-light) !important;
}

/* ── Footer & floating CTA ── */
.footer {
  background: linear-gradient(180deg, #2a2422 0%, var(--text) 100%) !important;
  border-top: 3px solid var(--brand);
  padding: 56px 0 32px !important;
}

.footer_inner {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: var(--content-max);
  margin-inline: auto !important;
  padding-inline: var(--section-x);
  box-sizing: border-box;
}

.footer_main {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
  padding-bottom: 32px;
  margin-bottom: 32px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.footer_logo {
  margin: 0;
  flex-shrink: 0;
}

.footer_logo img {
  display: block;
  width: min(200px, 42vw);
  height: auto;
}

.footer_nav {
  flex: 1;
  min-width: 0;
}

.footer_link {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  align-items: center;
  gap: 10px 28px !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}

.footer_link li {
  min-width: 0 !important;
  width: auto !important;
  margin: 0 !important;
}

.footer_link a {
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.footer_link a:hover {
  color: var(--brand-soft) !important;
  opacity: 1 !important;
}

.footer_dataProtectionPrivacy {
  width: 100% !important;
  max-width: none !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: var(--radius-md) !important;
  padding: 24px 28px !important;
  margin-bottom: 28px !important;
  box-sizing: border-box;
}

.footer_dataProtectionPrivacy_title {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #fff !important;
  font-size: 1.5rem !important;
  font-weight: 800 !important;
  margin: 0 0 12px !important;
  line-height: 1.4;
}

.footer_dataProtectionPrivacy_title img {
  flex-shrink: 0;
  width: 22px !important;
  height: auto !important;
  margin: 0 !important;
  transform: none !important;
}

.footer_dataProtectionPrivacy_txt {
  color: rgba(255, 255, 255, 0.72) !important;
  font-size: 1.3rem !important;
  line-height: 1.85 !important;
  margin: 0;
}

.footer_copyright {
  margin: 0 !important;
  padding-top: 4px;
  text-align: center;
  color: rgba(255, 255, 255, 0.45) !important;
  font-size: 1.2rem !important;
}

.floating-cta_launcher {
  background: var(--brand) !important;
  color: #fff !important;
  border-radius: var(--radius-pill) !important;
  font-weight: 800 !important;
  box-shadow: var(--shadow-md);
}

.floating-cta_panel {
  border: 2px solid var(--brand-border) !important;
  border-radius: var(--radius-md) !important;
}

/* ── Animations ── */
.animation {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.animation.is-visible,
.mainvisual.show,
.contactArea01.show {
  opacity: 1;
  transform: none;
}

/* ── Accordion / modal ── */
.accordion .accordion_inner {
  display: none;
}

.accordion.is-open .accordion_inner {
  display: block;
}

.floating-cta .floating-cta_panel {
  display: none;
}

.floating-cta.is-open .floating-cta_launcher {
  display: none;
}

.floating-cta.is-open .floating-cta_panel {
  display: block;
}

#overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(1, 56, 147, 0.55);
  z-index: 9998;
}

#overlay.is-open,
#consult-popup.is-open {
  display: block;
}

#consult-popup {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  overflow: auto;
}

body.modal-open {
  overflow: hidden;
}

@media (min-width: 768px) {
  .commonIssues01_sec {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
  }

  .contactArea01_btn {
    flex-direction: row;
    justify-content: center;
    max-width: 720px;
  }

  .contactArea01_btn01,
  .contactArea01_btn02 {
    flex: 1;
  }
}

@media (min-width: 1024px) {
  .mainvisual_inner {
    grid-template-columns: 1fr 1fr !important;
    gap: 48px !important;
    padding-bottom: 24px !important;
  }

  .mainvisual_inner > div:first-child {
    text-align: left;
  }

  .mainvisual_txt01::after,
  .mainvisual_txt02::after,
  .mainvisual_txt03 {
    text-align: left;
    margin-inline: 0;
  }

  .mainvisual_inner > div:last-child {
    justify-self: end;
  }
}

@media (max-width: 1023px) {
  .mainvisual_inner > div:last-child {
    opacity: 1;
    transform: none;
  }

  .contactArea01_inner {
    height: auto !important;
    padding: 32px var(--section-x) 40px !important;
  }
}

/* ══════════════════════════════════════
   Muvisuke-style components
   ══════════════════════════════════════ */

.mv-ribbon {
  position: relative;
  z-index: 3;
  margin: 0;
  padding: 10px var(--section-x);
  text-align: center;
  background: var(--brand-light);
  color: var(--text);
  font-weight: 800;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  letter-spacing: 0.06em;
}

.mv-ribbon__num {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.35em;
  font-weight: 700;
}

.mainvisual_badge--limited {
  background: var(--brand-light);
  color: var(--brand-dark);
  border: 1px solid var(--brand-border);
}

.mv-hero-steps {
  position: relative;
  z-index: 2;
  margin-top: -28px;
  background: var(--cream-light);
  padding: 32px var(--section-x) 40px;
  border-top: 3px solid #472915;
  border-bottom: 1px solid var(--border);
}

.mv-hero-steps__list {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px 8px;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0;
  list-style: none;
}

.mv-hero-steps__item {
  display: flex;
  align-items: center;
  gap: 12px;
}

.mv-hero-steps__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  background: var(--surface);
  border-radius: 50%;
}

.mv-hero-steps__icon img {
  display: block;
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.mv-hero-steps__label {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.mv-hero-steps__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: var(--brand);
  color: #fff;
  border-radius: 50%;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1;
}

.mv-hero-steps__txt {
  margin: 0;
  font-size: clamp(1.3rem, 2.4vw, 1.6rem);
  font-weight: 700;
  color: var(--text-body);
  line-height: 1.4;
  white-space: nowrap;
}

.mv-hero-steps__sep {
  flex-shrink: 0;
  width: 12px;
  height: 12px;
  margin: 0 8px;
  border-top: 2px solid #c8c0bc;
  border-right: 2px solid #c8c0bc;
  transform: rotate(45deg) translateY(2px);
}

@media (min-width: 1024px) {
  .mv-hero-steps__list {
    gap: 16px 48px;
  }

  .mv-hero-steps__sep {
    margin: 0 12px;
  }
}

.mv-about {
  background: var(--surface-muted);
  padding: 72px var(--section-x);
}

.mv-about__heading {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: baseline;
  gap: 0.2em;
  text-align: center;
  margin-bottom: 24px;
  line-height: 1.3;
}

.mv-about__brand {
  display: inline;
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 900;
  color: var(--brand);
}

.mv-about__suffix {
  display: inline;
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 900;
  color: var(--text);
}

.mv-about__lead {
  max-width: 760px;
  margin: 0 auto 40px;
  text-align: center;
  font-size: clamp(1.4rem, 2.5vw, 1.7rem);
  line-height: 2;
  color: var(--text-body);
}

.mv-about__features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin: 0 0 40px;
  padding: 0;
  list-style: none;
  align-items: stretch;
}

.mv-about__feature {
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 4px 16px rgba(0, 16, 51, 0.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0 !important;
  min-height: 200px;
}

.mv-about__featureImg {
  margin: 0;
  padding: 16px 12px 0;
  text-align: center;
  line-height: 0;
  width: 100%;
  min-height: 96px;
  box-sizing: border-box;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  flex-shrink: 0;
}

.mv-about__featureImg img {
  width: auto !important;
  max-width: 80px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.mv-about__featureInner {
  margin: 0;
  padding: 10px 12px 18px;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  gap: 8px;
  min-height: 96px;
}

.mv-about__featureMain {
  display: flex;
  align-items: baseline;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.08em;
  line-height: 1.15;
}

.mv-about__featureMain--text {
  font-size: clamp(2rem, 4.2vw, 2.5rem);
  font-weight: 800;
  color: var(--brand);
}

.mv-about__featureMainNum {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(3rem, 7vw, 3.8rem);
  font-weight: 800;
  color: var(--brand);
  letter-spacing: -0.02em;
}

.mv-about__featureMainUnit {
  font-size: clamp(1.7rem, 3.8vw, 2.1rem);
  font-weight: 800;
  color: var(--text);
}

.mv-about__featureCaption {
  display: block;
  font-size: clamp(1.25rem, 2.4vw, 1.45rem);
  font-weight: 700;
  color: var(--text-muted);
  line-height: 1.35;
}

.mv-about__sceneTitle {
  text-align: center;
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 800;
  color: var(--text);
  margin-bottom: 16px;
}

.mv-about__sceneList {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.mv-about__sceneList li {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  background: #fff;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 2px 12px rgba(0, 16, 51, 0.06);
}

.mv-about__sceneList li span {
  text-align: center;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text-body);
  padding: 8px;
  background: var(--surface-muted);
  border-radius: 8px;
}

.mv-flow {
  display: grid;
  gap: 20px;
  margin: 0;
  padding: 0;
  list-style: none;
  max-width: var(--content-max);
  margin-inline: auto;
}

.mv-flow__item {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 16px;
  align-items: start;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}

.mv-flow__num {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(2.4rem, 5vw, 3.2rem);
  font-weight: 700;
  color: var(--brand);
  line-height: 1;
}

.mv-flow__title {
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 800;
  color: var(--text);
  margin-bottom: 8px;
}

.mv-flow__txt {
  font-size: 1.4rem;
  line-height: 1.85;
  color: var(--text-body);
}

.mv-cases {
  background: var(--surface-muted);
  padding: 72px var(--section-x);
}

.mv-cases__title {
  text-align: center;
  font-size: clamp(2.4rem, 5vw, 3.2rem);
  font-weight: 900;
  color: var(--text);
  margin-bottom: 32px;
}

.mv-cases__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.mv-cases__item {
  background: #fff;
  border-radius: 20px;
  padding: 28px 24px;
  box-shadow: 0 8px 28px rgba(0, 16, 51, 0.08);
}

.mv-cases__label {
  display: inline-block;
  margin-bottom: 8px;
  padding: 4px 12px;
  background: var(--brand);
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  border-radius: 999px;
}

.mv-cases__name {
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  font-weight: 900;
  color: var(--text);
  margin-bottom: 16px;
}

.mv-cases__sub {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 6px;
}

.mv-cases__txt {
  font-size: 1.4rem;
  line-height: 1.75;
  color: var(--text-body);
  margin-bottom: 16px;
}

.mv-cases__plan {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text);
}

.mv-fixedBar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9000;
  display: flex;
  gap: 8px;
  padding: 10px var(--section-x);
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid rgba(0, 16, 51, 0.1);
  box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.12);
  backdrop-filter: blur(8px);
}

.mv-fixedBar__btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 10px 12px;
  border-radius: 999px;
  font-size: clamp(1.2rem, 2.8vw, 1.4rem);
  font-weight: 800;
  text-align: center;
  line-height: 1.3;
}

.mv-fixedBar__btn--primary {
  background: var(--text);
  color: var(--brand-light);
}

.mv-fixedBar__btn--secondary {
  background: var(--brand);
  color: #fff;
}

/* ══════════════════════════════════════
   Payme-style components
   ══════════════════════════════════════ */

.payme-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 24px;
  border-radius: 999px;
  font-size: 1.4rem;
  font-weight: 700;
  transition: color 0.2s, background 0.2s;
  box-sizing: border-box;
}

.payme-btn--flat {
  background: var(--brand);
  color: #fff !important;
  border: 2px solid var(--brand);
}

.payme-btn--flat:hover {
  background: var(--cream-light);
  color: var(--brand) !important;
}

.payme-btn--stroked {
  background: var(--cream-light);
  color: var(--brand) !important;
  border: 2px solid var(--brand);
}

.payme-btn--stroked:hover {
  background: var(--brand);
  color: #fff !important;
}

.payme-btn--large {
  min-height: 56px;
  padding: 0 32px;
  font-size: 1.6rem;
}

.payme-merits {
  background: #fff;
  padding: 72px var(--section-x);
}

.payme-merits__title {
  text-align: center;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 700;
  color: var(--text-body);
  margin-bottom: 32px;
  line-height: 1.5;
}

.payme-merits__list {
  display: grid;
  gap: 20px;
  margin: 0 0 32px;
  padding: 0;
  list-style: none;
}

.payme-merits__item {
  background: var(--cream-light);
  border-radius: 16px;
  padding: 28px 24px;
}

.payme-merits__itemTitle {
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 12px;
  line-height: 1.5;
}

.payme-merits__itemTxt {
  font-size: 1.4rem;
  line-height: 2;
  color: var(--text-body);
}

.payme-merits__cta {
  text-align: center;
}

.payme-flowBand {
  background: var(--cream);
  padding: 56px var(--section-x);
}

.payme-flowBand__inner {
  text-align: center;
}

.payme-flowBand__lead {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 700;
  color: var(--text-body);
  line-height: 1.75;
  margin-bottom: 24px;
}

.payme-flowBand__lead em {
  font-style: normal;
  color: var(--brand);
}

.payme-security {
  background: var(--cream-light);
  padding: 72px var(--section-x);
}

.payme-security__title {
  text-align: center;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 700;
  color: var(--text-body);
  margin-bottom: 32px;
}

.payme-security__list {
  display: grid;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.payme-security__item {
  background: #fff;
  border-radius: 12px;
  padding: 24px 20px;
}

.payme-security__itemTitle {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 10px;
  line-height: 1.5;
}

.payme-security__itemTxt {
  font-size: 1.4rem;
  line-height: 2;
  color: var(--text-body);
}

.payme-faq {
  max-width: var(--content-max);
  margin: 0 auto 40px;
}

.payme-faq__list {
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}

.payme-faq__item {
  background: var(--surface) !important;
  border: none !important;
  border-radius: var(--radius-md);
  padding: 0 !important;
  margin-bottom: 10px;
  overflow: hidden;
}

.payme-faq__trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin: 0;
  padding: 16px 18px;
  background: var(--surface) !important;
  border: none;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  box-sizing: border-box;
}

.payme-faq__trigger:hover {
  background: var(--surface-card) !important;
}

.payme-faq__item.is-open .payme-faq__trigger {
  background: var(--surface) !important;
}

.payme-faq__qText {
  flex: 1;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-body);
  line-height: 1.6;
}

.payme-faq__icon {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--brand);
  border-bottom: 2px solid var(--brand);
  transform: rotate(45deg);
  transition: transform 0.2s ease;
  margin-top: -4px;
}

.payme-faq__item.is-open .payme-faq__icon {
  transform: rotate(-135deg);
  margin-top: 4px;
}

.payme-faq__panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.payme-faq__item.is-open .payme-faq__panel {
  max-height: 480px;
}

.payme-faq__panelInner {
  padding: 0 18px 16px;
}

.payme-faq__q {
  display: flex;
  gap: 10px;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-body);
  line-height: 1.6;
  margin-bottom: 12px;
}

.payme-faq__a {
  display: flex;
  gap: 10px;
  font-size: 1.4rem;
  line-height: 1.85;
  color: var(--text-body);
  margin: 0;
}

.payme-faq__badge {
  flex-shrink: 0;
  font-weight: 700;
  color: var(--brand);
}

.payme-faq__badge--a {
  color: var(--brand-dark);
}

.payme-ctaBand {
  background: var(--cream);
  padding: 64px var(--section-x);
}

.payme-ctaBand__inner {
  text-align: center;
}

.payme-ctaBand__title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700;
  color: var(--text-body);
  margin-bottom: 16px;
  line-height: 1.5;
}

.payme-ctaBand__lead {
  font-size: 1.4rem;
  line-height: 2;
  color: var(--text-body);
  margin-bottom: 24px;
}

.payme-ctaBand__cta {
  margin: 0;
}

/* Payme-style flow for 使い方 */
.introduction {
  background: var(--surface) !important;
  background-image: none !important;
  padding: 64px 0 72px !important;
}

.introduction_chara {
  display: none !important;
}

.introduction_header .introduction_title,
.introduction_header .introduction_subTitle,
.introduction_header.show .introduction_title,
.introduction_header.show .introduction_subTitle {
  opacity: 1 !important;
  transform: none !important;
}

.introduction_header .introduction_lead {
  margin-bottom: 28px !important;
}

.introduction_header .introduction_lead span,
.introduction_header.show .introduction_lead span {
  clip-path: none !important;
  opacity: 1 !important;
}

.introduction_sec {
  display: flex !important;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 24px !important;
  width: 100% !important;
  max-width: var(--content-max);
  margin: 0 auto !important;
  padding-top: 8px;
}

@media (min-width: 1024px) {
  .introduction_sec {
    flex-direction: row !important;
    justify-content: space-between;
    align-items: stretch;
    gap: 20px !important;
  }

  .introduction_box01,
  .introduction_box03 {
    flex: 0 0 318px;
    width: 318px !important;
    max-width: 318px;
  }

  .introduction_box02 {
    flex: 1 1 445px;
    width: 445px !important;
    max-width: 445px;
    min-width: 0;
  }
}

.introduction_box {
  height: auto !important;
  min-height: 0 !important;
  padding: 24px 20px 32px !important;
  margin-top: 0 !important;
  overflow: visible;
}

.introduction_box_label {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  margin: 0 auto 16px !important;
  width: 72px !important;
  height: 72px !important;
  line-height: 72px !important;
  font-size: 1.4rem !important;
  background: var(--brand) !important;
}

.payme-steps {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 720px;
  margin: 0 auto 48px;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 1;
}

.payme-steps__item {
  flex: 1;
  background: var(--cream-light);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-md);
  padding: 18px 16px;
  text-align: center;
  position: relative;
}

.payme-steps__item::after {
  display: none !important;
}

.payme-steps__txt {
  margin: 0;
  font-size: clamp(1.4rem, 2.8vw, 1.6rem);
  font-weight: 700;
  color: var(--text-body);
  line-height: 1.5;
  word-break: keep-all;
}

.payme-steps__txt em {
  font-style: normal;
  color: var(--brand);
}

@media (min-width: 768px) {
  .payme-steps {
    flex-direction: row;
    align-items: stretch;
    gap: 16px;
  }

  .payme-steps__item:not(:last-child)::before {
    content: "";
    position: absolute;
    right: -12px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 8px solid var(--brand);
    z-index: 1;
    pointer-events: none;
  }
}

.price_contractFlow {
  padding-inline: var(--section-x);
  color: var(--text) !important;
  text-align: left;
}

.price_contractFlow_title {
  text-align: center !important;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  color: var(--text) !important;
  margin-bottom: 32px !important;
}

.floating-cta {
  bottom: 72px !important;
}

@media (min-width: 768px) {
  .mv-about__features {
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }

  .mv-about__feature {
    min-height: 220px;
  }

  .mv-about__featureMain--text {
    font-size: clamp(1.75rem, 2.2vw, 2.2rem);
  }

  .mv-about__featureMainNum {
    font-size: clamp(2.6rem, 3.5vw, 3.4rem);
  }

  .mv-about__featureMainUnit {
    font-size: clamp(1.5rem, 2vw, 1.85rem);
  }

  .mv-about__featureCaption {
    font-size: clamp(1.15rem, 1.4vw, 1.35rem);
  }

  .mv-about__sceneList {
    grid-template-columns: repeat(3, 1fr);
  }

  .mv-cases__list {
    grid-template-columns: repeat(3, 1fr);
  }

  .payme-merits__list {
    grid-template-columns: repeat(3, 1fr);
  }

  .payme-security__list {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .mv-flow {
    grid-template-columns: repeat(3, 1fr);
  }

  .mv-flow__item {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .mv-flow__num {
    margin-bottom: 8px;
  }
}

/* ══════════════════════════════════════
   議員チェッカー オリジナル要素
   ══════════════════════════════════════ */

.gc-eyebrow {
  display: block;
  width: fit-content;
  margin: 0 auto 12px;
  padding: 4px 14px;
  background: var(--brand-light);
  color: var(--brand-dark);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-pill);
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-align: center;
}

.gc-hero-visual {
  width: min(420px, 100%);
  margin: 0 auto;
}

.gc-hero-visual__screen {
  background: var(--surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow: var(--shadow-md);
}

.gc-hero-visual__label {
  margin: 0 0 12px;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--brand);
}

.gc-hero-visual__search {
  margin: 0 0 12px;
  padding: 12px 14px;
  background: var(--cream-light);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-sm);
  font-size: 1.3rem;
  color: var(--text-muted);
}

.gc-hero-visual__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 16px;
  padding: 0;
  list-style: none;
}

.gc-hero-visual__chips li {
  padding: 6px 12px;
  background: var(--surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-pill);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text-body);
}

.gc-hero-visual__chat {
  padding: 14px;
  background: var(--cream-light);
  border-radius: var(--radius-md);
  border-left: 4px solid var(--brand);
}

.gc-hero-visual__chat p {
  margin: 0;
  font-size: 1.3rem;
  line-height: 1.6;
  color: var(--text-body);
}

.gc-hero-visual__source {
  margin-top: 8px !important;
  font-size: 1.1rem !important;
  color: var(--brand-dark) !important;
  font-weight: 700;
}

/* コンポーネントのブランド統一 */
.mv-ribbon {
  background: var(--brand-light);
  color: var(--brand-dark);
  border-bottom: 1px solid var(--brand-border);
}

.mv-ribbon__num {
  color: var(--brand-strong);
}

.mainvisual_badge--limited {
  background: var(--brand-light);
  color: var(--brand-dark);
  border: 1px solid var(--brand-border);
}

.mv-about__brand {
  color: var(--brand);
}

.mv-about__suffix {
  color: var(--text);
}

.mv-about__feature {
  border: 1px solid var(--brand-border);
  box-shadow: none;
}

.mv-about__featureNum,
.mv-about__featureMainNum {
  color: var(--brand);
}

.mv-about__sceneList li {
  border: 1px solid var(--brand-border);
  box-shadow: none;
}

.mv-about__sceneList li span {
  background: var(--brand-light);
  color: var(--text-body);
}

.mv-flow__item {
  background: transparent;
  border: none;
  box-shadow: none;
}

.mv-flow__num {
  color: var(--brand);
}

.mv-cases__item {
  border: 1px solid var(--brand-border);
  box-shadow: var(--shadow-sm);
}

.mv-cases__label {
  background: var(--brand);
}

.mv-cases__sub {
  color: var(--brand-dark);
}

.mv-fixedBar {
  border-top: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.98);
}

.mv-fixedBar__btn--primary {
  background: var(--brand);
  color: #fff;
}

.mv-fixedBar__btn--secondary {
  background: var(--surface);
  color: var(--brand);
  border: 2px solid var(--brand-border);
}

.payme-merits__item {
  border: 1px solid var(--brand-border);
  background: var(--cream-light);
}

.payme-merits__itemTitle {
  color: var(--brand-dark);
}

.payme-flowBand {
  background: var(--cream);
  border-block: 1px solid var(--border);
}

.payme-flowBand__lead em {
  color: var(--brand);
}

.payme-security {
  background: var(--surface);
}

.payme-security__item {
  border: 1px solid var(--brand-border);
}

.payme-security__itemTitle {
  color: var(--brand-dark);
}

.payme-faq__item {
  border-color: var(--brand-border);
}

.payme-faq__badge {
  color: var(--brand);
}

.payme-ctaBand {
  background: var(--cream-light);
  border-top: 1px solid var(--border);
}

.payme-steps__item {
  border-color: var(--brand-border);
  background: var(--cream-light);
}

.payme-steps__txt em {
  color: var(--brand);
}

.introduction::before {
  background: var(--brand);
  height: 3px;
}

/* ── 確定上書き（OCL top.css 対策） ── */
html,
body,
#wrapper {
  min-width: 0 !important;
  max-width: 100%;
}

.materialsConsultation {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.features_body > .features_intro .features_title,
section#features h2.features_title {
  display: block !important;
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  padding: 0 0 12px !important;
  margin: 0 auto 8px !important;
  font-size: clamp(2.4rem, 5vw, 3.6rem) !important;
  font-weight: 900 !important;
  line-height: 1.4 !important;
  color: var(--text) !important;
  box-sizing: border-box !important;
}

.features_body > .features_intro .features_lead {
  margin-bottom: 0 !important;
}

.features_body > .features_intro .features_lead span {
  clip-path: none !important;
  opacity: 1 !important;
}

@media screen and (max-width: 1023px) {
  section#features h2.features_title {
    padding: 0 0 12px !important;
    font-size: clamp(2rem, 7vw, 2.8rem) !important;
  }
}

section#howto .introduction_sec {
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 24px !important;
  width: 100% !important;
  max-width: var(--content-max) !important;
  margin-inline: auto !important;
  padding-top: 32px !important;
}

@media (min-width: 1024px) {
  section#howto .introduction_sec {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: stretch !important;
    gap: 20px !important;
  }

  section#howto .introduction_box01,
  section#howto .introduction_box03 {
    flex: 0 0 318px !important;
    width: 318px !important;
    max-width: 318px !important;
  }

  section#howto .introduction_box02 {
    flex: 1 1 445px !important;
    width: 445px !important;
    max-width: 445px !important;
    min-width: 0 !important;
  }
}

/* ── Color blocks: borderなし・色で区切る ── */
:root {
  --shadow-sm: none;
  --shadow-md: none;
}

/* セクション背景（白 ⇄ クリームで交互） */
.mainvisual,
.commonIssues01,
.payme-flowBand,
.features_header,
.mv-cases,
.qa,
.contactArea01:last-of-type {
  background: var(--surface-tint) !important;
  background-image: none !important;
}

.mv-about,
.commonIssues02,
.payme-merits,
.features_body,
.introduction,
.allInOneManagement,
.price,
.payme-ctaBand,
.contactArea01:first-of-type {
  background: var(--surface) !important;
  background-image: none !important;
}

.commonIssues02_inner {
  background: var(--surface-card) !important;
  border: none !important;
  box-shadow: none !important;
}

/* 白背景セクション上のカード → ピーチ色 */
.mv-about__feature,
.mv-about__sceneList li,
.payme-merits__item,
.features_box02,
.payme-steps__item,
.introduction_box,
.payme-security__item,
section#support .mv-flow__item {
  background: var(--surface-card) !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: var(--radius-md);
  padding: 24px 20px !important;
}

.mv-about__feature {
  padding: 0 !important;
}

/* クリーム背景セクション上のカード → 白 */
.commonIssues01_sec > .commonIssues01_card {
  background: var(--surface) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  box-shadow: 0 4px 24px rgba(31, 31, 31, 0.08) !important;
}

.mv-hero-steps__icon {
  background: var(--surface) !important;
  border: none !important;
  border-radius: 50% !important;
  box-shadow: none !important;
}

.gc-hero-visual__screen,
.mv-cases__item,
.payme-faq__item {
  background: var(--surface) !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: var(--radius-md);
}

.allInOneManagement_box {
  background: var(--surface-card) !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: var(--radius-md);
}

.introduction_box02 > div {
  background: var(--surface) !important;
  border: none !important;
  border-radius: var(--radius-sm);
  color: var(--text-body) !important;
}

.gc-hero-visual__search,
.gc-hero-visual__chat,
.gc-hero-visual__chips li {
  background: var(--surface-card) !important;
  border: none !important;
  border-radius: var(--radius-sm);
}

/* リボン・バッジははっきりした色 */
.mv-ribbon {
  background: var(--brand) !important;
  color: #fff !important;
  border: none !important;
}

.mv-ribbon__num {
  color: #fff !important;
}

.mainvisual_badge--free {
  background: var(--brand) !important;
  color: #fff !important;
  border: none !important;
}

.mainvisual_badge--register,
.mainvisual_badge--limited {
  background: var(--surface) !important;
  color: var(--brand-dark) !important;
  border: none !important;
}

.commonIssues01_title span,
.gc-eyebrow {
  background: var(--surface-card-strong) !important;
  color: var(--brand-dark) !important;
  border: none !important;
}

.mv-about__sceneList li span {
  background: var(--surface-card) !important;
  color: var(--text-body) !important;
  border: none !important;
}

/* ボタン: borderなし・塗りで区別 */
.header,
.contactArea01,
.payme-flowBand,
.payme-ctaBand,
.mv-fixedBar,
.floating-cta_panel {
  border: none !important;
  box-shadow: none !important;
}

.btn_signup,
.contactArea01_btn01 a,
.payme-btn--flat,
.mv-fixedBar__btn--primary {
  background: var(--brand) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: none !important;
}

.btn_download,
.contactArea01_btn02 a,
.payme-btn--stroked,
.mv-fixedBar__btn--secondary {
  background: var(--surface-card-strong) !important;
  color: var(--brand-dark) !important;
  border: none !important;
  box-shadow: none !important;
}

.btn_download:hover,
.contactArea01_btn02 a:hover,
.payme-btn--stroked:hover,
.mv-fixedBar__btn--secondary:hover {
  background: var(--brand) !important;
  color: #fff !important;
}

.payme-btn--flat:hover {
  background: var(--brand-dark) !important;
  color: #fff !important;
}

.contactArea01_btn01 a {
  box-shadow: none !important;
}

.introduction_box02::before,
.introduction_box02::after,
.introduction_box01::after {
  display: none !important;
}

/* 使い方 — box01/box03 イラスト（img02）の配置復元 */
section#howto .introduction_box01,
section#howto .introduction_box03 {
  position: relative !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 37px 0 28px !important;
  overflow: visible !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  box-sizing: border-box !important;
}

section#howto .introduction_box01 .introduction_box_label,
section#howto .introduction_box03 .introduction_box_label {
  position: absolute !important;
  left: -26px !important;
  top: -26px !important;
  width: 90px !important;
  height: 90px !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 2.1rem !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

section#howto .introduction_box_en {
  color: var(--brand) !important;
  opacity: 0.3 !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  text-align: right !important;
  margin-right: 40px !important;
}

section#howto .introduction_box_img01 {
  text-align: center !important;
}

section#howto .introduction_box01 .introduction_box_img01 img {
  width: 220px !important;
  max-width: calc(100% - 32px) !important;
  height: auto !important;
  margin: 6px 0 18px !important;
  transform: none;
}

section#howto .introduction_box03 .introduction_box_img01 img {
  width: 220px !important;
  max-width: calc(100% - 32px) !important;
  height: auto !important;
  margin: 23px 0 40px !important;
  transform: none;
}

section#howto .introduction_box_title {
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  color: var(--brand) !important;
  text-align: center !important;
  line-height: 1.67 !important;
  margin-bottom: 18px !important;
}

section#howto .introduction_box_txt {
  margin-left: 40px !important;
  margin-right: 40px !important;
  font-size: 1.4rem !important;
  line-height: 2 !important;
  color: var(--text-muted) !important;
}

section#howto .introduction_box_img02 {
  position: static !important;
  left: auto !important;
  bottom: auto !important;
  transform: none !important;
  margin: auto 0 0 !important;
  padding-top: 12px !important;
  width: 100% !important;
  text-align: center !important;
}

section#howto .introduction_box01 .introduction_box_img02 img,
section#howto .introduction_box03 .introduction_box_img02 img {
  width: 240px !important;
  max-width: calc(100% - 32px) !important;
  height: auto !important;
  display: block !important;
  margin-inline: auto !important;
  transform: none !important;
}

section#howto .introduction_box02 {
  padding: 28px 18px 32px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 14px !important;
  height: auto !important;
  min-height: 0 !important;
  box-sizing: border-box !important;
}

section#howto .introduction_box02 > div {
  display: flex !important;
  align-items: center !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 16px 14px 16px 12px !important;
  margin-top: 0 !important;
  gap: 14px !important;
  border-radius: var(--radius-md) !important;
}

section#howto .introduction_box02 > div + div {
  margin-top: 0 !important;
}

section#howto .introduction_box02 > div > div {
  flex: 1;
  min-width: 0;
  padding: 2px 0;
}

section#howto .introduction_box02 > div > p.introduction_box02_ico {
  width: 60px !important;
  min-width: 60px !important;
  flex-shrink: 0;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

section#howto .introduction_box02_ico01,
section#howto .introduction_box02_ico02,
section#howto .introduction_box02_ico03,
section#howto .introduction_box02_ico04 {
  margin-left: 0 !important;
  transform: none !important;
}

section#howto .introduction_box02_ico img {
  width: 52px !important;
  max-width: 52px !important;
  height: auto !important;
  display: block;
}

section#howto .introduction_box02_txt01 {
  font-size: 1.55rem !important;
  font-weight: 700 !important;
  margin-bottom: 4px !important;
  line-height: 1.45 !important;
  color: var(--text) !important;
}

section#howto .introduction_box02_txt02 {
  font-size: 1.2rem !important;
  line-height: 1.55 !important;
  color: var(--text-muted) !important;
}

@media screen and (max-width: 1023px) {
  section#howto .introduction_box01 {
    height: auto !important;
    min-height: 0 !important;
    padding: 37px 0 24px !important;
  }

  section#howto .introduction_box03 {
    height: auto !important;
    min-height: 0 !important;
    margin-top: 17.87vw !important;
    padding: 37px 0 24px !important;
  }

  section#howto .introduction_box01 .introduction_box_label,
  section#howto .introduction_box03 .introduction_box_label {
    left: -4vw !important;
    top: -6vw !important;
    width: 20vw !important;
    height: 20vw !important;
    max-width: 90px !important;
    max-height: 90px !important;
    font-size: 5.6vw !important;
    font-weight: 800 !important;
  }

  section#howto .introduction_box01 .introduction_box_img01 img,
  section#howto .introduction_box03 .introduction_box_img01 img {
    width: min(58vw, 220px) !important;
    margin: 1.6vw 0 4vw !important;
  }

  section#howto .introduction_box01 .introduction_box_img02 img,
  section#howto .introduction_box03 .introduction_box_img02 img {
    width: min(64vw, 240px) !important;
    transform: none !important;
  }

  section#howto .introduction_box02 {
    min-height: 0 !important;
    padding: 20px 14px 24px !important;
    gap: 12px !important;
    margin-top: 17.87vw !important;
  }

  section#howto .introduction_box02 > div {
    padding: 14px 12px !important;
    gap: 12px !important;
  }

  section#howto .introduction_box02_ico img {
    width: 46px !important;
    max-width: 46px !important;
  }

  section#howto .introduction_box02 > div > p.introduction_box02_ico {
    width: 52px !important;
    min-width: 52px !important;
  }

  section#howto .introduction_box02_txt01 {
    font-size: 3.73vw !important;
  }

  section#howto .introduction_box02_txt02 {
    font-size: 3.2vw !important;
  }

  section#howto .introduction_box_txt {
    margin-left: 6.4vw !important;
    margin-right: 6.4vw !important;
    font-size: 3.73vw !important;
    line-height: 1.86 !important;
  }

  section#howto .introduction_box_en {
    font-size: 4.27vw !important;
    margin-right: 10.67vw !important;
  }

  section#howto .introduction_box_title {
    font-size: 4.8vw !important;
    margin-bottom: 4.8vw !important;
  }
}

.commonIssues01_sec > .commonIssues01_card,
.features_box02,
.gc-hero-visual__chat {
  border-left: none !important;
}

/* ── allInOneManagement: コンパクト化 ── */
.allInOneManagement {
  background: var(--surface) !important;
}

.allInOneManagement_inner {
  width: min(var(--content-max), 100%) !important;
  margin-inline: auto !important;
  padding: 48px var(--section-x) 56px !important;
  box-sizing: border-box;
}

.allInOneManagement_title {
  font-size: clamp(2rem, 4vw, 2.8rem) !important;
  margin-bottom: 28px !important;
  line-height: 1.45 !important;
}

.allInOneManagement_subTitle {
  text-align: center;
  font-size: clamp(1.6rem, 3.2vw, 2rem);
  font-weight: 800;
  color: var(--text);
  margin: 0 0 20px;
  line-height: 1.45;
}

.allInOneManagement_trust {
  margin-top: 40px;
  padding-top: 36px;
  border-top: 1px solid var(--border);
}

.allInOneManagement_sec {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 12px !important;
}

.allInOneManagement_box--trust {
  padding: 18px 16px !important;
  text-align: left;
}

.allInOneManagement_box--trust .allInOneManagement_box_title {
  margin-bottom: 8px !important;
  text-align: left;
}

.allInOneManagement_box--trust .allInOneManagement_box_txt {
  text-align: left;
  line-height: 1.75 !important;
}

.allInOneManagement_box {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 16px 14px !important;
  box-sizing: border-box;
}

.allInOneManagement_box_img,
.allInOneManagement_box_img01,
.allInOneManagement_box_img02,
.allInOneManagement_box_img03,
.allInOneManagement_box_img04,
.allInOneManagement_box_img05,
.allInOneManagement_box_img06 {
  height: auto !important;
  padding-top: 0 !important;
  margin: 0 0 8px !important;
}

.allInOneManagement_box_img img {
  width: 32px !important;
  height: auto !important;
}

.allInOneManagement_box_title {
  font-size: 1.5rem !important;
  line-height: 1.4 !important;
  margin-bottom: 8px !important;
  color: var(--brand) !important;
}

.allInOneManagement_box_txt {
  margin: 0 !important;
  font-size: 1.3rem !important;
  line-height: 1.65 !important;
}

@media (min-width: 640px) {
  .allInOneManagement_sec--features {
    grid-template-columns: repeat(3, 1fr);
    gap: 14px !important;
  }

  .allInOneManagement_sec--trust {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px !important;
  }
}

@media (min-width: 1024px) {
  .allInOneManagement_sec--features {
    gap: 16px !important;
  }

  .allInOneManagement_sec--trust {
    grid-template-columns: repeat(4, 1fr);
    gap: 16px !important;
  }

  .allInOneManagement_box {
    padding: 18px 16px !important;
  }
}

/* ── FAQ パネル式 ── */
#qa .payme-faq__item {
  padding: 0 !important;
  overflow: hidden;
}

#qa .payme-faq__trigger {
  background: var(--surface) !important;
}

#qa .payme-faq__trigger:hover {
  background: var(--surface-card) !important;
}

#qa .payme-faq__item.is-open .payme-faq__trigger {
  background: var(--surface) !important;
}

#qa .payme-faq__item.is-open .payme-faq__panel {
  max-height: 480px !important;
}

#qa .payme-faq__item.is-open .payme-faq__panelInner {
  background: transparent !important;
  margin: 0;
  padding: 0 18px 16px !important;
  border-radius: 0;
}

/* ══════════════════════════════════════
   Responsive
   ══════════════════════════════════════ */
.footer_inner {
  width: 100% !important;
  max-width: var(--content-max);
  margin-inline: auto !important;
  padding-inline: var(--section-x);
  box-sizing: border-box;
}

.features_header_inner,
.commonIssues02_inner {
  width: 100% !important;
  max-width: var(--content-max);
  box-sizing: border-box;
}

@media screen and (max-width: 1023px) {
  #wrapper {
    padding-top: calc(var(--mobile-header-total) + env(safe-area-inset-top, 0px));
  }

  .header_inner {
    height: var(--mobile-header-inner) !important;
    align-items: center !important;
    padding-inline: var(--section-x) !important;
    box-sizing: border-box !important;
  }

  .header_logo {
    padding: 0 !important;
    width: auto !important;
    line-height: 0;
  }

  .header_logo img {
    width: min(136px, 34vw) !important;
    max-width: 136px !important;
  }

  .header_nav {
    top: var(--mobile-header-total) !important;
    height: calc(100dvh - var(--mobile-header-total) - env(safe-area-inset-top, 0px)) !important;
    border-top-color: var(--border) !important;
  }

  .header_nav_main a {
    font-size: 1.6rem !important;
    font-weight: 700 !important;
    padding: 14px var(--section-x) !important;
    line-height: 1.4 !important;
  }

  .header_nav_sub {
    padding: 20px var(--section-x) 24px !important;
  }

  .header_nav_sub li + li {
    margin-top: 10px !important;
  }

  .header_nav_sub a {
    height: auto !important;
    min-height: 44px !important;
    padding: 12px 20px !important;
    font-size: 1.4rem !important;
    border-radius: var(--radius-pill) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
  }

  .header_navToggle {
    top: var(--mobile-header-bar) !important;
    width: auto !important;
    min-width: 44px !important;
    height: var(--mobile-header-inner) !important;
    padding: 0 var(--section-x) !important;
    box-sizing: border-box !important;
  }

  .header_navToggle span {
    top: 50% !important;
    right: var(--section-x) !important;
    transform: translateY(-50%);
    width: 32px;
    line-height: 0;
  }

  .header_navToggle img {
    width: 32px !important;
    max-width: 32px !important;
    height: auto !important;
  }

  .header.is-open .header_nav {
    display: block !important;
  }

  .header.is-open .header_navToggle span:nth-child(1) {
    opacity: 0;
  }

  .header.is-open .header_navToggle span:nth-child(2) {
    opacity: 1;
  }

  .mainvisual {
    padding-bottom: 32px !important;
  }

  .mainvisual_inner {
    padding-top: 16px !important;
    gap: 24px !important;
  }

  .mainvisual_txt01::after {
    font-size: clamp(1.8rem, 6vw, 2.6rem) !important;
  }

  .mv-hero-steps {
    margin-top: -16px;
    padding: 24px var(--section-x) 28px;
  }

  .mv-hero-steps__list {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 16px 20px;
    width: 100%;
    max-width: none;
    margin-inline: auto;
  }

  .mv-hero-steps__sep {
    display: none;
  }

  .mv-hero-steps__item {
    flex: 0 1 auto;
    justify-content: flex-start !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  .mv-hero-steps__icon {
    width: 48px !important;
    height: 48px !important;
    flex-shrink: 0;
  }

  .mv-hero-steps__icon img {
    width: 36px !important;
    height: 36px !important;
  }

  .mv-hero-steps__label {
    flex: 1;
    min-width: 0;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px 8px;
  }

  .mv-hero-steps__txt {
    white-space: normal !important;
    font-size: 1.3rem !important;
    line-height: 1.35 !important;
  }

  .features_body {
    padding: 0 !important;
  }

  .features_intro {
    padding: 40px var(--section-x) 32px !important;
  }

  .features_box01 {
    flex-direction: column !important;
    margin-bottom: 0 !important;
    padding: 40px var(--section-x) !important;
  }

  .features_box01_02,
  .features_box01_04 {
    flex-direction: column !important;
  }

  .features_box01_02 > p.features_box01_img,
  .features_box01_04 > p.features_box01_img {
    order: -1;
  }

  #features .features_box01 {
    flex-direction: column !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  #features .features_box01_02,
  #features .features_box01_04 {
    flex-direction: column !important;
  }

  #features .features_box01_title {
    text-align: left !important;
  }

  #features .features_box01_label {
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
    border-radius: var(--radius-pill) !important;
  }

  #features .features_box01_point li {
    padding: 0 !important;
    line-height: 1.5 !important;
    border-radius: 0 !important;
  }

  .features_box01 > div,
  .features_box01 > p {
    width: 100% !important;
    max-width: 100% !important;
  }

  .features_box01_title {
    font-size: clamp(1.7rem, 5vw, 2.2rem) !important;
  }

  .features_box01_txt {
    font-size: 1.4rem !important;
    line-height: 1.75 !important;
  }

  .features_box01_point {
    margin-top: 20px !important;
  }

  .features_box01_point li {
    font-size: 1.3rem !important;
    line-height: 1.5 !important;
    padding: 0 !important;
  }

  .features_box02 {
    padding: 24px 16px !important;
  }

  .features_box02_img {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .features_box02_img img {
    min-width: 560px;
    max-width: none !important;
    width: auto !important;
    height: auto !important;
  }

  .introduction {
    padding: 40px 0 48px !important;
  }

  section#howto .introduction_sec {
    flex-direction: column !important;
  }

  section#howto .introduction_box01,
  section#howto .introduction_box02,
  section#howto .introduction_box03 {
    flex: none !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .payme-steps {
    margin-bottom: 32px !important;
  }

  .mv-flow {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    width: min(100%, 360px);
    margin-inline: auto;
  }

  .price_contractFlow {
    color: var(--text) !important;
    text-align: left !important;
  }

  .price_contractFlow_title {
    color: var(--text) !important;
    text-align: center !important;
    opacity: 1 !important;
    transform: none !important;
    margin-bottom: 24px !important;
    font-size: clamp(2rem, 5.5vw, 2.8rem) !important;
  }

  section#support .mv-flow__item {
    display: grid !important;
    grid-template-columns: 56px 1fr !important;
    gap: 12px 16px !important;
    align-items: start !important;
    padding: 20px 16px !important;
    text-align: left !important;
    opacity: 1 !important;
    transform: none !important;
  }

  section#support .mv-flow__num {
    font-size: 2rem !important;
    line-height: 1 !important;
  }

  section#support .mv-flow__title {
    font-size: 1.6rem !important;
    margin-bottom: 6px !important;
  }

  section#support .mv-flow__txt {
    font-size: 1.3rem !important;
    line-height: 1.65 !important;
  }

  section#support .mv-flow__txt br {
    display: none;
  }

  .mv-about,
  .payme-merits,
  .payme-security,
  .mv-cases,
  .commonIssues01,
  .commonIssues02,
  .payme-flowBand,
  .payme-ctaBand,
  .price,
  .qa {
    padding-block: 48px !important;
  }

  .commonIssues02_inner {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .commonIssues02_title {
    text-align: center !important;
  }

  .commonIssues02_img {
    width: min(300px, 88%) !important;
    margin: 8px auto 0 !important;
  }

  .mv-about__features {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .mv-cases__list,
  .payme-merits__list,
  .payme-security__list {
    grid-template-columns: 1fr !important;
  }

  .footer {
    padding: 40px 0 28px !important;
  }

  .footer_main {
    flex-direction: column;
    align-items: center;
    gap: 24px;
    padding-bottom: 24px;
    margin-bottom: 24px;
    text-align: center;
  }

  .footer_logo img {
    width: min(168px, 48vw) !important;
    margin-inline: auto;
  }

  .footer_link {
    justify-content: center !important;
    gap: 10px 20px !important;
  }

  .footer_link a {
    font-size: 1.3rem !important;
  }

  .footer_dataProtectionPrivacy {
    padding: 20px 16px !important;
    margin-bottom: 20px !important;
    text-align: left;
  }

  .footer_dataProtectionPrivacy_title {
    font-size: 1.4rem !important;
  }

  .footer_dataProtectionPrivacy_txt {
    font-size: 1.25rem !important;
    line-height: 1.75 !important;
  }

  .footer_dataProtectionPrivacy_txt br {
    display: none;
  }

  .footer_copyright {
    font-size: 1.1rem !important;
  }

  .payme-faq__qText {
    font-size: 1.4rem !important;
  }

  .payme-faq__trigger {
    padding: 14px 12px !important;
  }

  .payme-faq__a {
    font-size: 1.3rem !important;
  }

  .contactArea01_btn {
    flex-direction: column !important;
    max-width: 100% !important;
  }

  .mv-fixedBar {
    padding: 8px var(--section-x);
    gap: 8px;
  }

  .mv-fixedBar__btn {
    font-size: 1.2rem !important;
    padding: 10px 12px !important;
  }

  /* ── スマホ総合調整 ── */
  html {
    -webkit-text-size-adjust: 100%;
    scroll-padding-top: calc(var(--mobile-header-total) + env(safe-area-inset-top, 0px));
  }

  main {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .header {
    padding-top: env(safe-area-inset-top, 0px);
  }

  .mv-fixedBar,
  .floating-cta {
    padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
  }

  /* common.css の img{width:100%} からアイコン類を除外 */
  .mv-hero-steps__icon img,
  .features_box01_point img,
  .header_logo img,
  .introduction_box02_ico img,
  img[width="21"],
  img[width="24"],
  img[width="48"] {
    width: auto !important;
    max-width: 100%;
    height: auto !important;
  }

  .header_navToggle img {
    width: 32px !important;
    max-width: 32px !important;
    height: auto !important;
  }

  .commonIssues01 {
    padding: 48px var(--section-x) 40px !important;
  }

  .commonIssues01_title {
    max-width: 100% !important;
    font-size: clamp(2rem, 6vw, 3.2rem) !important;
  }

  .commonIssues01_sec {
    display: grid !important;
    overflow: visible !important;
  }

  .commonIssues01_sec > .commonIssues01_card {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    height: auto !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 24px 20px 16px !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .commonIssues01_sec > .commonIssues01_card:nth-child(1),
  .commonIssues01_sec > .commonIssues01_card:nth-child(2),
  .commonIssues01_sec > .commonIssues01_card:nth-child(3) {
    margin: 0 !important;
    padding-top: 24px !important;
  }

  .commonIssues01_card h3,
  .commonIssues01_card p {
    padding-right: 0 !important;
    margin-right: 0 !important;
  }

  .commonIssues01_card p br {
    display: none;
  }

  .commonIssues01_card-illust {
    position: static !important;
    align-self: flex-end;
    width: min(150px, 48%) !important;
    margin-top: 12px !important;
    margin-right: -8px !important;
    margin-bottom: -8px !important;
  }

  .commonIssues02 {
    padding-inline: var(--section-x) !important;
  }

  .commonIssues02_inner {
    padding: 24px 20px !important;
  }

  .commonIssues02_list li {
    word-break: break-word;
    font-size: 1.4rem !important;
  }

  .mv-about__lead {
    font-size: 1.4rem !important;
    line-height: 1.85 !important;
    padding-inline: 0;
  }

  .mv-about__lead br.pc {
    display: none;
  }

  .gc-hero-visual {
    width: 100%;
    max-width: 100%;
  }

  .gc-hero-visual__screen {
    padding: 20px 16px !important;
  }

  .contactArea01_inner {
    padding: 32px var(--section-x) 40px !important;
  }

  .contactArea01_btn01 a,
  .contactArea01_btn02 a {
    min-height: 48px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem !important;
    padding: 12px 16px !important;
    box-sizing: border-box;
  }

  .payme-btn,
  .btn_signup,
  .btn_download {
    min-height: 48px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
  }

  .features_header_inner {
    padding: 32px var(--section-x) !important;
  }

  .features_header_inner::after {
    font-size: clamp(1.6rem, 5.5vw, 2.2rem) !important;
    line-height: 1.45 !important;
  }

  .features_box01 {
    margin-bottom: 0 !important;
    padding: 36px var(--section-x) !important;
  }

  .features_box01_img {
    overflow: hidden;
  }

  .postImplementationChanges_inner {
    width: auto !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 48px var(--section-x) 40px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 28px;
    box-sizing: border-box;
  }

  .postImplementationChanges_inner > div:first-child {
    padding: 0 !important;
  }

  .postImplementationChanges_inner > div:first-child ul {
    display: grid !important;
    gap: 12px !important;
    margin: 0;
    padding: 0;
  }

  .postImplementationChanges_inner > div:first-child ul li {
    width: auto !important;
    height: auto !important;
    min-height: 0 !important;
    line-height: 1.55 !important;
    padding: 18px 16px !important;
    font-size: clamp(1.4rem, 4vw, 1.7rem) !important;
    margin: 0 !important;
  }

  .postImplementationChanges_inner > div:first-child ul li::after {
    display: none !important;
  }

  .postImplementationChanges_inner > div:first-child ul li + li {
    margin: 0 !important;
  }

  .postImplementationChanges_title {
    font-size: clamp(2rem, 6vw, 2.8rem) !important;
    text-align: center !important;
    margin-bottom: 20px !important;
  }

  .postImplementationChanges_txt {
    font-size: clamp(1.8rem, 5.5vw, 2.2rem) !important;
    line-height: 1.45 !important;
    margin: 0 0 16px !important;
    padding-right: 0 !important;
    text-align: center !important;
  }

  .postImplementationChanges_inner > div:last-child {
    position: relative !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  .postImplementationChanges_img {
    position: static !important;
    text-align: center;
  }

  .postImplementationChanges_img img {
    width: min(100%, 320px) !important;
    margin: 0 auto;
  }

  .postImplementationChanges_bg {
    display: none !important;
  }

  .introduction {
    padding: 48px 0 !important;
  }

  .introduction_header,
  .introduction_sec {
    padding-inline: var(--section-x);
    box-sizing: border-box;
  }

  .introduction_box02 > div {
    flex-direction: row !important;
    align-items: center !important;
    gap: 12px !important;
  }

  .price_availablePlans {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 20px !important;
    padding-inline: var(--section-x);
    box-sizing: border-box;
  }

  .price_availablePlans_box {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  .price_contractFlow_sec,
  .price_contractFlow_box {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  section#support .price {
    padding-inline: var(--section-x) !important;
    box-sizing: border-box;
  }

  .price_availablePlans_box_planDetails div {
    flex-wrap: wrap;
  }

  .allInOneManagement_inner {
    padding: 40px var(--section-x) 48px !important;
  }

  .payme-merits__title,
  .payme-flowBand__lead,
  .payme-security__title {
    font-size: clamp(2rem, 5.5vw, 2.8rem) !important;
    line-height: 1.45 !important;
  }

  .payme-merits__item,
  .payme-security__item {
    padding: 20px 16px !important;
  }

  .payme-faq {
    padding-inline: var(--section-x);
    box-sizing: border-box;
  }

  .lp-container {
    width: calc(100% - var(--section-x) * 2) !important;
  }
}

@media screen and (max-width: 639px) {
  :root {
    --section-x: 16px;
  }

  .mv-about__features {
    grid-template-columns: 1fr !important;
  }

  .mv-about__brand,
  .mv-about__suffix {
    font-size: clamp(2rem, 6.5vw, 2.8rem);
  }

  .mainvisual_badges {
    gap: 8px;
  }

  .mainvisual_badge {
    font-size: 1.1rem;
    padding: 5px 12px;
  }

  .mainvisual_txt01::after {
    font-size: clamp(1.7rem, 7vw, 2.2rem) !important;
  }

  .mv-hero-steps__list {
    gap: 14px 12px;
  }

  .commonIssues01_sec > .commonIssues01_card {
    padding: 20px 16px 12px !important;
  }

  .commonIssues01_card h3 {
    font-size: 1.6rem !important;
  }

  .commonIssues01_card p {
    font-size: 1.3rem !important;
    line-height: 1.65 !important;
  }

  .commonIssues01_card-illust {
    width: min(130px, 44%) !important;
  }

  .commonIssues02_img {
    width: min(260px, 100%) !important;
  }

  .features_box01_label {
    font-size: 1.2rem !important;
    padding: 8px 14px !important;
  }

  .features_box01_title {
    font-size: clamp(1.6rem, 5.5vw, 2rem) !important;
  }

  .payme-steps {
    margin-bottom: 32px !important;
  }

  .payme-steps__item {
    padding: 14px 12px !important;
  }

  .postImplementationChanges ul {
    display: grid !important;
    gap: 12px;
  }

  .contactArea01_btn01 a .shape {
    font-size: 1.1rem !important;
  }

  .mv-fixedBar {
    flex-direction: column;
    align-items: stretch;
  }

  .mv-fixedBar__btn {
    width: 100%;
    text-align: center;
  }
}
