@charset "UTF-8";
/*
Theme Name: 導入事例・構成例
Theme URI: https://328b3110-076e-468b-a50c-e7cdb7387103.p.bardy.io/
Version: 2.0.66
*/
.alignnone {
  margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
  display: block;
  margin: 5px auto;
}

.alignright {
  float: right;
}

.alignleft {
  float: left;
}

a img.alignright {
  float: right;
}

a img.alignleft {
  float: left;
}

a img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption {
  background: #ffffff;
  border: 1px solid #f0f0f0;
  max-width: 96%;
  padding: 5px 3px 10px;
  text-align: center;
}
.wp-caption img {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 98.5%;
  padding: 0;
  width: auto;
}

.wp-caption .wp-caption-text,
.gallery-caption {
  font-size: 11px;
  line-height: 17px;
  margin: 0;
  padding: 0 4px 5px;
}

:root {
  /* font */
  --font-family-base: "Noto Sans JP", sans-serif;
  --font-family-en: futura, "Century Gothic", sans-serif;
  --font-size-base: 1rem;
  --font-size-s: 0.875rem;
  --font-size-xs: 0.8125rem;
  /* color */
  --primary-color: #ff5577;
  --secondary-color: #808080;
  --attention-color: #e11c45;
  --color-base: #1d1d1d;
  --color-gray-8: #7c7c7c;
  --color-gray-9: #6b6b6b;
  /* icon */
  --arrow-chevron: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="6" height="10" viewBox="0 0 6 10" fill="none"><path d="M0.773865 1.30212L5.00001 5L0.773865 8.69788" stroke="%231D1D1D" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  --arrow-chevron-active: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="6" height="10" viewBox="0 0 6 10" fill="none"><path d="M0.773865 1.30212L5.00001 5L0.773865 8.69788" stroke="%23f57" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  --arrow-chevron-bottom: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8" fill="none"><path d="M1 1.5L6 6.5L11 1.5" stroke="%231D1D1D" stroke-width="2"/></svg>');
}

@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  src: url("../fonts/NotoSansJP-VariableFont_wght.woff2") format("woff2");
}
*,
*::after,
*::before {
  box-sizing: border-box;
}

body {
  color: #354659;
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Helvetica, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 1rem;
  line-height: 1.5;
  margin: 0;
}

h1,
h2,
h3,
h4,
h5 {
  margin: 0;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

a {
  color: #1168a6;
  text-decoration: none;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  padding: 0;
}

dd {
  margin-left: 0;
}

/* --------------------
  Common
-------------------- */
@media (width >= 768px) {
  .for-sp {
    display: none;
  }
}
@media (width < 768px) {
  .for-pc {
    display: none;
  }
}
/*  */
.globalheader {
  align-items: center;
  background: #ffffff;
  border-bottom: solid 1px rgba(0, 0, 0, 0.15);
  color: var(--color-base);
  display: flex;
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: antialiased;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  gap: 5rem;
  line-height: 1.75;
  padding: 0 2rem;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
}
.globalheader > * {
  position: relative;
  z-index: 10;
}

.globalheader-logo {
  align-items: center;
  display: flex;
  width: 14.2744rem;
}
.globalheader-logo svg {
  width: 100%;
}

.globalnav {
  flex: 1;
}

.globalnav-container {
  align-items: center;
  display: flex;
}

.globalnav-list {
  align-items: center;
  display: flex;
  gap: 1rem;
}

.globalnav-item {
  position: relative;
}

.globalnav-link {
  color: var(--color-base);
  cursor: pointer;
  font-size: 0.9375rem;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  padding: 0.9679rem 0.625rem;
}

.globalnav-toggle-button {
  align-items: center;
  background: none;
  border: none;
  color: var(--color-base);
  display: flex;
  gap: 0.375rem;
}
.globalnav-toggle-button::after {
  background: var(--arrow-chevron-bottom) no-repeat center center;
  background-size: 100% 100%;
  content: "";
  display: block;
  height: 8px;
  transition: 0.3s;
  width: 12px;
}
.globalnav-toggle-button[aria-expanded=true] {
  --arrow-chevron-bottom: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8" fill="none"><path d="M1 1.5L6 6.5L11 1.5" stroke="%23f57" stroke-width="2"/></svg>');
  color: var(--primary-color);
}
.globalnav-toggle-button[aria-expanded=true]::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.globalnav-submenu {
  left: 50%;
  opacity: 1;
  padding-top: 0.69rem;
  position: absolute;
  top: 100%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  transition: 0.3s;
  visibility: visible;
  z-index: 999;
}
.globalnav-submenu[hidden] {
  display: block;
  opacity: 0;
  visibility: hidden;
}

.globalnav-submenu-list {
  background: #ffffff;
  border-radius: 0.5rem;
  box-shadow: 0 15px 20px 0 rgba(84, 84, 113, 0.15);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 2rem 2.56rem 1.5rem;
  white-space: nowrap;
}

.globalnav-submenu-link {
  align-items: center;
  color: var(--color-base);
  display: flex;
  font-size: 0.9375rem;
  gap: 1rem;
  justify-content: space-between;
  letter-spacing: 0.04em;
}
.globalnav-submenu-link::after {
  background: var(--arrow-chevron) no-repeat center center;
  background-size: 100% 100%;
  content: "";
  display: block;
  height: 10px;
  transition: 0.3s;
  width: 6px;
}

.globalnav-all-service {
  color: var(--primary-color);
  padding: 0.25rem 0;
}
.globalnav-all-service::after {
  background-image: var(--arrow-chevron-active);
}

.globalnav-login {
  background: #ffffff;
  border: 1px solid #d4d4da;
  border-radius: 1.375rem;
  color: var(--color-base);
  font-size: 0.875rem;
  font-variation-settings: "wght" 500;
  font-weight: 500;
  line-height: 1.7;
  margin: 0 0 0 auto;
  padding: 0.4375rem 1.0625rem 0.375rem;
}

.globalheader-menu {
  display: none;
}

.globalnav-cloase-button {
  display: none;
}

@media (width >= 992px) {
  .globalheader:not(:has(h1)) {
    justify-content: space-between;
    position: relative;
    z-index: 10000;
  }
  .globalheader:not(:has(h1)) .globalnav {
    flex: 0 0 auto;
  }
  .globalheader:not(:has(h1)) .globalnav-login {
    margin: 0 0 0 1.625rem;
  }
  .globalnav-link {
    transition: 0.3s;
  }
  .globalnav-link:hover {
    color: var(--primary-color);
    text-decoration: none;
  }
  .globalnav-toggle-button:hover {
    text-decoration: none;
    --arrow-chevron-bottom: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8" fill="none"><path d="M1 1.5L6 6.5L11 1.5" stroke="%23f57" stroke-width="2"/></svg>');
  }
  .globalnav-submenu-link {
    transition: 0.3s;
  }
  .globalnav-submenu-link:hover {
    color: var(--primary-color);
    text-decoration: none;
  }
  .globalnav-submenu-link:hover::after {
    background-image: var(--arrow-chevron-active);
  }
  .globalnav-all-service:hover {
    font-variation-settings: "wght" 700;
    font-weight: 700;
    text-decoration: none;
  }
  .globalnav-login {
    transition: 0.3s;
  }
  .globalnav-login:hover {
    background: #efeff7;
    text-decoration: none;
  }
}
@media (width < 992px) {
  body:has(.globalheader-menu[aria-expanded=true]) {
    overflow: hidden;
  }
  .globalheader {
    padding: 0;
    position: relative;
    z-index: 999;
  }
  .globalheader-bar {
    align-items: center;
    background: #ffffff;
    display: flex;
    flex: 1;
    justify-content: space-between;
    padding: 0.22rem 0.5rem 0.22rem 0;
    position: relative;
    z-index: 999;
  }
  .globalheader-logo {
    width: 9.875rem;
  }
  .globalheader-menu {
    align-items: center;
    background: none;
    border: none;
    display: flex;
    flex-direction: column;
    gap: 0.31rem;
    justify-content: center;
    padding: 0;
    width: 2.5rem;
  }
  .globalheader-menu::after {
    color: var(--secondary-color);
    content: "メニュー";
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 0.675rem;
    font-variation-settings: "wght" 700;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
  }
  .globalheader-menu[aria-expanded=true]::after {
    content: "閉じる";
  }
  .globalheader-menu[aria-expanded=true] .globalheader-menu-icon span {
    width: 0.875rem;
  }
  .globalheader-menu[aria-expanded=true] .globalheader-menu-icon span:first-child {
    -webkit-transform: rotate(45deg) translate(0.5rem, 0.125rem);
            transform: rotate(45deg) translate(0.5rem, 0.125rem);
  }
  .globalheader-menu[aria-expanded=true] .globalheader-menu-icon span:nth-child(2) {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    visibility: hidden;
  }
  .globalheader-menu[aria-expanded=true] .globalheader-menu-icon span:last-child {
    -webkit-transform: rotate(-45deg) translate(0.375rem, 0);
            transform: rotate(-45deg) translate(0.375rem, 0);
  }
  .globalheader-menu-icon {
    display: flex;
    flex-direction: column;
    height: 0.875rem;
    justify-content: space-between;
    width: 1.375rem;
  }
  .globalheader-menu-icon span {
    background: var(--secondary-color);
    height: 2px;
    transition: 0.3s;
    width: 100%;
  }
  .globalnav {
    display: block;
    height: calc(100% - 2.6875rem);
    left: 0;
    overflow: auto;
    -ms-scroll-chaining: none;
        overscroll-behavior: none;
    position: fixed;
    top: 2.6875rem;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
    width: 100%;
  }
  .globalnav[hidden] {
    -webkit-transform: translateY(calc(-100% - 2.6875rem));
            transform: translateY(calc(-100% - 2.6875rem));
  }
  .globalnav-container {
    align-items: stretch;
    background: #ffffff;
    box-shadow: 0 2px 1px 0 #efeff7 inset;
    flex-direction: column;
  }
  .globalnav-list {
    align-items: stretch;
    flex-direction: column;
    gap: 0;
  }
  .globalnav-item {
    border-bottom: 1px solid #cccccf;
  }
  .globalnav-link {
    align-items: center;
    display: flex;
    font-size: var(--font-size-s);
    font-variation-settings: "wght" 400;
    font-weight: 400;
    justify-content: flex-start;
    line-height: 2;
    padding: 0.5rem 1.5rem;
  }
  .globalnav-link::after {
    background: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="6" height="10" viewBox="0 0 6 10" fill="none"><path d="M0.773865 1.30212L5.00001 5L0.773865 8.69788" stroke="%231D1D1D" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center center;
    background-size: 100% 100%;
    content: "";
    display: block;
    height: 10px;
    margin-left: auto;
    width: 6px;
  }
  .globalnav-link-services {
    gap: 0.5rem;
  }
  .globalnav-link-services::before {
    background: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="12" viewBox="0 0 16 12" fill="none"><circle cx="1.5" cy="6.0625" r="1.5" fill="%23FF5577"/><rect x="4" y="4.5625" width="12" height="3" rx="1.5" fill="%23FF5577"/><circle cx="1.5" cy="1.5625" r="1.5" fill="%23FF5577"/><rect x="4" y="0.0625" width="12" height="3" rx="1.5" fill="%23FF5577"/><circle cx="1.5" cy="10.4375" r="1.5" fill="%23FF5577"/><rect x="4" y="8.9375" width="12" height="3" rx="1.5" fill="%23FF5577"/></svg>') no-repeat center center;
    background-size: 100% 100%;
    content: "";
    display: block;
    height: 0.75rem;
    width: 1rem;
  }
  .globalnav-toggle-button {
    display: none;
  }
  .globalnav-submenu {
    opacity: 1;
    padding: 0;
    position: static;
    -webkit-transform: none;
            transform: none;
    visibility: visible;
  }
  .globalnav-submenu-list {
    background: #f5f5fb;
    border-radius: 0;
    box-shadow: none;
    gap: 0;
    padding: 0;
  }
  .globalnav-submenu-item + .globalnav-submenu-item {
    border-top: 1px solid #dcdce8;
  }
  .globalnav-submenu-link {
    font-size: var(--font-size-s);
    line-height: 2;
    padding: 0.5rem 1.5rem 0.5rem 2.81rem;
  }
  .globalnav-login {
    align-items: center;
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    margin: 1rem 1.47rem;
    text-align: center;
    width: auto;
  }
  .globalnav-login::before {
    background: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="13" height="14" viewBox="0 0 13 14" fill="none"><circle cx="6.5" cy="3.6875" r="3" fill="%23FF5577"/><path d="M0.500001 13.3125C0.500001 12.5246 0.655196 11.7444 0.956724 11.0164C1.25825 10.2884 1.70021 9.62701 2.25736 9.06986C2.81451 8.51271 3.47595 8.07075 4.2039 7.76922C4.93185 7.46769 5.71207 7.3125 6.5 7.3125C7.28793 7.3125 8.06815 7.46769 8.7961 7.76922C9.52405 8.07075 10.1855 8.51271 10.7426 9.06986C11.2998 9.62701 11.7417 10.2884 12.0433 11.0164C12.3448 11.7444 12.5 12.5246 12.5 13.3125L6.5 13.3125L0.500001 13.3125Z" fill="%23FF5577"/></svg>') no-repeat center center;
    background-size: 100% 100%;
    content: "";
    display: block;
    height: 14px;
    width: 13px;
  }
  .globalnav-cloase-button {
    align-items: center;
    background: var(--secondary-color);
    color: #ffffff;
    display: flex;
    font-size: 0.625rem;
    font-variation-settings: "wght" 700;
    font-weight: 700;
    gap: 0.125rem;
    justify-content: center;
    line-height: 1;
    padding: 0.6rem 0;
  }
}
/* global footer */
.globalfooter {
  background: #5f5f64;
  color: var(--color-base);
  color: #f1f1f1;
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: antialiased;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.75;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
}
.globalfooter a {
  color: #f1f1f1;
}

.globalfooter-main {
  padding: 2.4rem 2rem 1.5rem;
}

.globalfooter-layout {
  align-items: flex-start;
  display: flex;
  gap: 2rem;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 75rem;
}

.globalfooter-logo {
  width: 19.6667%;
}

.global-sitemap {
  display: flex;
  flex-shrink: 0;
  gap: 4.09rem;
}

.global-sitemap-column {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

.global-sitemap-title {
  font-size: var(--font-size-s);
  font-variation-settings: "wght" 700;
  font-weight: 700;
  line-height: 1.4;
}

.global-sitemap-menu {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  line-height: 1.2;
}

.global-sitemap-link {
  display: block;
  font-size: var(--font-size-s);
}

.globalfooter-mark {
  background: #f1f1f1;
}

.globalfooter-mark-list {
  align-items: center;
  display: flex;
  gap: 1.25rem;
}

.globalfooter-mark-item {
  align-items: center;
  display: flex;
  line-height: 0;
}
.globalfooter-mark-item .p-mark {
  width: 4.1047rem;
}
.globalfooter-mark-item .pci-dss {
  width: 3.1743rem;
}
.globalfooter-mark-item .iso-mark {
  width: 6.5675rem;
}

.globalfooter-legal {
  border-top: solid 1px #78787a;
  padding: 1.5rem 2rem 2.5rem;
}

.globalfooter-legal-list {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.globalfooter-legal-link {
  font-size: var(--font-size-xs);
  font-variation-settings: "wght" 500;
  font-weight: 500;
}

.globalfooter-legal-copyright {
  font-size: var(--font-size-s);
  font-variation-settings: "wght" 500;
  font-weight: 500;
}

@media (width >= 992px) {
  .globalfooter a {
    transition: opacity 0.3s;
  }
  .globalfooter a:hover {
    opacity: 0.8;
    text-decoration: none;
  }
}
@media (width < 992px) {
  .globalfooter {
    padding: 1rem 1rem 2rem;
  }
  .globalfooter-layout {
    align-items: stretch;
    flex-direction: column;
    gap: 0;
  }
  .globalfooter-main {
    padding: 0;
  }
  .globalfooter-logo {
    margin: 0 auto;
    width: 14.75rem;
  }
  .global-sitemap {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    display: grid;
    gap: 1.5rem 0;
    grid-template-columns: 50% 50%;
    margin-top: 1rem;
    padding: 1rem 0 0;
  }
  .global-sitemap-column {
    gap: 1rem;
    grid-column: 1/2;
  }
  .global-sitemap-column:last-child {
    grid-column: 2/2;
    grid-row: 1/3;
  }
  .global-sitemap-title {
    font-size: var(--font-family-base);
    line-height: 1.7;
  }
  .global-sitemap-menu {
    gap: 0.75rem;
    line-height: 1.7;
  }
  .global-sitemap-link {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: var(--font-family-base);
  }
  .globalfooter-mark {
    align-self: center;
    margin: 2rem 0 0;
  }
  .globalfooter-legal {
    margin-top: 1.5rem;
    padding: 1.5rem 0 0;
  }
  .globalfooter-legal .globalfooter-layout {
    align-items: center;
    gap: 1.5rem;
  }
  .globalfooter-legal-list {
    gap: 0.56rem 1rem;
    line-height: 1.7;
  }
  .globalfooter-legal-link {
    font-size: var(--font-size-s);
  }
}
.btn {
  align-items: center;
  border-radius: 40px;
  display: flex;
  font-size: 0.875rem;
  font-weight: bold;
  height: 2.625rem;
  justify-content: center;
  line-height: 1;
  min-width: 12rem;
  position: relative;
}
.btn.primary {
  background-color: #1168a6;
  color: #ffffff;
}
.btn.primary:hover {
  background-color: #1688d9;
}
.btn svg {
  fill: #ffffff;
  position: absolute;
  right: 1rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 6px;
}
.btn.secondary {
  border: 1px solid #ffffff;
  color: #ffffff;
}
.btn.secondary:hover {
  background: rgba(255, 255, 255, 0.2);
}
.btn.cta {
  background-color: #ff9e4f;
  color: #354659;
}
.btn.cta:hover {
  background-color: #ffc871;
}
.btn.cta svg {
  fill: #354659;
}
.btn.large {
  padding: 0 5rem;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  .btn {
    padding-top: 0.3125rem;
  }
}
/* ========================================
case-nav
======================================== */
.case-header.windows .case-nav-upper {
  background: #007bbc;
}
.case-header.windows .case-nav-upper .list.stay::after {
  border-color: transparent transparent #def4ff;
}

.case-nav {
  background: linear-gradient(-225deg, rgb(56, 110, 206) 0%, rgb(0, 199, 221) 100%);
  overflow: hidden;
  position: relative;
  transition: all 0.3s;
}
.case-nav .cb {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 960px;
  width: 100%;
}
.case-nav .cb.front {
  display: block;
  padding: 60px 0;
}
.case-nav .cb.fixed {
  display: flex;
  height: auto;
  min-height: auto;
  padding: 0;
}
.case-nav .logo {
  line-height: 1;
}
.case-nav .btn.secondary {
  margin-left: 1rem;
}
.case-nav.fixed {
  background: #ffffff;
  box-shadow: 0 4px 15px 0 rgba(0, 0, 0, 0.15);
  left: 0;
  padding: 15px 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1000;
}
.case-nav.fixed .logo svg {
  width: 10rem;
}
.case-nav.fixed .logo svg path {
  fill: #354659;
}
.case-nav.fixed .case-nav-cta {
  display: flex;
  gap: 8px;
}
.case-nav.pc {
  align-items: center;
  display: flex;
}

.case-nav-bg {
  height: auto;
  left: 50%;
  opacity: 0.2;
  position: absolute;
  top: -170px;
  -webkit-transform: translateX(50px);
          transform: translateX(50px);
  width: 430px;
}
.case-nav-bg.hidden {
  display: none;
}

.case-nav-header-lead {
  color: #ffffff;
  display: block;
  font-size: 0.875rem;
  line-height: 1.8;
  margin: 32px 0 0;
  width: 100%;
}
.case-nav-header-lead.hidden {
  display: none;
}

.case-nav-cta {
  display: none;
}
.case-nav-cta .btn.primary {
  background-color: #ff9e4f;
  color: #354659;
}
.case-nav-cta .btn.primary:hover {
  background: #ffc871;
}
.case-nav-cta .btn.primary svg {
  fill: #354659;
}

@media screen and (min-width: 960px) {
  .case-nav:not(.front):not(.fixed) {
    height: 7.625rem;
  }
  .front .case-nav-bg {
    opacity: 1;
    top: -110px;
  }
}
@media screen and (max-width: 959px) {
  .case-nav:not(.front) {
    height: 6.375rem;
  }
  .case-nav .cb {
    justify-content: center;
    max-width: 334px;
  }
  .case-nav .cb.front {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    padding: 60px 20px;
  }
  .case-nav .logo {
    z-index: 0;
  }
  .case-nav.fixed {
    height: 44px;
  }
  .case-nav.fixed .cb {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
    margin: 0;
    max-width: 100%;
    padding: 0;
    width: 100%;
  }
  .case-nav.fixed .logo {
    margin-left: 8px;
  }
  .case-nav.fixed .logo svg {
    width: 144px;
  }
  .case-nav.fixed .case-nav-cta {
    gap: 1px;
  }
  .case-nav.fixed .btn {
    border-radius: 0;
    font-size: 0.75rem;
    height: 44px;
    line-height: 120%;
    min-width: 86px;
    padding: 0;
    text-align: center;
    width: 86px;
  }
  .case-nav.fixed .btn svg {
    display: none;
  }
  .case-nav-bg {
    align-items: center;
    display: flex;
    left: 50%;
    max-width: 380px;
    top: -140%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .case-nav-bg img {
    width: 100%;
  }
  .front .case-nav-bg {
    bottom: 0;
    left: 0;
    margin: auto;
    right: 0;
    top: 0;
    -webkit-transform: none;
            transform: none;
    width: 300px;
  }
  .case-nav-upper .cb {
    justify-content: center;
  }
}
/* --------------------
パンくず
-------------------- */
.breadcrumbs {
  align-items: center;
  background-color: #f6f9fb;
  display: flex;
  font-size: 0.875rem;
  height: 3.125rem;
  margin: 0 auto;
}
.breadcrumbs .post {
  margin: 0;
}
.breadcrumbs a:hover {
  text-decoration: underline;
}

.breadcrumbs-inner {
  margin: 0 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 960px;
}

.breadcrumbs-separator {
  fill: #8999ab;
  margin: 0 1rem;
  vertical-align: middle;
  width: 0.375rem;
}

@media screen and (max-width: 959px) {
  .breadcrumbs {
    display: none;
  }
}
/* ========================================
search-tool
======================================== */
.search-tool {
  background-color: #f6f9fb;
  font-size: 14px;
  min-height: 296px;
  opacity: 0;
  padding: 40px 0;
  scroll-margin-top: 72px;
  transition: all 0.2s ease-out;
}
.search-tool.mounted {
  min-height: auto;
  opacity: 1;
}

.search-tool-title {
  color: #354659;
  font-size: 1.25rem;
  margin-bottom: 32px;
  text-align: center;
}

.search-tool-inner {
  margin: 0 auto;
  max-width: 960px;
  width: 80%;
}

.search-tool-category.hide {
  display: none;
}

.search-tool-tabs {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.search-tool-tab {
  align-items: center;
  background-color: #e0e7ec;
  border-radius: 4px 4px 0 0;
  color: #354659;
  display: flex;
  font-weight: bold;
  height: 2.75rem;
  justify-content: center;
  padding: 0.5rem 1rem;
  text-align: center;
  width: 25%;
}
.search-tool-tab:hover {
  background-color: #ecf0f3;
  cursor: pointer;
}
.search-tool-tab.current {
  background-color: #ffffff;
  box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
  cursor: pointer;
}
.search-tool-tab:not(:first-child) {
  margin-left: 30px;
}

.search-tool-bodies {
  background-color: #ffffff;
  box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 24px;
  position: relative;
  z-index: 100;
}

.search-tool-body {
  display: inline-block;
}
.search-tool-body a {
  border: 1px solid #e0e7ec;
  border-radius: 18px;
  color: #354659;
  display: inline-block;
  font-size: 12px;
  padding: 0.5rem 1rem;
}
.search-tool-body a:hover {
  border-color: #a0b6c5;
}

.search-tool-body-icon {
  display: none;
}

.search-tool-buttons {
  display: none;
}

@media screen and (max-width: 959px) {
  .search-tool-tabs {
    display: none;
  }
  .search-tool-buttons {
    display: block;
  }
  .search-tool-buttons .fade-enter,
  .search-tool-buttons .fade-leave-to {
    opacity: 0;
    -webkit-transform: translateY(-4px);
            transform: translateY(-4px);
  }
  .search-tool-buttons .fade-enter-active {
    transition: all 0.5s ease;
  }
  .search-tool-buttons .fade-leave-active {
    transition: all 0.3s cubic-bezier(1, 0.5, 0.8, 1);
  }
  .search-tool-category-inner {
    margin-top: 1px;
  }
  .search-tool-button:not(:first-child) {
    margin-top: 24px;
  }
  .search-tool-item {
    align-items: center;
    background-color: #ffffff;
    border-radius: 4px 4px 0 0;
    box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
    color: #354659;
    display: flex;
    font-weight: bold;
    height: 2.75rem;
    justify-content: center;
    position: relative;
    text-align: center;
    width: 100%;
  }
  .search-tool-item-icon {
    position: absolute;
    right: 1.5rem;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
  }
  .search-tool-item-icon svg {
    fill: #8999ab;
    width: 0.375rem;
  }
  .is-open .search-tool-item-icon {
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
  }
  .search-tool-bodies {
    gap: 0;
    padding: 0;
  }
  .search-tool-body {
    border-left: none;
    border-radius: 0;
    border-top: none;
    display: flex;
    height: auto;
    justify-content: space-between;
    margin: 0;
    position: relative;
    text-align: left;
    width: 50%;
  }
  .search-tool-body a {
    align-items: center;
    border-left: none;
    border-radius: 0;
    border-top: none;
    display: flex;
    padding: 1rem;
  }
  .search-tool-body:nth-child(2n) a {
    border-right: none;
  }
  .search-tool-category {
    display: none;
  }
  .search-tool-link {
    padding: 1rem 1.75rem 1rem 0.5rem;
    width: 100%;
  }
  .search-tool-body-icon {
    display: inline-block;
    margin-right: 0.5rem;
    position: absolute;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 0.25rem;
  }
  .search-tool-body-icon svg {
    fill: #8999ab;
  }
}
/* ========================================
scroll-to-search-tool
検索エリアまでスクロールする固定ボタン
======================================== */
#scroll-to-search-tool-btn {
  align-items: center;
  background: #ff9e4f;
  border: none;
  border-radius: 50%;
  bottom: 40px;
  box-shadow: 0 4px 15px rgba(193, 202, 222, 0.3);
  color: #354659;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  font-size: 0.8125rem;
  font-weight: 600;
  gap: 5px;
  height: 90px;
  justify-content: center;
  line-height: 130%;
  padding: 10px 0 0;
  position: fixed;
  right: 40px;
  width: 90px;
  z-index: 100;
}
#scroll-to-search-tool-btn svg {
  display: block;
}
#scroll-to-search-tool-btn.hidden {
  visibility: hidden;
}
#scroll-to-search-tool-btn:hover {
  background-color: #ffc871;
}

@media screen and (max-width: 959px) {
  #scroll-to-search-tool-btn {
    bottom: 10px;
    height: 80px;
    right: 10px;
    width: 80px;
  }
}
.archive .layout_main {
  margin: 40px 0 80px;
}

.post-list {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
}
.post-list .post {
  background-color: #ffffff;
  border-radius: 4px;
  box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
}
.post-list .post:hover {
  box-shadow: 0 2px 2px 0 rgba(193, 200, 222, 0.3);
}
.post-list .post-link {
  color: #354659;
  display: flex;
  flex-direction: column-reverse;
}
.post-list .post-info {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 32px;
}
.post-list .post-info .corporate-logo {
  height: 65px;
}
.post-list .post-info .corporate-logo img {
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
}
.post-list .post-info .corporate-name {
  font-size: 0.75rem;
  font-weight: normal;
  text-align: center;
}
.post-list .post-info .post-description {
  -webkit-box-orient: vertical;
  color: #354659;
  display: -webkit-box;
  font-size: 1rem;
  font-weight: bold;
  height: 72px;
  -webkit-line-clamp: 3;
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
}
.post-list .categories {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.post-list .categories .category {
  font-size: 0.75rem;
}
.post-list .categories.industry {
  color: #1168a6;
  font-weight: bold;
}
.post-list .categories.industry .category {
  font-size: 0.8125rem;
  line-height: 1.25rem;
}
.post-list .categories.industry .category::after {
  content: "/";
  margin: 0 0.3125rem;
}
.post-list .categories.industry .category:last-child::after {
  content: none;
}
.post-list .categories.services .category {
  border: 1px solid #e0e7ec;
  border-radius: 1.0625rem;
  color: #8999ab;
  margin: 0.5rem 0.5rem 0 0;
  padding: 0.3125rem 1rem;
}
.post-list .categories.services .category:last-child {
  margin-right: 0;
}
.post-list .thumbnail {
  background-color: #e0e7ec;
  min-height: 0%;
  text-align: center;
}
.post-list .thumbnail img {
  aspect-ratio: 3/2;
  -o-object-fit: cover;
     object-fit: cover;
}

.archive .btn-goto-list {
  margin: 40px 20px 0;
}

@media screen and (max-width: 959px) {
  .archive .page-title {
    margin-bottom: 0;
  }
  .post-list .post {
    flex-grow: 1;
    margin: 32px 20px 0;
    min-width: 300px;
    width: calc(50% - 40px);
  }
}
@media screen and (min-width: 960px) {
  .archive .layout_main {
    margin: 60px 0 120px;
  }
  .post-list .post {
    margin: 0 30px 0 0;
    width: calc((100% - 60px) / 3);
  }
  .post-list .post:nth-child(3n) {
    margin-right: 0;
  }
  .post-list .post:nth-child(n+4) {
    margin-top: 30px;
  }
  .archive .btn-goto-list {
    margin: 40px auto 0;
    width: 14.375rem;
  }
}
@media screen and (min-width: 680px) and (max-width: 959px) {
  .post-list .post:last-child:nth-child(odd) {
    max-width: calc(50% - 40px);
  }
}
@media screen and (max-width: 340px) {
  .post-list .post {
    min-width: 280px;
  }
}
.contents-inner {
  margin: 0 auto;
  max-width: 960px;
}

.page-title {
  color: #354659;
  font-size: 1.75rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 0 0 40px;
}

#post-404 {
  margin: 40px 20px;
}
#post-404 .headline {
  font-size: 1.75rem;
  line-height: 1.5;
  margin-bottom: 32px;
}
#post-404 p {
  line-height: 2;
}
#post-404 .btn-goto-home {
  margin: 32px auto 0;
}

@media screen and (max-width: 959px) {
  .page-title {
    margin: 0 20px 32px;
  }
}
@media screen and (min-width: 960px) {
  #post-404 {
    margin: 60px auto;
  }
  #post-404 .headline {
    margin-bottom: 40px;
  }
  #post-404 .btn-goto-home {
    width: 14.375rem;
  }
}
.single .layout_main {
  margin: 40px auto 80px;
}

@media screen and (min-width: 960px) {
  .single .layout_main {
    margin: 60px auto 120px;
  }
}
.post-type {
  font-size: 0.875rem;
  margin: 0 20px 8px;
}

.single-title {
  font-size: 1.75rem;
  font-weight: bold;
  margin: 0 20px 32px;
}

.company-info-under-title {
  background: #ffffff;
  border: 1px solid #e0e7ec;
  border-radius: 4px;
  margin: 32px 20px;
  padding: 24px;
}
.company-info-under-title .company-logo {
  margin-bottom: 16px;
  text-align: center;
}
.company-info-under-title .company-name {
  font-size: 1rem;
}
.company-info-under-title .company-industry-item {
  display: inline-block;
}
.company-info-under-title .company-industry-item:not(:last-child)::after {
  color: #8999ab;
  content: " / ";
  font-size: 0.75rem;
}
.company-info-under-title .company-industry-item a {
  color: #8999ab;
  font-size: 0.75rem;
}

.single-service-wrap {
  margin: 32px 20px;
}
.single-service-wrap .service-head {
  font-size: 0.875rem;
  font-weight: bold;
}
.single-service-wrap .services {
  display: flex;
  flex-wrap: wrap;
}
.single-service-wrap .service-item {
  font-size: 0.875rem;
  line-height: 1.4;
  margin: 0.6875rem 0.5rem 0 0;
}
.single-service-wrap .service-item a {
  border: 1px solid #e0e7ec;
  border-radius: 1.25rem;
  color: #354659;
  display: block;
  padding: 0.25rem 1.25rem;
}
.single-service-wrap .service-item a:hover {
  border-color: #a0b6c5;
}

.single-thumbnail {
  margin: 32px 20px;
}

@media screen and (min-width: 960px) {
  .layout_single-article-header {
    display: flex;
    justify-content: space-between;
  }
  .post-type {
    margin: 0 0 8px;
  }
  .single-title {
    margin: 0 0 30px;
  }
  .single-case .single-title {
    width: 443px;
  }
  .company-info-under-title {
    align-items: center;
    display: flex;
    margin: 30px 0 33px;
    width: 443px;
  }
  .company-info-under-title .company-logo {
    margin: 0;
    margin-right: 32px;
    min-width: 110px;
    width: 110px;
  }
  .single-service-wrap {
    margin: 0;
  }
  .single-thumbnail {
    height: 295px;
    margin: 0 0 20px;
    width: 465px;
  }
  .single .social-button-wrap {
    display: flex;
    justify-content: flex-end;
  }
  .single-format .social-button-wrap {
    justify-content: flex-end;
  }
}
.single-case-lead {
  line-height: 2;
  margin: 56px 20px;
}

.agenda-effect-frame {
  display: flex;
  flex-direction: column;
  margin: 56px 20px;
}

.agenda-box-frame {
  background: #ffffff;
  border-radius: 4px;
  border-top: 6px solid;
  box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
  margin: 0;
  padding: 32px 24px;
}
.agenda-box-frame.before {
  border-top-color: #386ece;
}
.agenda-box-frame.before svg {
  fill: #386ece;
  height: 1.1875rem;
  margin-right: 1rem;
  width: 1.4375rem;
}
.agenda-box-frame.after {
  border-top-color: #00c7dd;
}
.agenda-box-frame.after svg {
  fill: #00c7dd;
  height: 1.1875rem;
  margin-right: 1rem;
  width: 1.1875rem;
}

.agenda-box-frame-term {
  align-items: center;
  display: flex;
  font-size: 1rem;
  font-weight: bold;
  justify-content: center;
  line-height: 1.5;
  margin-bottom: 16px;
}
.agenda-box-frame-term img {
  margin-right: 1rem;
}
.agenda-box-frame-term.icon-bulblight svg {
  height: 1.25rem;
  width: 1.6875rem;
}

.agenda-box-frame-description {
  display: list-item;
  line-height: 2;
  list-style: disc;
  margin: 0 0 8px 15px;
}
.agenda-box-frame-description:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 959px) {
  .agenda-effect-frame .agenda-arrow {
    align-items: center;
    display: flex;
    height: 58px;
    justify-content: center;
    margin: 16px;
  }
  .agenda-effect-frame .agenda-arrow img {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}
@media screen and (min-width: 960px) {
  .single-case-lead {
    margin: 60px 0 80px;
  }
  .agenda-effect-frame {
    flex-direction: row;
    justify-content: space-between;
    margin: 80px 0;
    position: relative;
  }
  .agenda-effect-frame .agenda-arrow {
    left: 50%;
    margin: -18px 0 0 -29px;
    position: absolute;
    top: 50%;
  }
  .agenda-box-frame {
    padding: 32px;
    width: 465px;
  }
}
.service-end-notification {
  background-color: #fffdd9;
  display: flex;
  padding: 1rem;
}
.service-end-notification + .service-end-notification {
  margin-top: 1.25rem;
}
.service-end-notification .notification-icon {
  margin-right: 1.375rem;
  min-width: 22px;
  padding-top: 4px;
  width: 22px;
}
.service-end-notification .notification-icon svg {
  height: 20px;
}
.service-end-notification .notification-body {
  font-size: 0.875rem;
  line-height: 2;
}
.service-end-notification .notification-body a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 959px) {
  .service-end-notification {
    margin: 0 20px;
  }
}
.company-info-under-content {
  background: #f6f9fb;
  display: flex;
  flex-direction: column-reverse;
  padding: 24px 20px;
}
.company-info-under-content .company-info {
  margin: 0;
}
.company-info-under-content .company-logo {
  align-items: center;
  background-color: #ffffff;
  display: flex;
  height: 187px;
  justify-content: center;
  margin-bottom: 24px;
}
.company-info-under-content .company-logo img {
  max-height: 187px;
}
.company-info-under-content .company-name {
  font-size: 1rem;
  font-weight: bold;
}
.company-info-under-content .company-info-details {
  margin: 16px 0 0;
}
.company-info-under-content .company-info-detail {
  display: flex;
  font-size: 0.875rem;
  line-height: 2;
  margin-bottom: 8px;
}
.company-info-under-content .company-info-detail:last-child {
  margin-bottom: 0;
}
.company-info-under-content .company-info-detail dt {
  margin-right: 14px;
  min-width: 4.5rem;
  width: 4.5rem;
}
.company-info-under-content .company-info-detail .company-link {
  color: #354659;
}

@media screen and (min-width: 960px) {
  .company-info-under-content {
    flex-direction: row-reverse;
    justify-content: flex-end;
    padding: 32px;
  }
  .company-info-under-content .company-logo {
    height: 200px;
    justify-content: center;
    margin: 0 70px 0 0;
    min-width: 300px;
    width: 300px;
  }
  .company-info-under-content .company-logo img {
    max-height: 200px;
    max-width: 300px;
  }
  .company-info-under-content .company-info {
    max-width: 526px;
  }
  .company-info-under-content .company-info-details {
    margin: 24px 0 0;
  }
  .company-info-under-content .company-info-detail {
    margin-bottom: 16px;
  }
  .company-info-under-content .company-info-detail dt {
    margin-right: 20px;
    min-width: 5.5rem;
    width: 5.5rem;
  }
}
.single .btn-goto-list {
  margin: 40px 20px 0;
}

@media screen and (min-width: 960px) {
  .single .btn-goto-list {
    margin: 56px auto 0;
    width: 14.375rem;
  }
}
.introduction-partner-layout {
  background-color: #e6eff6;
  padding: 24px 20px;
}
.introduction-partner-layout .introduction-partner-head {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 24px;
  text-align: left;
}
.introduction-partner-layout .introduction-partner_info {
  background-color: #ffffff;
  border-radius: 4px;
  box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
  color: #354659;
  display: flex;
  flex-direction: column-reverse;
  overflow: hidden;
  position: relative;
}
.introduction-partner-layout .introduction-partner_info .partner_info {
  flex-grow: 1;
  margin: 0;
  padding: 28px 34px;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-name {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 16px;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-details {
  max-width: 24px 0 0;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-details .partner_info-detail {
  display: flex;
  font-size: 0.875rem;
  line-height: 2;
  margin-bottom: 8px;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-details .partner_info-detail dt {
  margin-right: 14px;
  min-width: 4.5rem;
  width: 4.5rem;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-details .partner_info-detail dd {
  margin-left: 0;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-details .partner_info-detail a {
  color: #354659;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-description {
  font-size: 0.875rem;
  line-height: 2;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-contact {
  display: flex;
  flex-direction: row;
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.56px;
  line-height: 170%; /* 23.8px */
  margin-top: 16px;
}
.introduction-partner-layout .introduction-partner_info .partner_info .partner_info-contact .introduction-partner-angle svg {
  fill: #8999ab;
  height: 12px;
  margin-left: 10px;
  width: 6px;
}
.introduction-partner-layout .introduction-partner_info .partner_info-logo {
  align-items: center;
  display: flex;
  justify-content: center;
  max-height: 186px;
  overflow: hidden;
}
.introduction-partner-layout .introduction-partner_info .partner_info-logo img {
  max-width: 100%;
  vertical-align: bottom;
}

.introduction-services {
  background-color: #e6eff6;
  padding: 24px 20px;
}
.service-end-notification + .introduction-services {
  margin-top: 80px;
}

.introduction-services-head {
  font-size: 1.25rem;
  font-weight: bold;
  margin: 0 0 24px;
  text-align: left;
}

.introduction-service-static,
.introduction-service-link {
  background-color: #ffffff;
  border-radius: 4px;
  box-shadow: 0 8px 16px 0 rgba(193, 200, 222, 0.3);
  color: #354659;
  display: flex;
  flex-direction: column-reverse;
  overflow: hidden;
  position: relative;
}
.introduction-service-static + .introduction-service-static,
.introduction-service-static + .introduction-service-link,
.introduction-service-link + .introduction-service-static,
.introduction-service-link + .introduction-service-link {
  margin-top: 24px;
}

.introduction-service-link:hover {
  box-shadow: 0 2px 2px 0 rgba(193, 200, 222, 0.3);
}

.introduction-service-info {
  margin: 24px 50px 32px 32px;
}

.introduction-service-name {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 16px;
}

.introduction-service-description {
  font-size: 0.875rem;
  line-height: 2;
}

.introduction-service-logo {
  align-items: center;
  display: flex;
  justify-content: center;
  max-height: 186px;
  overflow: hidden;
}

.introduction-service-angle {
  margin-top: 77px;
  position: absolute;
  right: 24px;
  top: 50%;
}
.introduction-service-angle svg {
  fill: #8999ab;
  height: 12px;
  width: 6px;
}

@media screen and (min-width: 960px) {
  .introduction-services {
    padding: 32px;
  }
  .introduction-service-static,
  .introduction-service-link {
    align-items: stretch;
    flex-direction: row-reverse;
    justify-content: flex-end;
  }
  .introduction-service-info {
    flex-grow: 1;
    margin: 0;
    padding: 28px 64px 28px 34px;
  }
  .introduction-service-logo {
    height: auto;
    min-height: 180px;
    min-width: 270px;
    width: 270px;
  }
  .introduction-service-logo img {
    width: 100%;
  }
  .introduction-service-angle {
    margin-top: -6px;
  }
}
.layout_single-content {
  margin: 80px 20px;
}
.layout_single-content h2,
.layout_single-content h3,
.layout_single-content h4 {
  clear: both;
  font-weight: bold;
  line-height: 1.5;
  margin: 56px 0 24px;
  position: relative;
  width: 100%;
}
.layout_single-content h2 {
  font-size: 1.625rem;
  padding: calc(16px - 0.40625rem) 24px;
}
.layout_single-content h2::before {
  background: linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 8px;
}
.layout_single-content h3 {
  font-size: 1.375rem;
  padding-bottom: calc(16px - 0.34375rem);
}
.layout_single-content h3::before {
  background: linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
  bottom: 0;
  content: "";
  height: 4px;
  left: 0;
  position: absolute;
  width: 100%;
}
.layout_single-content h4 {
  font-size: 1rem;
  padding: calc(8px - 0.25rem) 20px;
}
.layout_single-content h4::before {
  background: linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 4px;
}
.layout_single-content h2 + h3,
.layout_single-content h3 + h4 {
  margin-top: 24px;
}
.layout_single-content p {
  line-height: 2;
  margin: 16px 0;
}
.layout_single-content mark {
  background: linear-gradient(transparent 65%, rgba(0, 167, 218, 0.3) 35%);
  color: #354659;
  font-weight: 600;
  padding-bottom: 0.25rem;
}
.layout_single-content ul {
  list-style-type: disc;
  margin: 16px 0;
  padding-left: 40px;
}
.layout_single-content li {
  margin-bottom: 0.4375rem;
}
.layout_single-content .wp-block-table {
  margin: 80px 0;
}
.layout_single-content table {
  border-collapse: collapse;
}
.layout_single-content th,
.layout_single-content td {
  border: 1px solid #e0e7ec;
  padding: 14px;
}
.layout_single-content th {
  background-color: #f6f8f9;
  text-align: left;
}
.layout_single-content a:hover {
  text-decoration: underline;
}
.layout_single-content .wp-block-table figcaption {
  margin-top: 0.4375rem;
  text-align: center;
}
.layout_single-content .alignright {
  margin: 0 0 20px 20px;
}
.layout_single-content .alignleft {
  margin: 0 20px 20px 0;
}
.layout_single-content .wp-block-image {
  margin: 40px 0;
}
.layout_single-content .wp-block-image.profile {
  margin: 0;
}
.layout_single-content .wp-block-image.profile figcaption {
  font-size: 0.75rem;
  margin: 14px 0 0;
  text-align: left;
}
.layout_single-content .wp-block-column > :first-child {
  margin-top: 0;
}
.layout_single-content .wp-block-column > :last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 959px) {
  .layout_single-content .wp-block-column + .wp-block-column {
    margin-top: 24px;
  }
  .layout_single-content .wp-block-image img {
    height: auto;
    width: 100%;
  }
  .layout_single-content .wp-block-group__inner-container {
    align-items: center;
    display: flex;
    flex-direction: column;
  }
  .layout_single-content .wp-block-group__inner-container .wp-block-image.profile {
    margin: 24px 0 0;
    max-width: 385px;
    order: 1;
    width: 100%;
  }
  .layout_single-content .wp-block-group__inner-container .wp-block-image.profile .alignright {
    margin: 0 auto;
    width: 100%;
  }
  .layout_single-content table {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
  }
}
@media screen and (min-width: 960px) {
  .layout_single-content {
    margin: 80px 0;
  }
  .layout_single-content h2,
  .layout_single-content h3,
  .layout_single-content h4 {
    margin: 80px 0 30px;
  }
  .layout_single-content .wp-block-image {
    margin: 80px 0;
  }
}
@media screen and (min-width: 960px) {
  .introduction-partner-layout {
    padding: 32px;
  }
  .introduction-partner-layout .introduction-partner_info {
    flex-direction: row-reverse;
    justify-content: flex-end;
  }
  .introduction-partner-layout .introduction-partner_info .partner_info-logo {
    height: auto;
    min-width: 270px;
    width: 270px;
  }
  .introduction-partner-layout .introduction-partner_info .partner_info-logo img {
    width: 100%;
  }
}
@media screen and (max-width: 960px) {
  .introduction-partner-layout .introduction-partner-head {
    text-align: center;
  }
  .introduction-partner-layout .introduction-partner_info {
    flex-direction: column-reverse;
  }
  .introduction-partner-layout .introduction-partner_info .partner_info-logo {
    width: 100%;
  }
  .introduction-services-head {
    text-align: center;
  }
}
.yarpp-related {
  margin: 80px auto 40px;
}
.yarpp-related.yarpp-related-none {
  display: none;
}

.yarpp-headline {
  margin: 0 auto 32px;
  position: relative;
  text-align: center;
}
.yarpp-headline .headline {
  background-color: #ffffff;
  display: inline-block;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1;
  padding: 0 1.5625rem;
}
.yarpp-headline::after {
  background-color: #e0e7ec;
  content: "";
  display: block;
  height: 2px;
  margin-left: 20px;
  position: absolute;
  top: calc(50% - 1px);
  width: calc(100% - 40px);
  z-index: -1;
}

@media screen and (min-width: 960px) {
  .yarpp-related {
    margin: 120px auto 56px;
  }
  .yarpp-headline {
    margin-bottom: 72px;
  }
  .yarpp-headline::after {
    margin: 0;
    width: 100%;
  }
}
.layout_cta {
  background-image: url("assets/images/resource/cta_bg.png"), linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
  background-size: cover;
  margin-top: 40px;
  padding: 60px 0;
  text-align: center;
}
.search-tool + .layout_cta {
  margin-top: 0;
}

.cta-title {
  color: #ffffff;
  font-size: 1.25rem;
}

.cta-main {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 960px;
  min-height: 256px;
  position: relative;
}

.cta-inner {
  align-items: center;
  background-color: #ffffff;
  border-radius: 4px;
  box-shadow: 0 4px 15px 0 rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 100%;
  padding: 32px;
  width: 460px;
}

.cta-head {
  color: #354659;
  font-size: 1.375rem;
  line-height: 100%;
  position: relative;
}
.cta-head span {
  font-size: 0.875rem;
}
.cta-head::before, .cta-head::after {
  background: #000000;
  content: "";
  display: block;
  height: 2px;
  position: absolute;
  top: 50%;
  width: 30px;
}
.cta-head::before {
  left: -45px;
}
.cta-head::after {
  right: -45px;
}

.cta-description {
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 180%;
}

.cta-btn {
  height: 3.75rem;
  width: 16.25rem;
}

@media screen and (max-width: 959px) {
  .layout_cta {
    background-image: url("assets/images/resource/cta_bg_mobile.png"), linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
    background-position: bottom, center;
    background-repeat: no-repeat;
    background-size: auto;
    padding: 60px 20px 140px;
  }
  .cta-main {
    align-items: center;
    flex-direction: column;
    gap: 32px;
  }
}
.cta-under-content {
  background-image: url("assets/images/resource/cta_bg_under_content.png"), linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 4px;
  display: flex;
  justify-content: flex-end;
  margin: 120px 0;
  padding: 32px;
}
.cta-under-content .cta-under-content-inner {
  background-color: #ffffff;
  border-radius: 3px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 20px;
  width: 480px;
}
.cta-under-content .cta-under-content-lead {
  font-size: 1.625rem;
  font-weight: 600;
}
.cta-under-content .cta-under-content-lead span {
  font-size: 1rem;
}
.cta-under-content .cta-under-content-description {
  font-size: 0.875rem;
}
.cta-under-content .cta-under-content-btn {
  width: 192px;
}

@media screen and (max-width: 959px) {
  .cta-under-content {
    background-image: linear-gradient(-225deg, rgb(0, 199, 221) 0%, rgb(56, 116, 206) 100%);
    margin: 80px 20px;
    padding: 20px;
  }
  .cta-under-content .cta-under-content-lead {
    position: relative;
  }
  .cta-under-content .cta-under-content-lead::after {
    content: url("assets/images/resource/cta_sp_under_content.png");
    position: absolute;
    top: -40px;
  }
  .cta-under-content .cta-under-content-inner {
    gap: 20px;
  }
  .cta-under-content .cta-under-content-btn {
    width: 100%;
  }
  .cta-under-content br {
    display: none;
  }
}
.social-buttons {
  align-items: flex-end;
  display: flex;
}

.social-button {
  display: flex;
  margin-right: 0.625rem;
}

@media screen and (max-width: 959px) {
  .social-buttons {
    margin: 0 20px;
  }
}
@media all and (-ms-high-contrast: none) {
  .twitter-share-button {
    background-color: #1b95e0;
    border-radius: 3px;
    box-sizing: border-box;
    color: #ffffff;
    font-size: 11px;
    font-weight: 500;
    height: 20px;
    padding: 3px 8px 0;
  }
}
.pagination {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-top: 48px;
}
.pagination .page {
  font-size: 0.875rem;
  margin: 0 32px;
}
.pagination .next,
.pagination .prev {
  height: 2.25rem;
  width: 4.375rem;
}
.pagination .next a,
.pagination .prev a {
  align-items: center;
  border: 1px solid #e0e7ec;
  border-radius: 4px;
  color: #354659;
  display: flex;
  font-size: 0.875rem;
  height: 100%;
  justify-content: center;
  width: 100%;
}
.pagination .next a:hover,
.pagination .prev a:hover {
  border-color: #a0b6c5;
}

@media screen and (min-width: 960px) {
  .pagination {
    margin-top: 56px;
  }
}
.home-section {
  margin: 80px auto;
}
.home-section:first-child {
  margin-top: 56px;
}

.home-headline {
  position: relative;
  text-align: center;
}
.home-headline .headline {
  background-color: #ffffff;
  display: inline-block;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  padding: 0 1.5625rem;
}
.home-headline::after {
  background-color: #e0e7ec;
  content: "";
  display: block;
  height: 2px;
  margin-left: 20px;
  position: absolute;
  top: calc(50% - 1px);
  width: calc(100% - 40px);
  z-index: -1;
}

.home .btn-goto-list {
  margin: 40px 20px 0;
}

.home .customers {
  align-items: center;
  -webkit-column-gap: 24px;
     -moz-column-gap: 24px;
          column-gap: 24px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 32px;
  row-gap: 16px;
}
.home .customers a {
  width: 160px;
}
.home .customers a:hover {
  opacity: 0.5;
}
.home .customers img {
  display: block;
  height: auto;
  width: 100%;
}

@media screen and (min-width: 960px) {
  .home-section {
    margin: 80px auto;
  }
  .home-section:first-child {
    margin-top: 60px;
  }
  .home-headline {
    margin: 0 0 40px;
  }
  .home-headline .headline {
    font-size: 1.5rem;
  }
  .home-headline::after {
    margin: 0;
    width: 100%;
  }
  .home .btn-goto-list {
    margin: 56px auto 0;
    width: 14.375rem;
  }
  .home .customers {
    -webkit-column-gap: 20px;
       -moz-column-gap: 20px;
            column-gap: 20px;
    justify-content: start;
    margin: 40px 0 0;
    row-gap: 24px;
  }
  .home .customers a {
    width: 176px;
  }
}
@media screen and (max-width: 600px) {
  .pad-block,
  .pc-block {
    display: none;
  }
}
@media screen and (min-width: 601px) {
  .pad-block,
  .sp-block {
    display: none;
  }
}