/* ============================================================
   business.css — 事業内容ページ
   Figma file: cXgaasCaJjL2vNZRjM1rNy  node: 4595:22775
   ※ Figma画像URLは7日で失効します。本番では永続URLに差し替えてください。
   ============================================================ */

:root {
  --biz-blue:   #3a34ff;
  --biz-badge:  #1a15bb;
  --biz-navy-1: #020087;
  --biz-navy-2: #0300b3;
  --biz-gold:   #c6a700;
  --biz-text:   #4a5051;
  --biz-gray:   #707070;
  --biz-light:  #f3f3ff;
}

.business {
  min-width: 1512px;
  overflow-x: hidden;
  background-color: #fff;
}


/* ============================================================
   Hero
   ============================================================ */

.business__hero {
  position: relative;
  height: 780px;
  display: flex;
  align-items: center;
}

.business__hero-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.business__hero-bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.business__hero-bg-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 129, 0.45);
}

/* 装飾ストリップ */
.business__hero-strip {
  position: absolute;
  border-radius: 110px;
  transform: rotate(45deg);
  background-color: #fff;
  pointer-events: none;
  z-index: 1;
}

.business__hero-strip--a {
  width: 134px;
  height: 552px;
  left: -310px;
  top: 530px;
  opacity: 0.10;
}

.business__hero-strip--b {
  width: 96px;
  height: 372px;
  right: -80px;
  top: 200px;
  opacity: 0.12;
}

.business__hero-strip--c {
  width: 112px;
  height: 461px;
  left: 710px;
  top: -80px;
  opacity: 0.12;
}

.business__hero-inner {
    position: relative;
    z-index: 2;
    width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1250px;
}

/* 左テキスト */
.business__hero-left {
  display: flex;
  flex-direction: column;
  gap: 32px;
  width: 618px;
}

.business__hero-breadcrumb {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 1.5rem;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.03em;
  line-height: 1.18;
}

.business__hero-headings {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.business__hero-badge {
    display: inline-flex;
    align-items: center;
    background-color: var(--biz-badge);
    padding: 20px 0px 28px 22px;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 4.5625rem;
    color: #fff;
    letter-spacing: 0.04em;
    line-height: 0.74;
    white-space: nowrap;
    width: fit-content;
}

.business__hero-desc {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    font-size: 1.2rem;
    color: #fff;
    letter-spacing: 0.03em;
    line-height: 2.08;
}

/* 右ビジュアル */
.business__hero-visual {
  position: relative;
  width: 640px;
  height: 572px;
  flex-shrink: 0;
}

.business__hero-polygon,
.business__hero-polygon-stroke {
  position: absolute;
  left: 33px;
  top: 48px;
  width: 515px;
  height: 446px;
  object-fit: contain;
}

.business__hero-circle {
  position: absolute;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.business__hero-circle--center {
  left: 172px;
  top: 221px;
  width: 239px;
  height: 239px;
  background: linear-gradient(52.64deg, #5800ff 15%, #5ce1e6 84%);
  border: 10px solid #8ab1ff;
  box-shadow: 0 0 22px rgba(224, 242, 238, 0.6);
  flex-direction: column;
  gap: 9px;
  padding-top: 24px;
  padding-bottom: 11px;
}

.business__hero-circle--center img {
  width: 179px;
  height: auto;
}

.business__hero-circle--training,
.business__hero-circle--consult,
.business__hero-circle--dev {
  width: 171px;
  height: 171px;
  border-width: 7px;
  border-style: solid;
  padding: 7px;
}

.business__hero-circle--training {
  left: 0;
  top: 400px;
  background: radial-gradient(circle, #f6f3ff 0%, #dcdaff 70%, #b4b1ff 100%);
  border-color: #e9dcff;
  box-shadow: 0 0 15px #e9dcff;
}

.business__hero-circle--consult {
  left: 206px;
  top: 0;
  background: radial-gradient(circle, #e9f6ff 0%, #caeaff 70%, #a4dbff 100%);
  border-color: #caeaff;
  box-shadow: 0 0 15px #caeaff;
}

.business__hero-circle--dev {
  left: 428px;
  top: 400px;
  background: radial-gradient(circle, #f2fdff 0%, #d6f9ff 60%, #81edff 100%);
  border-color: #c0f6ff;
  box-shadow: 0 0 15px #caeaff;
}

.business__hero-circle--training img { width: 79px;  height: auto; }
.business__hero-circle--consult img  { width: 104px; height: auto; }
.business__hero-circle--dev img      { width: 81px;  height: auto; }

/* キャラクター */
.business__hero-character {
    position: absolute;
    left: 50%;
    bottom: -155px;
    z-index: 2;
    width: 249px;
    transform: translateX(-50%);
}

.business__hero-character-img {
  position: relative;
  width: 100%;
  height: auto;
}


/* ============================================================
   Implementation
   ============================================================ */

.business__impl {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    padding: 100px 0;
}

.business__impl-card {
    width: 100%;
    background: linear-gradient(to top, #020087 17%, #0300b3 96%);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 1200px;
}

.business__impl-inner {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 65px 0;
    max-width: 1100px;
}

/* 左テキスト */
.business__impl-left {
  width: 65%;
  display: flex;
  flex-direction: column;
  gap: 60px;
  padding-top: 26px;
}

.business__impl-label {
  position: relative;
  display: flex;
  align-items: center;
  white-space: nowrap;
  height: 40px;
}

.business__impl-label-en {
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--biz-gold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 2;
  z-index: 2;
}

.business__impl-label-watermark {
  position: absolute;
  left: 60px;
  top: -29px;
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  font-style: italic;
  font-size: 4.5rem;
  color: #fff;
  opacity: 0.24;
  letter-spacing: 0.01em;
  line-height: normal;
  text-transform: capitalize;
  pointer-events: none;
}

.business__impl-headings {
  display: flex;
  flex-direction: column;
  gap: 26px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
}
.business__impl-headings p {
    color: #fff;
    line-height: 1;
}

.business__impl-heading-sm {
  font-size: 3rem;
  letter-spacing: 0.06em;
}

.business__impl-heading-lg {
  font-size: 6.8125rem;
  letter-spacing: 0.03em;
}

.business__impl-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 1.125rem;
  color: #fff;
  letter-spacing: 0.06em;
  line-height: 2;
  width: 100%;
}
.business__impl-body p {
    line-height: 1.9;
    color: #fff;
}

/* 右: 写真3枚（absolute） */
.business__impl-photos {
    position: absolute;
    right: -95px;
    top: 90px;
    display: flex;
	z-index: 1;
}

.business__impl-photo {
  position: absolute;
  overflow: hidden;
  border-radius: 10px;
}

.business__impl-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.business__impl-photo--1 {
  top: -20px;
  right: 0;
  width: 312px;
  height: 322px;
}

.business__impl-photo--2 {
  top: 333px;
  right: -120px;
  width: 380px;
  height: 214px;
}

.business__impl-photo--3 {
  top: 596px;
  right: 45px;
  width: 365px;
  height: 270px;
}


/* ============================================================
   Service
   ============================================================ */

/* ============================================================
   service-swiper.css — サービス Swiper セクション
   Figma node: 4607:32672
   ※ Figma画像URLは7日で失効します。本番では永続URLに差し替えてください。
   ============================================================ */

:root {
  --biz-blue:   #3a34ff;
  --biz-badge:  #1a15bb;
  --biz-navy-1: #020087;
  --biz-navy-2: #0300b3;
  --biz-gold:   #c6a700;
  --biz-text:   #4a5051;
  --biz-gray:   #707070;
  --biz-light:  #f3f3ff;
}


/* ============================================================
   Section wrapper
   ============================================================ */

.svc {
  position: relative;
  padding: 280px 0 200px;
  overflow: hidden;
  background-color: #fff;
  width: 100%;
}

/* 背景イラスト */
.svc__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.svc__wave {
  position: absolute;
  bottom: 18px;
  left: -94px;
  width: 1806px;
  height: auto;
}

.svc__char-left {
  position: absolute;
  left: 453px;
  bottom: 250px;
  width: 290px;
  height: auto;
}

.svc__char-right {
  position: absolute;
  right: 20px;
  bottom: 100px;
  width: 290px;
  height: auto;
}

.svc__inner {
    position: relative;
    width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    max-width: 1200px;
}


/* ============================================================
   左カード: サービスリスト（静的）
   ============================================================ */

.svc-list {
  position: relative;
  z-index: 1;
  width: 64%;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 0 34px rgba(0, 0, 0, 0.07);
  padding: 58px 42px 55px 52px;
  display: flex;
  flex-direction: column;
  gap: 34px;
}

.svc-list__label {
  position: relative;
  display: flex;
  align-items: center;
  white-space: nowrap;
  color: var(--biz-blue);
  height: 40px;
}

.svc-list__label-en {
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 2;
}

.svc-list__label-watermark {
  position: absolute;
  left: 60px;
  top: -29px;
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  font-style: italic;
  font-size: 4.5rem;
  color: var(--biz-blue);
  opacity: 0.10;
  letter-spacing: 0.01em;
  line-height: normal;
  text-transform: capitalize;
  pointer-events: none;
}

.svc-list__desc {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 1.125rem;
  color: var(--biz-text);
  letter-spacing: 0.06em;
  line-height: 2;
  width: 580px;
}

.svc-list__items {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.svc-list__item {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: 0.3s ease-in-out;
}
.svc-list__item:hover {
    opacity: 0.8;
}

.svc-list__num {
  width: 56px;
  height: 56px;
  border-radius: 60px;
  border: 1px solid #ddd;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background-color: #fff;
  transition: background-color 0.3s;
}

.svc-list__num span {
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  font-style: italic;
  font-size: 1.625rem;
  color: var(--biz-blue);
  line-height: normal;
  transition: color 0.3s;
}

.svc-list__num--active {
  background-color: var(--biz-blue);
}

.svc-list__num--active span {
  color: #fff;
}

.svc-list__body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  line-height: 1.15;
}

.svc-list__sub {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 1rem;
  color: var(--biz-gray);
  letter-spacing: 0.02em;
}

.svc-list__title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 900;
  font-size: 1.625rem;
  color: var(--biz-blue);
  letter-spacing: 0.06em;
}


/* ============================================================
   右カード: Swiper コンテナ
   ============================================================ */

.svc-detail {
    position: absolute;
    right: 0;
    top: -179px;
    width: 55%;
    background-color: var(--biz-light);
    border-radius: 8px;
    box-shadow: 0 0 34px rgba(0, 0, 0, 0.07);
    overflow: hidden;
    z-index: 2;
}

/* ページネーションドット (右上 / absolute) */
.swiper-pagination-bullets.swiper-pagination-horizontal {
    position: absolute;
    right: 34px;
    top: 34px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 10;
    width: fit-content;
    height: fit-content;
    left: auto;
}

.svc-detail__dot {
    display: block;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background-color: #fff;
    cursor: pointer;
    transition: background-color 0.3s;
}

.svc-detail__dot--active {
  background-color: var(--biz-blue);
}

/* スライド番号 (左上 / absolute) */
.svc-detail__num {
  position: absolute;
  left: 34px;
  top: 24px;
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  font-style: italic;
  font-size: 3.375rem;
  color: var(--biz-blue);
  line-height: normal;
  z-index: 10;
  pointer-events: none;
  text-shadow: 0 0 14px rgba(255, 255, 255, 0.6);
}

/* Swiper リセット (reset.css 上書き) */
.svc-detail .swiper {
  width: 100%;
}


/* ============================================================
   スライドコンテンツ
   ============================================================ */

.svc-slide {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: center;
  padding: 38px 50px 51px;
}

/* 画像: カード左右いっぱいに広げる */
.svc-slide__img {
  width: calc(100% + 100px);
  margin: -38px -50px 0;
  height: 360px;
  overflow: hidden;
  flex-shrink: 0;
}

.svc-slide__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.svc-slide__text {
  display: flex;
  flex-direction: column;
  gap: 9px;
  text-align: center;
  line-height: 1.15;
  width: 100%;
}

.svc-slide__sub {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 1.25rem;
  color: #000;
  letter-spacing: 0.02em;
}

.svc-slide__title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 900;
  font-size: 2.25rem;
  color: var(--biz-blue);
  letter-spacing: 0.06em;
  line-height: 1;
}

.svc-slide__body {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 1.125rem;
  color: #000;
  letter-spacing: 0.06em;
  line-height: 1.79;
  width: 100%;
}

/* CTAボタン */
.svc-slide__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 260px;
  height: 57px;
  background: linear-gradient(to right, #5800ff, #5ce1e6);
  border-radius: 50px;
  padding: 16px 18px 16px 20px;
  text-decoration: none;
  flex-shrink: 0;
}

.svc-slide__cta-text {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 1rem;
  color: #fff;
  letter-spacing: 0.02em;
}

.svc-slide__cta-icon {
  font-size: 1.25rem;
  color: rgba(255, 255, 255, 0.8);
  line-height: 1;
}


/* ============================================================
   進捗バー (5秒アニメーション)
   ============================================================ */

@keyframes svc-progress-anim {
  from { width: 0%; }
  to   { width: 100%; }
}

.svc-detail__progress {
  height: 6px;
  background-color: #fff;
}

.svc-detail__progress-fill {
  height: 100%;
  width: 0;
  background-color: #03a9f4;
}

.svc-detail__progress-fill.is-running {
  animation: svc-progress-anim 10s linear forwards;
}

/* cta */
section#servicecta {
    position: relative;
    background: #EBF5FA;
}
.servicecta__inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 0 100px;
}

@media screen and (max-width: 1500px) {
/* （1500px以下のスタイルを記述） */
	.business__impl-photos {
    right: 0;
	}
	section.svc {
    padding-bottom: 120px;
	}
}

@media screen and (max-width: 1250px) {
/* （1250px以下のスタイルを記述） */
	/* mv */
	.business__hero-inner {
    padding-left: 4%;
    padding-right: 4%;
	}
	.business__hero-visual {
    width: 50%;
	}
	/* business */
	section.business__impl {
    padding-left: 4%;
    padding-right: 4%;
	}
	.business__impl-inner {
    flex-direction: column;
    gap: 50px;
    align-items: center;
	}
	.business__impl-photos {
    position: relative;
    display: flex;
    width: 100%;
    flex-direction: row;
    gap: 35px;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
	right: auto;
	}
	.business__impl-photo {
    position: relative;
    top: auto;
    right: auto;
	}
}

@media screen and (max-width: 1200px) {
/* （1200px以下のスタイルを記述） */
	section.business__hero {
    height: auto;
	}
	.business__hero-inner {
    flex-direction: column;
    padding: 120px 0;
	}
	section.svc {
    padding-bottom: 100px;
	}
	.svc__inner {
    padding-left: 4%;
    padding-right: 4%;
	flex-direction: column;
	align-items: center;
	}
	.svc-detail {
    position: relative;
    top: auto;
    right: auto;
    margin-top: -80px;
    width: 60%;
	}
	.svc-list {
    width: 70%;
    padding-bottom: 160px;
	}
	.servicecta__inner {
    padding-left: 4%;
    padding-right: 4%;
	}
}

@media screen and (max-width: 1000px) {
/* （1000px以下のスタイルを記述） */
	.business__hero-visual {
    width: 70%;
	}
	section.business__impl {
    padding-bottom: 20px;
	}
	.business__impl-left {
    width: 88%;
	}
	section.svc {
    padding-top: 110px;
	}
	.svc-list {
    width: 80%;
	}
	.svc-detail {
    width: 70%;
	}
	.business__impl-photos {
    top: auto;
	}
}

@media screen and (max-width: 767px) {
/* （ここにモバイル用スタイルを記述） */
	/* mv */
	.business__hero-left {
    width: 100%;
    align-items: center;
	}
	.business__hero-badge {
    font-size: 2.4rem;
    padding: 15px 0px 22px 12px;
	}
	p.business__hero-desc {
    padding-left: 4%;
    padding-right: 4%;
	}
	p.business__hero-desc br {
    display: none;
	}
	.business__hero-visual {
    width: 100%;
	height: auto;
	}
	.business__hero-character {
    width: 180px;
	}
	/* hero under */
	section.business__impl {
    padding-top: 50px;
	}
	.business__impl-inner {
    padding: 30px 0;
	}
	.business__impl-label {
    height: auto;
	}
	span.business__impl-label-en {
    text-align: center;
    width: 100%;
	}
	.business__impl-label-watermark {
    left: 50%;
    top: 30%;
    transform: translateX(-50%);
    font-size: 2.2rem;
	}
	p.business__impl-heading-sm {
    font-size: 1.6rem;
    transform: translateX(12px);
	}
	p.business__impl-heading-lg {
    font-size: 3.2125rem;
    transform: translateX(21px);
	}
	.business__impl-body p br {
    display: none;
	}
	.business__impl-photo {
    width: 86%;
	}
	/* service */
	section.svc {
    padding-top: 40px;
	}
	.svc__bg img {
    height: 1200px;
    object-fit: cover;
    object-position: center;
	}
	.svc-list {
    width: 100%;
    padding: 40px 25px 120px 25px;
	}
	span.svc-list__label-en {
    text-align: center;
    width: 100%;
	}
	span.svc-list__label-watermark {
    left: 50%;
    top: 30%;
    transform: translateX(-50%);
    font-size: 2.2rem;
	}
	.svc-list p.svc-list__desc {
    width: 100%;
	}
	p.svc-list__desc br {
    display: none;
	}
	.svc-detail {
    width: 92%;
	}
	/* swiper inner */
	.svc-detail__num {
    top: 9px;
    left: 15px;
    font-size: 2.5rem;
	}
	.swiper-pagination-bullets.swiper-pagination-horizontal {
    right: 16px;
    top: 18px;
	}
	.svc-slide {
    padding: 38px 20px 30px;
	}
	.svc-slide__img {
    height: 220px;
	}
	.svc-slide__title {
    font-size: 1.65rem;
	}
	.svc-slide__title {
    font-size: 1.65rem;
	}
	.svc-list__sub {
    font-size: 0.8rem;
	}
	.svc-list__title {
    font-size: 1.325rem;
	}
}