@charset "UTF-8";
/* --------------------------------------------------
 ※※※※※※※※※※※※※※※※※※※※※※※※
 AWSページ用
 このファイルはsassでコンパイルされています
 以下の内容を変更したい場合は構成するscssファイルを
 ご確認ください
 ※※※※※※※※※※※※※※※※※※※※※※※※
-------------------------------------------------- */
@import "../common.css";
:root {
  --color-s-black: #1c242c;
  --color-s-gray-dark: #5d6268;
  --color-s-gray-base: #bebebe;
  --color-s-gray-middle: #e2e2e2;
  --color-s-gray-light: #f5f5f5;
}

:root {
  --color-s-white: #fff;
  --color-s-main-dark: #dd4200;
  --color-s-main-base: #ed6103;
  --color-s-main-medium: #f95;
  --color-s-main-light: #fff0e0;
  --color-s-main-pale: #f8f5f0;
}

/* ------------------------------
  base
------------------------------ */
html {
  background-color: #fff;
}
html.is-fixed {
  height: 100%;
  overflow-y: scroll;
}

body {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  color: var(--color-s-black);
  font-family: var(--font-family-jp);
  font-size: var(--font-m);
  font-weight: var(--font-weight-normal);
  letter-spacing: 0.05em;
  line-height: var(--line-m);
  word-wrap: break-word;
  overflow-wrap: anywhere;
  image-rendering: auto;
  container-type: inline-size;
  container-name: body;
}
.is-fixed body {
  position: fixed;
  width: 100%;
}

form {
  display: contents;
}

img {
  max-width: 100%;
  max-height: 100%;
  vertical-align: middle;
  image-rendering: auto;
}

a {
  transition: var(--trans-default);
}

input,
textarea,
select {
  font-family: var(--font-family-jp);
}

button {
  transition: var(--trans-default);
  font-family: var(--font-family-jp);
}
@media (any-hover: hover) {
  button:hover {
    cursor: pointer;
  }
}

.only-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  border: 0;
  pointer-events: none;
}

@media screen and (max-width: 768.9px) {
  .is-onlyPC {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .is-onlySP {
    display: none !important;
  }
}

/* ------------------------------
  button-mixin
------------------------------ */
/* ------------------------------
  service-button-primary
------------------------------ */
.service-button-primary {
  display: flex;
  position: relative;
  box-sizing: border-box;
  align-items: center;
  width: 100%;
  min-height: 48px;
  padding: 10px 48px 10px 24px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 800px;
  background-color: var(--color-s-main-base);
  color: #fff;
  font-weight: var(--font-weight-bold);
  text-decoration: none;
}
@media screen and (max-width: 768.9px) {
  .service-button-primary {
    max-width: 330px;
  }
}
@media screen and (min-width: 769px) {
  .service-button-primary {
    width: 400px;
    padding: 16px 44px 16px 32px;
    font-size: var(--font-l);
  }
}
.service-button-primary::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  box-sizing: border-box;
  width: 28px;
  height: 28px;
  transform: translateY(-50%);
  transition: background-color var(--trans-default), border-color var(--trans-default);
  border: 1px solid var(--color-s-main-base);
  border-radius: 50%;
  background-color: #fff;
}
.service-button-primary::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  width: 12px;
  height: 12px;
  transform: translateY(-50%);
  transition: var(--color-s-main-base) var(--trans-default);
  background-color: var(--color-s-main-base);
  mask: url("../../../assets/images/service/icon/ico_arrow_right.svg") no-repeat center/contain;
}
@media (any-hover: hover) {
  .service-button-primary:hover {
    border-color: var(--color-s-main-dark);
    background-color: var(--color-s-main-dark);
  }
  .service-button-primary:hover::before {
    border-color: var(--color-s-white);
    background-color: var(--color-s-main-dark);
  }
  .service-button-primary:hover::after {
    background-color: var(--color-s-white);
  }
}

/* ------------------------------
  service-button-secondary
------------------------------ */
.service-button-secondary {
  display: flex;
  position: relative;
  box-sizing: border-box;
  align-items: center;
  width: 100%;
  min-height: 48px;
  padding: 10px 48px 10px 24px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 800px;
  background-color: #fff;
  color: var(--color-s-main-base);
  font-weight: var(--font-weight-bold);
  text-decoration: none;
}
@media screen and (max-width: 768.9px) {
  .service-button-secondary {
    max-width: 330px;
  }
}
@media screen and (min-width: 769px) {
  .service-button-secondary {
    width: 400px;
    padding: 16px 44px 16px 32px;
    font-size: var(--font-l);
  }
}
.service-button-secondary::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  box-sizing: border-box;
  width: 28px;
  height: 28px;
  transform: translateY(-50%);
  transition: background-color var(--trans-default), border-color var(--trans-default);
  border: 1px solid var(--color-s-main-base);
  border-radius: 50%;
  background-color: #fff;
}
.service-button-secondary::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  width: 12px;
  height: 12px;
  transform: translateY(-50%);
  transition: #fff var(--trans-default);
  background-color: var(--color-s-main-base);
  mask: url("../../../assets/images/service/icon/ico_arrow_right.svg") no-repeat center/contain;
}
@media (any-hover: hover) {
  .service-button-secondary:hover {
    background-color: var(--color-s-main-light);
    color: var(--color-s-main-dark);
  }
  .service-button-secondary:hover::before {
    border-color: var(--color-s-main-base);
    background-color: var(--color-s-main-base);
  }
  .service-button-secondary:hover::after {
    background-color: var(--color-s-white);
  }
}

/* ------------------------------
  service-cta
------------------------------ */
.service-cta {
  padding: 40px 24px;
  background-color: var(--color-s-black);
}
@media screen and (min-width: 769px) {
  .service-cta {
    padding: 40px 56px;
  }
}
.service-cta__inner {
  max-width: 1100px;
  margin-inline: auto;
}
.service-cta__button-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin-top: 32px;
}

/* ------------------------------
  service-cta-menu
------------------------------ */
.service-cta-menu {
  display: grid;
  margin-block: 32px 0;
  padding-left: 0;
  list-style: none;
  gap: 16px;
}
@media screen and (min-width: 769px) {
  .service-cta-menu {
    grid-template-columns: repeat(2, minmax(0, 450px));
    justify-content: center;
    margin-top: 56px;
  }
}
.service-cta-menu__item {
  display: flex;
  flex: 1;
}
.service-cta-menu__link {
  display: flex;
  position: relative;
  align-items: center;
  width: 100%;
  padding: 16px 60px 16px 16px;
  border-radius: 8px;
  background-color: #fff;
  color: #000;
  text-decoration: none;
  gap: 16px;
}
.service-cta-menu__link::before {
  content: "";
  position: absolute;
  right: 16px;
  box-sizing: border-box;
  width: 28px;
  height: 28px;
  transition: border-color var(--trans-default);
  border: 1px solid var(--color-s-black);
  border-radius: 50%;
}
.service-cta-menu__link::after {
  content: "";
  position: absolute;
  right: 24px;
  width: 12px;
  height: 12px;
  transition: background-color var(--trans-default);
  background-color: var(--color-s-black);
  mask: url("../../../assets/images/service/icon/ico_arrow_right.svg") no-repeat center/contain;
}
@media (any-hover: hover) {
  .service-cta-menu__link:hover::before {
    border-color: var(--color-s-main-dark);
  }
  .service-cta-menu__link:hover::after {
    background-color: var(--color-s-main-dark);
  }
}
.service-cta-menu__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  overflow: hidden;
  border-radius: 8px;
}
.service-cta-menu__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.service-cta-menu__text {
  margin-block: 0;
  transition: color var(--trans-default);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
@media (any-hover: hover) {
  .service-cta-menu__link:hover .service-cta-menu__text {
    color: var(--color-s-main-dark);
  }
}
.service-cta-menu__sub {
  margin-block: 2px 0;
  color: var(--color-s-gray-dark);
  font-size: var(--font-xs);
}

/* ------------------------------
  service-heading
------------------------------ */
.service-heading {
  margin-block: 0;
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
}
@media screen and (min-width: 769px) {
  .service-heading {
    font-size: var(--font-3xl);
  }
}
.service-heading b {
  display: block;
  font-size: var(--font-4xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
@media screen and (min-width: 769px) {
  .service-heading b {
    font-size: var(--font-5xl);
  }
}

/* ------------------------------
  service-heading02
------------------------------ */
.service-heading02 {
  margin-block: 0;
  font-size: var(--font-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
  text-align: center;
}
.service-heading02--on-bg {
  color: #fff;
}
@media screen and (min-width: 769px) {
  .service-heading02 {
    font-size: var(--font-4xl);
  }
}
.service-heading02__sub {
  display: block;
  color: var(--color-s-main-base);
  font-size: var(--font-s);
}
@media screen and (min-width: 769px) {
  .service-heading02__sub {
    font-size: var(--font-m);
  }
}
.service-heading02__deco {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-block: 4px 12px;
  gap: 8px;
}
.service-heading02__deco span {
  width: 4px;
  height: 4px;
  border-radius: 1px;
  background-color: var(--color-s-main-base);
}
.service-heading02__deco::before, .service-heading02__deco::after {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 1px;
  background-color: var(--color-s-main-base);
}
@media screen and (min-width: 769px) {
  .service-heading02__deco {
    margin-bottom: 16px;
  }
}

/* ------------------------------
  service-heading03
------------------------------ */
.service-heading03 {
  margin-block: 0;
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.service-heading03 span {
  display: block;
  color: var(--color-s-main-base);
  font-size: var(--font-s);
}

/* ------------------------------
  service-heading04
------------------------------ */
.service-heading04 {
  position: relative;
  width: fit-content;
  margin-block: 0;
  padding-inline: 10px;
  font-size: var(--font-s);
  font-weight: var(--font-weight-bold);
}
.service-heading04::before, .service-heading04::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 1px;
  height: 16px;
  transform: translateY(-50%);
  background-color: var(--color-s-black);
  rotate: 20deg;
}
.service-heading04::before {
  left: 0;
}
.service-heading04::after {
  right: 6px;
}

/* ------------------------------
  service-tag-primary
------------------------------ */
.service-tag-primary {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 4px;
  background-color: var(--color-s-main-base);
  color: #fff;
  font-size: var(--font-2xs);
}

/* ------------------------------
  service-tag-secondary
------------------------------ */
.service-tag-secondary {
  padding: 4px 8px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 4px;
  background-color: #fff;
  color: var(--color-s-main-base);
  font-size: var(--font-2xs);
}

/* ------------------------------
  service-tag-tertiary
------------------------------ */
.service-tag-tertiary {
  padding: 4px 8px;
  border-radius: 4px;
  background-color: var(--color-s-black);
  color: #fff;
  font-size: var(--font-2xs);
}

/* ------------------------------
  service-tag-quaternary
------------------------------ */
.service-tag-quaternary {
  padding: 4px 8px;
  border-radius: 4px;
  background-color: var(--color-s-gray-light);
  color: var(--color-s-black);
  font-size: var(--font-2xs);
}

/* ------------------------------
  service-text
------------------------------ */
.service-text {
  margin-block: 12px 0;
  font-size: var(--font-s);
}
.service-text--on-bg {
  color: #fff;
}
@media screen and (min-width: 769px) {
  .service-text {
    margin-top: 16px;
    font-size: var(--font-m);
    text-align: center;
  }
}

/* ------------------------------
  service-text-lead
------------------------------ */
.service-text-lead {
  margin-block: 16px 0;
  font-size: var(--font-xs);
}
@media screen and (min-width: 769px) {
  .service-text-lead {
    font-size: var(--font-m);
  }
}

/* --------------------------------------------------
 ※※※※※※※※※※※※※※※※※※※※※※※※
 AWSページ まとめ用
 ※※※※※※※※※※※※※※※※※※※※※※※※
-------------------------------------------------- */
/* ------------------------------
  aws-top-approach
------------------------------ */
.aws-top-approach {
  margin-top: 32px;
}
@media screen and (min-width: 769px) {
  .aws-top-approach {
    margin-top: 56px;
  }
}
.aws-top-approach__box {
  display: flex;
  flex-direction: column;
  gap: 64px;
}
@media (width >= 910px) {
  .aws-top-approach__box {
    flex-direction: row;
    justify-content: center;
  }
}
.aws-top-approach__section {
  display: flex;
  flex-direction: column;
  padding: 8px;
  border-radius: 16px;
  background-color: var(--color-s-gray-dark);
}
@media screen and (min-width: 769px) {
  .aws-top-approach__section {
    flex: 1;
    padding: 16px;
  }
}
.aws-top-approach__section--after {
  position: relative;
  background-color: var(--color-s-main-base);
}
.aws-top-approach__section--after::before {
  content: "";
  position: absolute;
  top: -64px;
  left: 50%;
  width: 64px;
  height: 64px;
  transform: translateX(-50%);
  background: url("../../../assets/images/service/aws/ico_triangle_down.svg") no-repeat center/contain;
}
@media (width >= 910px) {
  .aws-top-approach__section--after::before {
    top: 50%;
    left: -64px;
    transform: translate(0, -50%);
    background-image: url("../../../assets/images/service/aws/ico_triangle_right.svg");
  }
}
.aws-top-approach__heading {
  margin-block: 0 8px;
  color: var(--color-s-white);
  font-size: var(--font-m);
  font-weight: var(--font-weight-bold);
  text-align: center;
}
@media screen and (min-width: 769px) {
  .aws-top-approach__heading {
    margin-bottom: 16px;
    font-size: var(--font-l);
  }
}
.aws-top-approach__inner {
  flex: 1;
  padding: 16px;
  border-radius: 8px;
  background-color: var(--color-s-white);
}
@media screen and (min-width: 769px) {
  .aws-top-approach__inner {
    padding: 24px;
  }
}
.aws-top-approach__figure {
  display: flex;
  justify-content: center;
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-approach__figure {
    gap: 16px;
  }
}
.aws-top-approach__figure-item {
  display: flex;
  box-sizing: border-box;
  flex-direction: column;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  min-width: 90px;
  padding: 8px;
  border-radius: 8px;
  background-color: var(--color-s-gray-middle);
  gap: 12px;
}
@media (width >= 1120px) {
  .aws-top-approach__figure-item {
    width: 100%;
    max-width: 150px;
    padding: 8px 16px;
  }
}
.aws-top-approach__section--after .aws-top-approach__figure-item {
  background-color: var(--color-s-main-light);
}
.aws-top-approach__image {
  height: 40px;
}
@media (width >= 1120px) {
  .aws-top-approach__image {
    height: 60px;
  }
}
.aws-top-approach__figure-item:not(:has(.aws-top-approach__label)) .aws-top-approach__image {
  height: 50px;
}
@media (width >= 1120px) {
  .aws-top-approach__figure-item:not(:has(.aws-top-approach__label)) .aws-top-approach__image {
    height: 70px;
  }
}
.aws-top-approach__image img {
  width: auto;
  height: 100%;
}
.aws-top-approach__label {
  margin-block: 0;
  font-size: var(--font-2xs);
  font-weight: var(--font-weight-bold);
  text-align: center;
}
@media screen and (min-width: 769px) {
  .aws-top-approach__label {
    font-size: var(--font-s);
  }
}
.aws-top-approach__arrow {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  color: var(--color-s-gray-dark);
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  gap: 10px;
}
@media screen and (min-width: 769px) {
  .aws-top-approach__arrow {
    font-size: var(--font-s);
  }
}
.aws-top-approach__arrow::before {
  content: "";
  width: 24px;
  height: 24px;
  background-color: var(--color-s-gray-dark);
  mask: url("../../../assets/images/service/icon/ico_arrow_right.svg") no-repeat center/contain;
}
.aws-top-approach__cycle {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  padding: 5px;
  background: url("../../../assets/images/service/aws/ico_cycle_arrow.svg") no-repeat center/contain;
  color: var(--color-s-main-base);
  font-size: var(--font-2xs);
  font-weight: var(--font-weight-bold);
}
@media screen and (min-width: 769px) {
  .aws-top-approach__cycle {
    padding: 12px;
    font-size: var(--font-s);
  }
}
.aws-top-approach__message {
  margin-block: 40px 0;
  color: var(--color-s-main-base);
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-l);
  text-align: center;
}
@media screen and (min-width: 769px) {
  .aws-top-approach__message {
    margin-block: 56px 0;
  }
}
.aws-top-approach__line {
  display: block;
  margin-top: 8px;
}
.aws-top-approach__highlight {
  display: inline-block;
  margin-inline: 4px;
  padding: 2px 8px 0;
  border-radius: 8px;
  background-color: var(--color-s-main-light);
}
.aws-top-approach__highlight b {
  padding-top: 0.1em;
  background-image: radial-gradient(circle at center, var(--color-s-main-base) 20%, transparent 20%);
  background-repeat: repeat-x;
  background-position: top right;
  background-size: 1em 0.3em;
  font-size: var(--font-3xl);
  font-weight: var(--font-weight-bold);
}

/* ------------------------------
  aws-top-approach-merit
------------------------------ */
.aws-top-approach-merit {
  display: grid;
  margin-block: 24px 0;
  padding-left: 0;
  list-style: none;
  gap: 8px;
}
.aws-top-approach-merit__item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--font-s);
}
.aws-top-approach-merit__item::before {
  content: "";
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background-color: var(--color-s-main-base);
  mask: url("../../../assets/images/service/icon/ico_check.svg") no-repeat center/contain;
}

/* ------------------------------
  aws-top-approach-demerit
------------------------------ */
.aws-top-approach-demerit {
  display: grid;
  margin-block: 28px 0;
  padding-left: 0;
  list-style: none;
  gap: 8px;
}
.aws-top-approach-demerit__item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--font-s);
}
.aws-top-approach-demerit__item::before {
  content: "";
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background-color: var(--color-s-gray-dark);
  mask: url("../../../assets/images/service/icon/ico_close.svg") no-repeat center/contain;
}

/* ------------------------------
  aws-top-article-list
------------------------------ */
.aws-top-article-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-block: 32px 0;
  padding-left: 0;
  list-style: none;
}
@media screen and (min-width: 769px) {
  .aws-top-article-list {
    flex-direction: row;
    gap: 24px;
    margin-block: 56px 0;
  }
}
@media screen and (min-width: 769px) {
  .aws-top-article-list__item {
    width: calc((100% - 48px) / 3);
  }
}
.aws-top-article-list__link {
  display: block;
  box-sizing: border-box;
  height: 100%;
  padding: 24px;
  overflow: hidden;
  border-radius: 16px;
  box-shadow: 4px 4px 16px rgba(0, 0, 0, 0.16);
  color: var(--color-s-black);
  text-decoration: none;
}
@media screen and (min-width: 769px) {
  .aws-top-article-list__link {
    border: solid 3px var(--color-s-white);
  }
}
@media (any-hover: hover) {
  .aws-top-article-list__link:hover {
    border: solid 3px var(--color-s-main-pale);
    box-shadow: none;
  }
  .aws-top-article-list__link:hover .aws-top-article-list__title {
    color: var(--color-s-main-dark);
  }
}
.aws-top-article-list__image {
  width: 100%;
  height: 180px;
  overflow: hidden;
  border-radius: 8px;
}
.aws-top-article-list__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.aws-top-article-list__title {
  margin-block: 24px 0;
  transition: color var(--trans-default);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-article-list__text {
  margin-block: 12px 0;
  font-size: var(--font-s);
  line-height: var(--line-s);
}

/* ------------------------------
  aws-top-build-step
------------------------------ */
.aws-top-build-step {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-block: 0;
  padding-left: 0;
  list-style: none;
  gap: 4px;
}
@media (width >= 950px) {
  .aws-top-build-step {
    flex-direction: row;
    justify-content: center;
  }
}
.aws-top-build-step__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
@media (width >= 950px) {
  .aws-top-build-step__item {
    flex-direction: row;
    width: 25%;
  }
}
.aws-top-build-step__item:not(:last-child)::after {
  content: "";
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background-color: #000;
  mask: url("../../../assets/images/service/aws/ico_triangle_down.svg") no-repeat center/contain;
}
@media (width >= 950px) {
  .aws-top-build-step__item:not(:last-child)::after {
    mask: url("../../../assets/images/service/aws/ico_triangle_right.svg") no-repeat center/contain;
  }
}
@media (width >= 950px) {
  .aws-top-build-step__item:last-child {
    width: calc(25% - 20px);
  }
}
.aws-top-build-step__content {
  width: 100%;
}
.aws-top-build-step__title {
  margin-block: 0;
  border-radius: 8px 8px 0 0;
  background-color: var(--color-s-main-base);
  color: var(--color-s-white);
  font-family: var(--font-family-en);
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  text-align: center;
}
.aws-top-build-step__text {
  margin-block: 0;
  padding: 8px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 0 0 8px 8px;
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
  text-align: center;
}

/* ------------------------------
  aws-top-case
------------------------------ */
.aws-top-case {
  margin-top: 40px;
  overflow: hidden;
  border-radius: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-case {
    margin-top: 56px;
  }
}
.aws-top-case__header {
  padding: 16px;
  background-color: var(--color-s-black);
}
@media screen and (min-width: 769px) {
  .aws-top-case__header {
    padding: 16px 24px;
  }
}
.aws-top-case__heading-box {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.aws-top-case__number {
  position: relative;
  margin-block: 0;
  padding-inline: 10px;
  color: var(--color-s-main-base);
  font-family: var(--font-family-en);
  font-size: var(--font-s);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-case__number span {
  margin-left: 4px;
  font-size: var(--font-m);
}
.aws-top-case__number::before, .aws-top-case__number::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 1px;
  height: 12px;
  transform: translateY(-50%);
  background-color: var(--color-s-main-base);
  rotate: 20deg;
}
.aws-top-case__number::before {
  left: 0;
}
.aws-top-case__number::after {
  right: 4px;
}
.aws-top-case__heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-block: 0;
  color: var(--color-s-white);
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
  gap: 8px;
}
.aws-top-case__tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-block: 0;
  padding: 16px 16px 0;
  background-color: var(--color-s-white);
  list-style: none;
}
@media screen and (min-width: 769px) {
  .aws-top-case__tag-list {
    padding: 0;
    background-color: transparent;
  }
}
.aws-top-case__tag {
  display: flex;
}
.aws-top-case__inner {
  padding: 16px;
  background-color: var(--color-s-white);
}
@media screen and (min-width: 769px) {
  .aws-top-case__inner {
    padding: 24px;
  }
}
.aws-top-case__title-box {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-case__title-box {
    flex-direction: row;
    align-items: center;
  }
}
.aws-top-case__title {
  margin-block: 0;
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
}
.aws-top-case__image {
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
  aspect-ratio: 295/174;
}
.aws-top-case__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (min-width: 769px) {
  .aws-top-case__image {
    width: 140px;
  }
}
.aws-top-case__point-list {
  display: grid;
  margin-block: 16px 0;
  padding-left: 0;
  list-style: none;
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-case__point-list {
    grid-template-columns: 1fr 350px;
  }
}
.aws-top-case__point-item {
  display: flex;
  flex-direction: column;
  padding: 16px;
  border: 1px solid var(--color-s-main-light);
  border-radius: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-case__point-item:has(.aws-top-case-figure) {
    grid-column: 2/3;
    grid-row: 1/4;
  }
}
.aws-top-case__point-label {
  position: relative;
  margin-block: 0;
  padding-left: 20px;
  font-size: var(--font-s);
  font-weight: var(--font-weight-bold);
}
.aws-top-case__point-label::before {
  content: "";
  position: absolute;
  top: calc(50% - 8px);
  left: 0;
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.aws-top-case__point-label--problem::before {
  background-image: url("../../../assets/images/service/aws/ico_alert.svg");
}
.aws-top-case__point-label--solution::before {
  background-image: url("../../../assets/images/service/aws/ico_idea.svg");
}
.aws-top-case__point-label--result::before {
  background-image: url("../../../assets/images/service/aws/ico_check.svg");
}
.aws-top-case__point-label--architecture::before {
  background-image: url("../../../assets/images/service/aws/ico_sitemap.svg");
}
.aws-top-case__point-label span {
  font-size: var(--font-xs);
}
.aws-top-case__point-text {
  margin-block: 8px 0;
  font-size: var(--font-xs);
}

/* ------------------------------
  aws-top-case-figure
------------------------------ */
.aws-top-case-figure {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding-top: 16px;
  background-color: var(--color-s-white);
}
@media screen and (min-width: 769px) {
  .aws-top-case-figure {
    justify-content: center;
    margin-block: auto;
  }
}
.aws-top-case-figure__arrow-box {
  display: flex;
  align-items: center;
  gap: 8px;
}
.aws-top-case-figure__arrow {
  width: 12px;
  height: 12px;
  background-color: var(--color-s-gray-base);
  mask: url("../../../assets/images/service/icon/ico_arrow_down.svg") no-repeat center/contain;
}
.aws-top-case-figure__arrow--right-slope {
  transform: rotate(45deg);
}
.aws-top-case-figure__arrow--left-slope {
  transform: rotate(-45deg);
}
.aws-top-case-figure__item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.aws-top-case-figure__tag {
  padding: 4px 12px;
  border: 1px solid var(--color-s-main-medium);
  border-radius: 4px;
  background-color: var(--color-s-main-light);
  font-size: var(--font-xs);
  text-align: center;
}

/* ------------------------------
  aws-top-case-list
------------------------------ */
.aws-top-case-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
  margin-block: 12px 0;
  padding-left: 0;
  list-style: none;
}
@media screen and (min-width: 769px) {
  .aws-top-case-list {
    margin-top: 24px;
  }
}
.aws-top-case-list__item {
  display: grid;
  grid-row: span 5;
  grid-template-rows: subgrid;
  gap: 0;
}
.aws-top-case-list__link {
  display: grid;
  box-sizing: border-box;
  grid-row: span 5;
  grid-template-rows: subgrid;
  align-items: flex-start;
  height: 100%;
  padding: 32px 24px;
  border-radius: 16px;
  background-color: var(--color-s-white);
  box-shadow: 4px 4px 16px rgba(28, 36, 44, 0.16);
  color: var(--color-s-black);
  line-height: var(--line-s);
  text-decoration: none;
}
@media screen and (min-width: 769px) {
  .aws-top-case-list__link {
    border: solid 3px var(--color-s-white);
  }
}
@media (any-hover: hover) {
  .aws-top-case-list__link:hover {
    border: solid 3px var(--color-s-main-pale);
    box-shadow: none;
  }
  .aws-top-case-list__link:hover .aws-top-case-list__title {
    color: var(--color-s-main-dark);
  }
}
.aws-top-case-list__image {
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
  aspect-ratio: 280/150;
}
@media screen and (min-width: 769px) {
  .aws-top-case-list__image {
    max-width: 280px;
    margin: 0 auto;
  }
}
.aws-top-case-list__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.aws-top-case-list__company {
  margin-block: 16px 0;
  font-size: var(--font-xs);
}
.aws-top-case-list__title {
  margin-block: 4px 0;
  transition: color var(--trans-default);
  font-size: var(--font-m);
  font-weight: var(--font-weight-bold);
}
.aws-top-case-list__text {
  margin-block: 16px 0;
  font-size: var(--font-s);
}
.aws-top-case-list__tag-list {
  display: flex;
  flex-wrap: wrap;
  margin-block: 16px 0;
  padding-left: 0;
  list-style: none;
  gap: 4px;
}
.aws-top-case-list__tag {
  display: flex;
}

/* ------------------------------
  aws-top-case-menu
------------------------------ */
.aws-top-case-menu {
  margin-top: 32px;
}
@media screen and (min-width: 769px) {
  .aws-top-case-menu {
    margin-top: 56px;
  }
}
.aws-top-case-menu__list {
  display: grid;
  gap: 8px;
  margin-block: 12px 0;
  padding-left: 0;
  list-style: none;
}
@media screen and (min-width: 769px) {
  .aws-top-case-menu__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-top: 16px;
  }
}
@media screen and (min-width: 769px) {
  .aws-top-case-menu__item {
    display: flex;
  }
}
.aws-top-case-menu__link {
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  border-radius: 8px;
  background-color: var(--color-s-white);
  box-shadow: 4px 4px 8px rgba(26, 36, 44, 0.12);
  color: var(--color-s-black);
  text-decoration: none;
  gap: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-case-menu__link {
    border: solid 3px var(--color-s-white);
  }
}
@media (any-hover: hover) {
  .aws-top-case-menu__link:hover {
    border: solid 3px var(--color-s-main-pale);
    box-shadow: none;
  }
  .aws-top-case-menu__link:hover .aws-top-case-menu__title {
    color: var(--color-s-main-dark);
  }
}
.aws-top-case-menu__title {
  margin-block: 0;
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-case-menu__title span {
  margin-right: 8px;
}
.aws-top-case-menu__text {
  margin-block: 8px 0;
  font-size: var(--font-s);
  line-height: var(--line-s);
}
.aws-top-case-menu__image {
  flex-shrink: 0;
}
.aws-top-case-menu__number {
  margin-block: 0;
  color: var(--color-s-main-base);
  font-family: var(--font-family-en);
  font-size: var(--font-l);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
  text-align: center;
}
.aws-top-case-menu__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  border-radius: 8px;
  background-color: var(--color-s-main-light);
}

/* ------------------------------
  aws-top-certification-list
------------------------------ */
.aws-top-certification-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-block: 8px 0;
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-certification-list {
    grid-template-columns: 1fr 1fr 1fr 1fr auto;
  }
}
.aws-top-certification-list__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-radius: 8px;
  background-color: var(--color-s-white);
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-certification-list__item {
    flex-direction: column;
    justify-content: center;
    padding: 12px 0;
  }
}
.aws-top-certification-list__item--total {
  grid-column: 1/-1;
  flex-direction: column;
  padding-block: 16px;
  border-radius: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-certification-list__item--total {
    grid-column: 5/6;
    grid-row: 1/3;
    padding: 48px 64px;
  }
}
.aws-top-certification-list__label {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
@media screen and (min-width: 769px) {
  .aws-top-certification-list__label {
    text-align: center;
  }
}
.aws-top-certification-list__item--total .aws-top-certification-list__label {
  font-size: var(--font-l);
  text-align: center;
}
.aws-top-certification-list__data {
  margin-left: 0;
  color: var(--color-s-main-base);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-certification-list__item--total .aws-top-certification-list__data {
  font-size: var(--font-2xl);
}
.aws-top-certification-list__data b {
  font-family: var(--font-family-en);
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-none);
}
.aws-top-certification-list__item--total .aws-top-certification-list__data b {
  margin-right: 8px;
  font-size: var(--font-5xl);
}
.aws-top-certification-list__data span {
  font-size: var(--font-l);
}

/* ------------------------------
  aws-top-cycle
------------------------------ */
.aws-top-cycle {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: 1fr auto 1fr;
  gap: 4px;
  place-items: center;
  width: 100%;
}
.aws-top-cycle__step {
  display: flex;
  box-sizing: border-box;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-block: 0;
  padding: 8px 10px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 8px;
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  gap: 8px;
}
.aws-top-cycle__step--first {
  grid-area: 1/1;
}
.aws-top-cycle__step--second {
  grid-area: 1/3;
}
.aws-top-cycle__step--third {
  grid-area: 3/3;
}
.aws-top-cycle__step--fourth {
  grid-area: 3/1;
}
.aws-top-cycle__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
}
.aws-top-cycle__icon img {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.aws-top-cycle__arrow {
  width: 16px;
  height: 16px;
  background-color: var(--color-s-black);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}
.aws-top-cycle__arrow--first {
  grid-area: 1/2;
  mask-image: url("../../../assets/images/service/icon/ico_arrow_right.svg");
}
.aws-top-cycle__arrow--second {
  grid-area: 2/3;
  mask-image: url("../../../assets/images/service/icon/ico_arrow_down.svg");
}
.aws-top-cycle__arrow--third {
  grid-area: 3/2;
  mask-image: url("../../../assets/images/service/icon/ico_arrow_left.svg");
}
.aws-top-cycle__arrow--fourth {
  grid-area: 2/1;
  mask-image: url("../../../assets/images/service/icon/ico_arrow_up.svg");
}

/* ------------------------------
  aws-top-flow
------------------------------ */
.aws-top-flow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 64px;
  margin-block: 32px 0;
  padding-left: 0;
  list-style: none;
}
@media screen and (min-width: 769px) {
  .aws-top-flow {
    flex-direction: row;
    align-items: flex-start;
    margin-block: 56px 0;
  }
}
.aws-top-flow__item {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  max-width: 334px;
  gap: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-flow__item {
    width: calc((100% - 192px) / 4);
  }
}
.aws-top-flow__item:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -48px;
  left: 50%;
  width: 32px;
  height: 32px;
  transform: translateX(-50%);
  background-color: #000;
  mask: url("../../../assets/images/service/icon/ico_chevron_arrow_down.svg") no-repeat center/contain;
}
@media screen and (min-width: 769px) {
  .aws-top-flow__item:not(:first-child)::before {
    top: 50%;
    left: -48px;
    transform: translate(0, -50%);
    mask-image: url("../../../assets/images/service/icon/ico_chevron_arrow_right.svg");
  }
}
.aws-top-flow__icon {
  padding: 34px;
  border-radius: 50%;
  background-color: var(--color-s-white);
}
.aws-top-flow__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.aws-top-flow__title {
  margin-block: 0;
  font-weight: var(--font-weight-bold);
  text-align: center;
}
.aws-top-flow__step {
  display: flex;
  justify-content: center;
  margin-bottom: 4px;
  color: var(--color-s-main-base);
  font-family: var(--font-family-en);
  font-size: var(--font-s);
  line-height: var(--line-none);
  gap: 4px;
}
.aws-top-flow__text {
  margin-block: 0;
  font-size: var(--font-s);
}

/* ------------------------------
  aws-top-hero
------------------------------ */
.aws-top-hero {
  padding: 72px 16px 40px;
  background: linear-gradient(to left bottom, #ffdcdc 0%, #fff4e6 50%, #fff5f1 100%);
}
@media screen and (min-width: 769px) {
  .aws-top-hero {
    padding: 72px 40px 0;
  }
}
.aws-top-hero__inner {
  max-width: 1200px;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .aws-top-hero__inner {
    display: flex;
    align-items: center;
    gap: 20px;
  }
}
@media screen and (min-width: 769px) {
  .aws-top-hero__text-box {
    padding-bottom: 40px;
  }
}
@media screen and (min-width: 769px) {
  .aws-top-hero__image {
    width: 480px;
  }
  .aws-top-hero__image img {
    width: 100%;
    height: auto;
  }
}

/* ------------------------------
  aws-top-hero-cta
------------------------------ */
.aws-top-hero-cta {
  padding: 24px;
  background-color: var(--color-s-black);
}
.aws-top-hero-cta__button-box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

/* ------------------------------
  aws-top-hero-evidence
------------------------------ */
.aws-top-hero-evidence {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(166px, 1fr));
  gap: 8px;
  margin-block: 32px 0;
}
@media screen and (min-width: 769px) {
  .aws-top-hero-evidence {
    display: flex;
    flex-wrap: wrap;
  }
}
.aws-top-hero-evidence__item {
  display: flex;
  box-sizing: border-box;
  flex-direction: column;
  align-items: center;
  padding: 8px 24px 4px;
  border-radius: 16px;
  background-color: var(--color-s-white);
  gap: 4px;
}
@media screen and (min-width: 769px) {
  .aws-top-hero-evidence__item {
    width: fit-content;
  }
}
.aws-top-hero-evidence__label {
  margin-block: 0;
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  text-align: center;
}
.aws-top-hero-evidence__data {
  display: flex;
  align-items: center;
  margin: 0;
  color: var(--color-s-main-base);
  font-weight: var(--font-weight-bold);
}
.aws-top-hero-evidence__data b {
  margin-right: 4px;
  font-family: var(--font-family-en);
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
}
.aws-top-hero-evidence__data span {
  display: inline-block;
  margin-top: -2px;
  font-size: var(--font-xl);
}

/* ------------------------------
  aws-top-hero-tags
------------------------------ */
.aws-top-hero-tags {
  display: flex;
  flex-wrap: wrap;
  margin-block: 32px 0;
  padding-left: 0;
  list-style: none;
  gap: 8px;
}

/* ------------------------------
  aws-top-reason
------------------------------ */
.aws-top-reason {
  display: grid;
  margin-top: 32px;
  gap: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-reason {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 56px;
  }
}
.aws-top-reason__section {
  padding: 24px;
  border-radius: 16px;
  background-color: var(--color-s-main-pale);
}
@media screen and (min-width: 769px) {
  .aws-top-reason__section {
    display: flex;
    flex-direction: column;
    padding: 32px;
  }
  .aws-top-reason__section.aws-top-reason__section--large {
    grid-column: span 2;
  }
}
.aws-top-reason__header {
  display: grid;
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-reason__header {
    grid-template-columns: auto 1fr;
    gap: 0 16px;
  }
}
.aws-top-reason__number {
  width: fit-content;
  color: var(--color-s-white);
  font-family: var(--font-family-en);
  font-size: var(--font-5xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-none);
  text-shadow: 0 1px 0 var(--color-s-black), 0.7px 0.7px 0 var(--color-s-black), 1px 0 0 var(--color-s-black), 0.7px -0.7px 0 var(--color-s-black), 0 -1px 0 var(--color-s-black), -0.7px -0.7px 0 var(--color-s-black), -1px 0 0 var(--color-s-black), -0.7px 0.7px 0 var(--color-s-black);
}
@media screen and (min-width: 769px) {
  .aws-top-reason__number {
    font-size: var(--font-6xl);
  }
  .aws-top-reason__section--large .aws-top-reason__number {
    grid-row: span 2;
    font-size: 88px;
  }
}
.aws-top-reason__heading {
  margin-block: 0;
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-reason__text {
  margin-block: 0;
  font-size: var(--font-s);
}
@media screen and (min-width: 769px) {
  .aws-top-reason__text {
    grid-column: span 2;
    margin-top: 16px;
  }
  .aws-top-reason__section--large .aws-top-reason__text {
    grid-column: span 1;
    margin-top: 8px;
  }
}
.aws-top-reason__block {
  margin-top: 24px;
}
.aws-top-reason__box {
  margin-top: 24px;
  padding: 16px;
  border-radius: 8px;
  background-color: var(--color-s-white);
}
@media screen and (min-width: 769px) {
  .aws-top-reason__box {
    display: flex;
    flex: 1;
    align-items: center;
    justify-content: center;
  }
}
.aws-top-reason__tag-list {
  display: flex;
  flex-wrap: wrap;
  margin-block: 0;
  padding-left: 0;
  list-style: none;
  gap: 4px;
}
.aws-top-reason__tag {
  display: flex;
}

/* ------------------------------
  aws-top-section
------------------------------ */
.aws-top-section {
  padding: 56px 24px;
}
.aws-top-section--bg {
  background-color: var(--color-s-main-pale);
}
@media screen and (min-width: 769px) {
  .aws-top-section {
    padding: 100px 56px;
  }
}
.aws-top-section__inner {
  max-width: 1100px;
  margin-inline: auto;
}
.aws-top-section__block {
  margin-top: 40px;
}
@media screen and (min-width: 769px) {
  .aws-top-section__block {
    margin-top: 72px;
  }
}

/* ------------------------------
  aws-top-service-list
------------------------------ */
.aws-top-service-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  width: 100%;
  margin-block: 0;
  padding-left: 0;
  list-style: none;
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-service-list {
    grid-template-columns: repeat(auto-fill, minmax(105px, 1fr));
  }
}
.aws-top-service-list__item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 12px 8px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-service-list__item {
    flex-direction: column;
  }
}
.aws-top-service-list__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
}
.aws-top-service-list__icon img {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media screen and (min-width: 769px) {
  .aws-top-service-list__icon {
    width: 24px;
    height: 24px;
  }
}
.aws-top-service-list__text {
  display: flex;
  align-items: center;
  margin-block: 0;
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
@media screen and (min-width: 769px) {
  .aws-top-service-list__text {
    min-height: 34px;
    font-size: var(--font-2xs);
    text-align: center;
  }
}

/* ------------------------------
  aws-top-solution
------------------------------ */
.aws-top-solution {
  margin: 32px -24px 0;
  padding: 24px;
  border-radius: 16px;
  background-color: var(--color-s-main-pale);
}
@media screen and (max-width: 768.9px) {
  .aws-top-solution + .aws-top-solution {
    margin-top: 40px;
  }
}
@media screen and (min-width: 769px) {
  .aws-top-solution {
    margin: 56px 0 0;
  }
}
.aws-top-solution__heading {
  margin-block: 0;
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-solution__heading span {
  display: block;
  margin-bottom: 2px;
  color: var(--color-s-main-base);
  font-size: var(--font-s);
}
.aws-top-solution__box {
  margin-top: 24px;
}
@media screen and (min-width: 769px) {
  .aws-top-solution__box {
    padding: 24px;
    border-radius: 16px;
    background-color: var(--color-s-white);
  }
}
.aws-top-solution__block {
  margin-top: 24px;
}
.aws-top-solution__block:first-child {
  margin-top: 0;
}

/* ------------------------------
  aws-top-solution-detail
------------------------------ */
.aws-top-solution-detail {
  display: grid;
  gap: 8px;
  margin-block: 8px 0;
  padding-left: 0;
  list-style: none;
}
@media screen and (min-width: 769px) {
  .aws-top-solution-detail {
    grid-template-columns: repeat(3, 1fr);
  }
}
.aws-top-solution-detail__item {
  padding: 16px;
  border: 1px solid var(--color-s-gray-base);
  border-radius: 8px;
  background-color: var(--color-s-white);
}
.aws-top-solution-detail__title {
  margin-block: 0;
  font-size: var(--font-s);
  font-weight: var(--font-weight-bold);
}
.aws-top-solution-detail__text {
  margin-block: 8px 0;
  font-size: var(--font-xs);
}
.aws-top-solution-detail__tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-block: 16px 0;
  padding-left: 0;
  list-style: none;
}

/* ------------------------------
  aws-top-solution-list
------------------------------ */
.aws-top-solution-list {
  display: grid;
  margin-block: 8px 0;
  padding-left: 0;
  list-style: none;
  gap: 8px;
}
@media screen and (min-width: 769px) {
  .aws-top-solution-list {
    grid-template-columns: repeat(4, 1fr);
  }
}
.aws-top-solution-list__item {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  border: 1px solid var(--color-s-main-base);
  border-radius: 8px;
  background-color: var(--color-s-white);
  gap: 8px;
}
.aws-top-solution-list__icon {
  display: flex;
  box-sizing: border-box;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 8px;
  border-radius: 8px;
  background-color: var(--color-s-main-light);
}
.aws-top-solution-list__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.aws-top-solution-list__text {
  margin-block: 0;
  font-size: var(--font-s);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-s);
}
.aws-top-solution-list__sub {
  margin-block: 4px 0;
  color: var(--color-s-gray-dark);
  font-size: var(--font-xs);
}

/* ------------------------------
  aws-top-technology
------------------------------ */
.aws-top-technology {
  margin-top: 32px;
}
.aws-top-technology + .aws-top-technology {
  margin-top: 40px;
}
@media screen and (min-width: 769px) {
  .aws-top-technology {
    margin-top: 56px;
  }
  .aws-top-technology + .aws-top-technology {
    margin-top: 72px;
  }
}

/* ------------------------------
  aws-top-technology-list
------------------------------ */
.aws-top-technology-list {
  display: grid;
  margin-block: 12px 0;
  padding-left: 0;
  list-style: none;
  gap: 16px;
}
@media screen and (min-width: 769px) {
  .aws-top-technology-list--col2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .aws-top-technology-list--col3 {
    grid-template-columns: repeat(3, 1fr);
  }
}
.aws-top-technology-list__item {
  padding: 16px;
  border-radius: 8px;
  background-color: var(--color-s-white);
}
.aws-top-technology-list__tag-list {
  display: flex;
  flex-wrap: wrap;
  margin-block: 8px 0;
  padding-left: 0;
  list-style: none;
  gap: 4px;
}
.aws-top-technology-list__text {
  margin-block: 8px 0;
  font-size: var(--font-xs);
}
