:root {
  --navy: #071426;
  --navy-2: #0B1B33;
  --navy-3: #102746;
  --gold: #D6A935;
  --gold-2: #E8C56E;
  --white: #FFFFFF;
  --ivory: #F7F5EF;
  --ink: #1E293B;
  --muted: #64748B;
  --line: #DDE3EA;
  --surface: #FFFFFF;
  --shadow: 0 14px 34px rgba(7, 20, 38, 0.08);
  --radius: 14px;
  --max: 1280px;
}

/* Company page */
.company-page {
  --company-navy: #06152a;
  --company-deep: #04101f;
  --company-gold: #d6a935;
  --company-gold-2: #efcc73;
  --company-ivory: #f7f5ef;
  color: #112036;
  background: #fff;
}

.company-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 24px;
  min-height: 72px;
  padding: 12px clamp(18px, 4vw, 42px);
  color: #fff;
  background: rgba(6, 21, 42, 0.96);
  border-bottom: 1px solid rgba(214, 169, 53, 0.28);
  backdrop-filter: blur(14px);
}

.company-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  white-space: nowrap;
}

.company-logo strong {
  font-size: 20px;
  font-weight: 950;
}

.company-logo span {
  padding: 4px 8px;
  color: var(--company-gold-2);
  border: 1px solid var(--company-gold);
  border-radius: 4px;
  font-size: 12px;
  font-weight: 900;
}

.company-nav {
  display: flex;
  justify-content: center;
  gap: clamp(14px, 2vw, 28px);
  flex: 1;
  font-size: 13px;
  font-weight: 850;
  white-space: nowrap;
}

.company-download,
.company-consult {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}

.company-download {
  border: 1px solid var(--company-gold);
}

.company-consult {
  color: var(--company-navy);
  background: linear-gradient(135deg, var(--company-gold-2), var(--company-gold));
}

.company-hero {
  overflow: hidden;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(4, 16, 31, 0.98) 0%, rgba(4, 16, 31, 0.95) 42%, rgba(4, 16, 31, 0.38) 68%, rgba(4, 16, 31, 0.06) 100%),
    url("./assets/hero-main.webp") center / cover,
    var(--company-navy);
}

.company-hero-inner {
  display: grid;
  grid-template-columns: minmax(390px, 0.9fr) minmax(0, 1.1fr);
  gap: 40px;
  align-items: center;
  max-width: 1280px;
  min-height: 520px;
  margin: 0 auto;
  padding: clamp(54px, 7vw, 82px) clamp(18px, 4vw, 42px);
}

.company-kicker {
  margin: 0 0 10px;
  color: var(--company-gold-2);
  font-size: 18px;
  font-weight: 950;
}

.company-hero h1 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(56px, 7vw, 86px);
  font-weight: 700;
  line-height: 1.1;
}

.company-hero h1::first-letter {
  color: var(--company-gold-2);
}

.company-hero h1 span {
  color: var(--company-gold-2);
}

.company-hero p {
  max-width: 620px;
  margin: 24px 0 0;
  font-size: 17px;
  font-weight: 850;
}

.company-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.company-tags span {
  min-width: 120px;
  padding: 11px 14px;
  border: 1px solid rgba(214, 169, 53, 0.5);
  background: rgba(6, 21, 42, 0.72);
  text-align: center;
  font-weight: 900;
}

.company-hero-card {
  position: relative;
  align-self: stretch;
  min-height: 360px;
}

.company-proof {
  position: absolute;
  right: 0;
  bottom: 0;
  min-width: 230px;
  padding: 18px 20px;
  color: var(--company-navy);
  background: linear-gradient(135deg, var(--company-gold-2), var(--company-gold));
  border-radius: 8px;
  text-align: center;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.2);
}

.company-proof span,
.company-proof small {
  display: block;
  font-weight: 900;
}

.company-proof strong {
  display: block;
  font-size: 36px;
  line-height: 1.1;
}

.structured-hero {
  position: relative;
  overflow: hidden;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(4, 16, 31, 0.98) 0%, rgba(4, 16, 31, 0.94) 44%, rgba(4, 16, 31, 0.72) 62%, rgba(4, 16, 31, 0.88) 100%),
    url("./assets/hero-network-bg.png") center / cover no-repeat,
    #071426;
}

.structured-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 48% 28%, rgba(26, 123, 255, 0.16), transparent 28%),
    radial-gradient(circle at 82% 45%, rgba(214, 169, 53, 0.12), transparent 24%);
  pointer-events: none;
}

.structured-mock-bg {
  display: none;
}

.structured-hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(430px, 0.94fr) minmax(430px, 1.06fr);
  gap: 30px;
  align-items: center;
  max-width: 1400px;
  min-height: 560px;
  margin: 0 auto;
  padding: clamp(54px, 6vw, 78px) clamp(22px, 4vw, 54px) 28px;
}

.structured-hero-copy {
  max-width: 650px;
}

.structured-hero h1 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(58px, 6.5vw, 90px);
  font-weight: 700;
  line-height: 1.14;
  letter-spacing: 0;
  text-shadow: 0 14px 36px rgba(0, 0, 0, 0.34);
}

.structured-hero h1::first-letter {
  color: #fff;
}

.structured-hero h1 span {
  color: var(--company-gold-2);
}

.structured-lead {
  max-width: 650px;
  margin: 26px 0 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.95;
}

.structured-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 32px;
}

.structured-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  min-height: 58px;
  padding: 0 24px;
  border-radius: 6px;
  font-size: 16px;
  font-weight: 950;
}

.structured-actions a:first-child {
  color: var(--company-navy);
  background: linear-gradient(135deg, var(--company-gold-2), var(--company-gold));
  box-shadow: 0 18px 36px rgba(214, 169, 53, 0.18);
}

.structured-actions a:last-child {
  border: 1px solid var(--company-gold);
  background: rgba(6, 21, 42, 0.56);
}

.structured-hero-mock {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 380px;
}

.structured-hero-mock img {
  display: block;
  width: min(610px, 46vw);
  max-width: 100%;
  filter: drop-shadow(0 28px 44px rgba(0, 0, 0, 0.45));
}

.structured-kpi-panel {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 clamp(22px, 4vw, 54px) 26px;
}

.structured-kpi-panel article {
  min-height: 112px;
  padding: 18px 20px;
  border: 1px solid rgba(153, 176, 210, 0.24);
  border-radius: 12px;
  background: linear-gradient(145deg, rgba(17, 42, 73, 0.72), rgba(8, 27, 51, 0.82));
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
}

.structured-kpi-panel span {
  display: block;
  color: var(--company-gold-2);
  font-size: 13px;
  font-weight: 950;
}

.structured-kpi-panel strong {
  display: block;
  margin-top: 5px;
  color: #fff;
  font-size: 27px;
  font-weight: 950;
  line-height: 1.2;
}

.structured-kpi-panel p {
  margin: 8px 0 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 13px;
  font-weight: 800;
}

.structured-service-strip {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid rgba(153, 176, 210, 0.22);
  background: rgba(4, 16, 31, 0.76);
}

.structured-service-strip span {
  display: flex;
  align-items: center;
  min-height: 86px;
  padding: 18px clamp(16px, 3vw, 42px);
  color: #fff;
  border-right: 1px solid rgba(153, 176, 210, 0.18);
  font-size: 17px;
  font-weight: 950;
}

.structured-service-strip span::before {
  content: "";
  width: 10px;
  height: 10px;
  margin-right: 12px;
  border: 2px solid var(--company-gold);
  border-radius: 50%;
  box-shadow: 0 0 14px rgba(214, 169, 53, 0.34);
}

.company-section {
  padding: clamp(58px, 7vw, 86px) clamp(18px, 4vw, 42px);
  background: #fff;
}

.company-ivory {
  background: var(--company-ivory);
}

.company-heading {
  max-width: 900px;
  margin: 0 auto 30px;
  text-align: center;
}

.company-heading h2,
.company-axdx h2,
.company-cta h2 {
  margin: 0;
  color: var(--company-navy);
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 950;
  line-height: 1.25;
}

.company-heading h2::after {
  content: "";
  display: block;
  width: 54px;
  height: 2px;
  margin: 14px auto 0;
  background: var(--company-gold);
}

.company-heading p {
  margin: 12px 0 0;
  color: #5f6b7a;
  font-weight: 800;
}

.company-service-grid,
.industry-grid,
.reason-cards,
.company-flow,
.app-grid,
.builder-grid {
  max-width: 1280px;
  margin: 0 auto;
}

.company-service-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}

.company-service-grid article,
.industry-grid article,
.reason-cards article,
.company-flow li,
.app-grid article,
.builder-grid article {
  border: 1px solid #dde3ea;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(6, 21, 42, 0.06);
}

.company-service-grid article {
  min-height: 210px;
  padding: 28px 18px;
  text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.company-service-grid article:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(6, 21, 42, 0.09);
}

.company-service-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  margin-bottom: 16px;
  color: var(--company-gold-2);
  background: var(--company-navy);
  border-radius: 50%;
  font-weight: 950;
}

.company-service-grid strong,
.industry-grid strong,
.reason-cards strong,
.company-flow strong,
.app-grid strong,
.builder-grid strong {
  display: block;
  color: var(--company-navy);
  font-size: 18px;
  font-weight: 950;
}

.company-service-grid p,
.industry-grid p,
.reason-cards p,
.company-flow p,
.app-grid p,
.builder-grid p,
.company-axdx p,
.company-cta p,
.company-footer p {
  margin: 10px 0 0;
  color: #5f6b7a;
  font-size: 14px;
  font-weight: 700;
}

.industry-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px;
}

.industry-grid article {
  overflow: hidden;
  text-align: center;
}

.industry-grid img,
.company-image-placeholder {
  width: 100%;
  height: 118px;
  object-fit: cover;
}

.company-image-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
  color: rgba(255, 255, 255, 0.72);
  background:
    linear-gradient(135deg, rgba(6, 21, 42, 0.96), rgba(11, 27, 51, 0.92)),
    repeating-linear-gradient(45deg, rgba(214, 169, 53, 0.1) 0 1px, transparent 1px 12px);
  border-bottom: 1px solid #dde3ea;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-align: center;
}

.industry-grid strong {
  padding: 14px 12px 0;
}

.industry-grid p {
  padding: 0 12px 18px;
}

.reason-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.reason-cards article {
  padding: 22px;
  border-color: rgba(214, 169, 53, 0.55);
}

.reason-cards span,
.company-flow span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  margin-bottom: 14px;
  color: #fff;
  background: var(--company-navy);
  border-radius: 50%;
  font-weight: 950;
}

.company-axdx {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 28px;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: clamp(58px, 7vw, 86px) clamp(18px, 4vw, 42px);
  background: #fff;
}

.company-axdx-copy {
  padding: 36px;
  border: 1px solid #dde3ea;
  border-radius: 12px;
  background: #fff;
}

.company-axdx img,
.company-axdx-placeholder {
  order: -1;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid #dde3ea;
}

.company-axdx-placeholder {
  height: auto;
  min-height: 310px;
  border-bottom: 1px solid #dde3ea;
}

.mini-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.mini-tags span {
  padding: 7px 12px;
  border-radius: 6px;
  color: #5a4a18;
  background: #fbf5df;
  font-size: 12px;
  font-weight: 900;
}

.app-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.builder-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.builder-grid article {
  min-height: 210px;
  padding: 26px;
}

.builder-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  margin-bottom: 16px;
  color: #fff;
  background: var(--company-navy);
  border-radius: 50%;
  font-weight: 950;
}

.app-grid article {
  min-height: 190px;
  padding: 24px;
}

.app-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  height: 34px;
  margin-bottom: 18px;
  padding: 0 12px;
  color: var(--company-navy);
  background: #fbf5df;
  border: 1px solid rgba(214, 169, 53, 0.55);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 950;
}

.company-flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  padding: 0;
  list-style: none;
}

.company-flow li {
  position: relative;
  min-height: 170px;
  padding: 22px;
}

.company-flow li:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -18px;
  width: 12px;
  height: 12px;
  border-top: 2px solid var(--company-gold);
  border-right: 2px solid var(--company-gold);
  transform: translateY(-50%) rotate(45deg);
  background: transparent;
}

.company-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 36px;
  padding: clamp(48px, 6vw, 76px) clamp(18px, 4vw, 72px);
  color: #fff;
  background:
    linear-gradient(90deg, rgba(6, 21, 42, 0.98), rgba(6, 21, 42, 0.9)),
    var(--company-navy);
}

.company-cta h2 {
  color: #fff;
}

.company-cta p {
  color: rgba(255, 255, 255, 0.86);
}

.company-cta-actions {
  display: grid;
  gap: 12px;
  min-width: 300px;
}

.company-cta-actions a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  border-radius: 6px;
  font-weight: 950;
}

.company-cta-actions a:first-child {
  color: var(--company-navy);
  background: linear-gradient(135deg, var(--company-gold-2), var(--company-gold));
}

.company-cta-actions a:last-child {
  border: 1px solid var(--company-gold);
}

.company-footer {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 34px;
  padding: 42px clamp(18px, 4vw, 72px);
  color: #fff;
  background: var(--company-deep);
}

.company-footer strong {
  display: inline-block;
  margin-right: 10px;
  font-size: 18px;
}

.company-footer span {
  padding: 4px 8px;
  color: var(--company-gold-2);
  border: 1px solid var(--company-gold);
  border-radius: 4px;
  font-size: 12px;
  font-weight: 900;
}

.company-footer p {
  color: rgba(255, 255, 255, 0.72);
}

.company-footer nav {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 24px;
  color: rgba(255, 255, 255, 0.82);
  font-weight: 800;
}

.company-footer small {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.55);
}

@media (max-width: 1180px) {
  .company-header {
    flex-wrap: wrap;
  }

  .company-nav {
    order: 3;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .company-hero-inner,
  .company-axdx,
  .company-cta {
    grid-template-columns: 1fr;
  }

  .company-service-grid,
  .industry-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .reason-cards,
  .company-flow,
  .app-grid,
  .builder-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .company-cta {
    display: grid;
  }

  .structured-hero-inner {
    grid-template-columns: minmax(390px, 0.94fr) minmax(390px, 1.06fr);
  }

  .structured-hero-mock {
    min-height: 340px;
    justify-content: flex-end;
  }

  .structured-hero-mock img {
    width: min(540px, 47vw);
  }

  .structured-kpi-panel {
    grid-template-columns: repeat(2, 1fr);
  }

  .structured-service-strip {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  .company-header {
    position: static;
    gap: 12px;
  }

  .company-logo {
    flex-wrap: wrap;
    white-space: normal;
  }

  .company-logo strong {
    width: 100%;
  }

  .company-download,
  .company-consult {
    flex: 1;
  }

  .company-hero-inner {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 44px;
  }

  .company-hero h1 {
    font-size: 44px;
  }

  .company-hero p {
    font-size: 15px;
  }

  .company-tags span {
    flex: 1 1 calc(50% - 10px);
    min-width: 0;
  }

  .company-proof {
    position: static;
    margin-top: 12px;
  }

  .company-service-grid,
  .industry-grid,
  .reason-cards,
  .company-flow,
  .app-grid,
  .builder-grid,
  .company-footer {
    grid-template-columns: 1fr;
  }

  .company-service-grid article,
  .company-flow li,
  .app-grid article,
  .builder-grid article {
    min-height: auto;
  }

  .company-flow li::after {
    display: none;
  }

  .industry-grid img {
    height: 190px;
  }

  .company-image-placeholder {
    height: 190px;
  }

  .company-axdx {
    padding-left: 18px;
    padding-right: 18px;
  }

  .company-axdx-copy {
    padding: 24px;
  }

  .company-cta-actions {
    min-width: 0;
  }

  .company-footer nav {
    grid-template-columns: 1fr;
  }

  .structured-hero-inner {
    grid-template-columns: 1fr;
    padding: 42px 18px 22px;
  }

  .structured-hero h1 {
    font-size: 45px;
  }

  .structured-lead {
    font-size: 15px;
  }

  .structured-actions {
    display: grid;
    gap: 12px;
  }

  .structured-actions a {
    width: 100%;
    min-width: 0;
  }

  .structured-hero-mock {
    min-height: 230px;
    justify-content: center;
  }

  .structured-hero-mock img {
    width: 112vw;
    max-width: none;
    transform: translateX(8vw);
  }

  .structured-kpi-panel {
    display: flex;
    overflow-x: auto;
    gap: 12px;
    padding: 0 18px 20px;
    scroll-snap-type: x mandatory;
  }

  .structured-kpi-panel article {
    flex: 0 0 76%;
    min-height: 108px;
    scroll-snap-align: start;
  }

  .structured-service-strip {
    grid-template-columns: 1fr;
  }

  .structured-service-strip span {
    min-height: 64px;
    padding: 14px 18px;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--ink);
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", Meiryo, sans-serif;
  background: var(--white);
  line-height: 1.75;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

.component {
  position: relative;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 28px;
  min-height: 72px;
  padding: 12px clamp(20px, 4vw, 48px);
  color: var(--white);
  background: rgba(7, 20, 38, 0.96);
  border-bottom: 1px solid rgba(214, 169, 53, 0.22);
  backdrop-filter: blur(14px);
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
  white-space: nowrap;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(214, 169, 53, 0.7);
  border-radius: 50%;
  color: var(--gold-2);
  font-size: 20px;
  font-weight: 950;
}

.brand-name {
  color: var(--white);
  font-size: 21px;
  font-weight: 950;
}

.brand-name::first-letter {
  color: var(--gold-2);
}

.brand-company {
  padding-left: 14px;
  border-left: 1px solid rgba(255, 255, 255, 0.32);
  color: rgba(255, 255, 255, 0.86);
  font-size: 13px;
  font-weight: 800;
}

.global-nav {
  display: flex;
  justify-content: center;
  gap: clamp(16px, 2vw, 28px);
  flex: 1;
  font-size: 14px;
  font-weight: 850;
  white-space: nowrap;
}

.global-nav a:hover {
  color: var(--gold-2);
}

.header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  color: var(--navy);
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  border-radius: 0;
  font-weight: 950;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 26px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 950;
}

.btn-gold {
  color: var(--navy);
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
}

.btn-outline {
  color: var(--white);
  border: 1px solid rgba(255, 255, 255, 0.5);
  background: transparent;
}

.hero-section {
  position: relative;
  overflow: hidden;
  color: var(--white);
  background: var(--navy);
}

/* === 背景動画レイヤー === */
.hero-bgvideo{
  position: absolute; inset: 0; z-index: 0;
  overflow: hidden; pointer-events: none;
}
.hero-bgvideo-el{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  filter: brightness(0.85) contrast(1.05);
  /* 初期は透明、再生準備が整ったらフェードイン */
  opacity: 0;
  transition: opacity 600ms ease-out;
}
/* 動きを減らす設定の人には動画を再生しない */
@media (prefers-reduced-motion: reduce){
  .hero-bgvideo-el{ display: none !important; }
}
.hero-bgvideo-el.is-ready{ opacity: 1; }
/* オーバーレイの下にプレースホルダー — 動画読み込み中はネイビーグラデを表示 */
.hero-bgvideo::before{
  content: ''; position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(31,79,182,0.35), transparent 60%),
    radial-gradient(ellipse at 70% 70%, rgba(196,160,82,0.18), transparent 60%),
    linear-gradient(135deg, #0F2447 0%, #050E21 100%);
}
.hero-bgvideo-overlay{
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(7,20,38,0.92) 0%, rgba(7,20,38,0.78) 38%, rgba(7,20,38,0.45) 62%, rgba(7,20,38,0.20) 100%),
    radial-gradient(circle at 75% 40%, rgba(214,169,53,0.16), transparent 38%),
    linear-gradient(180deg, rgba(7,20,38,0.10) 0%, rgba(7,20,38,0.50) 100%);
}

.hero-shell {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: minmax(520px, 1.1fr) minmax(0, 0.9fr);
  align-items: center;
  gap: 44px;
  max-width: var(--max);
  min-height: 620px;
  margin: 0 auto;
  padding: clamp(58px, 7vw, 88px) clamp(20px, 4vw, 48px);
}

/* モバイルは動画が重いので静的グラデに */
@media (max-width: 760px){
  .hero-bgvideo-el{ display: none; }
  .hero-bgvideo-overlay{
    background:
      linear-gradient(180deg, rgba(7,20,38,0.95) 0%, rgba(7,20,38,0.75) 100%),
      radial-gradient(circle at 70% 35%, rgba(214,169,53,0.20), transparent 50%);
  }
}

.eyebrow,
.section-heading span,
.axdx-copy span {
  display: block;
  margin-bottom: 12px;
  color: var(--gold);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.02em;
}

.hero-copy h1 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(52px, 6vw, 78px);
  font-weight: 700;
  line-height: 1.14;
  letter-spacing: 0;
}

.hero-copy h1::first-letter {
  color: var(--gold-2);
}

/* === Hero trust chips（30日無料・¥0・AIノウハウ） === */
.hero-trust{
  display: flex; flex-wrap: wrap;
  gap: 8px 14px;
  align-items: center;
  margin-top: 2px;
}
.hero-trust-item{
  display: inline-flex; align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(24,183,122,0.08);
  border: 1px solid rgba(24,183,122,0.30);
  font-size: 11.5px; font-weight: 700;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.005em;
}
.hero-trust-item svg{
  color: #2ED98C;
  flex-shrink: 0;
}
.hero-trust-item strong{
  color: #2ED98C;
  font-weight: 900;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  margin-right: 2px;
}
/* AI variant — gold */
.hero-trust-ai{
  background: linear-gradient(135deg, rgba(255,213,104,0.15), rgba(196,160,82,0.08)) !important;
  border-color: rgba(255,213,104,0.45) !important;
}
.hero-trust-ai strong{
  color: #FFD568 !important;
}
/* Human supervision variant — soft blue */
.hero-trust-human{
  background: linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04)) !important;
  border-color: rgba(255,255,255,0.30) !important;
}
.hero-trust-human strong{
  color: #fff !important;
}
@media(max-width: 760px){
  .hero-trust{ gap: 6px; }
  .hero-trust-item{ padding: 5px 10px; font-size: 10.5px; }
}

/* === Philosophy tag sections === */
.phil-tag-section{ margin-bottom: 12px; }
.phil-tag-section:last-child{ margin-bottom: 0; }
.phil-tag-label{
  display: block;
  font-size: 9.5px; font-weight: 900;
  color: #C4A052;
  letter-spacing: 0.10em;
  margin-bottom: 6px;
}
.phil-card-tags-genre li{
  background: linear-gradient(135deg, #FFD568 0%, #C4A052 100%) !important;
  color: #0F2447 !important;
  border: none !important;
  font-weight: 900 !important;
}

/* =================================================
   Before / After v4 — vertical layout (BEFORE / arrow / AFTER)
   ================================================= */
.ba-v4-section{
  padding: 0;
  background: #FBF9F2;
}
.ba-v4-shell{ max-width: 1280px; margin: 0 auto; }

/* Block head */
.ba-v4-block{ padding: clamp(56px, 7vw, 84px) clamp(20px, 4vw, 64px); }
.ba-v4-before{ background: #FAF8F2; }
.ba-v4-after{ background: linear-gradient(180deg, #0A1A30 0%, #07142A 100%); padding-top: 64px; padding-bottom: 96px; }
.ba-v4-block-head{ text-align: center; margin-bottom: 36px; }
.ba-v4-h2{
  font-size: clamp(32px, 4.6vw, 56px);
  font-weight: 900;
  color: #0F2447;
  letter-spacing: 0.18em;
  margin: 0 0 10px;
  font-family: 'Noto Sans JP', 'Hiragino Mincho ProN', serif;
}
.ba-v4-sub{
  font-size: 15px; font-weight: 700;
  color: #5A6A82;
  margin: 0;
  letter-spacing: 0.005em;
}
.ba-v4-h2-after{ color: #fff; }
.ba-v4-sub-after{ color: rgba(255,255,255,0.7); }

/* Down arrow */
.ba-v4-arrow-down{
  position: relative;
  display: grid; place-items: center;
  background: linear-gradient(180deg, #FAF8F2 0%, #07142A 100%);
  padding: 18px 0 22px;
  color: #C4A052;
}
.bv4-arrow-tab{
  position: absolute;
  top: 0;
  width: 0; height: 0;
  border-left: 28px solid transparent;
  border-right: 28px solid transparent;
  border-top: 22px solid #FAF8F2;
}

/* Tags row at top of BEFORE */
.ba-v4-tags{
  list-style: none; padding: 0;
  display: flex; gap: 24px; justify-content: center; flex-wrap: wrap;
  margin: 0 auto 18px;
  position: relative; z-index: 2;
}
.ba-v4-tags li{
  display: inline-flex; align-items: center;
  padding: 8px 22px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 999px;
  font-size: 14px; font-weight: 800; color: #25334A;
  box-shadow: 0 4px 10px -2px rgba(15,36,71,0.08);
}

/* Canvas */
.ba-v4-canvas{
  position: relative;
  display: block;
  min-height: 480px;
  margin-top: 8px;
}
.bv4-conns{
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}

/* Element common */
.bv4-el{
  position: absolute;
  display: flex; flex-direction: column; align-items: center;
  gap: 8px;
  z-index: 2;
}
.bv4-mock{
  background: #fff;
  border-radius: 8px;
  border: 1px solid #E5E9EF;
  box-shadow: 0 8px 22px -8px rgba(15,36,71,0.18);
}
.bv4-label{
  display: inline-block;
  padding: 5px 14px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 999px;
  font-size: 11.5px; font-weight: 800; color: #25334A;
  white-space: nowrap;
  box-shadow: 0 2px 6px -2px rgba(15,36,71,0.08);
}

/* Excel */
.bv4-el-excel{ top: 4%; left: 2%; width: 220px; }
.bv4-mock-excel{
  width: 100%;
  padding: 8px;
  position: relative;
}
.bv4-x-icon{
  position: absolute;
  top: -8px; left: -8px;
  display: grid; place-items: center;
  width: 36px; height: 36px;
  border-radius: 9px;
  background: #1D6F42;
  color: #fff;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 18px; font-weight: 900;
  box-shadow: 0 4px 10px -2px rgba(29,111,66,0.4);
}
.bv4-x-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: #E5E9EF;
  border: 1px solid #E5E9EF;
  border-radius: 4px;
  overflow: hidden;
}
.bv4-x-grid i{
  background: #fff;
  height: 14px;
  display: block;
}
.bv4-x-grid i:nth-child(-n+4){ background: #FAFBFD; height: 11px; }

/* Paper documents */
.bv4-el-paper{ top: 22%; left: 19%; }
.bv4-mock-paper{
  position: relative;
  width: 90px; height: 110px;
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}
.bv4-paper{
  position: absolute;
  width: 80px; height: 100px;
  background: #fff;
  border: 1px solid #D5DCE5;
  border-radius: 4px;
  box-shadow: 0 8px 18px -6px rgba(15,36,71,0.12);
}
.bv4-paper::before{
  content: '';
  position: absolute;
  top: 12px; left: 12px; right: 12px;
  height: 1px; background: #C5CCD6;
  box-shadow:
    0 6px 0 #DEE3EB,
    0 12px 0 #DEE3EB,
    0 18px 0 #DEE3EB,
    0 24px 0 #DEE3EB,
    0 30px 0 #DEE3EB;
}
.bv4-paper-1{ transform: rotate(-12deg); top: 0; left: 0; }
.bv4-paper-2{ transform: rotate(-2deg); top: 4px; left: 8px; }
.bv4-paper-3{ transform: rotate(8deg); top: 2px; left: 16px; }

/* Memo (yellow sticky) */
.bv4-el-memo{ top: 18%; left: 38%; }
.bv4-mock-memo{
  position: relative;
  width: 130px; height: 120px;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.bv4-memo{
  position: absolute;
  padding: 8px 10px;
  border-radius: 3px;
  font-size: 10px; font-weight: 700;
  font-family: 'Caveat','Noto Sans JP', sans-serif;
  line-height: 1.35;
  box-shadow:
    0 1px 0 rgba(0,0,0,0.05),
    0 6px 14px -4px rgba(0,0,0,0.18);
}
.bv4-memo-1{
  top: 0; left: 0;
  width: 70px; height: 56px;
  background: linear-gradient(135deg, #FFEFB5 0%, #FFE57F 100%);
  color: #5B4500;
  transform: rotate(-6deg);
}
.bv4-memo-2{
  top: 12px; left: 38px;
  width: 70px; height: 56px;
  background: linear-gradient(135deg, #FFD06B 0%, #F5A623 100%);
  color: #5B3500;
  transform: rotate(8deg);
  z-index: 2;
}
.bv4-memo-3{
  top: 56px; left: 14px;
  width: 70px; height: 50px;
  background: linear-gradient(135deg, #C8E6FF 0%, #8FCFFF 100%);
  color: #14416B;
  transform: rotate(-3deg);
}

/* Email */
.bv4-el-email{ top: 9%; left: 56%; width: 240px; }
.bv4-mock-email{
  width: 100%;
  padding: 12px 14px 14px;
  position: relative;
}
.bv4-mock-email header{
  position: absolute;
  top: -10px; left: 14px;
}
.bv4-mail-icon{
  display: grid; place-items: center;
  width: 26px; height: 26px;
  background: #1F4FB6;
  color: #fff;
  border-radius: 6px;
  font-size: 14px;
}
.bv4-mock-email strong{
  display: block;
  font-size: 11px; color: #0F2447; font-weight: 900;
  padding-bottom: 6px;
  border-bottom: 1px solid #EFF2F6;
  margin: 4px 0 6px;
  margin-left: 28px;
}
.bv4-mock-email p{
  font-size: 10px; line-height: 1.6;
  color: #25334A; margin: 0;
  font-weight: 500;
}

/* Calendar */
.bv4-el-cal{ top: 4%; right: 2%; width: 230px; }
.bv4-mock-cal{
  width: 100%;
  padding: 10px;
}
.bv4-mock-cal header{
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11px; font-weight: 900; color: #0F2447;
  margin-bottom: 6px;
}
.bv4-cal-nav{
  font-size: 12px; color: #95A1B3; font-weight: 700;
  letter-spacing: 0.05em;
}
.bv4-cal-week{
  display: grid; grid-template-columns: repeat(7, 1fr);
  font-size: 8px; font-weight: 800; color: #95A1B3;
  text-align: center;
  padding-bottom: 4px;
  border-bottom: 1px solid #EFF2F6;
  margin-bottom: 4px;
}
.bv4-cal-week span:first-child{ color: #E0444B; }
.bv4-cal-week span:last-child{ color: #1F4FB6; }
.bv4-cal-grid{
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  font-size: 9.5px; font-weight: 700;
  color: #25334A;
  text-align: center;
}
.bv4-cal-grid span{ padding: 3px 0; }
.bv4-cal-mute{ color: #C5CCD6 !important; }
.bv4-cal-sun{ color: #E0444B; }
.bv4-cal-sat{ color: #1F4FB6; }
.bv4-cal-on{
  background: #1F4FB6; color: #fff !important;
  border-radius: 50%;
  font-weight: 900;
}
.bv4-cal-mark{
  background: rgba(196,160,82,0.18);
  border-radius: 50%;
}

/* LINE */
.ba-v4-canvas{ padding-bottom: 0; }
.bv4-el-line{ top: 56%; left: 0; width: 230px; align-items: flex-start; }
.bv4-label-left{ margin-left: 8px; }
.bv4-mock-line{
  width: 100%;
  overflow: hidden;
}
.bv4-mock-line header{
  display: flex; align-items: center; gap: 7px;
  padding: 7px 11px;
  background: #06C755;
  color: #fff;
  font-size: 11px; font-weight: 800;
}
.bv4-line-icon{
  display: grid; place-items: center;
  width: 20px; height: 20px;
  background: #fff;
  color: #06C755;
  border-radius: 4px;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-weight: 900;
  font-size: 11px;
}
.bv4-line-body{
  padding: 10px;
  background: #DEEBF6;
  display: flex; flex-direction: column; gap: 6px;
}
.bv4-line-bubble{
  background: #fff;
  padding: 7px 10px;
  border-radius: 8px;
  font-size: 10px; font-weight: 700;
  color: #25334A;
  line-height: 1.4;
  position: relative;
}
.bv4-line-bubble time{
  display: block;
  font-size: 8px; color: #95A1B3;
  margin-top: 3px;
  font-family: 'Inter','Noto Sans JP', sans-serif;
}

/* Person silhouette */
.bv4-el-person{ top: 56%; right: 0; width: 200px; align-items: flex-end; }
.bv4-mock-person{
  display: flex; align-items: center; gap: 12px;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 10px;
  width: 100%;
}
.bv4-thought{
  flex: 1;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 12px;
  padding: 9px 12px;
  font-size: 11px; font-weight: 700;
  color: #25334A;
  line-height: 1.45;
  position: relative;
  box-shadow: 0 6px 14px -4px rgba(15,36,71,0.10);
}
.bv4-thought::after{
  content: '';
  position: absolute;
  top: 50%; right: -8px; transform: translateY(-50%);
  border: 6px solid transparent;
  border-left-color: #fff;
}
.bv4-thought::before{
  content: '';
  position: absolute;
  top: 50%; right: -9px; transform: translateY(-50%);
  border: 7px solid transparent;
  border-left-color: #E5E9EF;
}
.bv4-silh{
  width: 50px; height: 64px;
  flex-shrink: 0;
}

/* Center warning */
.bv4-warning{
  position: absolute;
  top: 65%; left: 50%; transform: translate(-50%, 0);
  display: flex; align-items: center; gap: 14px;
  padding: 18px 24px;
  background: linear-gradient(180deg, #FFFBED 0%, #FFF5D5 100%);
  border: 1px solid rgba(196,160,82,0.45);
  border-radius: 14px;
  box-shadow: 0 16px 36px -10px rgba(196,160,82,0.30);
  z-index: 5;
  max-width: 460px;
}
.bv4-warn-icon{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, #F4A23F, #E5841F);
  color: #fff;
  box-shadow: 0 4px 12px -2px rgba(244,162,63,0.4);
}
.bv4-warn-icon svg{ width: 22px; height: 22px; }
.bv4-warning ul{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.bv4-warning li{
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px; font-weight: 800; color: #5B4500;
  line-height: 1.5;
}
.bv4-warn-chk{
  display: grid; place-items: center;
  width: 14px; height: 14px;
  background: #C4A052;
  color: #fff;
  border-radius: 50%;
  font-size: 9px; font-weight: 900;
  flex-shrink: 0;
}

/* === AFTER section: dashboard wrapper === */
.ba-v4-after .ba-dash{
  margin: 0 auto;
  max-width: 1180px;
  border-radius: 14px;
  border: 2px solid rgba(255,213,104,0.45);
  box-shadow: 0 30px 80px -22px rgba(0,0,0,0.6);
}

/* === Mobile === */
@media (max-width: 980px){
  .ba-v4-block{ padding: 48px 16px; }
  .ba-v4-h2{ font-size: 28px; letter-spacing: 0.14em; }
  .ba-v4-sub{ font-size: 13px; }
  .ba-v4-tags{ gap: 8px; }
  .ba-v4-tags li{ font-size: 11px; padding: 5px 12px; }

  .ba-v4-canvas{ min-height: auto; padding: 0; }
  .bv4-conns{ display: none; }
  .ba-v4-canvas{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-top: 24px;
  }
  .bv4-el{
    position: static;
    width: 100% !important;
    max-width: none;
    align-items: center !important;
  }
  .bv4-el-excel, .bv4-el-paper, .bv4-el-memo, .bv4-el-email,
  .bv4-el-cal, .bv4-el-line, .bv4-el-person{
    grid-column: span 1;
  }
  .bv4-el-cal{ grid-column: 1 / -1; }
  .bv4-mock-paper, .bv4-mock-memo{ margin: 0 auto; }
  .bv4-thought::after, .bv4-thought::before{ display: none; }
  .bv4-warning{
    position: static;
    transform: none;
    margin: 24px auto 0;
    grid-column: 1 / -1;
  }

  .ba-v4-arrow-down{ padding: 14px 0 18px; }

  /* Dashboard inside ba-v4-after needs to stay readable */
  .ba-v4-after .ba-dash{ overflow-x: auto; }
}

/* =================================================
   Before / After v3 — full reference recreation
   ================================================= */
.ba-v3-section{
  padding: clamp(72px, 9vw, 120px) clamp(20px, 4vw, 64px);
  background: #FBF9F2;
}
.ba-v3-shell{ max-width: 1480px; margin: 0 auto; }
.ba-v3-head{ text-align: center; margin-bottom: 56px; }
.ba-v3-eyebrow{
  display: inline-block;
  padding: 5px 18px;
  border-top: 1px solid #C4A052;
  border-bottom: 1px solid #C4A052;
  color: #C4A052;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.22em;
  margin-bottom: 22px;
}
.ba-v3-h2{
  font-size: clamp(28px, 4.4vw, 56px);
  font-weight: 900;
  color: #0F2447;
  line-height: 1.35;
  letter-spacing: -0.005em;
  margin: 0;
  font-family: 'Noto Sans JP','Hiragino Mincho ProN', serif;
}
.ba-v3-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052 0%, #8E703D 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.ba-v3-grid{
  display: grid;
  grid-template-columns: 0.78fr 50px 1.22fr;
  gap: 16px;
  align-items: start;
}
@media(max-width: 1080px){
  .ba-v3-grid{ grid-template-columns: 1fr; gap: 24px; }
}
.ba-v3-card{
  padding: 30px 30px 26px;
  border-radius: 20px;
  position: relative;
}
.ba-v3-before{
  background: #fff;
  border: 1px solid rgba(15,36,71,0.08);
  box-shadow: 0 24px 60px -28px rgba(15,36,71,0.20);
}
.ba-v3-after{
  background: linear-gradient(180deg, #0F2447 0%, #0B1B33 100%);
  color: #fff;
  border: 2px solid rgba(255,213,104,0.45);
  box-shadow: 0 30px 80px -22px rgba(15,36,71,0.5);
}
.ba-v3-card-head{ display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.ba-v3-state{
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 10.5px; font-weight: 900;
  letter-spacing: 0.20em;
  padding: 6px 12px;
  border-radius: 6px;
  background: #EFF2F6;
  color: #5A6A82;
}
.ba-v3-state-after{
  background: linear-gradient(135deg, #FFD568 0%, #C4A052 100%);
  color: #0F2447;
  box-shadow: 0 4px 12px -2px rgba(196,160,82,0.4);
}
.ba-v3-card h3{
  font-size: 20px; font-weight: 900;
  margin: 0;
  letter-spacing: -0.005em;
}
.ba-v3-after h3{ color: #fff; }
.ba-v3-h{
  font-size: 16px; font-weight: 900;
  color: #0F2447;
  margin: 0 0 6px;
  letter-spacing: -0.005em;
  line-height: 1.55;
}
.ba-v3-h-after{ color: #fff; }
.ba-v3-sub{
  font-size: 12.5px; font-weight: 600;
  color: #5A6A82;
  margin: 0 0 22px;
  line-height: 1.7;
}
.ba-v3-sub-after{ color: rgba(255,255,255,0.65); }
.ba-v3-sub-after em{ color: #FFD568; font-style: normal; font-weight: 800; }

.ba-v3-arrow{ display: grid; place-items: center; color: #C4A052; align-self: center; }
@media(max-width: 1080px){ .ba-v3-arrow{ transform: rotate(90deg); } }

/* ===== BEFORE — scattered real UI elements ===== */
.ba-v3-mess{
  position: relative;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: auto auto auto;
  gap: 12px;
  margin-bottom: 24px;
  min-height: 540px;
}

/* Excel */
.ba-x-excel{
  grid-column: 1 / span 7;
  background: #fff;
  border-radius: 8px;
  border: 1px solid #E5E9EF;
  box-shadow: 0 8px 18px -6px rgba(15,36,71,0.10);
  overflow: hidden;
  transform: rotate(-1deg);
}
.ba-x-excel header{
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: #F4F6FA;
  border-bottom: 1px solid #E5E9EF;
  font-size: 11px; font-weight: 800; color: #25334A;
}
.ba-x-icon{
  display: inline-grid; place-items: center;
  width: 18px; height: 18px;
  border-radius: 4px;
  font-size: 11px;
}
.ba-x-icon-excel{
  background: #1D6F42; color: #fff;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-weight: 900; font-size: 11px;
}
.ba-x-excel table{
  width: 100%; border-collapse: collapse;
  font-size: 10.5px;
}
.ba-x-excel th, .ba-x-excel td{
  padding: 7px 10px;
  border-bottom: 1px solid #EFF2F6;
  border-right: 1px solid #EFF2F6;
  text-align: left;
  white-space: nowrap;
}
.ba-x-excel th{
  background: #FBFCFD;
  font-size: 9.5px; font-weight: 800; color: #5A6A82;
}
.ba-x-excel td{
  font-weight: 700; color: #25334A;
}
.bx-tag{
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 9.5px; font-weight: 800;
}
.bx-tag-blue{ background: #E5EDF8; color: #1F4FB6; }
.bx-tag-amber{ background: #FCF6E0; color: #7E5B19; }

/* LINE */
.ba-x-line{
  grid-column: 8 / span 5;
  background: #fff;
  border-radius: 12px;
  border: 1px solid #E5E9EF;
  box-shadow: 0 8px 18px -6px rgba(15,36,71,0.10);
  overflow: hidden;
  transform: rotate(1deg);
}
.ba-x-line header{
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: #06C755;
  color: #fff;
  font-size: 11px; font-weight: 800;
}
.ba-x-icon-line{
  background: #fff; color: #06C755; font-size: 11px;
}
.ba-x-line-body{
  padding: 12px; background: #8AB7DE;
  display: flex; flex-direction: column; gap: 8px;
}
.bx-bubble{
  max-width: 80%;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 10px; font-weight: 700;
  position: relative;
  line-height: 1.4;
}
.bx-bubble strong{
  display: block; font-size: 9px; color: #5A6A82; font-weight: 800; margin-bottom: 2px;
}
.bx-bubble p{ margin: 0; color: #25334A; font-weight: 700; }
.bx-bubble time{
  display: block;
  font-size: 8px; color: #95A1B3;
  margin-top: 3px;
  font-family: 'Inter','Noto Sans JP', sans-serif;
}
.bx-bubble-them{ background: #fff; align-self: flex-start; }
.bx-bubble-me{
  background: #06C755; color: #fff;
  align-self: flex-end;
}
.bx-bubble-me p, .bx-bubble-me time{ color: rgba(255,255,255,0.95); }

/* 御見積書 */
.ba-x-quote{
  grid-column: 1 / span 4;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 6px;
  padding: 14px 16px;
  box-shadow: 0 8px 18px -6px rgba(15,36,71,0.10);
  transform: rotate(-2deg);
}
.ba-x-quote h5{
  font-size: 14px; font-weight: 900; color: #0F2447;
  text-align: center;
  margin: 0 0 10px;
  padding-bottom: 8px;
  border-bottom: 2px solid #0F2447;
  letter-spacing: 0.05em;
}
.ba-x-quote p{
  font-size: 9.5px; color: #25334A; font-weight: 700;
  margin: 4px 0;
  line-height: 1.5;
}
.bx-q-amount{
  text-align: center;
  margin: 10px 0 !important;
  font-size: 10px !important;
}
.bx-q-amount strong{
  display: inline-block;
  font-size: 13px; font-weight: 900; color: #0F2447;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  margin-left: 4px;
}
.ba-x-quote dl{
  display: grid; grid-template-columns: auto 1fr; gap: 4px 8px;
  margin: 8px 0 0;
  font-size: 9px;
  border-top: 1px dashed #E5E9EF;
  padding-top: 8px;
}
.ba-x-quote dt{ color: #95A1B3; font-weight: 700; }
.ba-x-quote dd{ margin: 0; color: #25334A; font-weight: 700; }

/* メモ（付箋） */
.ba-x-memo{
  grid-column: 5 / span 4;
  background: linear-gradient(135deg, #FFF2A8 0%, #FFE57F 100%);
  padding: 14px 16px;
  border-radius: 4px;
  box-shadow:
    0 1px 0 rgba(0,0,0,0.05),
    0 8px 18px -4px rgba(0,0,0,0.15);
  transform: rotate(2deg);
  position: relative;
}
.ba-x-memo::before{
  content: '';
  position: absolute;
  top: -6px; left: 50%; transform: translateX(-50%) rotate(-2deg);
  width: 60px; height: 14px;
  background: rgba(255,255,255,0.6);
  border: 1px dashed rgba(196,160,82,0.4);
}
.ba-x-memo h5{
  font-size: 12px; font-weight: 900; color: #5B4500;
  margin: 0 0 6px;
}
.ba-x-memo ul{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 3px;
}
.ba-x-memo li{
  font-size: 10.5px; font-weight: 700; color: #5B4500;
  padding-left: 12px;
  position: relative;
  font-family: 'Caveat','Noto Sans JP', sans-serif;
  line-height: 1.4;
}
.ba-x-memo li::before{
  content: '・';
  position: absolute; left: 0;
}

/* 電話 */
.ba-x-phone{
  grid-column: 9 / span 4;
  background: #fff;
  border-radius: 8px;
  border: 1px solid #E5E9EF;
  padding: 12px 14px;
  box-shadow: 0 8px 18px -6px rgba(15,36,71,0.10);
  transform: rotate(-1deg);
}
.ba-x-phone header{
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 900; color: #0F2447;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}
.bx-phone-note{
  margin: 4px 0 0;
  font-size: 10px; font-weight: 800; color: #E0444B;
}

/* ブラウザタスク */
.ba-x-task{
  grid-column: 7 / span 6;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 8px 18px -6px rgba(15,36,71,0.10);
  transform: rotate(0.5deg);
}
.ba-x-task header{
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px;
  background: #F4F6FA;
  border-bottom: 1px solid #E5E9EF;
  font-size: 10px; font-weight: 800; color: #5A6A82;
}
.bx-traffic{ display: inline-flex; gap: 3px; }
.bx-traffic i{
  display: block; width: 8px; height: 8px; border-radius: 50%;
}
.bx-traffic i:nth-child(1){ background: #FF5F57; }
.bx-traffic i:nth-child(2){ background: #FEBC2E; }
.bx-traffic i:nth-child(3){ background: #28C840; }
.ba-x-task ul{ list-style: none; padding: 8px 12px; margin: 0; }
.ba-x-task li{
  display: flex; align-items: center; gap: 8px;
  padding: 4px 0;
  font-size: 11px; font-weight: 700; color: #25334A;
}
.bx-chk{
  display: grid; place-items: center;
  width: 14px; height: 14px;
  border: 1.5px solid #C5CCD6;
  border-radius: 3px;
  font-size: 10px;
  flex-shrink: 0;
}
.bx-chk-on{
  background: #1F4FB6;
  border-color: #1F4FB6;
  color: #fff;
}

.ba-v3-warns{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center;
}
.ba-v3-warns li{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px;
  background: #FCEEEE;
  color: #B0383F;
  border-radius: 8px;
  font-size: 13px; font-weight: 800;
}

/* ===== AFTER — Full Dashboard Mock ===== */
.ba-dash{
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 20px 40px -16px rgba(0,0,0,0.5);
  margin-bottom: 22px;
  font-size: 10px;
}
.ba-dash-top{
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 14px;
  background: #fff;
  border-bottom: 1px solid #EFF2F6;
}
.ba-dash-brand{
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 800; color: #0F2447;
}
.ba-dash-mark{
  display: grid; place-items: center;
  width: 22px; height: 22px;
  border-radius: 5px;
  background: linear-gradient(135deg, #1F4FB6, #2E63D6);
  color: #fff;
  font-size: 10px; font-weight: 900;
  font-family: 'Inter','Noto Sans JP', sans-serif;
}
.ba-dash-co{
  font-size: 9.5px; font-weight: 700; color: #C4A052;
  padding: 2px 7px;
  border: 1px solid rgba(196,160,82,0.35);
  border-radius: 999px;
  margin-left: 6px;
}
.ba-dash-top-right{
  display: flex; align-items: center; gap: 10px;
  font-size: 9px; color: #25334A;
}
.ba-dash-date{
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px;
  border: 1px solid #E5E9EF;
  border-radius: 999px;
  font-weight: 800; color: #25334A;
  font-family: 'Inter','Noto Sans JP', sans-serif;
}
.ba-dash-date::before{ content: '📅'; }
.ba-dash-bell{
  position: relative;
  display: inline-grid; place-items: center;
  width: 22px; height: 22px;
  border: 1px solid #E5E9EF;
  border-radius: 50%;
}
.ba-dash-bell i{
  position: absolute; top: -3px; right: -3px;
  min-width: 14px; height: 14px; padding: 0 3px;
  border-radius: 999px; background: #E0444B; color: #fff;
  font-size: 8px; font-weight: 900; font-style: normal;
  display: grid; place-items: center;
  font-family: 'Inter';
}
.ba-dash-user{
  display: flex; align-items: center; gap: 6px;
  font-size: 8px; font-weight: 700; color: #5A6A82;
  text-align: right;
}
.ba-dash-user i{
  display: grid; place-items: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1F4FB6, #2E63D6);
  color: #fff; font-size: 10px; font-weight: 900; font-style: normal;
  flex-shrink: 0;
}
.ba-dash-user strong{ font-size: 9.5px; color: #0F2447; font-weight: 900; }

.ba-dash-body{
  display: grid;
  grid-template-columns: 132px 1fr;
}
.ba-dash-side{
  background: #FAFBFD;
  border-right: 1px solid #EFF2F6;
  padding: 8px 6px;
}
.ba-dash-mi{
  padding: 5px 8px;
  font-size: 9px; font-weight: 700; color: #5A6A82;
  border-radius: 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  letter-spacing: 0.005em;
}
.ba-dash-mi.is-on{
  background: #fff;
  color: #0F2447; font-weight: 900;
  box-shadow: 0 2px 6px -1px rgba(15,36,71,0.06);
  position: relative;
}
.ba-dash-mi.is-on::before{
  content: ''; position: absolute; left: 0; top: 4px; bottom: 4px;
  width: 2px; background: #1F4FB6; border-radius: 2px;
}
.ba-dash-mi-sep{
  height: 1px; background: #E5E9EF;
  margin: 6px 4px;
}
.ba-dash-main{
  padding: 12px;
  background: linear-gradient(180deg, #FAFBFD 0%, #F4F6FA 100%);
  display: flex; flex-direction: column; gap: 10px;
}
.ba-dash-pagehead{
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 8px;
}
.ba-dash-pagehead h5{
  font-size: 13px; font-weight: 900; color: #0F2447; margin: 0;
}
.ba-dash-pagehead p{
  font-size: 9px; color: #5A6A82; margin: 2px 0 0; font-weight: 700;
}
.ba-dash-export{
  flex-shrink: 0;
  padding: 5px 9px;
  background: #fff; border: 1px solid #E5E9EF;
  border-radius: 5px;
  font-size: 9px; font-weight: 800; color: #1F4FB6;
}
.ba-dash-export::before{ content: '⬇ '; }

.ba-dash-kpis{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.ba-dash-kpi{
  position: relative;
  display: flex; align-items: center; gap: 7px;
  padding: 8px 9px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 7px;
}
.ba-dk-icon{
  display: grid; place-items: center;
  width: 24px; height: 24px;
  border-radius: 6px;
  color: #fff;
  font-size: 11px; font-weight: 900;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  flex-shrink: 0;
}
.ba-dash-kpi[data-c="blue"]   .ba-dk-icon{ background: linear-gradient(135deg,#1F4FB6,#2E63D6); }
.ba-dash-kpi[data-c="green"]  .ba-dk-icon{ background: linear-gradient(135deg,#18B77A,#2BC68A); }
.ba-dash-kpi[data-c="purple"] .ba-dk-icon{ background: linear-gradient(135deg,#7E5BA6,#9B7BC4); }
.ba-dash-kpi[data-c="orange"] .ba-dk-icon{ background: linear-gradient(135deg,#F4A23F,#FFB659); }
.ba-dash-kpi[data-c="red"]    .ba-dk-icon{ background: linear-gradient(135deg,#E0444B,#EF6168); }
.ba-dk-l{ display: block; font-size: 8px; font-weight: 700; color: #95A1B3; }
.ba-dk-v{
  display: block; font-size: 11px; font-weight: 900; color: #0F2447;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  letter-spacing: -0.01em; line-height: 1.1; margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ba-dk-d{ display: block; font-size: 8px; font-weight: 800; color: #18B77A; margin-top: 1px; }
.ba-dk-d em{ font-style: normal; font-family: 'Inter'; }
.ba-dk-d-warn{ color: #E0444B; }
.ba-dk-badge{
  position: absolute; top: -4px; right: -4px;
  min-width: 16px; height: 16px; padding: 0 4px;
  border-radius: 999px; background: #E0444B;
  color: #fff; font-size: 8.5px; font-weight: 900;
  display: grid; place-items: center;
  font-family: 'Inter';
}

.ba-dash-row{
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 6px;
}
.ba-dash-card{
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 7px;
  padding: 9px 10px;
  font-size: 9px;
}
.ba-dash-card > header{
  display: flex; justify-content: space-between; align-items: flex-start;
  font-size: 9.5px; font-weight: 900; color: #0F2447;
  margin-bottom: 7px;
  padding-bottom: 6px;
  border-bottom: 1px dashed #EFF2F6;
}
.ba-dash-meta{
  font-size: 8px; font-weight: 700; color: #5A6A82;
  text-align: right; line-height: 1.3;
}
.ba-dash-meta em{ font-style: normal; font-weight: 900; }
.ba-dash-bars{ width: 100%; height: 110px; }

.ba-dash-rank{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.ba-dash-rank li{
  display: flex; align-items: center; gap: 7px;
  padding: 3px 0;
  font-size: 9px;
  border-bottom: 1px dashed #EFF2F6;
}
.ba-dash-rank li:last-child{ border-bottom: none; }
.ba-dash-rank i{
  display: grid; place-items: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #EFF2F6;
  color: #5A6A82;
  font-size: 9px; font-weight: 900;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-style: normal;
  flex-shrink: 0;
}
.bd-rk-1{ background: linear-gradient(135deg,#FFD568,#E5A100) !important; color: #5B4500 !important; }
.bd-rk-2{ background: linear-gradient(135deg,#E2E8EE,#A6B2BF) !important; color: #3D4A5C !important; }
.bd-rk-3{ background: linear-gradient(135deg,#E8B186,#B07A4E) !important; color: #4A2D14 !important; }
.ba-dash-rank span{ flex: 1; font-weight: 800; color: #0F2447; }
.ba-dash-rank b{
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 9px; font-weight: 900; color: #0F2447;
}
.ba-dash-more, .ba-dash-more-r{
  display: block;
  margin-top: 6px;
  font-size: 8px; font-weight: 800; color: #1F4FB6;
  text-align: right;
  cursor: pointer;
}
.ba-dash-more-r{ display: inline-block; text-align: right; }

.bd-donut-row{ display: flex; gap: 8px; align-items: center; }
.bd-donut{ width: 70px; height: 70px; flex-shrink: 0; }
.bd-donut-leg{
  list-style: none; padding: 0; margin: 0; flex: 1;
  display: flex; flex-direction: column; gap: 3px;
}
.bd-donut-leg li{
  display: flex !important; align-items: center; gap: 5px;
  font-size: 8.5px; font-weight: 700; color: #25334A;
}
.bd-donut-leg em{
  margin-left: auto;
  font-style: normal; font-weight: 900; color: #0F2447;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 8px;
}
.bd-donut-leg i{
  width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0;
  display: inline-block;
}

.bd-tbl{
  width: 100%; border-collapse: collapse;
  font-size: 8.5px;
}
.bd-tbl th, .bd-tbl td{
  padding: 4px 5px;
  text-align: left;
  border-bottom: 1px dashed #EFF2F6;
  font-weight: 700;
}
.bd-tbl thead th{
  font-size: 7.5px; color: #95A1B3; font-weight: 800;
  border-bottom: 1px solid #E5E9EF;
}
.bd-tbl tbody td:first-child{
  display: flex; align-items: center; gap: 5px;
  font-weight: 800; color: #0F2447;
}
.bd-tbl small{ font-size: 7px; color: #95A1B3; font-weight: 700; margin-left: 2px; }
.bd-av{
  display: grid; place-items: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  font-size: 8.5px; font-weight: 900;
  font-style: normal;
  flex-shrink: 0;
}
.bd-pct{
  display: inline-block;
  padding: 1px 6px;
  border-radius: 4px;
  background: #EFF2F6; color: #5A6A82;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-weight: 900;
}
.bd-pct-hi{ background: #E5F2EC; color: #18B77A; }
.bd-pct-lo{ background: #FCEEEE; color: #E0444B; }

.bd-tag{
  display: inline-block;
  padding: 1px 6px; border-radius: 4px;
  font-size: 8px; font-weight: 800;
}
.bd-tag-red{ background: #FCE2E2; color: #B0383F; }
.bd-tag-amber{ background: #FCF6E0; color: #7E5B19; }
.bd-tag-gray{ background: #EFF2F6; color: #5A6A82; }

.bd-alerts{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.bd-al{
  display: flex; align-items: center; gap: 7px;
  padding: 6px 8px;
  border-radius: 5px;
  border-left: 2px solid #E5E9EF;
  background: #FAFBFD;
}
.bd-al-red{ background: #FCEEEE; border-left-color: #E0444B; }
.bd-al-amber{ background: #FCF6E0; border-left-color: #F4A23F; }
.bd-al-gray{ background: #EFF2F6; border-left-color: #A6B2BF; }
.bd-al > span{
  display: grid; place-items: center;
  width: 18px; height: 18px;
  border-radius: 50%; background: #fff;
  font-size: 10px; font-weight: 900;
  flex-shrink: 0;
}
.bd-al-red > span{ color: #E0444B; }
.bd-al-amber > span{ color: #B47A1A; }
.bd-al-gray > span{ color: #7B8693; }
.bd-al > div{ flex: 1; min-width: 0; }
.bd-al strong{ display: block; font-size: 9px; font-weight: 900; color: #0F2447; }
.bd-al small{ display: block; font-size: 7.5px; font-weight: 700; color: #5A6A82; margin-top: 1px; }

.bd-cal{
  display: grid; grid-template-columns: repeat(17, 1fr);
  gap: 3px;
}
.bd-day{
  display: flex; flex-direction: column; align-items: center;
  padding: 5px 3px;
  background: #FAFBFD;
  border: 1px solid #EFF2F6;
  border-radius: 4px;
  min-height: 56px;
}
.bd-day b{
  font-size: 8.5px; font-weight: 900; color: #0F2447;
  font-family: 'Inter','Noto Sans JP', sans-serif; line-height: 1;
}
.bd-day small{ font-size: 7px; font-weight: 700; color: #5A6A82; margin-top: 1px; }
.bd-today{
  background: linear-gradient(180deg, #FFF7E0, #FFFCF0);
  border-color: #C4A052;
  box-shadow: 0 0 0 2px rgba(196,160,82,0.15);
}
.bd-ev{
  display: inline-block;
  margin-top: 4px;
  padding: 2px 4px;
  border-radius: 3px;
  font-size: 7px; font-weight: 900; color: #fff;
  text-align: center;
  width: 100%;
  line-height: 1.25;
}
.bd-ev em{ font-style: normal; font-weight: 700; opacity: 0.85; font-size: 6px; display: block; }
.bd-ev-purple{ background: linear-gradient(135deg, #7E5BA6, #9B7BC4); }
.bd-ev-blue{ background: linear-gradient(135deg, #1F4FB6, #2E63D6); }
.bd-ev-orange{ background: linear-gradient(135deg, #F4A23F, #FFB659); }

.ba-v3-checks{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 8px;
}
.ba-v3-checks li{
  display: inline-flex; align-items: center;
  padding: 8px 16px;
  background: rgba(46,217,140,0.16);
  border: 1px solid rgba(46,217,140,0.32);
  color: #2ED98C;
  border-radius: 999px;
  font-size: 12px; font-weight: 800;
}

/* === Mobile === */
@media (max-width: 1080px){
  .ba-v3-section{ padding: 56px 16px; }
  .ba-v3-card{ padding: 22px 18px 18px; border-radius: 14px; }
  .ba-v3-h2{ font-size: 24px; }
  .ba-v3-h{ font-size: 14px; }
  .ba-v3-sub{ font-size: 12px; }
  .ba-v3-mess{
    grid-template-columns: 1fr; min-height: auto; gap: 14px;
  }
  .ba-x-excel, .ba-x-line, .ba-x-quote, .ba-x-memo, .ba-x-phone, .ba-x-task{
    grid-column: 1 / -1; transform: none;
  }
  .ba-x-excel table{ font-size: 9.5px; }
  .ba-x-excel th, .ba-x-excel td{ padding: 5px 7px; }
  .ba-v3-warns li{ font-size: 11px; padding: 7px 12px; }
  .ba-dash{ overflow-x: auto; }
  .ba-dash-body{ grid-template-columns: 100px 1fr; }
  .ba-dash-mi{ font-size: 8px; }
  .ba-dash-kpis{ grid-template-columns: repeat(2, 1fr); }
  .ba-dash-row{ grid-template-columns: 1fr; }
  .bd-cal{ grid-template-columns: repeat(7, 1fr); }
  .ba-v3-checks li{ font-size: 11px; padding: 6px 12px; }
}

/* === Before / After v2 === */
.ba-v2-section{
  padding: clamp(72px, 9vw, 110px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #FAFBFD 0%, #F4F6FA 100%);
}
.ba-shell{ max-width: 1280px; margin: 0 auto; }
.ba-head{ text-align: center; margin-bottom: 48px; }
.ba-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(196,160,82,0.12);
  color: #C4A052;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}
.ba-h2{
  font-size: clamp(26px, 3.6vw, 42px);
  font-weight: 900;
  color: #0F2447;
  line-height: 1.35;
  letter-spacing: -0.01em;
  margin: 0;
}
.ba-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052 0%, #8E703D 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.ba-grid{
  display: grid;
  grid-template-columns: 1fr 50px 1.25fr;
  gap: 14px;
  align-items: stretch;
}
@media(max-width: 980px){
  .ba-grid{ grid-template-columns: 1fr; }
}
.ba-card{
  padding: 28px 26px 24px;
  border-radius: 18px;
  display: flex; flex-direction: column;
  position: relative;
}
.ba-card-head{
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 14px;
}
.ba-state{
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 10px; font-weight: 900;
  letter-spacing: 0.18em;
  padding: 5px 11px;
  border-radius: 6px;
  background: #EFF2F6;
  color: #5A6A82;
}
.ba-state-after{
  background: linear-gradient(135deg, #FFD568 0%, #C4A052 100%);
  color: #0F2447;
  box-shadow: 0 4px 12px -2px rgba(196,160,82,0.40);
}
.ba-card h3{
  font-size: 16px; font-weight: 900;
  color: inherit;
  margin: 0;
  letter-spacing: -0.005em;
}
.ba-line-h{
  font-size: 19px; font-weight: 900;
  color: #0F2447;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
  line-height: 1.4;
}
.ba-line-h-after{ color: #fff; }
.ba-line-sub{
  font-size: 12.5px; font-weight: 600;
  color: #5A6A82;
  margin: 0 0 18px;
  line-height: 1.6;
}
.ba-line-sub-after{ color: rgba(255,255,255,0.7); }
.ba-line-sub-after em{
  font-style: normal;
  color: #FFD568;
  font-weight: 800;
}

.ba-arrow{
  display: grid; place-items: center;
  color: #C4A052;
}
@media(max-width: 980px){
  .ba-arrow{ transform: rotate(90deg); padding: 6px 0; }
}

/* ===== BEFORE v2 ===== */
.ba-before-v2{
  background: #FAFBFD;
  border: 1px solid #E5E9EF;
  overflow: hidden;
}

.ba-scatter{
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 3.2;
  margin: 8px 0 18px;
  background:
    radial-gradient(circle at center, rgba(15,36,71,0.03), transparent 70%);
  border-radius: 12px;
  min-height: 220px;
}
.ba-connectors{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}
.ba-source{
  position: absolute;
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 12px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 10px;
  box-shadow: 0 6px 14px -4px rgba(15,36,71,0.10);
  font-size: 12px; font-weight: 800;
  color: #0F2447;
  z-index: 2;
  transition: transform 240ms;
}
.ba-source:hover{ transform: translateY(-2px); }
.ba-source-tl{ top: 8%; left: 4%; }
.ba-source-tr{ top: 6%; right: 4%; }
.ba-source-bl{ bottom: 12%; left: 2%; }
.ba-source-br{ bottom: 8%; right: 4%; }
.ba-source-icon{
  display: grid; place-items: center;
  width: 22px; height: 22px;
  border-radius: 5px;
  font-size: 12px; font-weight: 900;
  flex-shrink: 0;
}
.ba-icon-excel{ background: #1D6F42; color: #fff; font-family: 'Inter'; }
.ba-icon-line{ background: #06C755; }
.ba-icon-paper{ background: #F4F6FA; }
.ba-icon-memory{ background: #FBF8F0; }

.ba-docs{
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  z-index: 1;
}
.ba-doc{
  position: relative;
  width: 56px; height: 70px;
  background: #fff;
  border-radius: 4px;
  box-shadow: 0 4px 12px -2px rgba(15,36,71,0.12);
}
.ba-doc svg{ width: 100%; height: 100%; display: block; }
.ba-doc-1{ transform: rotate(-8deg); margin-right: -16px; z-index: 1; }
.ba-doc-2{ transform: rotate(2deg); z-index: 3; }
.ba-doc-3{ transform: rotate(10deg); margin-left: -16px; z-index: 2; }
.ba-doc-alert{
  position: absolute;
  top: -8px; right: -6px;
  width: 22px; height: 22px;
  background: #E0444B;
  color: #fff;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 13px; font-weight: 900;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  box-shadow: 0 4px 10px -2px rgba(224,68,75,0.45);
  border: 2px solid #FAFBFD;
}

.ba-warnings{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 8px;
  justify-content: center;
}
.ba-warnings li{
  display: inline-flex; align-items: center; gap: 5px;
  padding: 8px 14px;
  background: #FCEEEE;
  color: #B0383F;
  border: 1px solid rgba(224,68,75,0.18);
  border-radius: 8px;
  font-size: 12.5px; font-weight: 800;
  letter-spacing: 0.005em;
}
.ba-warn-x{ color: #B0383F; }
.ba-warn-loop{ color: #B0383F; }
.ba-warn-tri{ color: #B47A1A; background: #FCF6E0; border-color: rgba(244,162,63,0.25); }

/* ===== AFTER v2 ===== */
.ba-after-v2{
  background: linear-gradient(180deg, #0F2447 0%, #0B1B33 100%);
  color: #fff;
  border: 2px solid rgba(255,213,104,0.35);
  box-shadow: 0 28px 60px -22px rgba(15,36,71,0.4);
  overflow: hidden;
}

.ba-mock{
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 0;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  margin: 8px 0 18px;
  box-shadow: 0 16px 32px -12px rgba(0,0,0,0.4);
}
.ba-mock-side{
  background: #0F2447;
  padding: 12px 8px;
  display: flex; flex-direction: column; gap: 2px;
}
.ba-mock-menu{
  padding: 6px 8px;
  font-size: 9.5px; font-weight: 800;
  color: rgba(255,255,255,0.55);
  border-radius: 5px;
  letter-spacing: 0.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ba-mock-menu.is-on{
  background: rgba(255,255,255,0.10);
  color: #fff;
}
.ba-mock-main{
  padding: 12px;
  background: linear-gradient(180deg, #FAFBFD 0%, #F4F6FA 100%);
  display: flex; flex-direction: column; gap: 8px;
}
.ba-mock-kpis{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.ba-mock-kpi{
  padding: 8px 9px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 7px;
  display: flex; flex-direction: column; gap: 1px;
}
.ba-mk-l{ font-size: 8.5px; font-weight: 700; color: #5A6A82; }
.ba-mk-v{
  font-size: 11.5px; font-weight: 900;
  color: #0F2447;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.ba-mk-v small{ font-size: 8.5px; font-weight: 700; color: #5A6A82; margin-left: 1px; }
.ba-mk-spark{ width: 100%; height: 14px; margin-top: 2px; }

.ba-mock-row{
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 6px;
}
.ba-mock-card{
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 7px;
  padding: 9px 10px;
}
.ba-mock-card header{
  display: flex; justify-content: space-between; align-items: center;
  font-size: 9.5px; font-weight: 900; color: #0F2447;
  margin-bottom: 7px;
  padding-bottom: 5px;
  border-bottom: 1px dashed #EFF2F6;
}
.ba-mock-card header a{
  font-size: 8px; font-weight: 700; color: #1F4FB6;
  text-decoration: none;
}
.ba-mock-card ul{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.ba-mock-card li{
  font-size: 9px; color: #25334A; font-weight: 700;
  display: flex; justify-content: space-between; align-items: center;
  line-height: 1.3;
}
.ba-mc-bell{ font-size: 10px; }

.ba-donut-wrap{
  display: flex; gap: 8px; align-items: center;
}
.ba-donut-svg{ width: 56px; height: 56px; flex-shrink: 0; }
.ba-donut-legend{
  flex: 1;
}
.ba-donut-legend li{
  font-size: 8.5px; color: #25334A; font-weight: 700;
  display: flex !important; align-items: center; gap: 5px;
}
.ba-donut-legend i{
  width: 6px; height: 6px; border-radius: 1.5px; display: inline-block;
  flex-shrink: 0;
}

.ba-mock-tasks{
  width: 100%; border-collapse: collapse;
  font-size: 9px;
}
.ba-mock-tasks thead th{
  text-align: left;
  font-size: 8px; font-weight: 700; color: #95A1B3;
  padding: 4px 6px;
  border-bottom: 1px solid #EFF2F6;
}
.ba-mock-tasks tbody td{
  padding: 5px 6px;
  font-weight: 700;
  color: #25334A;
  border-bottom: 1px dashed #EFF2F6;
}
.ba-mock-tasks tbody tr:last-child td{ border-bottom: none; }
.ba-mock-tasks td:first-child{ color: #95A1B3; width: 14px; }
.ba-mock-tasks td:nth-child(2){ font-weight: 800; color: #0F2447; }

.ba-checks{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.ba-checks li{
  display: inline-flex; align-items: center;
  padding: 6px 11px;
  background: rgba(46,217,140,0.16);
  border: 1px solid rgba(46,217,140,0.32);
  color: #2ED98C;
  border-radius: 999px;
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.005em;
}

/* ===== Mobile ===== */
@media (max-width: 760px){
  .ba-v2-section{ padding: 56px 16px; }
  .ba-h2{ font-size: 22px; }
  .ba-card{ padding: 22px 18px 18px; border-radius: 14px; }
  .ba-line-h{ font-size: 16px; }
  .ba-line-sub{ font-size: 12px; margin-bottom: 14px; }

  .ba-scatter{ aspect-ratio: 4 / 3; min-height: 200px; }
  .ba-source{ font-size: 10.5px; padding: 6px 9px; gap: 5px; }
  .ba-source-icon{ width: 18px; height: 18px; font-size: 10px; }
  .ba-doc{ width: 44px; height: 56px; }
  .ba-doc-alert{ width: 18px; height: 18px; font-size: 11px; }
  .ba-warnings li{ font-size: 11px; padding: 6px 10px; }

  .ba-mock-side{ padding: 8px 6px; }
  .ba-mock-menu{ font-size: 8.5px; padding: 5px 6px; }
  .ba-mock{ grid-template-columns: 90px 1fr; }
  .ba-mock-kpis{ grid-template-columns: repeat(2, 1fr); gap: 5px; }
  .ba-mock-row{ grid-template-columns: 1fr; }
  .ba-checks{ gap: 5px; }
  .ba-checks li{ font-size: 10.5px; padding: 5px 9px; }
}

/* === 14-day Trial Flow === */
.trial-flow{
  padding: clamp(72px, 9vw, 110px) clamp(20px, 4vw, 64px);
  background: #fff;
}
.tf-shell{ max-width: 1080px; margin: 0 auto; }
.tf-head{ text-align: center; margin-bottom: 56px; }
.tf-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(46,217,140,0.10);
  color: #18B77A;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}
.tf-h2{
  font-size: clamp(26px, 3.6vw, 42px);
  font-weight: 900;
  color: #0F2447;
  line-height: 1.35;
  letter-spacing: -0.01em;
  margin: 0 0 16px;
}
.tf-h2 em{
  font-style: normal;
  color: #18B77A;
}
.tf-sub{
  font-size: 14.5px; line-height: 1.85;
  color: #25334A;
  font-weight: 600;
  margin: 0;
}
.tf-sub strong{
  color: #0F2447; font-weight: 900;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}
.tf-steps{
  list-style: none; padding: 0; margin: 0 0 40px;
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 14px;
  align-items: stretch;
}
@media(max-width: 980px){
  .tf-steps{ grid-template-columns: 1fr; }
  .tf-step-arrow{ transform: rotate(90deg); justify-self: center; padding: 6px 0; }
}
.tf-step{
  padding: 28px 26px;
  background: linear-gradient(180deg, #FAFBFD 0%, #F4F6FA 100%);
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  position: relative;
  display: flex; flex-direction: column;
  transition: transform 240ms, border-color 240ms, box-shadow 240ms;
}
.tf-step:hover{
  transform: translateY(-3px);
  border-color: rgba(196,160,82,0.45);
  box-shadow: 0 18px 40px -16px rgba(15,36,71,0.18);
}
.tf-step-last{
  background: linear-gradient(180deg, #FBF8F0 0%, #F4ECD3 100%);
  border-color: rgba(196,160,82,0.45);
}
.tf-step-num{
  display: grid; place-items: center;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid #E5E9EF;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 16px; font-weight: 900;
  color: #0F2447;
  letter-spacing: -0.01em;
  margin-bottom: 14px;
  box-shadow: 0 4px 10px -2px rgba(15,36,71,0.06);
}
.tf-step-num-final{
  background: linear-gradient(135deg, #18B77A 0%, #2ED98C 100%);
  color: #fff;
  border-color: rgba(24,183,122,0.40);
  box-shadow: 0 8px 20px -4px rgba(24,183,122,0.35);
}
.tf-step-body h3{
  font-size: 16px; font-weight: 900;
  color: #0F2447;
  margin: 0 0 10px;
  letter-spacing: -0.005em;
}
.tf-step-body p{
  font-size: 12.5px; line-height: 1.85;
  color: #25334A;
  margin: 0;
  font-weight: 600;
}
.tf-step-body strong{
  color: #18B77A;
  font-weight: 900;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}
.tf-step-arrow{
  display: grid; place-items: center;
  color: #C4A052;
}
.tf-cta-row{
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}
.tf-cta{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 14px; font-weight: 900;
  text-decoration: none;
  letter-spacing: 0.005em;
  transition: transform 200ms, box-shadow 200ms;
}
.tf-cta-pri{
  background: linear-gradient(135deg, #18B77A 0%, #2ED98C 100%);
  color: #fff !important;
  box-shadow: 0 12px 28px -8px rgba(24,183,122,0.40);
}
.tf-cta-pri:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 38px -10px rgba(24,183,122,0.50);
}
.tf-cta-sec{
  background: #fff;
  color: #0F2447 !important;
  border: 1px solid #E5E9EF;
}
.tf-cta-sec:hover{
  border-color: #C4A052;
  color: #C4A052 !important;
}

@media(max-width: 760px){
  .ba-section, .trial-flow{ padding: 56px 16px; }
  .ba-h2, .tf-h2{ font-size: 22px; }
  .ba-card{ padding: 22px 20px; }
  .ba-card h3{ font-size: 15px; }
  .ba-line{ font-size: 12.5px; }
  .ba-tags li{ font-size: 10.5px; padding: 4px 8px; }
  .tf-sub{ font-size: 13px; }
  .tf-step{ padding: 22px 20px; }
  .tf-step-num{ width: 40px; height: 40px; font-size: 14px; }
  .tf-step-body h3{ font-size: 14.5px; }
  .tf-step-body p{ font-size: 12px; }
  .tf-cta{ width: 100%; justify-content: center; padding: 13px 20px; font-size: 13px; }
}

/* === Hero philosophy line（業種ごとに見るべき情報は違う） === */
.hero-philosophy{
  margin: -4px 0 22px;
  padding: 12px 16px;
  border-left: 3px solid #FFD568;
  background: rgba(255,213,104,0.06);
  border-radius: 0 6px 6px 0;
}
.hero-philosophy span{
  font-size: 14px; font-weight: 800;
  line-height: 1.7; color: #fff;
  letter-spacing: 0.005em;
}
.hero-philosophy em{
  font-style: normal;
  background: linear-gradient(180deg, #FFD568, #E5A100);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-weight: 900;
}
@media(max-width: 760px){
  .hero-philosophy{ padding: 10px 12px; margin: 0 0 18px; }
  .hero-philosophy span{ font-size: 12.5px; line-height: 1.7; }
  .hero-philo-br{ display: none; }
}

/* === Philosophy section（業種ごとの実務をダッシュボードに） === */
.phil-section{
  padding: clamp(72px, 9vw, 120px) clamp(20px, 4vw, 64px);
  background: #fff;
}
.phil-shell{ max-width: 1240px; margin: 0 auto; }
.phil-head{ text-align: center; max-width: 820px; margin: 0 auto 56px; }
.phil-eyebrow{
  display: inline-block; padding: 5px 14px; border-radius: 999px;
  background: rgba(196,160,82,0.12); color: #C4A052;
  font-size: 11px; font-weight: 900; letter-spacing: 0.12em;
  margin-bottom: 18px;
}
.phil-head h2{
  font-size: clamp(28px, 3.6vw, 44px);
  font-weight: 900; color: #0F2447;
  line-height: 1.3; letter-spacing: -0.01em;
  margin: 0 0 22px;
}
.phil-head h2 em{ font-style: normal; color: #C4A052; }
.phil-lead{
  font-size: 15px; line-height: 2; color: #25334A;
  margin: 0;
}
.phil-lead strong{ color: #0F2447; font-weight: 900; }

.phil-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
  margin-bottom: 32px;
}
@media(max-width: 980px){ .phil-grid{ grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 600px){ .phil-grid{ grid-template-columns: 1fr; } }

.phil-card{
  display: flex; flex-direction: column;
  padding: 28px 26px 22px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  transition: transform 240ms cubic-bezier(.4,0,.2,1),
              box-shadow 240ms,
              border-color 240ms;
  position: relative;
}
.phil-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 50px -16px rgba(15,36,71,0.18);
  border-color: rgba(196,160,82,0.55);
}
.phil-card-re{
  background: linear-gradient(180deg, #fff 0%, #FBF8F0 100%);
  border-color: rgba(196,160,82,0.45);
  box-shadow: 0 14px 32px -16px rgba(196,160,82,0.25);
}
.phil-card-re::before{
  content: 'FIRST  RELEASE';
  position: absolute; top: -10px; right: 16px;
  padding: 4px 10px; border-radius: 999px;
  background: #C4A052; color: #fff;
  font-size: 9.5px; font-weight: 900; letter-spacing: 0.12em;
}

.phil-card-head{
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 18px;
  border-bottom: 1px dashed #EFF2F6;
  margin-bottom: 18px;
}
.phil-card-mark{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 48px; height: 48px;
  background: linear-gradient(135deg, #FEF6E0 0%, #FDF1D0 100%);
  border: 1px solid #F3E6C0;
  border-radius: 12px;
  font-size: 22px;
}
.phil-card h3{
  font-size: 17px; font-weight: 900; color: #0F2447;
  margin: 0 0 3px;
}
.phil-card-genre{
  font-size: 11.5px; font-weight: 800; color: #C4A052;
  margin: 0;
  letter-spacing: 0.02em;
}

.phil-card-body{ flex: 1; }
.phil-card-intro{
  font-size: 13px; line-height: 1.85; color: #25334A;
  margin: 0 0 14px; font-weight: 700;
}
.phil-card-tags{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 5px;
}
.phil-card-tags li{
  padding: 4px 9px;
  background: #F4F6FA;
  border-radius: 4px;
  font-size: 11px; font-weight: 700; color: #25334A;
  letter-spacing: 0.02em;
}
.phil-card-re .phil-card-tags li{
  background: rgba(196,160,82,0.10);
  color: #6B5025;
  border: 1px solid rgba(196,160,82,0.20);
}

.phil-card-link{
  display: block;
  margin-top: 18px; padding-top: 14px;
  border-top: 1px dashed #EFF2F6;
  text-align: right;
  font-size: 12px; font-weight: 900; color: #C4A052;
  text-decoration: none;
}
.phil-card-soon{
  color: #95A1B3 !important;
  text-align: right;
  font-weight: 800;
}
.phil-foot{
  text-align: center;
  font-size: 13.5px; color: #5A6A82;
}
.phil-foot a{
  color: #C4A052; font-weight: 900; text-decoration: none;
  border-bottom: 1px solid currentColor;
}

@media(max-width: 760px){
  .phil-section{ padding: 56px 16px; }
  .phil-head{ margin-bottom: 32px; }
  .phil-head h2{ font-size: 24px; }
  .phil-lead{ font-size: 13.5px; line-height: 1.85; }
  .phil-card{ padding: 22px 20px 18px; }
  .phil-card h3{ font-size: 16px; }
  .phil-card-intro{ font-size: 12.5px; }
  .phil-card-tags li{ font-size: 10.5px; padding: 3px 7px; }
}

/* === Custom Band（カスタマイズは標準） === */
.custom-band{
  padding: clamp(56px, 7vw, 88px) clamp(20px, 4vw, 64px);
  background: linear-gradient(135deg, #0F2447 0%, #1A3563 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.custom-band::before{
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 50%, rgba(255,213,104,0.10), transparent 60%);
  pointer-events: none;
}
.custom-band-inner{
  position: relative;
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 48px;
  align-items: center;
}
@media(max-width: 880px){
  .custom-band-inner{ grid-template-columns: 1fr; gap: 32px; text-align: center; }
}
.custom-band-eyebrow{
  font-size: 11px; font-weight: 900; letter-spacing: 0.15em;
  color: #FFD568;
  margin: 0 0 14px;
}
.custom-band-h2{
  font-size: clamp(26px, 3.4vw, 40px);
  font-weight: 900; color: #fff;
  line-height: 1.4; letter-spacing: -0.01em;
  margin: 0;
}
.custom-band-h2 em{
  font-style: normal;
  color: rgba(255,255,255,0.5);
  text-decoration: line-through;
  text-decoration-color: rgba(255,99,99,0.7);
  text-decoration-thickness: 2px;
}
.custom-band-h2 strong{
  background: linear-gradient(180deg, #FFD568 0%, #E5A100 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-weight: 900;
}

.custom-band-compare{
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  gap: 12px;
  align-items: stretch;
}
.cb-col{
  padding: 26px 22px;
  border-radius: 14px;
  display: flex; flex-direction: column; justify-content: center;
}
.cb-col-other{
  background: rgba(255,255,255,0.04);
  border: 1px dashed rgba(255,255,255,0.20);
  color: rgba(255,255,255,0.55);
}
.cb-col-ours{
  background: linear-gradient(180deg, rgba(255,213,104,0.18), rgba(255,213,104,0.06));
  border: 2px solid rgba(255,213,104,0.55);
  color: #fff;
  box-shadow: 0 12px 40px -12px rgba(255,213,104,0.25);
}
.cb-col-tag{
  display: inline-block; align-self: flex-start;
  padding: 3px 10px; border-radius: 999px;
  background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.7);
  font-size: 10px; font-weight: 900; letter-spacing: 0.06em;
  margin-bottom: 14px;
}
.cb-col-ours .cb-col-tag{
  background: #FFD568; color: #0F2447;
}
.cb-col-line{
  font-size: 16px; font-weight: 900;
  line-height: 1.55; margin: 0;
}
.cb-col-other .cb-col-line{ color: rgba(255,255,255,0.55); }
.cb-vs{
  display: grid; place-items: center;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 14px; font-weight: 900; color: #FFD568;
  letter-spacing: 0.06em;
}
.cb-vs span{
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,213,104,0.10);
  border: 1px solid rgba(255,213,104,0.30);
  display: grid; place-items: center;
}
@media(max-width: 600px){
  .custom-band-compare{ grid-template-columns: 1fr; gap: 8px; }
  .cb-vs{ padding: 6px 0; }
  .cb-vs span{ width: 36px; height: 36px; font-size: 12px; }
  .cb-col{ padding: 20px 18px; }
  .cb-col-line{ font-size: 14px; }
}

/* === Industries Hub（業種選択ハブ） === */
.industries-hub{
  padding: clamp(72px, 9vw, 120px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #FAFBFD 0%, #F4F6FA 100%);
}
.industries-shell{ max-width: 1200px; margin: 0 auto; }
.industries-hub .section-heading{ text-align: center; max-width: 760px; margin: 0 auto 18px; }
.industries-hub h2{ font-size: clamp(28px, 3.6vw, 44px); font-weight: 900; color: #0F2447; line-height: 1.3; letter-spacing: -0.01em; }
.industries-hub h2 .ind-em{ font-style: normal; color: #C4A052; }
.industries-lead{
  text-align: center; max-width: 720px; margin: 18px auto 56px;
  font-size: 15px; line-height: 2; color: #25334A;
}
.industries-lead strong{ color: #0F2447; font-weight: 800; }
.industries-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
@media(max-width: 980px){ .industries-grid{ grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 600px){ .industries-grid{ grid-template-columns: 1fr; } }
.ind-card{
  display: block;
  padding: 28px 26px 22px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  text-decoration: none;
  color: #0F2447;
  transition: transform 240ms cubic-bezier(.4,0,.2,1),
              box-shadow 240ms,
              border-color 240ms;
  position: relative; overflow: hidden;
}
.ind-card::before{
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: linear-gradient(180deg, #D6A935 0%, #FFD568 100%);
  opacity: 0; transition: opacity 240ms;
}
.ind-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 50px -16px rgba(15,36,71,0.18);
  border-color: rgba(214,169,53,0.55);
}
.ind-card:hover::before{ opacity: 1; }
.ind-icon{
  display: grid; place-items: center;
  width: 56px; height: 56px;
  background: linear-gradient(135deg, #FEF6E0 0%, #FDF1D0 100%);
  border: 1px solid #F3E6C0;
  border-radius: 14px;
  margin-bottom: 18px;
  font-size: 26px;
}
.ind-card h3{
  font-size: 18px; font-weight: 900; color: #0F2447;
  margin: 0 0 10px;
  letter-spacing: -0.01em;
}
.ind-card h3 em{ font-style: normal; color: #C4A052; }
.ind-card p{
  font-size: 13px; line-height: 1.85; color: #5A6A82;
  margin: 0 0 22px; min-height: 70px;
}
.ind-foot{
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 14px;
  border-top: 1px dashed #E5E9EF;
}
.ind-from{
  font-size: 12px; font-weight: 900; color: #0F2447;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}
.ind-arrow{
  font-size: 12px; font-weight: 800; color: #C4A052;
  letter-spacing: 0.02em;
}
.ind-arrow-soon{
  color: #95A1B3;
  background: #F4F6FA;
  padding: 3px 10px; border-radius: 999px;
}
.industries-foot{
  margin-top: 36px; text-align: center;
  font-size: 13px; color: #5A6A82;
}
.industries-foot a{ color: #C4A052; font-weight: 900; text-decoration: none; border-bottom: 1px solid currentColor; }

/* === Pricing intro（小さく始められる理由） === */
.pricing-intro{
  padding: clamp(72px, 9vw, 110px) clamp(20px, 4vw, 64px) clamp(32px, 4vw, 48px);
  background: linear-gradient(180deg, #fff 0%, #FAFBFD 100%);
  text-align: center;
}
.pi-shell{ max-width: 820px; margin: 0 auto; }
.pi-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(196,160,82,0.10);
  color: #C4A052;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 22px;
}
.pi-h2{
  font-size: clamp(28px, 3.8vw, 46px);
  font-weight: 900;
  color: #0F2447;
  line-height: 1.3;
  letter-spacing: -0.015em;
  margin: 0 0 24px;
}
.pi-h2-em{
  display: inline-block;
  background: linear-gradient(180deg, #C4A052 0%, #8E703D 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.pi-pair{
  display: inline-block;
  margin: 0 auto 24px;
  padding: 10px 22px;
  background: linear-gradient(180deg, #fff 0%, #FBF8F0 100%);
  border-left: 3px solid #C4A052;
  border-right: 3px solid #C4A052;
  font-size: 16px;
  font-weight: 900;
  color: #0F2447;
  letter-spacing: -0.005em;
}
.pi-pair em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052 0%, #8E703D 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
@media(max-width: 760px){
  .pi-pair{ font-size: 13.5px; padding: 8px 16px; }
}
.pi-lead{
  font-size: 15.5px;
  line-height: 2;
  color: #25334A;
  font-weight: 600;
  margin: 0 0 28px;
}
.pi-lead strong{ color: #0F2447; font-weight: 800; }
.pi-conclusion{
  font-size: 17px;
  font-weight: 800;
  color: #0F2447;
  margin: 0;
  letter-spacing: -0.005em;
}
.pi-mark{
  font-style: normal;
  display: inline-block;
  padding: 2px 10px;
  background: linear-gradient(180deg, #FBF8F0, #F4ECD3);
  border: 1px solid rgba(196,160,82,0.45);
  border-radius: 6px;
  color: #6B5025;
  font-weight: 900;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}
.pi-mark-strong{
  background: linear-gradient(180deg, #0F2447 0%, #1A3563 100%);
  border-color: rgba(255,213,104,0.55);
  color: #FFD568;
  box-shadow: 0 4px 14px -4px rgba(15,36,71,0.3);
}
@media(max-width: 760px){
  .pricing-intro{ padding: 56px 16px 24px; }
  .pi-h2{ font-size: 24px; line-height: 1.4; }
  .pi-lead{ font-size: 13.5px; line-height: 1.85; }
  .pi-conclusion{ font-size: 14px; }
  .pi-br, .pi-lead-br{ display: none; }
}

/* =================================================
   Pricing v2 — IT-company grade（Stripe / Linear feel）
   ================================================= */
.pricing-v2{
  position: relative;
  padding: clamp(96px, 11vw, 160px) clamp(20px, 4vw, 64px);
  background: #05101F;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
/* Background grid + glow */
.pv2-bg{
  position: absolute; inset: 0; z-index: 0;
  pointer-events: none;
}
.pv2-grid-overlay{
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  opacity: 0.6;
}
.pv2-glow{
  position: absolute; border-radius: 50%;
  filter: blur(80px);
  opacity: 0.55;
}
.pv2-glow-1{
  top: -10%; left: 10%;
  width: 480px; height: 480px;
  background: radial-gradient(circle, #C4A052 0%, transparent 70%);
}
.pv2-glow-2{
  bottom: -10%; right: 8%;
  width: 520px; height: 520px;
  background: radial-gradient(circle, #1F4FB6 0%, transparent 70%);
  opacity: 0.4;
}

.pv2-shell{
  position: relative; z-index: 1;
  max-width: 1140px; margin: 0 auto;
}

/* Head */
.pv2-head{
  text-align: center;
  max-width: 720px; margin: 0 auto 56px;
}
.pv2-eyebrow{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(255,213,104,0.10);
  border: 1px solid rgba(255,213,104,0.25);
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.18em;
  color: #FFD568;
  margin-bottom: 20px;
}
.pv2-eyebrow::before{
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: #FFD568; box-shadow: 0 0 8px #FFD568;
}
.pv2-h2{
  font-size: clamp(32px, 4.6vw, 56px);
  font-weight: 900;
  line-height: 1.18;
  letter-spacing: -0.02em;
  margin: 0 0 18px;
  color: #fff;
}
.pv2-h2-thin{
  display: inline-block;
  font-weight: 400;
  color: rgba(255,255,255,0.55);
  letter-spacing: -0.01em;
}
.pv2-sub{
  font-size: 15px; font-weight: 600;
  color: rgba(255,255,255,0.65);
  margin: 0;
  letter-spacing: 0.005em;
}

/* === Hero Price Card === */
.pv2-hero{
  position: relative;
  max-width: 720px;
  margin: 0 auto 64px;
}
.pv2-hero-aura{
  position: absolute; inset: -4px;
  background: linear-gradient(135deg,
    rgba(255,213,104,0.6) 0%,
    rgba(196,160,82,0.2) 25%,
    rgba(31,79,182,0.4) 75%,
    rgba(255,213,104,0.5) 100%);
  border-radius: 24px;
  filter: blur(2px);
  opacity: 0.7;
  z-index: 0;
  animation: pv2AuraShift 8s ease-in-out infinite alternate;
}
@keyframes pv2AuraShift{
  0%   { filter: blur(2px) hue-rotate(0deg); transform: scale(1); }
  100% { filter: blur(4px) hue-rotate(15deg); transform: scale(1.01); }
}
@media (prefers-reduced-motion: reduce){
  .pv2-hero-aura{ animation: none; }
}
.pv2-hero-card{
  position: relative;
  background: linear-gradient(180deg, #0A1A30 0%, #07142A 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 22px;
  padding: 36px 40px 32px;
  z-index: 1;
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.6),
    0 0 0 1px rgba(255,255,255,0.04) inset;
}
/* === v3: minimal premium card === */
.pv2-hero-card-v3{
  padding: 44px 48px 38px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
}
.pv2-hero-card-v3 .pv2-plan-tag{ margin-bottom: 36px; }

.pv2-price-block{
  display: flex; flex-direction: column; align-items: center;
  margin-bottom: 32px;
  width: 100%;
}
.pv2-month-label{
  font-size: 13px; font-weight: 800;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}
.pv2-price-line{
  display: inline-flex; align-items: flex-start;
  gap: 6px;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
  line-height: 0.92;
}
.pv2-hero-card-v3 .pv2-yen{
  font-size: clamp(40px, 5.5vw, 60px);
  font-weight: 700;
  color: rgba(255,255,255,0.55);
  margin-top: clamp(18px, 3vw, 32px);
  letter-spacing: -0.02em;
}
.pv2-hero-card-v3 .pv2-num{
  font-size: clamp(96px, 13vw, 168px);
  font-weight: 900;
  letter-spacing: -0.05em;
  background: linear-gradient(180deg, #ffffff 0%, #ddeaff 50%, #94aac8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 6px 40px rgba(255,255,255,0.10);
}
.pv2-from{
  font-size: clamp(40px, 5vw, 56px);
  font-weight: 700;
  color: rgba(255,213,104,0.85);
  margin-top: clamp(28px, 4.5vw, 50px);
  letter-spacing: -0.02em;
}

.pv2-points{
  list-style: none; padding: 0;
  margin: 0 0 32px;
  display: flex; gap: 28px;
  flex-wrap: wrap; justify-content: center;
  width: 100%;
}
.pv2-points li{
  position: relative;
  font-size: 14px; font-weight: 700;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.005em;
  padding-left: 22px;
}
.pv2-points li::before{
  content: '';
  position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 14px; height: 14px;
  border-radius: 50%;
  background:
    linear-gradient(135deg, #FFD568 0%, #C4A052 100%);
  box-shadow: 0 0 0 1px rgba(255,213,104,0.20);
}
.pv2-points li::after{
  content: '';
  position: absolute; left: 4px; top: 50%; transform: translateY(-55%);
  width: 6px; height: 4px;
  border-left: 1.5px solid #0F2447;
  border-bottom: 1.5px solid #0F2447;
  transform: translateY(-65%) rotate(-45deg);
}

.pv2-cta-row{
  display: flex; gap: 12px;
  width: 100%;
  flex-wrap: wrap;
}
.pv2-cta{
  flex: 1; min-width: 200px;
  display: flex; align-items: center; justify-content: center;
  gap: 10px;
  padding: 16px 24px;
  border-radius: 12px;
  font-size: 14px; font-weight: 900;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: transform 220ms cubic-bezier(.4,0,.2,1),
              box-shadow 220ms,
              background 220ms,
              border-color 220ms;
  position: relative;
  overflow: hidden;
}
.pv2-cta-pri{
  background: linear-gradient(180deg, #ffffff 0%, #f0f4fa 100%);
  color: #05101F !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.5) inset,
    0 -2px 0 rgba(0,0,0,0.05) inset,
    0 14px 32px -10px rgba(255,255,255,0.20);
}
.pv2-cta-pri::before{
  content: ''; position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,213,104,0.4), transparent);
  transition: left 600ms;
}
.pv2-cta-pri:hover{
  transform: translateY(-2px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 -2px 0 rgba(0,0,0,0.05) inset,
    0 22px 50px -12px rgba(255,213,104,0.35);
}
.pv2-cta-pri:hover::before{ left: 100%; }
.pv2-cta-pri svg{ flex-shrink: 0; transition: transform 220ms; }
.pv2-cta-pri:hover svg{ transform: translateX(3px); }
.pv2-cta-sec{
  background: rgba(255,255,255,0.05);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.20);
}
.pv2-cta-sec:hover{
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.40);
}
.pv2-hero-top{
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 22px;
}
.pv2-plan-tag{
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px; border-radius: 6px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 10.5px; font-weight: 800;
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.85);
}
.pv2-plan-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: #18B77A;
  box-shadow: 0 0 0 0 rgba(24,183,122,0.5);
  animation: pv2Pulse 2s ease-out infinite;
}
@keyframes pv2Pulse{
  0%   { box-shadow: 0 0 0 0 rgba(24,183,122,0.5); }
  70%  { box-shadow: 0 0 0 8px rgba(24,183,122,0); }
  100% { box-shadow: 0 0 0 0 rgba(24,183,122,0); }
}
.pv2-plan-badge{
  font-size: 10.5px; font-weight: 800;
  color: #FFD568;
  padding: 5px 11px; border-radius: 6px;
  background: rgba(255,213,104,0.10);
  border: 1px solid rgba(255,213,104,0.30);
  letter-spacing: 0.04em;
}

/* === Price Row === */
.pv2-price-row{
  display: flex; align-items: flex-start;
  gap: 6px;
  margin-bottom: 14px;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
}
.pv2-yen{
  font-size: 32px; font-weight: 700;
  color: rgba(255,255,255,0.6);
  margin-top: 16px;
  letter-spacing: -0.02em;
}
.pv2-num{
  font-size: clamp(76px, 10vw, 120px);
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.045em;
  color: #fff;
  background: linear-gradient(180deg, #ffffff 0%, #d8e1ee 60%, #aab7cc 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 4px 30px rgba(255,255,255,0.08);
  font-variant-numeric: tabular-nums;
}
.pv2-price-suffix{
  display: flex; flex-direction: column;
  margin-top: 26px;
  margin-left: 4px;
}
.pv2-per{
  font-size: 14px; font-weight: 700;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.02em;
}
.pv2-tax{
  font-size: 11px; font-weight: 600;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.05em;
  margin-top: 2px;
}
.pv2-tagline{
  font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,0.7);
  margin: 0 0 24px;
  font-weight: 500;
}

/* === Meta strip === */
.pv2-meta{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  padding: 16px 0;
  margin-bottom: 24px;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.pv2-meta-item{
  display: flex; flex-direction: column; align-items: center;
  gap: 4px;
  position: relative;
}
.pv2-meta-item:not(:last-child)::after{
  content: '';
  position: absolute; right: 0; top: 50%; transform: translateY(-50%);
  width: 1px; height: 28px;
  background: rgba(255,255,255,0.08);
}
.pv2-meta-label{
  font-size: 10.5px; font-weight: 700;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.05em;
}
.pv2-meta-value{
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 17px; font-weight: 900;
  color: #fff;
  letter-spacing: -0.01em;
}

/* === CTA === */
.pv2-cta{
  display: flex; align-items: center; justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 24px;
  background: linear-gradient(180deg, #ffffff 0%, #f0f4fa 100%);
  color: #05101F !important;
  border-radius: 12px;
  font-size: 15px; font-weight: 900;
  letter-spacing: 0.005em;
  text-decoration: none;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.5) inset,
    0 -2px 0 rgba(0,0,0,0.05) inset,
    0 14px 32px -10px rgba(255,255,255,0.20);
  transition: transform 220ms cubic-bezier(.4,0,.2,1),
              box-shadow 220ms,
              background 220ms;
  position: relative;
  overflow: hidden;
}
.pv2-cta::before{
  content: ''; position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,213,104,0.4), transparent);
  transition: left 600ms;
}
.pv2-cta:hover{
  transform: translateY(-2px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 -2px 0 rgba(0,0,0,0.05) inset,
    0 22px 50px -12px rgba(255,213,104,0.35);
}
.pv2-cta:hover::before{ left: 100%; }
.pv2-cta svg{ flex-shrink: 0; transition: transform 220ms; }
.pv2-cta:hover svg{ transform: translateX(3px); }
.pv2-cta-sub{
  text-align: center; margin: 12px 0 0;
  font-size: 11.5px; font-weight: 600;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.02em;
}

/* === 3-Plan Layout === */
.pv2-plans{
  display: grid;
  grid-template-columns: 1fr 1.4fr 1fr;
  gap: 16px;
  align-items: stretch;
  margin: 0 0 56px;
}
@media(max-width: 980px){
  .pv2-plans{ grid-template-columns: 1fr; gap: 14px; }
}

.pv2-plan{
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.01) 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 28px 26px 24px;
  display: flex; flex-direction: column;
  transition: transform 240ms cubic-bezier(.4,0,.2,1),
              border-color 240ms,
              background 240ms;
}
.pv2-plan:hover{
  transform: translateY(-3px);
  border-color: rgba(255,255,255,0.15);
}

.pv2-plan-head{ margin-bottom: 22px; }
.pv2-plan-name{
  font-size: 17px; font-weight: 900;
  color: #fff;
  margin: 12px 0 6px;
  letter-spacing: -0.005em;
}
.pv2-plan-pitch{
  font-size: 12px; font-weight: 700;
  color: rgba(255,255,255,0.55);
  margin: 0; line-height: 1.5;
}

.pv2-plan-tag-gold{
  background: rgba(255,213,104,0.12) !important;
  border-color: rgba(255,213,104,0.40) !important;
  color: #FFD568 !important;
}

.pv2-plan-price{
  display: flex; align-items: flex-start;
  gap: 4px;
  margin-bottom: 22px;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
}
.pv2-plan-yen{
  font-size: 20px; font-weight: 700;
  color: rgba(255,255,255,0.55);
  margin-top: 12px;
  letter-spacing: -0.02em;
}
.pv2-plan-num{
  font-size: 56px; font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.pv2-plan-num-soudan{
  font-size: 32px;
  letter-spacing: -0.01em;
  margin-top: 12px;
}
.pv2-plan-suf{
  display: flex; flex-direction: column;
  margin-top: 16px;
  margin-left: 4px;
  line-height: 1.2;
}
.pv2-plan-suf span{
  font-size: 16px; font-weight: 700;
  color: rgba(255,213,104,0.8);
  letter-spacing: -0.02em;
}
.pv2-plan-suf small{
  font-size: 10px; font-weight: 700;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.04em;
  margin-top: 2px;
}

.pv2-plan-list{
  list-style: none; padding: 0; margin: 0 0 22px;
  display: flex; flex-direction: column; gap: 10px;
  flex: 1;
}
.pv2-plan-list li{
  font-size: 12.5px; line-height: 1.6;
  color: rgba(255,255,255,0.78);
  font-weight: 600;
  position: relative;
  padding-left: 18px;
}
.pv2-plan-list li::before{
  content: '';
  position: absolute; left: 0; top: 7px;
  width: 4px; height: 4px; border-radius: 50%;
  background: rgba(255,255,255,0.4);
}

.pv2-plan-cta{
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px 16px;
  border-radius: 10px;
  font-size: 12.5px; font-weight: 800;
  text-decoration: none;
  letter-spacing: 0.005em;
  transition: background 200ms, border-color 200ms, transform 200ms;
}
.pv2-plan-cta-sec{
  background: rgba(255,255,255,0.06);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.16);
}
.pv2-plan-cta-sec:hover{
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.30);
}

/* === HERO PLAN (29,800円) === */
.pv2-plan-hero{
  background: transparent;
  border: none;
  padding: 0;
  position: relative;
  z-index: 2;
}
.pv2-plan-aura{
  position: absolute; inset: -4px;
  background: linear-gradient(135deg,
    rgba(255,213,104,0.7) 0%,
    rgba(196,160,82,0.3) 30%,
    rgba(31,79,182,0.45) 70%,
    rgba(255,213,104,0.6) 100%);
  border-radius: 22px;
  filter: blur(2px);
  opacity: 0.85;
  z-index: 0;
  animation: pv2AuraShift 8s ease-in-out infinite alternate;
}
@media (prefers-reduced-motion: reduce){
  .pv2-plan-aura{ animation: none; }
}
.pv2-plan-inner{
  position: relative;
  background: linear-gradient(180deg, #0A1A30 0%, #07142A 100%);
  border: 1px solid rgba(255,213,104,0.20);
  border-radius: 18px;
  padding: 32px 28px 26px;
  z-index: 1;
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.6),
    0 0 0 1px rgba(255,255,255,0.04) inset;
  height: 100%;
  display: flex; flex-direction: column;
}
@media(min-width: 981px){
  .pv2-plan-hero{ transform: scale(1.04); }
  .pv2-plan-hero:hover{ transform: scale(1.05) translateY(-2px); }
}
.pv2-plan-recommended{
  display: inline-block;
  align-self: flex-start;
  padding: 5px 12px;
  background: linear-gradient(135deg, #FFD568 0%, #C4A052 100%);
  color: #0F2447;
  font-size: 10.5px; font-weight: 900;
  letter-spacing: 0.06em;
  border-radius: 999px;
  margin-bottom: 14px;
}
.pv2-plan-name-hero{
  font-size: 22px;
  background: linear-gradient(180deg, #fff 0%, #FFD568 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.pv2-plan-pitch-hero{
  color: rgba(255,255,255,0.7);
  font-size: 12.5px;
  font-weight: 600;
}

.pv2-plan-price-hero{
  margin-bottom: 16px;
}
.pv2-plan-num-hero{
  font-size: clamp(60px, 9vw, 96px);
  background: linear-gradient(180deg, #ffffff 0%, #ddeaff 50%, #94aac8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 6px 40px rgba(255,255,255,0.10);
}
.pv2-plan-suf-hero{ margin-top: clamp(20px, 3vw, 30px); }

.pv2-plan-promise{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 8px;
  align-items: center;
  margin-bottom: 14px;
  padding: 12px;
  background: rgba(255,213,104,0.06);
  border: 1px solid rgba(255,213,104,0.18);
  border-radius: 12px;
}
.pv2-promise-card{
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
}
.pv2-promise-num{
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 28px; font-weight: 900;
  color: #FFD568;
  line-height: 1;
  letter-spacing: -0.02em;
  display: inline-flex; align-items: baseline; gap: 2px;
}
.pv2-promise-num small{
  font-size: 10px; font-weight: 800;
  color: rgba(255,213,104,0.7);
  letter-spacing: 0.04em;
  margin-left: 2px;
}
.pv2-promise-card-zero .pv2-promise-num{
  background: linear-gradient(180deg, #2ED98C, #18B77A);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.pv2-promise-label{
  font-size: 9.5px; font-weight: 800;
  color: rgba(255,255,255,0.65);
  letter-spacing: 0.04em;
  margin-top: 4px;
}
.pv2-promise-plus{
  font-size: 18px; font-weight: 700;
  color: rgba(255,255,255,0.4);
}

.pv2-plan-promise-line{
  font-size: 12px; line-height: 1.7;
  color: rgba(255,255,255,0.85);
  text-align: center;
  margin: 0 0 18px;
  padding-bottom: 18px;
  border-bottom: 1px dashed rgba(255,255,255,0.10);
  font-weight: 600;
}
.pv2-plan-promise-line strong{
  color: #FFD568;
  font-weight: 900;
  font-family: 'Inter','Noto Sans JP', sans-serif;
}

.pv2-plan-list-hero li{
  color: rgba(255,255,255,0.85);
}
.pv2-plan-list-hero li::before{
  background: #FFD568;
  width: 5px; height: 5px;
}

.pv2-plan-cta-row{
  display: flex; gap: 8px; margin-top: 8px;
}
.pv2-plan-cta-pri{
  flex: 1.4;
  background: linear-gradient(180deg, #ffffff 0%, #f0f4fa 100%);
  color: #05101F !important;
  font-size: 13px; font-weight: 900;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.5) inset,
    0 14px 32px -10px rgba(255,213,104,0.30);
  position: relative;
  overflow: hidden;
}
.pv2-plan-cta-pri::before{
  content: ''; position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,213,104,0.45), transparent);
  transition: left 600ms;
}
.pv2-plan-cta-pri:hover{
  transform: translateY(-2px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 22px 50px -12px rgba(255,213,104,0.40);
}
.pv2-plan-cta-pri:hover::before{ left: 100%; }
.pv2-plan-cta-pri svg{ flex-shrink: 0; transition: transform 220ms; }
.pv2-plan-cta-pri:hover svg{ transform: translateX(3px); }
.pv2-plan-cta-ghost{
  flex: 1;
  background: rgba(255,255,255,0.05);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.18);
}
.pv2-plan-cta-ghost:hover{
  background: rgba(255,255,255,0.12);
}

/* === Bento section head === */
.pv2-bento-section-head{
  text-align: center;
  margin-bottom: 24px;
}
.pv2-bento-section-head h3{
  font-size: 20px; font-weight: 900;
  color: #fff;
  margin: 0 0 8px;
  letter-spacing: -0.005em;
}
.pv2-bento-section-head h3 em{
  font-style: normal;
  color: #FFD568;
}
.pv2-bento-section-head p{
  font-size: 13px; color: rgba(255,255,255,0.55);
  margin: 0;
  font-weight: 600;
}

/* === Bento Comparison === */
.pv2-bento{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 48px;
}
@media(max-width: 720px){ .pv2-bento{ grid-template-columns: 1fr; } }

.pv2-bento-card{
  position: relative;
  padding: 26px 26px 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  transition: border-color 240ms, transform 240ms, background 240ms;
}
.pv2-bento-card:hover{
  border-color: rgba(255,255,255,0.15);
  transform: translateY(-2px);
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.02) 100%);
}
.pv2-bento-head{
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.pv2-bento-icon{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 26px; height: 26px;
  border-radius: 7px;
}
.pv2-icon-yes{
  background: rgba(24,183,122,0.15);
  color: #2ED98C;
  border: 1px solid rgba(24,183,122,0.30);
}
.pv2-icon-add{
  background: rgba(255,213,104,0.12);
  color: #FFD568;
  border: 1px solid rgba(255,213,104,0.30);
}
.pv2-bento-card h3{
  flex: 1;
  font-size: 14px; font-weight: 900;
  color: #fff;
  margin: 0;
  letter-spacing: -0.005em;
}
.pv2-bento-meta{
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 10.5px; font-weight: 700;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.04em;
}
.pv2-bento-list{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.pv2-bento-list li{
  font-size: 13px; line-height: 1.6;
  color: rgba(255,255,255,0.78);
  font-weight: 600;
  position: relative;
  padding-left: 16px;
}
.pv2-bento-list li::before{
  content: '';
  position: absolute; left: 0; top: 8px;
  width: 4px; height: 4px; border-radius: 50%;
  background: rgba(255,255,255,0.3);
}
.pv2-bento-list-add li{
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px;
}
.pv2-bento-list-add li::before{
  background: rgba(255,213,104,0.5);
}
.pv2-bento-list-add small{
  flex-shrink: 0;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 11px; font-weight: 800;
  color: #FFD568;
  letter-spacing: 0.02em;
}

/* === Trust strip === */
.pv2-trust{
  display: flex; flex-wrap: wrap;
  justify-content: center; align-items: center;
  gap: 14px 28px;
  padding: 18px 24px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
}
.pv2-trust-item{
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 700;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.005em;
}
.pv2-trust-item svg{
  color: #2ED98C;
  flex-shrink: 0;
}

/* === Mobile === */
@media (max-width: 760px){
  .pricing-v2{ padding: 56px 16px; }
  .pv2-head{ margin-bottom: 32px; }
  .pv2-h2{ font-size: 24px; line-height: 1.35; }
  .pv2-sub{ font-size: 12.5px; }

  /* 3プラン: モバイルでは順序入れ替え（カスタマイズ→ライト→顧問） */
  .pv2-plans{ gap: 12px; margin-bottom: 36px; }
  .pv2-plan{ padding: 22px 20px 20px; }
  .pv2-plan-hero{ order: -1; }
  .pv2-plan-hero{ transform: none; }
  .pv2-plan-hero:hover{ transform: none; }
  .pv2-plan-inner{ padding: 24px 20px 20px; }
  .pv2-plan-name{ font-size: 16px; }
  .pv2-plan-name-hero{ font-size: 19px; }
  .pv2-plan-pitch{ font-size: 11.5px; }
  .pv2-plan-yen{ font-size: 18px; margin-top: 10px; }
  .pv2-plan-num{ font-size: 48px; }
  .pv2-plan-num-hero{ font-size: 64px; }
  .pv2-plan-num-soudan{ font-size: 28px; margin-top: 8px; }
  .pv2-plan-suf{ margin-top: 14px; }
  .pv2-plan-suf-hero{ margin-top: 18px; }
  .pv2-plan-list li{ font-size: 12px; }
  .pv2-promise-num{ font-size: 22px; }
  .pv2-promise-label{ font-size: 9px; }
  .pv2-plan-promise-line{ font-size: 11.5px; }
  .pv2-plan-cta{ padding: 11px 14px; font-size: 12px; }
  .pv2-plan-cta-row{ flex-direction: column; gap: 6px; }

  .pv2-bento-section-head h3{ font-size: 16px; }
  .pv2-bento-section-head p{ font-size: 12px; }
  .pv2-bento{ grid-template-columns: 1fr; }
  .pv2-bento-card{ padding: 22px 20px 18px; }
  .pv2-bento-card h3{ font-size: 13px; }
  .pv2-bento-list li{ font-size: 12px; }
  .pv2-trust{ padding: 14px 16px; gap: 10px 16px; }
  .pv2-trust-item{ font-size: 11px; }
  .pv2-glow-1, .pv2-glow-2{ width: 320px; height: 320px; opacity: 0.35; }
}

/* === 旧 .pricing-clear（互換用に空にしておく） === */
.pricing-clear{
  padding: clamp(72px, 9vw, 120px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #0F2447 0%, #0B1B33 100%);
  color: #fff;
}
.pc-shell{ max-width: 1180px; margin: 0 auto; }
.pricing-clear .section-heading{ text-align: center; max-width: 780px; margin: 0 auto 56px; }
.pricing-clear .section-heading span{ color: #FFD568; }
.pricing-clear h2{
  font-size: clamp(28px, 3.6vw, 44px);
  font-weight: 900; color: #fff;
  line-height: 1.3;
  letter-spacing: -0.01em;
}
.pricing-clear h2 .pc-em{
  font-style: normal;
  background: linear-gradient(180deg, #FFD568, #E5A100);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}
.pc-grid{
  display: grid; grid-template-columns: 1fr 1.05fr 1fr; gap: 16px;
  align-items: stretch;
}
@media(max-width: 980px){ .pc-grid{ grid-template-columns: 1fr; } }
.pc-col{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 28px 24px;
}
.pc-col-mid{
  background: linear-gradient(180deg, rgba(214,169,53,0.18), rgba(214,169,53,0.06));
  border: 2px solid rgba(214,169,53,0.50);
  text-align: center;
  display: flex; flex-direction: column; justify-content: center;
  position: relative;
}
.pc-col-mid::before{
  content: 'BASIC PLAN';
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  padding: 4px 14px; border-radius: 999px;
  background: #D6A935; color: #0F2447;
  font-size: 10px; font-weight: 900; letter-spacing: 0.15em;
}
.pc-col-title{
  font-size: 13px; font-weight: 900; color: #fff;
  letter-spacing: 0.04em; margin: 0 0 18px;
  padding-bottom: 12px; border-bottom: 1px dashed rgba(255,255,255,0.15);
}
.pc-list{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.pc-list li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; line-height: 1.65; color: rgba(255,255,255,0.88);
}
.pc-list li small{ display: block; font-size: 10px; color: #FFD568; font-weight: 800; margin-top: 2px; font-family:'Inter'; }
.pc-check{
  flex-shrink: 0; display: grid; place-items: center;
  width: 18px; height: 18px; border-radius: 50%;
  background: #18B77A; color: #fff;
  font-size: 11px; font-weight: 900;
  margin-top: 1px;
}
.pc-plus{
  flex-shrink: 0; display: grid; place-items: center;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(214,169,53,0.20); color: #FFD568;
  font-size: 13px; font-weight: 900;
  margin-top: 1px;
}
.pc-amount{
  display: flex; align-items: baseline; justify-content: center; gap: 4px;
  margin: 6px 0 8px;
}
.pc-amount-yen{ font-size: 20px; font-weight: 800; color: #FFD568; }
.pc-amount-num{
  font-size: clamp(48px, 6vw, 76px);
  font-weight: 900;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  background: linear-gradient(180deg, #FFD568 0%, #E5A100 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  letter-spacing: -0.03em;
  line-height: 1;
}
.pc-amount-suf{ font-size: 14px; font-weight: 800; color: rgba(255,255,255,0.85); }
.pc-amount-sub{
  font-size: 12px; color: rgba(255,255,255,0.7); margin: 0 0 22px;
  font-weight: 700;
}
.pc-amount-sub strong{ color: #FFD568; font-weight: 900; }
.pc-cta{
  display: inline-block;
  padding: 14px 22px;
  background: #fff; color: #0F2447 !important;
  border-radius: 10px;
  font-size: 13px; font-weight: 900;
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: transform 200ms, box-shadow 200ms;
}
.pc-cta:hover{
  transform: translateY(-2px);
  background: #FFD568;
  box-shadow: 0 16px 36px -10px rgba(214,169,53,0.5);
}

/* === New parent hero — 売り上げは増やせます。トラブルは減らせます。 === */
/* Legacy class kept (in case referenced elsewhere) */
.hero-h1-strong{
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(40px, 5.6vw, 76px) !important;
  line-height: 1.18 !important;
  letter-spacing: -0.01em !important;
  color: #fff;
}
.hero-h1-strong::first-letter{ color: inherit !important; }
.hero-h1-strong .stage{ display: inline-block; }
.hero-h1-strong .hero-em-up{
  font-style: normal;
  background: linear-gradient(180deg, #FFD568 0%, #E5A100 60%, #C68900 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* === Hero H1 v2 — staggered reveal (BtoB premium) === */
.hero-h1-v2{
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(30px, 4.6vw, 60px) !important;
  line-height: 1.22 !important;
  letter-spacing: -0.015em !important;
  color: #fff;
  margin: 0;
  /* Subtle dark gradient behind text for video readability */
  position: relative;
  display: block;
  padding: 0;
  text-shadow:
    0 2px 12px rgba(7,20,38,0.55),
    0 1px 2px rgba(0,0,0,0.35);
}
.hero-h1-v2::first-letter{ color: inherit !important; }
.hero-h1-v2 .hh-line{
  display: block;
  margin-bottom: 6px;
  white-space: nowrap;       /* 1行固定 — 折り返し禁止 */
}
.hero-h1-v2 .hh-line:last-child{ margin-bottom: 0; }

/* base parts (white) */
.hero-h1-v2 .hh-base{
  display: inline-block;
  color: #ffffff;
  opacity: 0;
  transform: translateY(14px);
  filter: blur(4px);
  animation: hhBaseIn 700ms cubic-bezier(0.2, 0.7, 0.2, 1) forwards;
}

/* emphasis parts (gold) — 同サイズ・色とグローで強調 */
.hero-h1-v2 .hh-emph{
  display: inline-block;
  position: relative;
  font-size: 1em;
  font-weight: 900;
  letter-spacing: -0.018em;
  margin-left: 0.04em;
  opacity: 0;
  transform: translateY(18px) scale(0.96);
  filter: blur(6px);
  animation: hhEmphIn 800ms cubic-bezier(0.2, 0.7, 0.15, 1.05) forwards;
}
.hero-h1-v2 .hh-emph-text{
  background: linear-gradient(180deg, #FFE89A 0%, #FFD568 35%, #E5A100 75%, #C68900 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 26px rgba(255,213,104,0.35);
  filter: drop-shadow(0 3px 14px rgba(214,169,53,0.30));
}
/* underline accent that draws in */
.hero-h1-v2 .hh-emph-line{
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: -0.04em;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, #FFD568 12%, #E5A100 50%, #FFD568 88%, transparent 100%);
  border-radius: 999px;
  transform-origin: center;
  transform: scaleX(0);
  opacity: 0;
  filter: drop-shadow(0 1px 8px rgba(255,213,104,0.55));
  animation: hhLineIn 600ms cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* delays — staggered reveal */
.hero-h1-v2 .hh-d1{ animation-delay: 0.10s; }
.hero-h1-v2 .hh-d2{ animation-delay: 0.45s; }
.hero-h1-v2 .hh-d2 .hh-emph-line{ animation-delay: 1.05s; }
.hero-h1-v2 .hh-d3{ animation-delay: 0.95s; }
.hero-h1-v2 .hh-d4{ animation-delay: 1.30s; }
.hero-h1-v2 .hh-d4 .hh-emph-line{ animation-delay: 1.85s; }

@keyframes hhBaseIn{
  to{ opacity: 1; transform: translateY(0); filter: blur(0); }
}
@keyframes hhEmphIn{
  60% {
    opacity: 1; transform: translateY(-2px) scale(1.02); filter: blur(0);
  }
  to{ opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes hhLineIn{
  to{ transform: scaleX(1); opacity: 1; }
}

/* Mobile: tighter, 1行を維持 */
@media(max-width: 760px){
  .hero-h1-v2{
    /* 6.4vw で 12文字が画面幅に収まる程度 */
    font-size: clamp(20px, 6.4vw, 32px) !important;
    line-height: 1.28 !important;
    letter-spacing: -0.012em !important;
  }
  .hero-h1-v2 .hh-emph{ font-size: 1em; }
  .hero-h1-v2 .hh-base{ transform: translateY(8px); filter: blur(2px); }
  .hero-h1-v2 .hh-emph{ transform: translateY(10px) scale(0.97); filter: blur(3px); }
  .hero-h1-v2 .hh-emph-line{ height: 2px; }
}
/* iPhone SE 等の極小画面で確実に1行に */
@media(max-width: 380px){
  .hero-h1-v2{
    font-size: 22px !important;
  }
}

/* prefers-reduced-motion: skip animation, show final state immediately */
@media (prefers-reduced-motion: reduce){
  .hero-h1-v2 .hh-base,
  .hero-h1-v2 .hh-emph{
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    animation: none !important;
  }
  .hero-h1-v2 .hh-emph-line{
    opacity: 1 !important;
    transform: scaleX(1) !important;
    animation: none !important;
  }
}
.hero-cta-row{
  display: flex; gap: 12px; flex-wrap: wrap;
  margin: 6px 0 20px;
}
.hero-cta-pri{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 24px;
  background: linear-gradient(135deg, #D6A935 0%, #FFD568 100%);
  color: #0F2447 !important;
  border-radius: 10px;
  font-size: 15px; font-weight: 900;
  letter-spacing: 0.02em;
  text-decoration: none;
  box-shadow: 0 10px 30px -8px rgba(214,169,53,0.5);
  transition: transform 200ms, box-shadow 200ms;
}
.hero-cta-pri:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 40px -10px rgba(214,169,53,0.6);
}
.hero-cta-sec{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 22px;
  background: rgba(255,255,255,0.06);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: 10px;
  font-size: 14px; font-weight: 800;
  text-decoration: none;
  transition: background 200ms, border-color 200ms;
}
.hero-cta-sec:hover{
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.40);
}
/* New badge style — 4 chips */
.hero-section .hero-badges{
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}
.hero-section .hero-badges span{
  padding: 7px 12px !important;
  background: rgba(255,255,255,0.06) !important;
  color: #fff !important;
  border: 1px solid rgba(214,169,53,0.30) !important;
  border-radius: 999px !important;
  font-size: 11.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em;
}
.hero-section .hero-badges span:first-child,
.hero-section .hero-badges span:last-child{
  background: linear-gradient(135deg, rgba(214,169,53,0.25), rgba(214,169,53,0.10)) !important;
  border-color: rgba(214,169,53,0.55) !important;
  color: #FFD568 !important;
}

/* === 親 / 新セクションのモバイル調整 === */
@media (max-width: 760px){
  /* Hero h1 を小さく */
  .hero-h1-strong{
    font-size: clamp(30px, 8.5vw, 44px) !important;
    line-height: 1.22 !important;
  }
  .hero-section .eyebrow{
    font-size: 10px !important;
    letter-spacing: 0.04em;
  }
  /* Hero shell のpaddingを縮小・縦並びに */
  .hero-shell{
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    gap: 24px !important;
    padding: 36px 18px 44px !important;
  }
  /* Hero画像はモバイルではh1の下に */
  .hero-visual{ order: 2; margin: 0 -8px; }
  .hero-copy{ order: 1; }
  .hero-lead{
    font-size: 14px !important;
    line-height: 1.85 !important;
    margin: 18px 0 18px !important;
  }
  /* CTA縦並び */
  .hero-cta-row{
    flex-direction: column;
    gap: 8px;
    margin: 4px 0 16px;
  }
  .hero-cta-pri, .hero-cta-sec{
    width: 100%;
    justify-content: center;
    padding: 13px 18px;
    font-size: 13.5px;
  }
  /* Badges 縦に並ぶ */
  .hero-section .hero-badges{
    gap: 6px !important;
  }
  .hero-section .hero-badges span{
    padding: 6px 10px !important;
    font-size: 10.5px !important;
  }

  /* Industries hub */
  .industries-hub{
    padding: 56px 16px !important;
  }
  .industries-hub h2{
    font-size: 24px;
    line-height: 1.4;
  }
  .industries-lead{
    font-size: 13px;
    margin: 14px auto 32px;
    line-height: 1.85;
  }
  .industries-grid{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .ind-card{
    padding: 22px 20px 18px;
  }
  .ind-icon{ width: 48px; height: 48px; font-size: 22px; margin-bottom: 14px; }
  .ind-card h3{ font-size: 16px; }
  .ind-card p{ font-size: 12.5px; min-height: auto; margin-bottom: 16px; }

  /* Pricing clear */
  .pricing-clear{
    padding: 56px 16px !important;
  }
  .pricing-clear h2{
    font-size: 24px;
    line-height: 1.4;
  }
  .pc-grid{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .pc-col{ padding: 22px 20px; }
  .pc-col-mid{
    order: -1; /* モバイルでは中央プランを最初に */
    margin-top: 14px;
  }
  .pc-amount-num{ font-size: 56px !important; }
  .pc-list li{ font-size: 12.5px; }

  /* Hero画像のリミット */
  .hero-visual img{
    max-width: 100%;
    max-height: 56vw;
  }
}

/* 微小画面（iPhone SE 等） */
@media (max-width: 380px){
  .hero-h1-strong{
    font-size: 28px !important;
  }
  .hero-section{ padding: 0; }
  .hero-shell{ padding: 28px 14px 36px !important; }
  .industries-hub h2,
  .pricing-clear h2{ font-size: 21px; }
}

.hero-lead {
  max-width: 620px;
  margin: 28px 0 26px;
  font-size: 18px;
  font-weight: 800;
}

.hero-badges {
  display: inline-flex;
  flex-wrap: wrap;
  overflow: hidden;
  border: 1px solid rgba(214, 169, 53, 0.65);
  border-radius: 4px;
}

.hero-badges span {
  padding: 12px 18px;
  font-weight: 950;
}

.hero-badges span:first-child {
  background: var(--navy-2);
}

.hero-badges span:last-child {
  color: var(--navy);
  background: var(--gold-2);
}

.hero-visual img {
  width: 100%;
  height: auto;
  aspect-ratio: auto;
  object-fit: contain;
  object-position: center;
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  /* 透明PNGなので drop-shadow で陰影だけ */
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.55));
}

.section {
  padding: clamp(70px, 8vw, 104px) clamp(20px, 4vw, 48px);
}

.section-light {
  background: var(--white);
}

.section-ivory {
  background: var(--ivory);
}

.section-heading {
  max-width: 860px;
  margin: 0 auto 34px;
}

.center {
  text-align: center;
}

.section-heading h2,
.axdx-copy h2,
.cta-section h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(34px, 4vw, 48px);
  font-weight: 950;
  line-height: 1.25;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  max-width: var(--max);
  margin: 0 auto;
}

.service-card,
.child-brand-grid article,
.why-grid article {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.service-card {
  overflow: hidden;
}

.service-card img {
  width: 100%;
  height: 128px;
  object-fit: cover;
  border-bottom: 1px solid var(--line);
}

.service-card h3 {
  margin: 0;
  padding: 18px 16px 0;
  color: var(--navy);
  font-size: 18px;
  font-weight: 950;
}

.service-card p {
  margin: 0;
  padding: 10px 16px 20px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.brand-map {
  display: grid;
  grid-template-columns: 1fr minmax(260px, 420px) 1fr;
  gap: 24px;
  align-items: center;
  max-width: 960px;
  margin: 0 auto 36px;
  color: var(--navy);
  text-align: center;
}

.brand-map-center {
  padding: 22px 28px;
  border-radius: 10px;
  color: var(--white);
  background: var(--navy);
  box-shadow: var(--shadow);
  font-size: 32px;
  font-weight: 950;
}

.brand-map-center::first-letter {
  color: var(--gold-2);
}

.brand-map-side {
  color: var(--muted);
  font-size: 14px;
  font-weight: 900;
}

.child-brand-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
  max-width: var(--max);
  margin: 0 auto;
}

.child-brand-grid article {
  min-height: 160px;
  padding: 22px 18px;
}

.child-brand-grid strong {
  display: block;
  color: var(--navy);
  font-size: 18px;
  font-weight: 950;
}

.child-brand-grid strong::first-letter {
  color: var(--gold);
}

.child-brand-grid p,
.why-grid p,
.axdx-copy p,
.cta-copy p,
.site-footer p {
  margin: 10px 0 0;
  color: var(--muted);
  font-weight: 700;
}

.brand-note {
  max-width: var(--max);
  margin: 28px auto 0;
  padding: 16px 24px;
  color: var(--white);
  background: var(--navy);
  text-align: center;
  font-weight: 900;
}

.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  max-width: var(--max);
  margin: 0 auto;
}

.why-grid article {
  padding: 24px;
}

.why-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  margin-bottom: 16px;
  color: var(--gold);
  border: 1px solid rgba(214, 169, 53, 0.5);
  border-radius: 50%;
  font-weight: 950;
}

.why-grid strong {
  display: block;
  color: var(--navy);
  font-size: 20px;
  font-weight: 950;
}

.section-split {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 54px;
  align-items: center;
  max-width: var(--max);
  margin: 0 auto;
}

.axdx-visual img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.axdx-copy {
  padding-right: clamp(0px, 3vw, 34px);
}

.check-list {
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

.check-list li {
  margin-top: 12px;
  color: var(--ink);
  font-weight: 850;
}

.check-list li::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  margin-right: 10px;
  color: var(--white);
  background: var(--gold);
  border-radius: 50%;
  font-size: 13px;
}

.cta-section {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 44px;
  align-items: center;
  padding: clamp(54px, 7vw, 82px) clamp(20px, 4vw, 48px);
  color: var(--white);
  background: var(--navy);
}

.cta-section h2 {
  color: var(--white);
}

.cta-copy {
  max-width: 720px;
}

.cta-copy p {
  color: rgba(255, 255, 255, 0.9);
}

.cta-actions {
  display: flex;
  gap: 14px;
  margin-top: 24px;
}

.site-footer {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 34px;
  padding: 44px clamp(20px, 4vw, 48px);
  color: var(--white);
  background: #06101e;
  border-top: 1px solid rgba(214, 169, 53, 0.25);
}

.footer-company strong {
  display: block;
  color: var(--white);
  font-size: 18px;
}

.footer-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 24px;
  color: rgba(255, 255, 255, 0.78);
  font-weight: 800;
}

.copyright {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 12px;
}

@media (max-width: 1180px) {
  .site-header {
    flex-wrap: wrap;
  }

  .global-nav {
    order: 3;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .hero-shell,
  .section-split,
  .cta-section {
    grid-template-columns: 1fr;
  }

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

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

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

@media (max-width: 720px) {
  .site-header {
    position: static;
    gap: 14px;
  }

  .brand {
    flex-wrap: wrap;
    white-space: normal;
  }

  .brand-company {
    width: 100%;
    padding-left: 46px;
    border-left: 0;
  }

  .header-cta {
    width: 100%;
    border-radius: 10px;
  }

  .hero-shell {
    min-height: auto;
    padding-top: 44px;
  }

  .hero-copy h1 {
    font-size: 43px;
  }

  .hero-lead {
    font-size: 16px;
  }

  .hero-badges {
    display: grid;
    width: 100%;
  }

  .hero-badges span {
    text-align: center;
  }

  .service-grid,
  .child-brand-grid,
  .why-grid,
  .brand-map,
  .site-footer {
    grid-template-columns: 1fr;
  }

  .service-card img {
    height: 190px;
  }

  .brand-map-center {
    font-size: 28px;
  }

  .cta-actions {
    flex-direction: column;
  }

  .btn {
    width: 100%;
  }

  .footer-links {
    grid-template-columns: 1fr;
  }
}

/* Modern top only for company page */
.company-header-modern {
  gap: 28px;
  min-height: 78px;
  background: rgba(5, 16, 31, 0.96);
}

.company-header-modern .company-logo {
  gap: 12px;
}

.modern-logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: #efc96b;
  border: 2px solid #d6a935;
  border-radius: 50%;
  font-size: 22px;
  font-weight: 950;
  box-shadow: 0 0 22px rgba(214, 169, 53, 0.18);
}

.company-header-modern .company-logo strong {
  color: #fff;
  font-size: 22px;
  font-weight: 950;
}

.company-header-modern .company-logo em {
  margin-left: 10px;
  padding-left: 18px;
  color: rgba(255, 255, 255, 0.92);
  border-left: 1px solid rgba(255, 255, 255, 0.24);
  font-size: 16px;
  font-style: normal;
  font-weight: 850;
}

.modern-hero {
  position: relative;
  overflow: hidden;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(4, 16, 31, 0.98) 0%, rgba(4, 16, 31, 0.9) 35%, rgba(4, 16, 31, 0.22) 64%, rgba(4, 16, 31, 0.04) 100%),
    url("./assets/hero-axdx-dashboard-wide.png") center / cover no-repeat,
    #071426;
}

.modern-network {
  display: none;
}

.modern-hero .company-hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(430px, 0.78fr) minmax(560px, 1.22fr);
  gap: 30px;
  align-items: center;
  max-width: 1500px;
  min-height: 610px;
  margin: 0 auto;
  padding: 52px clamp(28px, 4vw, 60px) 26px;
}

.modern-hero .company-hero-copy {
  position: relative;
  z-index: 3;
}

.modern-hero .company-hero h1,
.modern-hero h1 {
  margin: 0;
  color: #fff;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(68px, 6.1vw, 104px);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: 0;
  text-shadow: 0 16px 44px rgba(0, 0, 0, 0.34);
}

.modern-hero h1::first-letter {
  color: #fff;
}

.modern-hero h1 span {
  color: #efc96b;
}

.modern-hero .company-hero-copy p {
  max-width: 720px;
  margin: 28px 0 0;
  color: #f3f6fb;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.95;
}

.modern-hero-actions {
  display: flex;
  gap: 20px;
  margin-top: 34px;
}

.modern-hero-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 260px;
  min-height: 66px;
  padding: 0 28px;
  border-radius: 6px;
  font-size: 18px;
  font-weight: 950;
}

.modern-hero-actions a:first-child {
  color: #071426;
  background: linear-gradient(135deg, #f2d786, #d6a935);
  box-shadow: 0 18px 34px rgba(214, 169, 53, 0.2);
}

.modern-hero-actions a:last-child {
  color: #fff;
  border: 1px solid #d6a935;
  background: rgba(6, 21, 42, 0.48);
}

.modern-hero-visual {
  min-height: 500px;
  pointer-events: none;
}

.modern-hero-visual img {
  display: none;
}

.modern-kpis {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 clamp(28px, 4vw, 60px) 28px;
}

.modern-kpis article,
.modern-service-band article {
  background: linear-gradient(145deg, rgba(17, 42, 73, 0.82), rgba(8, 27, 51, 0.9));
  border: 1px solid rgba(153, 176, 210, 0.22);
  border-radius: 12px;
  box-shadow: 0 22px 46px rgba(0, 0, 0, 0.18);
}

.modern-kpis article {
  min-height: 126px;
  padding: 22px 28px;
}

.modern-kpis span,
.modern-service-band span {
  color: #efc96b;
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.modern-kpis strong {
  display: block;
  margin-top: 6px;
  color: #fff;
  font-size: 34px;
  font-weight: 950;
  line-height: 1.2;
}

.modern-kpis p,
.modern-service-band p {
  margin: 8px 0 0;
  color: rgba(217, 225, 242, 0.75);
  font-size: 15px;
  font-weight: 650;
}

.modern-service-band {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  max-width: 100%;
  border-top: 1px solid rgba(153, 176, 210, 0.22);
  border-bottom: 1px solid rgba(214, 169, 53, 0.12);
  background: rgba(4, 16, 31, 0.62);
}

.modern-service-band article {
  min-height: 156px;
  padding: 28px clamp(18px, 3vw, 52px);
  border-top: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: 0;
  box-shadow: none;
}

.modern-service-band strong {
  display: block;
  margin-top: 9px;
  color: #fff;
  font-size: 21px;
  font-weight: 950;
}

@media (max-width: 1180px) {
  .modern-hero .company-hero-inner {
    grid-template-columns: 1fr;
  }

  .modern-hero-visual {
    min-height: 420px;
  }

  .modern-hero-visual img {
    right: 50%;
    width: min(920px, 94vw);
    transform: translateX(50%);
  }

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

  .modern-service-band {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  .company-header-modern .company-logo {
    white-space: normal;
  }

  .company-header-modern .company-logo em {
    flex-basis: 100%;
    margin-left: 52px;
    padding-left: 0;
    border-left: 0;
    font-size: 12px;
  }

  .modern-hero .company-hero-inner {
    padding: 42px 18px 16px;
  }

  .modern-hero h1 {
    font-size: 48px;
  }

  .modern-hero .company-hero-copy p {
    font-size: 16px;
    line-height: 1.85;
  }

  .modern-hero-actions {
    display: grid;
    gap: 12px;
  }

  .modern-hero-actions a {
    width: 100%;
    min-width: 0;
    min-height: 56px;
    font-size: 16px;
  }

  .modern-hero-visual {
    min-height: 255px;
  }

  .modern-hero-visual img {
    bottom: -8px;
    width: 116vw;
  }

  .modern-kpis {
    display: flex;
    overflow-x: auto;
    gap: 12px;
    padding: 0 18px 22px;
    scroll-snap-type: x mandatory;
  }

  .modern-kpis article {
    flex: 0 0 76%;
    scroll-snap-align: start;
  }

  .modern-service-band {
    grid-template-columns: 1fr;
  }

  .modern-service-band article {
    min-height: 130px;
    padding: 22px 18px;
  }
}

/* AX/DX company page - dark SaaS style (disabled; one version back)
.company-page {
  --company-bg: #071426;
  --company-bg-2: #081b33;
  --company-bg-3: #0b1f3a;
  --company-card: rgba(13, 35, 62, 0.82);
  --company-line: rgba(153, 176, 210, 0.22);
  --company-gold: #d6a935;
  --company-gold-2: #efc96b;
  --company-text: #ffffff;
  --company-soft: #d9e1f2;
  color: var(--company-soft);
  background: var(--company-bg);
}

.company-page .company-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 28px;
  min-height: 78px;
  padding: 12px clamp(24px, 4vw, 56px);
  color: var(--company-text);
  background: rgba(5, 16, 31, 0.92);
  border-bottom: 1px solid rgba(214, 169, 53, 0.18);
  backdrop-filter: blur(16px);
}

.company-page .company-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
  white-space: nowrap;
}

.company-page .logo-symbol {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: var(--company-gold-2);
  border: 2px solid var(--company-gold);
  border-radius: 50%;
  font-size: 22px;
  font-weight: 950;
  box-shadow: 0 0 22px rgba(214, 169, 53, 0.18);
}

.company-page .company-logo strong {
  color: var(--company-text);
  font-size: 22px;
  font-weight: 950;
}

.company-page .company-logo em {
  margin-left: 10px;
  padding-left: 18px;
  color: rgba(255, 255, 255, 0.92);
  border-left: 1px solid rgba(255, 255, 255, 0.24);
  font-size: 16px;
  font-style: normal;
  font-weight: 850;
}

.company-page .company-nav {
  display: flex;
  justify-content: flex-end;
  gap: clamp(18px, 2.5vw, 34px);
  flex: 1;
  color: rgba(255, 255, 255, 0.9);
  font-size: 15px;
  font-weight: 850;
  white-space: nowrap;
}

.company-page .company-consult {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  color: #071426;
  background: linear-gradient(135deg, #f1d27b, var(--company-gold));
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  font-size: 15px;
  font-weight: 950;
  box-shadow: 0 12px 28px rgba(214, 169, 53, 0.18);
}

.company-page .company-hero {
  position: relative;
  overflow: hidden;
  color: var(--company-text);
  background:
    radial-gradient(circle at 55% 34%, rgba(0, 119, 255, 0.18), transparent 26%),
    radial-gradient(circle at 82% 12%, rgba(214, 169, 53, 0.12), transparent 24%),
    linear-gradient(135deg, #04101f 0%, #071426 46%, #0a1f3e 100%);
}

.network-bg {
  position: absolute;
  inset: 0;
  opacity: 0.55;
  background-image:
    radial-gradient(circle, rgba(19, 132, 255, 0.92) 1px, transparent 2px),
    linear-gradient(35deg, transparent 0 47%, rgba(20, 116, 219, 0.18) 48% 49%, transparent 50%),
    linear-gradient(145deg, transparent 0 47%, rgba(20, 116, 219, 0.12) 48% 49%, transparent 50%);
  background-size: 140px 140px, 260px 180px, 280px 210px;
  background-position: 40px 20px, 0 80px, 80px 0;
  pointer-events: none;
}

.company-page .company-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(430px, 0.86fr) minmax(580px, 1.14fr);
  gap: 30px;
  align-items: center;
  max-width: 1500px;
  min-height: 590px;
  margin: 0 auto;
  padding: 52px clamp(28px, 4vw, 60px) 26px;
}

.company-page .company-hero h1 {
  margin: 0;
  color: #fff;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(68px, 6.1vw, 104px);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: 0;
  text-shadow: 0 16px 44px rgba(0, 0, 0, 0.34);
}

.company-page .company-hero h1::first-letter {
  color: #fff;
}

.company-page .company-hero h1 span {
  color: var(--company-gold-2);
}

.company-page .company-hero p {
  max-width: 720px;
  margin: 28px 0 0;
  color: #f3f6fb;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.95;
}

.company-hero-actions {
  display: flex;
  gap: 20px;
  margin-top: 34px;
}

.company-hero-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 260px;
  min-height: 66px;
  padding: 0 28px;
  border-radius: 6px;
  font-size: 18px;
  font-weight: 950;
}

.company-hero-actions a:first-child {
  color: #071426;
  background: linear-gradient(135deg, #f2d786, var(--company-gold));
  box-shadow: 0 18px 34px rgba(214, 169, 53, 0.2);
}

.company-hero-actions a:last-child {
  color: #fff;
  border: 1px solid var(--company-gold);
  background: rgba(6, 21, 42, 0.48);
}

.company-hero-visual {
  position: relative;
  min-height: 500px;
}

.company-hero-visual img {
  position: absolute;
  right: -76px;
  bottom: -24px;
  width: min(940px, 63vw);
  max-width: none;
  filter: drop-shadow(0 36px 62px rgba(0, 0, 0, 0.5));
}

.hero-kpis {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 clamp(28px, 4vw, 60px) 28px;
}

.hero-kpis article,
.service-band article,
.dark-card-grid article,
.case-panel,
.flow-row li,
.download-box {
  background: linear-gradient(145deg, rgba(17, 42, 73, 0.82), rgba(8, 27, 51, 0.9));
  border: 1px solid var(--company-line);
  border-radius: 12px;
  box-shadow: 0 22px 46px rgba(0, 0, 0, 0.18);
}

.hero-kpis article {
  min-height: 126px;
  padding: 22px 28px;
}

.hero-kpis span,
.service-band span,
.dark-card-grid span,
.flow-row span {
  color: var(--company-gold-2);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.hero-kpis strong {
  display: block;
  margin-top: 6px;
  color: #fff;
  font-size: 34px;
  font-weight: 950;
  line-height: 1.2;
}

.hero-kpis p,
.service-band p,
.dark-card-grid p,
.flow-row p,
.case-panel p,
.about-panel p,
.download-box p,
.contact-panel p {
  margin: 8px 0 0;
  color: rgba(217, 225, 242, 0.75);
  font-size: 15px;
  font-weight: 650;
}

.service-band {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  max-width: 100%;
  border-top: 1px solid var(--company-line);
  border-bottom: 1px solid rgba(214, 169, 53, 0.12);
  background: rgba(4, 16, 31, 0.62);
}

.service-band article {
  min-height: 156px;
  padding: 28px clamp(18px, 3vw, 52px);
  border-top: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: 0;
  box-shadow: none;
}

.service-band article:last-child {
  border-right: 0;
}

.service-band strong {
  display: block;
  margin-top: 9px;
  color: #fff;
  font-size: 21px;
  font-weight: 950;
}

.dashboard-section,
.flow-section,
.download-contact-section,
.client-section {
  background:
    radial-gradient(circle at 80% 0%, rgba(18, 105, 198, 0.14), transparent 35%),
    linear-gradient(180deg, #071426, #081b33);
  color: #fff;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.dashboard-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.75fr) minmax(360px, 0.85fr);
  gap: 34px;
  max-width: 1500px;
  margin: 0 auto;
  padding: 66px clamp(28px, 4vw, 60px);
}

.section-label {
  margin: 0 0 4px;
  color: var(--company-gold-2);
  font-size: 15px;
  font-weight: 950;
  letter-spacing: 0.12em;
}

.dashboard-section h2,
.flow-section h2,
.about-news-section h2,
.download-contact-section h2,
.client-section h2,
.company-footer strong {
  margin: 0 0 18px;
  color: #fff;
  font-size: 28px;
  font-weight: 950;
}

.dark-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.dark-card-grid article {
  min-height: 232px;
  padding: 28px;
  transition: transform 0.18s ease, border-color 0.18s ease;
}

.dark-card-grid article:hover {
  transform: translateY(-3px);
  border-color: rgba(214, 169, 53, 0.48);
}

.dark-card-grid strong {
  display: block;
  margin-top: 18px;
  color: #fff;
  font-size: 21px;
  font-weight: 950;
}

.dark-card-grid a,
.case-panel > a,
.about-panel a,
.news-panel a,
.download-box a {
  display: inline-flex;
  margin-top: 20px;
  color: var(--company-gold-2);
  font-size: 14px;
  font-weight: 900;
}

.case-panel {
  padding: 34px;
}

.case-screen {
  overflow: hidden;
  margin-top: 24px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  background: #06101e;
}

.case-screen img {
  width: 100%;
  height: 210px;
  object-fit: cover;
}

.case-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin: 28px 0 0;
  padding: 0;
  border-top: 1px solid var(--company-line);
  border-bottom: 1px solid var(--company-line);
}

.case-metrics div {
  padding: 18px 12px;
  text-align: center;
}

.case-metrics div:not(:last-child) {
  border-right: 1px solid var(--company-line);
}

.case-metrics dt {
  color: rgba(217, 225, 242, 0.78);
  font-size: 13px;
  font-weight: 850;
}

.case-metrics dd {
  margin: 4px 0 0;
  color: #fff;
  font-size: 27px;
  font-weight: 900;
}

.flow-section {
  padding: 62px clamp(28px, 4vw, 60px);
}

.flow-section > .section-label,
.flow-section > h2 {
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
}

.flow-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  max-width: 1500px;
  margin: 28px auto 0;
  padding: 0;
  list-style: none;
}

.flow-row li {
  position: relative;
  min-height: 204px;
  padding: 26px;
  clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 50%, calc(100% - 22px) 100%, 0 100%);
}

.flow-row strong {
  display: block;
  margin-top: 20px;
  color: #fff;
  font-size: 20px;
  font-weight: 950;
}

.about-news-section {
  display: grid;
  grid-template-columns: 0.9fr 0.85fr 0.75fr;
  gap: 34px;
  padding: 76px clamp(28px, 4vw, 60px);
  color: #071426;
  background: radial-gradient(circle at 42% 58%, rgba(214, 169, 53, 0.13), transparent 24%), #f7f5ef;
}

.about-panel,
.news-panel,
.contact-panel {
  padding: 24px;
}

.about-panel .section-label,
.news-panel .section-label,
.download-contact-section .section-label,
.client-section .section-label {
  color: var(--company-gold);
}

.about-news-section h2,
.download-contact-section h2 {
  color: #071426;
}

.about-panel p {
  color: #344156;
  font-weight: 700;
}

.about-panel a {
  align-items: center;
  justify-content: center;
  min-width: 180px;
  min-height: 48px;
  color: #071426;
  background: linear-gradient(135deg, #f1d27b, var(--company-gold));
  border-radius: 4px;
}

.about-image {
  overflow: hidden;
  align-self: center;
  border-radius: 12px;
  box-shadow: 0 28px 56px rgba(7, 20, 38, 0.12);
}

.about-image img {
  width: 100%;
  height: 330px;
  object-fit: cover;
}

.news-panel {
  background: rgba(255, 255, 255, 0.72);
  border-left: 1px solid rgba(7, 20, 38, 0.08);
}

.news-panel ul {
  display: grid;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.news-panel li {
  display: grid;
  gap: 4px;
}

.news-panel time {
  color: #8b6d1f;
  font-size: 13px;
  font-weight: 850;
}

.news-panel span {
  color: #344156;
  font-size: 14px;
  font-weight: 750;
}

.download-contact-section {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
}

.download-panel {
  padding: 74px clamp(28px, 5vw, 72px);
  background: radial-gradient(circle at 92% 12%, rgba(15, 119, 219, 0.2), transparent 32%), linear-gradient(135deg, #071426, #0b2547);
}

.download-box {
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 28px;
  align-items: center;
  margin-top: 28px;
  padding: 28px;
}

.download-thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 5;
  color: rgba(255, 255, 255, 0.88);
  background: linear-gradient(145deg, rgba(13, 35, 62, 0.98), rgba(4, 16, 31, 0.96));
  border: 1px solid var(--company-line);
  border-radius: 10px;
  text-align: center;
  font-weight: 950;
}

.download-box strong {
  color: #fff;
  font-size: 22px;
  font-weight: 950;
}

.contact-panel {
  display: grid;
  gap: 12px;
  padding: 74px clamp(28px, 5vw, 72px);
  background: #f7f5ef;
}

.contact-panel p {
  color: #4b5870;
}

.contact-panel label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
}

.contact-panel input,
.contact-panel textarea {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  color: #071426;
  background: #fff;
  border: 1px solid #d9dde5;
  border-radius: 4px;
  font: inherit;
}

.contact-panel textarea {
  resize: vertical;
}

.contact-panel button {
  justify-self: start;
  min-width: 190px;
  min-height: 50px;
  margin-top: 10px;
  color: #071426;
  background: linear-gradient(135deg, #f1d27b, var(--company-gold));
  border: 0;
  border-radius: 4px;
  font: inherit;
  font-weight: 950;
}

.client-section {
  padding: 42px clamp(28px, 4vw, 60px);
}

.client-section h2 {
  font-size: 18px;
}

.client-logos {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 20px;
  align-items: center;
  max-width: 1380px;
}

.client-logos span {
  color: rgba(217, 225, 242, 0.68);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  padding: 12px 14px;
  text-align: center;
  font-weight: 850;
}

.client-section small {
  display: block;
  margin-top: 18px;
  color: rgba(217, 225, 242, 0.5);
}

.company-page .company-footer {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 36px;
  padding: 48px clamp(28px, 4vw, 60px);
  color: #fff;
  background: #04101f;
  border-top: 1px solid rgba(214, 169, 53, 0.16);
}

.company-page .company-footer span {
  padding: 4px 8px;
  color: var(--company-gold-2);
  border: 1px solid var(--company-gold);
  border-radius: 4px;
  font-size: 12px;
  font-weight: 900;
}

.company-page .company-footer p {
  color: rgba(217, 225, 242, 0.72);
}

.company-page .company-footer nav {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 24px;
  color: rgba(217, 225, 242, 0.84);
  font-weight: 800;
}

.company-page .company-footer small {
  grid-column: 1 / -1;
  color: rgba(217, 225, 242, 0.52);
}

@media (max-width: 1180px) {
  .company-page .company-header {
    flex-wrap: wrap;
  }

  .company-page .company-logo {
    width: 100%;
  }

  .company-page .company-nav {
    order: 3;
    justify-content: flex-start;
    width: 100%;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .company-page .company-hero-inner,
  .dashboard-layout,
  .about-news-section,
  .download-contact-section {
    grid-template-columns: 1fr;
  }

  .company-hero-visual {
    min-height: 420px;
  }

  .company-hero-visual img {
    right: 50%;
    width: min(920px, 94vw);
    transform: translateX(50%);
  }

  .hero-kpis,
  .dark-card-grid,
  .flow-row {
    grid-template-columns: repeat(2, 1fr);
  }

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

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

@media (max-width: 720px) {
  .company-page .company-header {
    position: static;
    min-height: auto;
    padding: 14px 18px;
  }

  .company-page .company-logo {
    gap: 9px;
    white-space: normal;
  }

  .company-page .logo-symbol {
    width: 34px;
    height: 34px;
  }

  .company-page .company-logo strong {
    font-size: 19px;
  }

  .company-page .company-logo em {
    flex-basis: 100%;
    margin-left: 43px;
    padding-left: 0;
    border-left: 0;
    font-size: 12px;
  }

  .company-page .company-consult {
    width: 100%;
  }

  .company-page .company-hero-inner {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 42px 18px 16px;
  }

  .company-page .company-hero h1 {
    font-size: 48px;
  }

  .company-page .company-hero p {
    font-size: 16px;
    line-height: 1.85;
  }

  .company-hero-actions {
    display: grid;
    gap: 12px;
  }

  .company-hero-actions a {
    min-width: 0;
    width: 100%;
    min-height: 56px;
    font-size: 16px;
  }

  .company-hero-visual {
    min-height: 255px;
  }

  .company-hero-visual img {
    bottom: -8px;
    width: 116vw;
  }

  .hero-kpis {
    display: flex;
    overflow-x: auto;
    gap: 12px;
    padding: 0 18px 22px;
    scroll-snap-type: x mandatory;
  }

  .hero-kpis article {
    flex: 0 0 76%;
    scroll-snap-align: start;
  }

  .service-band,
  .dark-card-grid,
  .flow-row,
  .client-logos,
  .company-page .company-footer {
    grid-template-columns: 1fr;
  }

  .service-band article {
    min-height: 130px;
    padding: 22px 18px;
  }

  .dashboard-layout,
  .flow-section,
  .about-news-section,
  .download-panel,
  .contact-panel,
  .client-section {
    padding-left: 18px;
    padding-right: 18px;
  }

  .dark-card-grid article,
  .case-panel,
  .flow-row li {
    min-height: auto;
    padding: 22px;
  }

  .flow-row li {
    clip-path: none;
  }

  .download-box {
    grid-template-columns: 1fr;
  }

  .download-thumb {
    max-width: 190px;
  }

  .company-page .company-footer nav {
    grid-template-columns: 1fr;
  }
}

*/

/* Hero placement fix: keep mockup on the right side of the AX/DX copy */
.structured-hero {
  min-height: 760px;
}

.structured-hero-inner {
  min-height: 520px;
  grid-template-columns: minmax(420px, 0.9fr) minmax(420px, 1.1fr);
}

.structured-hero-copy {
  position: relative;
  z-index: 3;
}

.structured-hero-mock {
  position: static;
  min-height: 420px;
  display: block;
}

.structured-hero-mock img {
  position: absolute;
  z-index: 2;
  top: 142px;
  right: clamp(26px, 5vw, 92px);
  width: min(560px, 42vw);
  max-width: none;
  transform: none;
  filter: drop-shadow(0 30px 48px rgba(0, 0, 0, 0.5));
}

@media (max-width: 900px) {
  .structured-hero {
    min-height: auto;
  }

  .structured-hero-inner {
    grid-template-columns: 1fr;
  }

  .structured-hero-mock {
    min-height: 300px;
  }

  .structured-hero-mock img {
    position: relative;
    top: auto;
    right: auto;
    width: min(620px, 92vw);
    margin: 10px auto 0;
    display: block;
  }
}

/* =================================================
   Legacy sections — hide
   ================================================= */
.ureru-legacy{ display: none !important; }

/* =================================================
   業種タブセクション (ind-tabs)
   ================================================= */
.ind-tabs-section{
  padding: clamp(72px, 9vw, 120px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #fff 0%, #FAFBFD 100%);
}
.indt-shell{ max-width: 1100px; margin: 0 auto; }
.indt-head{ text-align: center; max-width: 760px; margin: 0 auto 40px; }
.indt-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(196,160,82,0.12);
  color: #C4A052;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}
.indt-h2{
  font-size: clamp(28px, 3.6vw, 44px);
  font-weight: 900; color: #0F2447;
  line-height: 1.3; letter-spacing: -0.01em;
  margin: 0 0 18px;
}
.indt-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052, #8E703D);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.indt-sub{
  font-size: 15px; line-height: 1.95; color: #25334A;
  margin: 0;
}
.indt-sub strong{ color: #0F2447; font-weight: 900; }

/* Tabs */
.indt-tabs{
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 8px;
  background: #F4F6FA;
  padding: 8px;
  border-radius: 14px;
  margin-bottom: 28px;
}
.indt-tab{
  flex: 1; min-width: 140px;
  padding: 12px 18px;
  background: transparent;
  border: none;
  border-radius: 10px;
  font-size: 14px; font-weight: 900;
  color: #5A6A82;
  cursor: pointer;
  letter-spacing: 0.005em;
  transition: background 220ms, color 220ms, box-shadow 220ms, transform 220ms;
  font-family: inherit;
}
.indt-tab:hover{ color: #0F2447; }
.indt-tab.is-on{
  background: linear-gradient(135deg, #0F2447 0%, #1A3563 100%);
  color: #fff;
  box-shadow: 0 8px 18px -4px rgba(15,36,71,0.30);
}

/* Panels */
.indt-panels{
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 16px;
  padding: 36px 32px;
  box-shadow: 0 16px 40px -16px rgba(15,36,71,0.10);
  min-height: 320px;
  position: relative;
}
.indt-panel{
  display: none;
  animation: indtFade 280ms ease-out;
}
.indt-panel.is-on{ display: block; }
@keyframes indtFade{ from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:none;} }
.indt-panel-head{
  text-align: center;
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 1px dashed #EFF2F6;
}
.indt-panel-head h3{
  font-size: 24px; font-weight: 900; color: #0F2447;
  margin: 0 0 8px;
  letter-spacing: -0.005em;
}
.indt-panel-head h3 em{ font-style: normal; color: #C4A052; }
.indt-panel-head p{
  font-size: 13.5px; color: #5A6A82; font-weight: 700;
  margin: 0;
}
.indt-panel-body{ display: flex; flex-direction: column; gap: 18px; }
.indt-block{ }
.indt-block-l{
  display: block;
  font-size: 11px; font-weight: 900; color: #C4A052;
  letter-spacing: 0.10em;
  margin-bottom: 8px;
}
.indt-tags{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.indt-tags li{
  padding: 6px 12px;
  background: #F4F6FA;
  border-radius: 6px;
  font-size: 12px; font-weight: 700;
  color: #25334A;
  letter-spacing: 0.005em;
}
.indt-tags-genre li{
  background: linear-gradient(135deg, #FFD568 0%, #C4A052 100%) !important;
  color: #0F2447 !important;
  font-weight: 900 !important;
}
.indt-link{
  display: inline-block;
  margin-top: 10px;
  padding: 10px 22px;
  background: linear-gradient(135deg, #0F2447 0%, #1A3563 100%);
  color: #fff;
  border-radius: 8px;
  font-size: 13px; font-weight: 900;
  text-decoration: none;
  letter-spacing: 0.005em;
  transition: transform 200ms, box-shadow 200ms;
  align-self: flex-start;
}
.indt-link:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 26px -8px rgba(15,36,71,0.40);
}
.indt-soon{
  display: inline-block;
  margin-top: 6px;
  padding: 5px 14px;
  background: #F4F6FA;
  color: #95A1B3;
  border-radius: 999px;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.05em;
  align-self: flex-start;
}
@media(max-width: 760px){
  .ind-tabs-section{ padding: 56px 16px; }
  .indt-h2{ font-size: 23px; }
  .indt-sub{ font-size: 13px; }
  .indt-tabs{
    overflow-x: auto;
    flex-wrap: nowrap;
    justify-content: flex-start;
    padding: 6px;
    margin-bottom: 22px;
    scrollbar-width: thin;
  }
  .indt-tab{
    flex: 0 0 auto;
    min-width: auto;
    padding: 10px 16px;
    font-size: 12.5px;
  }
  .indt-panels{ padding: 26px 20px; }
  .indt-panel-head h3{ font-size: 20px; }
  .indt-panel-head p{ font-size: 12.5px; }
  .indt-tags li{ font-size: 11px; padding: 5px 10px; }
}

/* =================================================
   Dashboard Shot section (1 image + 4 points)
   ================================================= */
.dash-shot{
  padding: clamp(72px, 9vw, 110px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #FAFBFD 0%, #fff 100%);
}
.ds-shell{ max-width: 1240px; margin: 0 auto; }
.ds-head{ text-align: center; margin-bottom: 40px; }
.ds-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(31,79,182,0.10);
  color: #1F4FB6;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}
.ds-h2{
  font-size: clamp(28px, 3.8vw, 46px);
  font-weight: 900; color: #0F2447;
  line-height: 1.35; letter-spacing: -0.01em;
  margin: 0;
}
.ds-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #1F4FB6, #2E63D6);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.ds-img{
  margin: 0 auto 36px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 30px 80px -22px rgba(15,36,71,0.30);
  background: linear-gradient(135deg, #0F2447 0%, #07142A 100%);
  padding: 16px;
}
.ds-img img{
  width: 100%; height: auto;
  display: block;
  border-radius: 8px;
}
.ds-points{
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.ds-points li{
  display: flex; align-items: center; gap: 10px;
  padding: 18px 22px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 12px;
  font-size: 14px; font-weight: 700;
  color: #25334A;
  transition: border-color 240ms, transform 240ms, box-shadow 240ms;
}
.ds-points li:hover{
  border-color: rgba(46,217,140,0.50);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -8px rgba(15,36,71,0.10);
}
.ds-points strong{ color: #0F2447; font-weight: 900; }
.ds-chk{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, #18B77A, #2ED98C);
  color: #fff;
  font-size: 13px; font-weight: 900;
}
@media(max-width: 760px){
  .dash-shot{ padding: 56px 16px; }
  .ds-h2{ font-size: 22px; }
  .ds-img{ padding: 8px; margin-bottom: 24px; }
  .ds-points{ grid-template-columns: 1fr 1fr; gap: 8px; }
  .ds-points li{ padding: 13px 14px; font-size: 12.5px; }
  .ds-chk{ width: 20px; height: 20px; font-size: 11px; }
}

/* =================================================
   なぜ選ばれるのか (why-c)
   ================================================= */
.why-c{
  padding: clamp(72px, 9vw, 110px) clamp(20px, 4vw, 64px);
  background: #FBF9F2;
}
.wc-shell{ max-width: 1080px; margin: 0 auto; }
.wc-head{ text-align: center; margin-bottom: 48px; }
.wc-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(196,160,82,0.12);
  color: #C4A052;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}
.wc-h2{
  font-size: clamp(28px, 3.8vw, 46px);
  font-weight: 900; color: #0F2447;
  line-height: 1.3; letter-spacing: -0.01em;
  margin: 0;
}
.wc-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052, #8E703D);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.wc-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.wc-grid-5{
  grid-template-columns: repeat(3, 1fr);
}
.wc-grid-5 .wc-card:nth-child(4),
.wc-grid-5 .wc-card:nth-child(5){
  grid-column: span 1;
}
@media(min-width: 980px){
  .wc-grid-5 .wc-card:nth-child(1){ grid-column: 1 / span 1; }
  .wc-grid-5 .wc-card:nth-child(4){ grid-column: 1 / span 1; }
}
@media(max-width: 980px){
  .wc-grid, .wc-grid-5{ grid-template-columns: repeat(2, 1fr); }
}
@media(max-width: 600px){
  .wc-grid, .wc-grid-5{ grid-template-columns: 1fr; }
}
.wc-sub{
  margin: 18px 0 0;
  font-size: 14px;
  line-height: 1.85;
  color: #5A6A82;
  font-weight: 600;
}
.wc-sub strong{ color: #C4A052; font-weight: 900; }
@media(max-width: 760px){
  .wc-sub{ font-size: 12.5px; }
  .wc-sub-br{ display: none; }
}
/* Card 03 — 人間監修強調 */
.wc-card-human{
  background: linear-gradient(180deg, #fff 0%, #FBF8F0 100%) !important;
  border-color: rgba(196,160,82,0.45) !important;
  box-shadow: 0 14px 32px -16px rgba(196,160,82,0.30) !important;
  position: relative;
}
.wc-card-human::before{
  content: '👥';
  position: absolute; top: -12px; right: 16px;
  width: 28px; height: 28px;
  background: #C4A052;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 14px;
  box-shadow: 0 4px 10px -2px rgba(196,160,82,0.4);
}
.wc-card-human .wc-num{ color: #6B5025; }
.wc-card-human strong{ color: #6B5025; }
.wc-card{
  position: relative;
  padding: 28px 28px 26px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  transition: transform 240ms, border-color 240ms, box-shadow 240ms;
}
.wc-card:hover{
  transform: translateY(-3px);
  border-color: rgba(196,160,82,0.45);
  box-shadow: 0 18px 38px -16px rgba(15,36,71,0.18);
}
.wc-num{
  display: inline-block;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 12px; font-weight: 900;
  letter-spacing: 0.10em;
  color: #C4A052;
  margin-bottom: 10px;
}
.wc-card h3{
  font-size: 18px; font-weight: 900;
  color: #0F2447;
  margin: 0 0 10px;
  letter-spacing: -0.005em;
}
.wc-card p{
  font-size: 13px; line-height: 1.85;
  color: #25334A;
  margin: 0;
  font-weight: 600;
}
.wc-card p strong{
  color: #18B77A;
  font-weight: 900;
  font-family: 'Inter','Noto Sans JP', sans-serif;
}
@media(max-width: 760px){
  .why-c{ padding: 56px 16px; }
  .wc-h2{ font-size: 22px; }
  .wc-card{ padding: 22px 22px 20px; }
  .wc-card h3{ font-size: 16px; }
  .wc-card p{ font-size: 12.5px; }
}

/* =================================================
   Final CTA section
   ================================================= */
.final-cta{
  position: relative;
  padding: clamp(96px, 12vw, 160px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #05101F 0%, #0A1A30 100%);
  color: #fff;
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}
.fc-bg{
  position: absolute; inset: 0; z-index: 0;
  pointer-events: none;
}
.fc-glow{
  position: absolute; border-radius: 50%;
  filter: blur(100px);
}
.fc-glow-1{
  top: -20%; left: 5%;
  width: 480px; height: 480px;
  background: radial-gradient(circle, #C4A052 0%, transparent 70%);
  opacity: 0.5;
}
.fc-glow-2{
  bottom: -20%; right: 5%;
  width: 520px; height: 520px;
  background: radial-gradient(circle, #18B77A 0%, transparent 70%);
  opacity: 0.4;
}
.fc-shell{ position: relative; z-index: 1; max-width: 800px; margin: 0 auto; }
.fc-eyebrow{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px; border-radius: 999px;
  background: rgba(46,217,140,0.10);
  border: 1px solid rgba(46,217,140,0.30);
  color: #2ED98C;
  font-family: 'Inter','Noto Sans JP', sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 22px;
}
.fc-eyebrow::before{
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: #2ED98C; box-shadow: 0 0 8px #2ED98C;
}
.fc-h2{
  font-size: clamp(32px, 5vw, 60px);
  font-weight: 900;
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 24px;
  color: #fff;
}
.fc-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #FFD568 0%, #C4A052 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.fc-sub{
  font-size: 16px; font-weight: 600;
  color: rgba(255,255,255,0.75);
  margin: 0 0 36px;
  line-height: 1.8;
}
.fc-sub strong{ color: #2ED98C; font-weight: 900; font-family: 'Inter','Noto Sans JP', sans-serif; }
.fc-actions{
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 28px;
}
.fc-btn{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 18px 36px;
  border-radius: 12px;
  font-size: 15px; font-weight: 900;
  text-decoration: none;
  letter-spacing: 0.005em;
  transition: transform 220ms, box-shadow 220ms, background 220ms;
  position: relative;
  overflow: hidden;
}
.fc-btn-pri{
  background: linear-gradient(180deg, #ffffff 0%, #f0f4fa 100%);
  color: #05101F !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.5) inset,
    0 -2px 0 rgba(0,0,0,0.05) inset,
    0 16px 36px -10px rgba(255,213,104,0.30);
}
.fc-btn-pri::before{
  content: ''; position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,213,104,0.45), transparent);
  transition: left 600ms;
}
.fc-btn-pri:hover{
  transform: translateY(-3px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 24px 50px -12px rgba(255,213,104,0.45);
}
.fc-btn-pri:hover::before{ left: 100%; }
.fc-btn-pri svg{ flex-shrink: 0; transition: transform 220ms; }
.fc-btn-pri:hover svg{ transform: translateX(3px); }
.fc-btn-sec{
  background: rgba(255,255,255,0.05);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.20);
}
.fc-btn-sec:hover{
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.40);
}
.fc-trust{
  list-style: none; padding: 0; margin: 0;
  display: flex; justify-content: center; flex-wrap: wrap;
  gap: 10px 22px;
}
.fc-trust li{
  font-size: 12px; font-weight: 700;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.005em;
}
@media(max-width: 760px){
  .final-cta{ padding: 72px 16px; }
  .fc-h2{ font-size: 28px; }
  .fc-sub{ font-size: 14px; margin-bottom: 28px; }
  .fc-actions{ flex-direction: column; gap: 8px; }
  .fc-btn{ width: 100%; justify-content: center; padding: 16px 22px; font-size: 14px; }
  .fc-trust{ gap: 6px 14px; }
  .fc-trust li{ font-size: 10.5px; }
  .fc-glow-1, .fc-glow-2{ width: 320px; height: 320px; opacity: 0.35; }
}

/* =================================================
   売れる＋PLUS とは（about-service）
   ================================================= */
.about-service{
  padding: clamp(72px, 9vw, 120px) clamp(20px, 4vw, 64px);
  background: linear-gradient(180deg, #FAFBFD 0%, #fff 100%);
}
.as-shell{ max-width: 1180px; margin: 0 auto; }
.as-head{ text-align: center; max-width: 760px; margin: 0 auto 48px; }
.as-eyebrow{
  display: inline-block;
  padding: 5px 14px; border-radius: 999px;
  background: rgba(196,160,82,0.12);
  color: #C4A052;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 11px; font-weight: 900;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}
.as-h2{
  font-size: clamp(28px, 3.8vw, 48px);
  font-weight: 900; color: #0F2447;
  line-height: 1.3; letter-spacing: -0.01em;
  margin: 0 0 12px;
}
.as-h2 em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052, #8E703D);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.as-sub{
  font-size: 16px; color: #25334A; margin: 0;
  font-weight: 600;
}
.as-sub strong{ color: #0F2447; font-weight: 900; }

.as-pillars{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin-bottom: 36px;
}
@media(max-width: 980px){ .as-pillars{ grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 600px){ .as-pillars{ grid-template-columns: 1fr; } }
.as-pillar{
  padding: 28px 22px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  text-align: center;
  transition: transform 240ms, border-color 240ms, box-shadow 240ms;
}
.as-pillar:hover{
  transform: translateY(-3px);
  border-color: rgba(196,160,82,0.45);
  box-shadow: 0 16px 32px -16px rgba(15,36,71,0.14);
}
.as-pillar-strong{
  background: linear-gradient(180deg, #fff, #FBF8F0);
  border-color: rgba(196,160,82,0.45);
  box-shadow: 0 12px 28px -16px rgba(196,160,82,0.30);
}
.as-pillar-icon{
  display: grid; place-items: center;
  width: 52px; height: 52px;
  margin: 0 auto 14px;
  border-radius: 12px;
  background: linear-gradient(135deg, #FAFBFD, #EFF2F6);
  border: 1px solid #E5E9EF;
  color: #0F2447;
}
.as-pillar-icon svg{ width: 28px; height: 28px; }
.as-pillar-strong .as-pillar-icon{
  background: linear-gradient(135deg, #C4A052, #FFD568);
  border: none;
  color: #0F2447;
  box-shadow: 0 6px 14px -2px rgba(196,160,82,0.40);
}
.as-pillar h3{
  font-size: 15px; font-weight: 900;
  color: #0F2447; margin: 0 0 10px;
  letter-spacing: -0.005em; line-height: 1.45;
}
.as-pillar p{
  font-size: 12.5px; line-height: 1.85;
  color: #25334A; margin: 0; font-weight: 600;
}
.as-foot{
  text-align: center;
  font-size: 14.5px; line-height: 2;
  color: #25334A;
  margin: 0;
}
.as-foot strong{
  background: linear-gradient(180deg, #C4A052, #8E703D);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-weight: 900;
}
@media(max-width: 760px){
  .about-service{ padding: 56px 16px; }
  .as-head{ margin-bottom: 28px; }
  .as-h2{ font-size: 24px; }
  .as-sub{ font-size: 13.5px; }
  .as-pillar{ padding: 22px 18px; }
  .as-pillar h3{ font-size: 14px; }
  .as-pillar p{ font-size: 12px; }
  .as-foot{ font-size: 13px; }
  .as-foot-br{ display: none; }
}

/* =================================================
   BA v5 — 上下構造・問題6カード・ダッシュボード×ベネフィット×メトリクス
   ================================================= */
.ba-v5-section{
  padding: 0;
  background: #FBF9F2;
}
.ba-v5-shell{ max-width: 1280px; margin: 0 auto; }
.ba-v5-block{ padding: clamp(64px, 8vw, 100px) clamp(20px, 4vw, 56px); }
.ba-v5-before{ background: #FAF8F2; }
.ba-v5-after{
  background: linear-gradient(180deg, #FBF9F2 0%, #F4F1E5 100%);
  padding-top: 80px; padding-bottom: 96px;
}

.ba-v5-head{ text-align: center; margin-bottom: 48px; }
.ba-v5-h2{
  font-size: clamp(32px, 5vw, 60px);
  font-weight: 900; color: #0F2447;
  letter-spacing: 0.18em;
  margin: 0 0 14px;
  font-family: 'Noto Sans JP', 'Hiragino Mincho ProN', serif;
}
.ba-v5-h2-after{ color: #0F2447; }
.ba-v5-sub{
  font-size: clamp(20px, 2.6vw, 32px);
  font-weight: 900; color: #0F2447;
  margin: 0 0 14px; line-height: 1.4;
  letter-spacing: -0.005em;
}
.ba-v5-sub em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052, #8E703D);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.ba-v5-lead{
  font-size: 14.5px; line-height: 1.85;
  color: #5A6A82;
  margin: 0;
  font-weight: 600;
}

/* ===== BEFORE: 6 problem cards ===== */
.ba-v5-problems{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 32px;
}
@media(max-width: 880px){ .ba-v5-problems{ grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 560px){ .ba-v5-problems{ grid-template-columns: 1fr; } }
.ba-v5-pcard{
  position: relative;
  padding: 32px 24px 28px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  text-align: center;
  transition: transform 240ms, border-color 240ms, box-shadow 240ms;
}
.ba-v5-pcard:hover{
  transform: translateY(-3px);
  border-color: rgba(224,68,75,0.30);
  box-shadow: 0 16px 32px -16px rgba(15,36,71,0.18);
}
.ba-v5-pnum{
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  display: grid; place-items: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(180deg, #0F2447, #1A3563);
  color: #FFD568;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 14px; font-weight: 900;
  box-shadow: 0 6px 14px -2px rgba(15,36,71,0.30);
}
.ba-v5-picon{
  display: grid; place-items: center;
  width: 56px; height: 56px;
  margin: 8px auto 14px;
  color: #5A6A82;
}
.ba-v5-picon svg{ width: 36px; height: 36px; }
.ba-v5-ptext{
  font-size: 14.5px; line-height: 1.6;
  color: #25334A;
  margin: 0;
  font-weight: 700;
}
.ba-v5-ptext strong{
  color: #E0444B; font-weight: 900;
}

.ba-v5-warning{
  display: flex; align-items: center; justify-content: center;
  gap: 14px;
  max-width: 720px; margin: 0 auto;
  padding: 18px 28px;
  background: linear-gradient(180deg, #FFFBED 0%, #FFF5D5 100%);
  border: 1px solid rgba(196,160,82,0.45);
  border-radius: 14px;
  box-shadow: 0 12px 28px -10px rgba(196,160,82,0.30);
}
.ba-v5-warning-icon{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, #F4A23F, #E5841F);
  color: #fff;
  box-shadow: 0 4px 12px -2px rgba(244,162,63,0.4);
}
.ba-v5-warning-icon svg{ width: 22px; height: 22px; }
.ba-v5-warning-text{
  font-size: 15px; font-weight: 900;
  color: #5B4500;
  margin: 0;
  line-height: 1.5;
}
.ba-v5-warning-text strong{
  color: #C4A052;
  background: rgba(196,160,82,0.12);
  padding: 1px 6px; border-radius: 4px;
}

/* ===== Arrow between Before and After ===== */
.ba-v5-arrow{
  position: relative;
  display: grid; place-items: center;
  background: linear-gradient(180deg, #FAF8F2 0%, #FBF9F2 100%);
  padding: 16px 0 22px;
  color: #C4A052;
}
.ba-v5-arrow-cap{
  position: absolute;
  top: 0;
  width: 0; height: 0;
  border-left: 28px solid transparent;
  border-right: 28px solid transparent;
  border-top: 22px solid #FAF8F2;
}

/* ===== AFTER: dashboard + benefits + metrics ===== */
.ba-v5-head-after{
  margin-bottom: 48px;
}
.ba-v5-after-grid{
  display: grid;
  grid-template-columns: 1fr 2.4fr 1fr;
  gap: 18px;
  align-items: start;
  margin-bottom: 36px;
}
@media(max-width: 1080px){
  .ba-v5-after-grid{ grid-template-columns: 1fr; gap: 24px; }
}
.ba-v5-benefits{
  display: flex; flex-direction: column; gap: 14px;
}
@media(max-width: 1080px){
  .ba-v5-benefits{ flex-direction: row; flex-wrap: wrap; }
  .ba-v5-benefit{ flex: 1; min-width: 140px; }
}
.ba-v5-benefit{
  padding: 22px 18px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 12px;
  text-align: center;
  position: relative;
  transition: transform 240ms, border-color 240ms;
}
.ba-v5-benefit::before{
  content: '';
  position: absolute; top: -8px; right: -8px;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, #18B77A, #2ED98C);
  display: grid; place-items: center;
}
.ba-v5-benefit::after{
  content: '✓';
  position: absolute; top: -8px; right: -8px;
  width: 24px; height: 24px;
  display: grid; place-items: center;
  color: #fff;
  font-size: 13px; font-weight: 900;
}
.ba-v5-benefit:hover{
  transform: translateY(-2px);
  border-color: rgba(46,217,140,0.45);
}
.ba-v5-bicon{
  display: grid; place-items: center;
  width: 40px; height: 40px;
  margin: 0 auto 10px;
  color: #1F4FB6;
  background: linear-gradient(135deg, #E5EDF8, #F0F5FB);
  border-radius: 10px;
  border: 1px solid rgba(31,79,182,0.20);
}
.ba-v5-bicon svg{ width: 22px; height: 22px; }
.ba-v5-benefit p{
  font-size: 12.5px; line-height: 1.5;
  color: #25334A;
  margin: 0;
  font-weight: 700;
}
.ba-v5-benefit p strong{
  color: #0F2447; font-weight: 900;
}

.ba-v5-dash-wrap{
  background: #fff;
  border: 1px solid rgba(15,36,71,0.10);
  border-radius: 14px;
  padding: 8px;
  box-shadow: 0 30px 60px -22px rgba(15,36,71,0.30);
}
.ba-v5-dash-wrap .ba-dash{
  margin: 0;
  border: none;
  box-shadow: none;
  border-radius: 8px;
}

/* ===== Metrics strip ===== */
.ba-v5-metrics{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 28px;
}
@media(max-width: 760px){ .ba-v5-metrics{ grid-template-columns: repeat(2, 1fr); } }
.ba-v5-metric{
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 12px;
  transition: transform 240ms, border-color 240ms;
}
.ba-v5-metric:hover{
  transform: translateY(-2px);
  border-color: rgba(196,160,82,0.45);
}
.ba-v5-metric-icon{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 40px; height: 40px;
  border-radius: 10px;
  background: linear-gradient(135deg, #FBF8F0, #F4ECD3);
  color: #6B5025;
  border: 1px solid rgba(196,160,82,0.30);
}
.ba-v5-metric-icon svg{ width: 22px; height: 22px; }
.ba-v5-metric p{
  font-size: 13px; line-height: 1.5;
  color: #25334A;
  margin: 0;
  font-weight: 700;
}
.ba-v5-metric p strong{
  display: block;
  color: #C4A052;
  font-size: 16px; font-weight: 900;
  letter-spacing: -0.005em;
  margin-top: 2px;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}

/* ===== Mobile ===== */
@media(max-width: 760px){
  .ba-v5-block{ padding: 56px 16px; }
  .ba-v5-h2{ font-size: 28px; letter-spacing: 0.14em; }
  .ba-v5-sub{ font-size: 18px; }
  .ba-v5-lead{ font-size: 12.5px; }
  .ba-v5-pcard{ padding: 28px 18px 22px; }
  .ba-v5-ptext{ font-size: 13px; }
  .ba-v5-warning{ padding: 14px 18px; gap: 10px; }
  .ba-v5-warning-text{ font-size: 13px; }
  .ba-v5-metric{ padding: 14px 14px; gap: 10px; }
  .ba-v5-metric p{ font-size: 11.5px; }
  .ba-v5-metric p strong{ font-size: 14px; }
  .ba-v5-dash-wrap{ overflow-x: auto; }
}

/* =================================================
   BA v6 — 最小限のCSS（HTML構造を確認するため）
   後で2回目で見た目を整える
   ================================================= */
.ba-v6-section{
  padding: 0;
  background: #FBF9F2;
}
.ba-v6-shell{
  max-width: 1280px;
  margin: 0 auto;
}
.ba-v6-block{
  padding: clamp(56px, 7vw, 96px) clamp(20px, 4vw, 56px);
}
.ba-v6-before{ background: #FAF8F2; }
.ba-v6-after{
  background: linear-gradient(180deg, #FBF9F2 0%, #F4F1E5 100%);
}

/* 見出し */
.ba-v6-head{
  text-align: center;
  margin-bottom: 48px;
}
.ba-v6-h2{
  font-size: clamp(32px, 4.4vw, 56px);
  font-weight: 900;
  color: #0F2447;
  letter-spacing: 0.18em;
  margin: 0 0 14px;
  font-family: 'Noto Sans JP', 'Hiragino Mincho ProN', serif;
}
.ba-v6-sub{
  font-size: clamp(20px, 2.6vw, 32px);
  font-weight: 900;
  color: #0F2447;
  margin: 0;
  line-height: 1.4;
  letter-spacing: -0.005em;
}
.ba-v6-sub em{
  font-style: normal;
  background: linear-gradient(180deg, #C4A052, #8E703D);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}

/* === BEFORE: 主役3 === */
.ba-v6-main3{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1080px;
  margin: 0 auto 24px;
}
.ba-v6-main{
  padding: 36px 28px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 14px;
  text-align: center;
}
.ba-v6-main-text{
  font-size: 18px;
  font-weight: 700;
  color: #25334A;
  margin: 0;
  line-height: 1.7;
}
.ba-v6-main-text strong{
  color: #E0444B;
  font-weight: 900;
}

/* === BEFORE: 補足3 === */
.ba-v6-sub3{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  max-width: 1080px;
  margin: 0 auto 32px;
}
.ba-v6-subc{
  padding: 16px 18px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 10px;
  text-align: center;
  font-size: 13.5px;
  font-weight: 700;
  color: #5A6A82;
}
.ba-v6-subc strong{
  color: #25334A;
  font-weight: 900;
}

/* === BEFORE: 警告帯 === */
.ba-v6-warn{
  max-width: 720px;
  margin: 0 auto;
  padding: 18px 28px;
  background: linear-gradient(180deg, #FFFBED 0%, #FFF5D5 100%);
  border: 1px solid rgba(196,160,82,0.45);
  border-radius: 12px;
  text-align: center;
  font-size: 16px;
  font-weight: 900;
  color: #5B4500;
}
.ba-v6-warn strong{
  color: #C4A052;
  background: rgba(196,160,82,0.12);
  padding: 1px 8px;
  border-radius: 4px;
}

/* === 矢印 === */
.ba-v6-arrow{
  display: grid;
  place-items: center;
  padding: 18px 0 22px;
  color: #C4A052;
}

/* === AFTER: 中央ダッシュボード + 左右効果カード === */
.ba-v6-after-row{
  display: grid;
  grid-template-columns: 200px 1fr 200px;
  gap: 18px;
  align-items: center;
  margin-bottom: 32px;
  max-width: 1280px;
}
.ba-v6-effects{
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ba-v6-effect{
  padding: 22px 18px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 12px;
  text-align: center;
}
.ba-v6-effect p{
  font-size: 13.5px;
  font-weight: 700;
  color: #25334A;
  margin: 0;
  line-height: 1.5;
}
.ba-v6-effect p strong{
  color: #0F2447;
  font-weight: 900;
}

/* ダッシュボードのラッパー */
.ba-v6-dash-wrap{
  background: #fff;
  border: 1px solid rgba(15,36,71,0.10);
  border-radius: 14px;
  padding: 8px;
  box-shadow: 0 24px 50px -22px rgba(15,36,71,0.30);
}
.ba-v6-dash-wrap .ba-dash{
  margin: 0;
  border: none;
  box-shadow: none;
  border-radius: 8px;
}

/* === AFTER: 成果4つ === */
.ba-v6-outcomes{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  max-width: 1080px;
  margin: 0 auto;
}
.ba-v6-outcome{
  padding: 18px 20px;
  background: #fff;
  border: 1px solid #E5E9EF;
  border-radius: 10px;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #25334A;
  line-height: 1.5;
}
.ba-v6-outcome strong{
  display: block;
  color: #C4A052;
  font-size: 16px;
  font-weight: 900;
  margin-top: 4px;
}

/* =================================================
   BA v6 — 2回目（見た目を整える）追加CSS
   ================================================= */

/* === BEFORE: 主役カードに番号バッジ＋イラスト枠 === */
.ba-v6-main{
  position: relative;
  padding: 40px 28px 32px !important;
  transition: transform 240ms, border-color 240ms, box-shadow 240ms;
}
.ba-v6-main:hover{
  transform: translateY(-3px);
  border-color: rgba(224,68,75,0.30);
  box-shadow: 0 18px 38px -16px rgba(15,36,71,0.18);
}
.ba-v6-mnum{
  position: absolute; top: -16px; left: 50%; transform: translateX(-50%);
  display: grid; place-items: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(180deg, #0F2447, #1A3563);
  color: #FFD568;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 16px; font-weight: 900;
  box-shadow: 0 6px 14px -2px rgba(15,36,71,0.30);
}
.ba-v6-millust{
  display: grid; place-items: center;
  height: 100px;
  margin: 8px auto 18px;
}
.ba-v6-millust svg{ width: 100%; max-width: 140px; height: 100%; }
.ba-v6-main-text{
  font-size: 16px !important;
  line-height: 1.65 !important;
}

/* === BEFORE: 補足カード番号バッジ === */
.ba-v6-subc{
  display: flex !important;
  align-items: center !important;
  gap: 10px;
  text-align: left !important;
  padding: 14px 16px !important;
}
.ba-v6-snum{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: rgba(224,68,75,0.10);
  color: #B0383F;
  font-family: 'Inter','Noto Sans JP',sans-serif;
  font-size: 12px; font-weight: 900;
}

/* === BEFORE: 警告帯（アイコン付き） === */
.ba-v6-warn{
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 14px;
  max-width: 760px !important;
  text-align: left;
  box-shadow: 0 12px 28px -10px rgba(196,160,82,0.30);
}
.ba-v6-warn-icon{
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, #F4A23F, #E5841F);
  color: #fff;
  box-shadow: 0 4px 12px -2px rgba(244,162,63,0.4);
}
.ba-v6-warn-icon svg{ width: 22px; height: 22px; }
.ba-v6-warn-text{
  font-size: 16px;
  font-weight: 900;
  color: #5B4500;
  line-height: 1.5;
}

/* === AFTER: 効果カードに緑チェック＋アイコン === */
.ba-v6-effect{
  position: relative;
  padding: 24px 18px 22px !important;
  background: #fff !important;
}
.ba-v6-echk{
  position: absolute;
  top: -10px; right: -10px;
  display: grid; place-items: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #18B77A, #2ED98C);
  color: #fff;
  box-shadow: 0 4px 10px -2px rgba(24,183,122,0.4);
}
.ba-v6-echk svg{ width: 14px; height: 14px; }
.ba-v6-eicon{
  display: grid; place-items: center;
  width: 44px; height: 44px;
  margin: 0 auto 12px;
  border-radius: 12px;
  background: linear-gradient(135deg, #E5EDF8, #F0F5FB);
  color: #1F4FB6;
  border: 1px solid rgba(31,79,182,0.20);
}
.ba-v6-eicon svg{ width: 22px; height: 22px; }
.ba-v6-effect p{
  font-size: 13px !important;
  line-height: 1.55 !important;
}

/* === AFTER: 成果メトリクスにアイコン === */
.ba-v6-outcome{
  display: flex !important;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 22px 18px !important;
}
.ba-v6-oicon{
  display: grid; place-items: center;
  width: 48px; height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, #FBF8F0, #F4ECD3);
  color: #6B5025;
  border: 1px solid rgba(196,160,82,0.30);
}
.ba-v6-oicon svg{ width: 26px; height: 26px; }
.ba-v6-outcome p{
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: #5A6A82;
  text-align: center;
  line-height: 1.5;
}
.ba-v6-outcome p strong{
  display: block;
  color: #C4A052;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: -0.005em;
  margin-top: 4px;
  font-family: 'Inter','Noto Sans JP',sans-serif;
}

/* =================================================
   画像差し替え用（GPT画像をそのまま使う）
   ================================================= */
.as-img,
.ba-v6-img{
  max-width: 1280px;
  margin: 28px auto 0;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 60px -22px rgba(15,36,71,0.20);
}
.as-img img,
.ba-v6-img img{
  display: block;
  width: 100%;
  height: auto;
}
@media(max-width: 760px){
  .as-img,
  .ba-v6-img{
    margin-top: 18px;
    border-radius: 10px;
    box-shadow: 0 14px 32px -16px rgba(15,36,71,0.20);
  }
}

/* === Visually hidden（SEO/screen reader用に残すが視覚的に非表示） === */
.sr-only{
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* 画像のセクションは余白詰める（タイトル分） */
.about-service .as-img{ margin-top: 0; }
.ba-v6-before .ba-v6-img{ margin-top: 0; }
.ba-v6-after .ba-v6-img{ margin-top: 0; }
