@charset "UTF-8";
@import url("https: //fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap");
@import url("https: //fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Italianno&display=swap");
:root {
  --color-black: #303030;
  --color-white: #fff;
  --color-primary: #0166C9;
  --color-primary-light: #A1E0E7;
  --color-primary-light2: #008BD1;
  --color-txt-black: var(--color-black);
  --color-txt-white: var(--color-white);
  --color-txt-primary: var(--color-primary);
  --color-txt-primary-light: var(--color-primary-light);
  --color-txt-primary-light2: var(--color-primary-light2);
  --color-txt-annotation: #999;
  --color-txt-placeholder: #eee;
  --color-bg-black: var(--color-black);
  --color-bg-white: var(--color-white);
  --color-bg-gray: rgba(250, 249, 249, 0.94);
  --color-bg-primary: var(--color-primary);
  --color-bg-primary-light: var(--color-primary-light);
  --color-bg-primary-light2: var(--color-primary-light2);
  --color-border-gray: #cccccc;
  --color-border-black: var(--color-black);
  --color-border-white: var(--color-white);
  --color-border-primary: var(--color-primary);
  --color-border-primary-light: var(--color-primary-light);
  --color-border-primary-light2: var(--color-primary-light2);
  --color-border-input: #eee;
}

:root {
  --header-height: 74px;
  --header-service-height: 74px;
}
@media screen and (max-width: 949px) {
  :root {
    --header-height: 74px;
    --header-service-height: 74px;
  }
}
@media screen and (max-width: 767px) {
  :root {
    --header-height: 49px;
    --header-service-height: 49px;
  }
}

:root {
  --z-index-header: 1000;
  --z-service-contact-btn: 800;
  --z-service-contact-form: 900;
}

/*! destyle.css v4.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */
*,
::after,
::before {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  margin: 0;
}

main {
  display: block;
}

address,
blockquote,
dl,
figure,
form,
iframe,
p,
pre,
table {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

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

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

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

abbr[title] {
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

embed,
iframe,
img,
object,
svg {
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: 0 0;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
}

[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
}

[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled,
button:disabled {
  cursor: default;
}

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

[type=number] {
  -moz-appearance: textfield;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable]:focus {
  outline: auto;
}

table {
  border-color: inherit;
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
  font-weight: normal;
}

th {
  text-align: left;
  font-weight: normal;
}

html {
  scroll-behavior: smooth;
}

:target {
  scroll-margin-top: calc(var(--header-height) + 20px);
}

body {
  font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  background-color: var(--color-bg-black);
  color: var(--color-txt-white);
  line-height: 1.5;
}

main {
  min-height: 50vh;
  overflow-x: clip;
}

body.isHidden {
  overflow: hidden;
}

img,
svg,
iframe {
  display: block;
  object-fit: cover;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  a {
    transition: all 0.3s ease;
    transition-property: opacity;
  }
  a:active {
    opacity: 0.7;
  }
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes pulseMotion {
  0% {
    transform: scale(1, 1);
    opacity: 0.3;
  }
  100% {
    transform: scale(1.6, 1.6);
    opacity: 0;
  }
}
[data-aos][data-aos][data-aos-duration="50"], body[data-aos-duration="50"] [data-aos] {
  transition-duration: 50ms;
}

[data-aos][data-aos][data-aos-delay="50"], body[data-aos-delay="50"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="50"].aos-animate, body[data-aos-delay="50"] [data-aos].aos-animate {
  transition-delay: 50ms;
}

[data-aos][data-aos][data-aos-duration="100"], body[data-aos-duration="100"] [data-aos] {
  transition-duration: 0.1s;
}

[data-aos][data-aos][data-aos-delay="100"], body[data-aos-delay="100"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="100"].aos-animate, body[data-aos-delay="100"] [data-aos].aos-animate {
  transition-delay: 0.1s;
}

[data-aos][data-aos][data-aos-duration="150"], body[data-aos-duration="150"] [data-aos] {
  transition-duration: 0.15s;
}

[data-aos][data-aos][data-aos-delay="150"], body[data-aos-delay="150"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="150"].aos-animate, body[data-aos-delay="150"] [data-aos].aos-animate {
  transition-delay: 0.15s;
}

[data-aos][data-aos][data-aos-duration="200"], body[data-aos-duration="200"] [data-aos] {
  transition-duration: 0.2s;
}

[data-aos][data-aos][data-aos-delay="200"], body[data-aos-delay="200"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="200"].aos-animate, body[data-aos-delay="200"] [data-aos].aos-animate {
  transition-delay: 0.2s;
}

[data-aos][data-aos][data-aos-duration="250"], body[data-aos-duration="250"] [data-aos] {
  transition-duration: 0.25s;
}

[data-aos][data-aos][data-aos-delay="250"], body[data-aos-delay="250"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="250"].aos-animate, body[data-aos-delay="250"] [data-aos].aos-animate {
  transition-delay: 0.25s;
}

[data-aos][data-aos][data-aos-duration="300"], body[data-aos-duration="300"] [data-aos] {
  transition-duration: 0.3s;
}

[data-aos][data-aos][data-aos-delay="300"], body[data-aos-delay="300"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="300"].aos-animate, body[data-aos-delay="300"] [data-aos].aos-animate {
  transition-delay: 0.3s;
}

[data-aos][data-aos][data-aos-duration="350"], body[data-aos-duration="350"] [data-aos] {
  transition-duration: 0.35s;
}

[data-aos][data-aos][data-aos-delay="350"], body[data-aos-delay="350"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="350"].aos-animate, body[data-aos-delay="350"] [data-aos].aos-animate {
  transition-delay: 0.35s;
}

[data-aos][data-aos][data-aos-duration="400"], body[data-aos-duration="400"] [data-aos] {
  transition-duration: 0.4s;
}

[data-aos][data-aos][data-aos-delay="400"], body[data-aos-delay="400"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="400"].aos-animate, body[data-aos-delay="400"] [data-aos].aos-animate {
  transition-delay: 0.4s;
}

[data-aos][data-aos][data-aos-duration="450"], body[data-aos-duration="450"] [data-aos] {
  transition-duration: 0.45s;
}

[data-aos][data-aos][data-aos-delay="450"], body[data-aos-delay="450"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="450"].aos-animate, body[data-aos-delay="450"] [data-aos].aos-animate {
  transition-delay: 0.45s;
}

[data-aos][data-aos][data-aos-duration="500"], body[data-aos-duration="500"] [data-aos] {
  transition-duration: 0.5s;
}

[data-aos][data-aos][data-aos-delay="500"], body[data-aos-delay="500"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="500"].aos-animate, body[data-aos-delay="500"] [data-aos].aos-animate {
  transition-delay: 0.5s;
}

[data-aos][data-aos][data-aos-duration="550"], body[data-aos-duration="550"] [data-aos] {
  transition-duration: 0.55s;
}

[data-aos][data-aos][data-aos-delay="550"], body[data-aos-delay="550"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="550"].aos-animate, body[data-aos-delay="550"] [data-aos].aos-animate {
  transition-delay: 0.55s;
}

[data-aos][data-aos][data-aos-duration="600"], body[data-aos-duration="600"] [data-aos] {
  transition-duration: 0.6s;
}

[data-aos][data-aos][data-aos-delay="600"], body[data-aos-delay="600"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="600"].aos-animate, body[data-aos-delay="600"] [data-aos].aos-animate {
  transition-delay: 0.6s;
}

[data-aos][data-aos][data-aos-duration="650"], body[data-aos-duration="650"] [data-aos] {
  transition-duration: 0.65s;
}

[data-aos][data-aos][data-aos-delay="650"], body[data-aos-delay="650"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="650"].aos-animate, body[data-aos-delay="650"] [data-aos].aos-animate {
  transition-delay: 0.65s;
}

[data-aos][data-aos][data-aos-duration="700"], body[data-aos-duration="700"] [data-aos] {
  transition-duration: 0.7s;
}

[data-aos][data-aos][data-aos-delay="700"], body[data-aos-delay="700"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="700"].aos-animate, body[data-aos-delay="700"] [data-aos].aos-animate {
  transition-delay: 0.7s;
}

[data-aos][data-aos][data-aos-duration="750"], body[data-aos-duration="750"] [data-aos] {
  transition-duration: 0.75s;
}

[data-aos][data-aos][data-aos-delay="750"], body[data-aos-delay="750"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="750"].aos-animate, body[data-aos-delay="750"] [data-aos].aos-animate {
  transition-delay: 0.75s;
}

[data-aos][data-aos][data-aos-duration="800"], body[data-aos-duration="800"] [data-aos] {
  transition-duration: 0.8s;
}

[data-aos][data-aos][data-aos-delay="800"], body[data-aos-delay="800"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="800"].aos-animate, body[data-aos-delay="800"] [data-aos].aos-animate {
  transition-delay: 0.8s;
}

[data-aos][data-aos][data-aos-duration="850"], body[data-aos-duration="850"] [data-aos] {
  transition-duration: 0.85s;
}

[data-aos][data-aos][data-aos-delay="850"], body[data-aos-delay="850"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="850"].aos-animate, body[data-aos-delay="850"] [data-aos].aos-animate {
  transition-delay: 0.85s;
}

[data-aos][data-aos][data-aos-duration="900"], body[data-aos-duration="900"] [data-aos] {
  transition-duration: 0.9s;
}

[data-aos][data-aos][data-aos-delay="900"], body[data-aos-delay="900"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="900"].aos-animate, body[data-aos-delay="900"] [data-aos].aos-animate {
  transition-delay: 0.9s;
}

[data-aos][data-aos][data-aos-duration="950"], body[data-aos-duration="950"] [data-aos] {
  transition-duration: 0.95s;
}

[data-aos][data-aos][data-aos-delay="950"], body[data-aos-delay="950"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="950"].aos-animate, body[data-aos-delay="950"] [data-aos].aos-animate {
  transition-delay: 0.95s;
}

[data-aos][data-aos][data-aos-duration="1000"], body[data-aos-duration="1000"] [data-aos] {
  transition-duration: 1s;
}

[data-aos][data-aos][data-aos-delay="1000"], body[data-aos-delay="1000"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1000"].aos-animate, body[data-aos-delay="1000"] [data-aos].aos-animate {
  transition-delay: 1s;
}

[data-aos][data-aos][data-aos-duration="1050"], body[data-aos-duration="1050"] [data-aos] {
  transition-duration: 1.05s;
}

[data-aos][data-aos][data-aos-delay="1050"], body[data-aos-delay="1050"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1050"].aos-animate, body[data-aos-delay="1050"] [data-aos].aos-animate {
  transition-delay: 1.05s;
}

[data-aos][data-aos][data-aos-duration="1100"], body[data-aos-duration="1100"] [data-aos] {
  transition-duration: 1.1s;
}

[data-aos][data-aos][data-aos-delay="1100"], body[data-aos-delay="1100"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1100"].aos-animate, body[data-aos-delay="1100"] [data-aos].aos-animate {
  transition-delay: 1.1s;
}

[data-aos][data-aos][data-aos-duration="1150"], body[data-aos-duration="1150"] [data-aos] {
  transition-duration: 1.15s;
}

[data-aos][data-aos][data-aos-delay="1150"], body[data-aos-delay="1150"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1150"].aos-animate, body[data-aos-delay="1150"] [data-aos].aos-animate {
  transition-delay: 1.15s;
}

[data-aos][data-aos][data-aos-duration="1200"], body[data-aos-duration="1200"] [data-aos] {
  transition-duration: 1.2s;
}

[data-aos][data-aos][data-aos-delay="1200"], body[data-aos-delay="1200"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1200"].aos-animate, body[data-aos-delay="1200"] [data-aos].aos-animate {
  transition-delay: 1.2s;
}

[data-aos][data-aos][data-aos-duration="1250"], body[data-aos-duration="1250"] [data-aos] {
  transition-duration: 1.25s;
}

[data-aos][data-aos][data-aos-delay="1250"], body[data-aos-delay="1250"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1250"].aos-animate, body[data-aos-delay="1250"] [data-aos].aos-animate {
  transition-delay: 1.25s;
}

[data-aos][data-aos][data-aos-duration="1300"], body[data-aos-duration="1300"] [data-aos] {
  transition-duration: 1.3s;
}

[data-aos][data-aos][data-aos-delay="1300"], body[data-aos-delay="1300"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1300"].aos-animate, body[data-aos-delay="1300"] [data-aos].aos-animate {
  transition-delay: 1.3s;
}

[data-aos][data-aos][data-aos-duration="1350"], body[data-aos-duration="1350"] [data-aos] {
  transition-duration: 1.35s;
}

[data-aos][data-aos][data-aos-delay="1350"], body[data-aos-delay="1350"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1350"].aos-animate, body[data-aos-delay="1350"] [data-aos].aos-animate {
  transition-delay: 1.35s;
}

[data-aos][data-aos][data-aos-duration="1400"], body[data-aos-duration="1400"] [data-aos] {
  transition-duration: 1.4s;
}

[data-aos][data-aos][data-aos-delay="1400"], body[data-aos-delay="1400"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1400"].aos-animate, body[data-aos-delay="1400"] [data-aos].aos-animate {
  transition-delay: 1.4s;
}

[data-aos][data-aos][data-aos-duration="1450"], body[data-aos-duration="1450"] [data-aos] {
  transition-duration: 1.45s;
}

[data-aos][data-aos][data-aos-delay="1450"], body[data-aos-delay="1450"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1450"].aos-animate, body[data-aos-delay="1450"] [data-aos].aos-animate {
  transition-delay: 1.45s;
}

[data-aos][data-aos][data-aos-duration="1500"], body[data-aos-duration="1500"] [data-aos] {
  transition-duration: 1.5s;
}

[data-aos][data-aos][data-aos-delay="1500"], body[data-aos-delay="1500"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1500"].aos-animate, body[data-aos-delay="1500"] [data-aos].aos-animate {
  transition-delay: 1.5s;
}

[data-aos][data-aos][data-aos-duration="1550"], body[data-aos-duration="1550"] [data-aos] {
  transition-duration: 1.55s;
}

[data-aos][data-aos][data-aos-delay="1550"], body[data-aos-delay="1550"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1550"].aos-animate, body[data-aos-delay="1550"] [data-aos].aos-animate {
  transition-delay: 1.55s;
}

[data-aos][data-aos][data-aos-duration="1600"], body[data-aos-duration="1600"] [data-aos] {
  transition-duration: 1.6s;
}

[data-aos][data-aos][data-aos-delay="1600"], body[data-aos-delay="1600"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1600"].aos-animate, body[data-aos-delay="1600"] [data-aos].aos-animate {
  transition-delay: 1.6s;
}

[data-aos][data-aos][data-aos-duration="1650"], body[data-aos-duration="1650"] [data-aos] {
  transition-duration: 1.65s;
}

[data-aos][data-aos][data-aos-delay="1650"], body[data-aos-delay="1650"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1650"].aos-animate, body[data-aos-delay="1650"] [data-aos].aos-animate {
  transition-delay: 1.65s;
}

[data-aos][data-aos][data-aos-duration="1700"], body[data-aos-duration="1700"] [data-aos] {
  transition-duration: 1.7s;
}

[data-aos][data-aos][data-aos-delay="1700"], body[data-aos-delay="1700"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1700"].aos-animate, body[data-aos-delay="1700"] [data-aos].aos-animate {
  transition-delay: 1.7s;
}

[data-aos][data-aos][data-aos-duration="1750"], body[data-aos-duration="1750"] [data-aos] {
  transition-duration: 1.75s;
}

[data-aos][data-aos][data-aos-delay="1750"], body[data-aos-delay="1750"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1750"].aos-animate, body[data-aos-delay="1750"] [data-aos].aos-animate {
  transition-delay: 1.75s;
}

[data-aos][data-aos][data-aos-duration="1800"], body[data-aos-duration="1800"] [data-aos] {
  transition-duration: 1.8s;
}

[data-aos][data-aos][data-aos-delay="1800"], body[data-aos-delay="1800"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1800"].aos-animate, body[data-aos-delay="1800"] [data-aos].aos-animate {
  transition-delay: 1.8s;
}

[data-aos][data-aos][data-aos-duration="1850"], body[data-aos-duration="1850"] [data-aos] {
  transition-duration: 1.85s;
}

[data-aos][data-aos][data-aos-delay="1850"], body[data-aos-delay="1850"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1850"].aos-animate, body[data-aos-delay="1850"] [data-aos].aos-animate {
  transition-delay: 1.85s;
}

[data-aos][data-aos][data-aos-duration="1900"], body[data-aos-duration="1900"] [data-aos] {
  transition-duration: 1.9s;
}

[data-aos][data-aos][data-aos-delay="1900"], body[data-aos-delay="1900"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1900"].aos-animate, body[data-aos-delay="1900"] [data-aos].aos-animate {
  transition-delay: 1.9s;
}

[data-aos][data-aos][data-aos-duration="1950"], body[data-aos-duration="1950"] [data-aos] {
  transition-duration: 1.95s;
}

[data-aos][data-aos][data-aos-delay="1950"], body[data-aos-delay="1950"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1950"].aos-animate, body[data-aos-delay="1950"] [data-aos].aos-animate {
  transition-delay: 1.95s;
}

[data-aos][data-aos][data-aos-duration="2000"], body[data-aos-duration="2000"] [data-aos] {
  transition-duration: 2s;
}

[data-aos][data-aos][data-aos-delay="2000"], body[data-aos-delay="2000"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2000"].aos-animate, body[data-aos-delay="2000"] [data-aos].aos-animate {
  transition-delay: 2s;
}

[data-aos][data-aos][data-aos-duration="2050"], body[data-aos-duration="2050"] [data-aos] {
  transition-duration: 2.05s;
}

[data-aos][data-aos][data-aos-delay="2050"], body[data-aos-delay="2050"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2050"].aos-animate, body[data-aos-delay="2050"] [data-aos].aos-animate {
  transition-delay: 2.05s;
}

[data-aos][data-aos][data-aos-duration="2100"], body[data-aos-duration="2100"] [data-aos] {
  transition-duration: 2.1s;
}

[data-aos][data-aos][data-aos-delay="2100"], body[data-aos-delay="2100"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2100"].aos-animate, body[data-aos-delay="2100"] [data-aos].aos-animate {
  transition-delay: 2.1s;
}

[data-aos][data-aos][data-aos-duration="2150"], body[data-aos-duration="2150"] [data-aos] {
  transition-duration: 2.15s;
}

[data-aos][data-aos][data-aos-delay="2150"], body[data-aos-delay="2150"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2150"].aos-animate, body[data-aos-delay="2150"] [data-aos].aos-animate {
  transition-delay: 2.15s;
}

[data-aos][data-aos][data-aos-duration="2200"], body[data-aos-duration="2200"] [data-aos] {
  transition-duration: 2.2s;
}

[data-aos][data-aos][data-aos-delay="2200"], body[data-aos-delay="2200"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2200"].aos-animate, body[data-aos-delay="2200"] [data-aos].aos-animate {
  transition-delay: 2.2s;
}

[data-aos][data-aos][data-aos-duration="2250"], body[data-aos-duration="2250"] [data-aos] {
  transition-duration: 2.25s;
}

[data-aos][data-aos][data-aos-delay="2250"], body[data-aos-delay="2250"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2250"].aos-animate, body[data-aos-delay="2250"] [data-aos].aos-animate {
  transition-delay: 2.25s;
}

[data-aos][data-aos][data-aos-duration="2300"], body[data-aos-duration="2300"] [data-aos] {
  transition-duration: 2.3s;
}

[data-aos][data-aos][data-aos-delay="2300"], body[data-aos-delay="2300"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2300"].aos-animate, body[data-aos-delay="2300"] [data-aos].aos-animate {
  transition-delay: 2.3s;
}

[data-aos][data-aos][data-aos-duration="2350"], body[data-aos-duration="2350"] [data-aos] {
  transition-duration: 2.35s;
}

[data-aos][data-aos][data-aos-delay="2350"], body[data-aos-delay="2350"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2350"].aos-animate, body[data-aos-delay="2350"] [data-aos].aos-animate {
  transition-delay: 2.35s;
}

[data-aos][data-aos][data-aos-duration="2400"], body[data-aos-duration="2400"] [data-aos] {
  transition-duration: 2.4s;
}

[data-aos][data-aos][data-aos-delay="2400"], body[data-aos-delay="2400"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2400"].aos-animate, body[data-aos-delay="2400"] [data-aos].aos-animate {
  transition-delay: 2.4s;
}

[data-aos][data-aos][data-aos-duration="2450"], body[data-aos-duration="2450"] [data-aos] {
  transition-duration: 2.45s;
}

[data-aos][data-aos][data-aos-delay="2450"], body[data-aos-delay="2450"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2450"].aos-animate, body[data-aos-delay="2450"] [data-aos].aos-animate {
  transition-delay: 2.45s;
}

[data-aos][data-aos][data-aos-duration="2500"], body[data-aos-duration="2500"] [data-aos] {
  transition-duration: 2.5s;
}

[data-aos][data-aos][data-aos-delay="2500"], body[data-aos-delay="2500"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2500"].aos-animate, body[data-aos-delay="2500"] [data-aos].aos-animate {
  transition-delay: 2.5s;
}

[data-aos][data-aos][data-aos-duration="2550"], body[data-aos-duration="2550"] [data-aos] {
  transition-duration: 2.55s;
}

[data-aos][data-aos][data-aos-delay="2550"], body[data-aos-delay="2550"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2550"].aos-animate, body[data-aos-delay="2550"] [data-aos].aos-animate {
  transition-delay: 2.55s;
}

[data-aos][data-aos][data-aos-duration="2600"], body[data-aos-duration="2600"] [data-aos] {
  transition-duration: 2.6s;
}

[data-aos][data-aos][data-aos-delay="2600"], body[data-aos-delay="2600"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2600"].aos-animate, body[data-aos-delay="2600"] [data-aos].aos-animate {
  transition-delay: 2.6s;
}

[data-aos][data-aos][data-aos-duration="2650"], body[data-aos-duration="2650"] [data-aos] {
  transition-duration: 2.65s;
}

[data-aos][data-aos][data-aos-delay="2650"], body[data-aos-delay="2650"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2650"].aos-animate, body[data-aos-delay="2650"] [data-aos].aos-animate {
  transition-delay: 2.65s;
}

[data-aos][data-aos][data-aos-duration="2700"], body[data-aos-duration="2700"] [data-aos] {
  transition-duration: 2.7s;
}

[data-aos][data-aos][data-aos-delay="2700"], body[data-aos-delay="2700"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2700"].aos-animate, body[data-aos-delay="2700"] [data-aos].aos-animate {
  transition-delay: 2.7s;
}

[data-aos][data-aos][data-aos-duration="2750"], body[data-aos-duration="2750"] [data-aos] {
  transition-duration: 2.75s;
}

[data-aos][data-aos][data-aos-delay="2750"], body[data-aos-delay="2750"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2750"].aos-animate, body[data-aos-delay="2750"] [data-aos].aos-animate {
  transition-delay: 2.75s;
}

[data-aos][data-aos][data-aos-duration="2800"], body[data-aos-duration="2800"] [data-aos] {
  transition-duration: 2.8s;
}

[data-aos][data-aos][data-aos-delay="2800"], body[data-aos-delay="2800"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2800"].aos-animate, body[data-aos-delay="2800"] [data-aos].aos-animate {
  transition-delay: 2.8s;
}

[data-aos][data-aos][data-aos-duration="2850"], body[data-aos-duration="2850"] [data-aos] {
  transition-duration: 2.85s;
}

[data-aos][data-aos][data-aos-delay="2850"], body[data-aos-delay="2850"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2850"].aos-animate, body[data-aos-delay="2850"] [data-aos].aos-animate {
  transition-delay: 2.85s;
}

[data-aos][data-aos][data-aos-duration="2900"], body[data-aos-duration="2900"] [data-aos] {
  transition-duration: 2.9s;
}

[data-aos][data-aos][data-aos-delay="2900"], body[data-aos-delay="2900"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2900"].aos-animate, body[data-aos-delay="2900"] [data-aos].aos-animate {
  transition-delay: 2.9s;
}

[data-aos][data-aos][data-aos-duration="2950"], body[data-aos-duration="2950"] [data-aos] {
  transition-duration: 2.95s;
}

[data-aos][data-aos][data-aos-delay="2950"], body[data-aos-delay="2950"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2950"].aos-animate, body[data-aos-delay="2950"] [data-aos].aos-animate {
  transition-delay: 2.95s;
}

[data-aos][data-aos][data-aos-duration="3000"], body[data-aos-duration="3000"] [data-aos] {
  transition-duration: 3s;
}

[data-aos][data-aos][data-aos-delay="3000"], body[data-aos-delay="3000"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="3000"].aos-animate, body[data-aos-delay="3000"] [data-aos].aos-animate {
  transition-delay: 3s;
}

[data-aos][data-aos][data-aos-easing=linear], body[data-aos-easing=linear] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.25, 0.75, 0.75);
}

[data-aos][data-aos][data-aos-easing=ease], body[data-aos-easing=ease] [data-aos] {
  transition-timing-function: ease;
}

[data-aos][data-aos][data-aos-easing=ease-in], body[data-aos-easing=ease-in] [data-aos] {
  transition-timing-function: ease-in;
}

[data-aos][data-aos][data-aos-easing=ease-out], body[data-aos-easing=ease-out] [data-aos] {
  transition-timing-function: ease-out;
}

[data-aos][data-aos][data-aos-easing=ease-in-out], body[data-aos-easing=ease-in-out] [data-aos] {
  transition-timing-function: ease-in-out;
}

[data-aos][data-aos][data-aos-easing=ease-in-back], body[data-aos-easing=ease-in-back] [data-aos] {
  transition-timing-function: cubic-bezier(0.6, -0.28, 0.735, 0.045);
}

[data-aos][data-aos][data-aos-easing=ease-out-back], body[data-aos-easing=ease-out-back] [data-aos] {
  transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-back], body[data-aos-easing=ease-in-out-back] [data-aos] {
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

[data-aos][data-aos][data-aos-easing=ease-in-sine], body[data-aos-easing=ease-in-sine] [data-aos] {
  transition-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
}

[data-aos][data-aos][data-aos-easing=ease-out-sine], body[data-aos-easing=ease-out-sine] [data-aos] {
  transition-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-sine], body[data-aos-easing=ease-in-out-sine] [data-aos] {
  transition-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
}

[data-aos][data-aos][data-aos-easing=ease-in-quad], body[data-aos-easing=ease-in-quad] [data-aos] {
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-aos][data-aos][data-aos-easing=ease-out-quad], body[data-aos-easing=ease-out-quad] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-quad], body[data-aos-easing=ease-in-out-quad] [data-aos] {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-aos][data-aos][data-aos-easing=ease-in-cubic], body[data-aos-easing=ease-in-cubic] [data-aos] {
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-aos][data-aos][data-aos-easing=ease-out-cubic], body[data-aos-easing=ease-out-cubic] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-cubic], body[data-aos-easing=ease-in-out-cubic] [data-aos] {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-aos][data-aos][data-aos-easing=ease-in-quart], body[data-aos-easing=ease-in-quart] [data-aos] {
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-aos][data-aos][data-aos-easing=ease-out-quart], body[data-aos-easing=ease-out-quart] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-quart], body[data-aos-easing=ease-in-out-quart] [data-aos] {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-aos^=fade][data-aos^=fade] {
  opacity: 0;
  transition-property: opacity, transform;
}

[data-aos^=fade][data-aos^=fade].aos-animate {
  opacity: 1;
  transform: translateZ(0);
}

[data-aos=fade-up] {
  transform: translate3d(0, 100px, 0);
}

[data-aos=fade-down] {
  transform: translate3d(0, -100px, 0);
}

[data-aos=fade-right] {
  transform: translate3d(-100px, 0, 0);
}

[data-aos=fade-left] {
  transform: translate3d(100px, 0, 0);
}

[data-aos=fade-up-right] {
  transform: translate3d(-100px, 100px, 0);
}

[data-aos=fade-up-left] {
  transform: translate3d(100px, 100px, 0);
}

[data-aos=fade-down-right] {
  transform: translate3d(-100px, -100px, 0);
}

[data-aos=fade-down-left] {
  transform: translate3d(100px, -100px, 0);
}

[data-aos^=zoom][data-aos^=zoom] {
  opacity: 0;
  transition-property: opacity, transform;
}

[data-aos^=zoom][data-aos^=zoom].aos-animate {
  opacity: 1;
  transform: translateZ(0) scale(1);
}

[data-aos=zoom-in] {
  transform: scale(0.6);
}

[data-aos=zoom-in-up] {
  transform: translate3d(0, 100px, 0) scale(0.6);
}

[data-aos=zoom-in-down] {
  transform: translate3d(0, -100px, 0) scale(0.6);
}

[data-aos=zoom-in-right] {
  transform: translate3d(-100px, 0, 0) scale(0.6);
}

[data-aos=zoom-in-left] {
  transform: translate3d(100px, 0, 0) scale(0.6);
}

[data-aos=zoom-out] {
  transform: scale(1.2);
}

[data-aos=zoom-out-up] {
  transform: translate3d(0, 100px, 0) scale(1.2);
}

[data-aos=zoom-out-down] {
  transform: translate3d(0, -100px, 0) scale(1.2);
}

[data-aos=zoom-out-right] {
  transform: translate3d(-100px, 0, 0) scale(1.2);
}

[data-aos=zoom-out-left] {
  transform: translate3d(100px, 0, 0) scale(1.2);
}

[data-aos^=slide][data-aos^=slide] {
  transition-property: transform;
}

[data-aos^=slide][data-aos^=slide].aos-animate {
  transform: translateZ(0);
}

[data-aos=slide-up] {
  transform: translate3d(0, 100%, 0);
}

[data-aos=slide-down] {
  transform: translate3d(0, -100%, 0);
}

[data-aos=slide-right] {
  transform: translate3d(-100%, 0, 0);
}

[data-aos=slide-left] {
  transform: translate3d(100%, 0, 0);
}

[data-aos^=flip][data-aos^=flip] {
  backface-visibility: hidden;
  transition-property: transform;
}

[data-aos=flip-left] {
  transform: perspective(2500px) rotateY(-100deg);
}

[data-aos=flip-left].aos-animate {
  transform: perspective(2500px) rotateY(0);
}

[data-aos=flip-right] {
  transform: perspective(2500px) rotateY(100deg);
}

[data-aos=flip-right].aos-animate {
  transform: perspective(2500px) rotateY(0);
}

[data-aos=flip-up] {
  transform: perspective(2500px) rotateX(-100deg);
}

[data-aos=flip-up].aos-animate {
  transform: perspective(2500px) rotateX(0);
}

[data-aos=flip-down] {
  transform: perspective(2500px) rotateX(100deg);
}

[data-aos=flip-down].aos-animate {
  transform: perspective(2500px) rotateX(0);
}

[data-aos=fade-to-right] {
  clip-path: inset(0 100% 0 0);
  opacity: 0;
  transition-property: clip-path, opacity !important;
}
[data-aos=fade-to-right].aos-animate {
  clip-path: inset(0 0 0 0);
  opacity: 1;
}

[data-aos=fade-to-left] {
  clip-path: inset(0 0 0 100%);
  opacity: 0;
  transition-property: clip-path, opacity !important;
}
[data-aos=fade-to-left].aos-animate {
  clip-path: inset(0 0 0 0);
  opacity: 1;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.splide__arrow {
  aspect-ratio: 1;
  width: 55px;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  background: url("../img/common/common_icon_arrow_left_primary.png") no-repeat center center/contain;
  background-size: 18px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 767px) {
  .splide__arrow {
    width: 20px;
    background-size: 10px;
  }
}

.splide__arrow--prev {
  background-image: url("../img/common/common_icon_arrow_left_primary.png");
}

.splide__arrow--next {
  background-image: url("../img/common/common_icon_arrow_right_primary.png");
}

.splide__toggle {
  aspect-ratio: 1;
  width: 55px;
  display: grid;
  place-content: center;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 767px) {
  .splide__toggle {
    width: 20px;
  }
}

.splide__toggle__play,
.splide__toggle__pause {
  aspect-ratio: 1;
  width: 30px;
}
@media screen and (max-width: 767px) {
  .splide__toggle__play,
  .splide__toggle__pause {
    width: 12px;
  }
}

.splide__pagination {
  display: flex;
  align-items: center;
  column-gap: 9px;
}

.splide__pagination li button {
  --dotSize: 15px;
  aspect-ratio: 1;
  width: var(--dotSize);
  height: var(--dotSize);
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border-primary);
  box-shadow: 0 0 4px #0166C9;
}
.splide__pagination li button.is-active {
  background-color: var(--color-bg-primary);
  box-shadow: none;
}

/* 共通
----------------------------------------------- */
input[type=text],
input[type=email],
input[type=tel],
input[type=number],
textarea,
select {
  width: 100%;
  border: 1px solid var(--color-border-primary);
  background-color: var(--color-bg-white);
  border-radius: 3px;
  font-size: 15px;
  padding: 0.6em 0.5em 0.6em;
}
@media screen and (max-width: 767px) {
  input[type=text],
  input[type=email],
  input[type=tel],
  input[type=number],
  textarea,
  select {
    font-size: 16px;
    padding-block: 10px;
  }
}

/* input
----------------------------------------------- */
input::placeholder {
  color: var(--color-txt-placeholder);
}

input[type=text] {
  width: 100%;
}

/* radio
----------------------------------------------- */
input[type=radio] + span {
  display: inline-block;
  --radio-btn-size: 8px;
  position: relative;
  cursor: pointer;
  white-space: nowrap;
  width: 100%;
  max-width: 256px;
  border-radius: calc(infinity * 1px);
  font-size: 13px;
  color: var(--color-txt-white);
  padding-top: 0.2em;
  padding-inline: 0.5em;
  padding-bottom: 0.2em;
  transition: all 0.3s ease;
  transition-property: border-width, background-color;
}
@media screen and (max-width: 767px) {
  input[type=radio] + span {
    font-size: 16px;
    padding-block: 10px;
  }
}

input[type=radio] + span::before {
  display: inline-block;
  content: "";
  width: var(--radio-btn-size);
  height: var(--radio-btn-size);
  border: 0px solid var(--color-border-white);
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-white);
  vertical-align: middle;
  margin: -2px 8px 0 0;
  transition: all 0.1s linear;
  transition-property: border-width;
}

input[type=radio]:checked + span::before {
  background-color: var(--color-bg-primary);
  border-width: 1px;
}

/* checkbox
----------------------------------------------- */
input[type=checkbox] + span {
  --boxSize: 14px;
  position: relative;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.5;
  font-size: 15px;
  color: #565656;
}

input[type=checkbox] + span::before {
  display: inline-block;
  content: "";
  width: var(--boxSize);
  height: var(--boxSize);
  border: 1px solid var(--color-border-primary);
  border-radius: 3px;
  background-color: var(--color-bg-white);
  margin: -2px 8px 0 0;
  vertical-align: middle;
}

input[type=checkbox]:checked + span::after {
  position: absolute;
  top: 50%;
  left: 3px;
  content: "";
  width: 12px;
  height: 6px;
  border-left-width: 3px;
  border-bottom-width: 3px;
  border-color: var(--color-bg-primary);
  transform: translateY(-70%) rotate(-45deg);
}

/* textarea
----------------------------------------------- */
textarea {
  width: 100%;
  resize: vertical;
  min-height: 3em;
}
@media screen and (max-width: 767px) {
  textarea {
    height: 5em;
  }
}

select {
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  padding: 0.6em 0.5em 0.6em;
}
@media screen and (max-width: 767px) {
  select {
    font-size: 11px;
    min-height: 46px;
  }
}
@media screen and (max-width: 500px) {
  select {
    width: 100%;
  }
}

input[type=submit] {
  display: block;
  text-align: center;
  color: var(--color-txt-white);
  background-color: var(--color-bg-primary);
  font-weight: bold;
  line-height: 1.5;
  width: min(100%, 224px);
  padding-block: 18px;
  margin-inline: auto;
  transition: all 0.3s ease;
  transition-property: background-color, opacity;
}
input[type=submit]:disabled {
  background-color: #828386;
  color: var(--color-txt-white);
}
input[type=submit]:focus-visible:not(:disabled) {
  opacity: 0.8;
}
@media (any-hover: hover) {
  input[type=submit]:hover:not(:disabled) {
    opacity: 0.8;
  }
}

.wpcf7-list-item {
  margin: 0;
}
.wpcf7-list-item:not(:first-of-type) {
  margin-left: 15px;
}
@media screen and (max-width: 767px) {
  .wpcf7-list-item:not(:first-of-type) {
    margin-left: 9px;
  }
}

.wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap;
  column-gap: 30px;
  row-gap: 10px;
}
@media screen and (max-width: 767px) {
  .wpcf7-checkbox {
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .wpcf7-checkbox .wpcf7-list-item {
    margin-left: 0;
  }
}

.wpcf7-list-item:not(:first-of-type) {
  margin-left: 0;
}

.wpcf7-form-control.wpcf7-radio {
  display: grid;
}

.wpcf7-form-control.wpcf7-radio.flex {
  display: flex;
  flex-wrap: wrap;
}

.l-contact__wrap {
  display: grid;
  align-items: start;
  row-gap: 20px;
  color: var(--color-txt-black);
}
@media screen and (max-width: 767px) {
  .l-contact__wrap {
    padding-bottom: 50px;
  }
}

.l-contact__form--row {
  display: grid;
  row-gap: 9px;
  width: min(100%, 720px);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .l-contact__form--row {
    row-gap: 6px;
  }
}

.l-contact__form--label {
  font-weight: 500;
  font-size: clamp(13px, 1.1805555556vw, 17px);
}
@media screen and (max-width: 767px) {
  .l-contact__form--label {
    font-weight: normal;
  }
}

.l-contact__form--policy {
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border-primary);
  border-radius: 3px;
  padding: 11px 22px;
  overflow-y: auto;
  height: 200px;
  color: #565656;
  font-size: 13px;
  line-height: 1.3;
}
@media screen and (max-width: 949px) {
  .l-contact__form--policy {
    padding: 6px 10px;
  }
}
@media screen and (max-width: 767px) {
  .l-contact__form--policy {
    font-size: 11px;
  }
}

.l-contact__select .wpcf7-form-control-wrap::before {
  --iconSize: 18px;
  pointer-events: none;
  content: "";
  position: absolute;
  right: 8px;
  top: calc(50% + 3px);
  transform: translateY(-50%);
  aspect-ratio: 1;
  width: var(--iconSize);
  background: url(../img/common/common_icon_option_bottom.png) no-repeat center center/contain;
}

.l-contact__confirm {
  width: fit-content;
  margin-inline: auto;
}

.l-contact__submit {
  margin-top: 20px;
}

.l-headerService__space {
  height: var(--header-height);
}

.l-headerService__top {
  z-index: var(--z-index-header);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  position: fixed;
  bottom: 37px;
  right: 383px;
  display: grid;
  place-content: center;
  aspect-ratio: 1;
  width: 60px;
  background-color: #FAF9F9;
  border-radius: calc(infinity * 1px);
  transition: all 0.3s ease;
  transition-property: opacity, visibility;
}
@media screen and (max-width: 949px) {
  .l-headerService__top {
    display: none;
  }
}
.l-headerService__top.isActive {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.l-headerService__top > img {
  width: 26px;
}

.l-headerPc {
  z-index: var(--z-index-header);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background-color: rgba(99, 99, 99, 0.368627451);
  transition: all 0.3s ease;
  transition-property: background-color;
}
@media screen and (max-width: 949px) {
  .l-headerPc {
    display: none;
  }
}
.l-headerPc.isActive {
  background-color: #636363;
}

.l-headerPc__inner {
  min-height: var(--header-height);
  display: grid;
  align-items: center;
  grid-template-columns: clamp(100px, 8.4722222222vw, 122px) 1fr auto;
  column-gap: clamp(10px, 1.3541666667vw, 26px);
  padding-left: 33px;
  padding-right: 38px;
  padding-top: 14px;
  padding-bottom: 13px;
}
@media screen and (max-width: 949px) {
  .l-headerPc__inner {
    padding-left: clamp(20px, 2.2916666667vw, 33px);
    padding-right: clamp(20px, 2.6388888889vw, 38px);
  }
}

.l-headerPc__nav {
  justify-self: end;
  padding-right: clamp(20px, 2.7777777778vw, 40px);
}

.l-headerPc__nav--list {
  display: flex;
  column-gap: clamp(10px, 2.4305555556vw, 35px);
  align-items: center;
}

.l-headerPc__nav--item {
  position: relative;
}
.l-headerPc__nav--item::before {
  display: none;
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  translate: -50% 0;
  width: calc(100% + 40px);
  background-color: transparent;
  height: 100px;
}
.l-headerPc__nav--item:focus-visible::before {
  display: block;
}
@media (any-hover: hover) {
  .l-headerPc__nav--item:hover::before {
    display: block;
  }
}

.l-headerPc__nav--link {
  position: relative;
  display: block;
  font-weight: 500;
  font-size: 18px;
  line-height: 1.5;
  color: var(--color-txt-white);
  padding-bottom: 8px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 949px) {
  .l-headerPc__nav--link {
    font-size: 16px;
  }
}
.l-headerPc__nav--link::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50% 0;
  height: 1px;
  width: 7px;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-white);
  transition: all 0.3s ease;
  transition-property: background-color, width;
}
.l-headerPc__nav--link:focus-visible {
  color: var(--color-txt-primary);
}
.l-headerPc__nav--link:focus-visible::before {
  background-color: var(--color-bg-primary);
  width: 17px;
}
@media (any-hover: hover) {
  .l-headerPc__nav--link:hover {
    color: var(--color-txt-primary);
  }
  .l-headerPc__nav--link:hover::before {
    background-color: var(--color-bg-primary);
    width: 17px;
  }
}

.l-headerPc__cta {
  display: flex;
  align-items: center;
  column-gap: clamp(10px, 1.4583333333vw, 28px);
}

.l-headerPc__cta--item {
  position: relative;
}

.l-headerPc__cta--btn {
  display: block;
  min-width: 153px;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: bold;
  line-height: 1.5;
  font-size: 15px;
  padding-inline: 16px;
  padding-block: 12px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 949px) {
  .l-headerPc__cta--btn {
    min-width: unset;
    font-size: 13px;
  }
}
.l-headerPc__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-headerPc__cta--btn:hover {
    opacity: 0.8;
  }
}

.l-headerPc__cta--black {
  background-color: var(--color-bg-black);
}

.l-headerPc__child {
  --rightPosition: clamp(20px, 42 / 1920 * 100vw, 42px);
  --leftPosition: 20px;
  position: fixed;
  top: calc(var(--header-height) + 29px);
  right: var(--rightPosition);
  width: min(100% - (var(--rightPosition) + var(--leftPosition)), 1290px);
  display: grid;
  grid-template-rows: 0fr;
  transition: all 0.3s ease;
  transition-property: grid-template-rows;
  margin-left: var(--leftPosition);
}
@media screen and (max-width: 767px) {
  .l-headerPc__child {
    display: none;
  }
}

.js-headerPc__nav--item:focus-visible .l-headerPc__child {
  grid-template-rows: 1fr;
}

@media (any-hover: hover) {
  .js-headerPc__nav--item:hover .l-headerPc__child {
    grid-template-rows: 1fr;
  }
}
.l-headerPc-child__inner {
  overflow: hidden;
}

.l-headerPc-child__inner2 {
  background-color: #313131;
  padding-top: clamp(20px, 1.8055555556vw, 26px);
  padding-inline: clamp(20px, 3.8888888889vw, 56px);
  padding-bottom: clamp(20px, 3.8888888889vw, 56px);
}

.l-headerPc-child__head {
  display: flex;
  align-items: end;
  column-gap: 17px;
}

.l-headerPc-child__head--ja {
  color: var(--color-txt-white);
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.4;
  font-size: 25px;
}

.l-headerPc-child__head--en {
  color: var(--color-txt-primary-light);
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: 10px;
  padding-bottom: 5px;
}

.l-headerPc-child__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 250px), 1fr));
  column-gap: clamp(20px, 2.7777777778vw, 40px);
  row-gap: 20px;
  margin-top: 22px;
}

.l-headerPc-child__item {
  display: grid;
  justify-items: center;
  align-content: start;
  background-color: #636363;
  color: var(--color-txt-white);
  padding-top: 12px;
  padding-inline: clamp(20px, 2.5vw, 36px);
  padding-bottom: clamp(20px, 1.6666666667vw, 24px);
}

.l-headerPc-child__item--img {
  aspect-ratio: 1;
  width: 35px;
}

.l-headerPc-child__ttl {
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.02em;
  font-size: 11px;
  margin-top: 5px;
}

.l-headerPc-child__desc {
  text-align: center;
  letter-spacing: 0.02em;
  font-size: 9px;
  margin-top: 2px;
}

.l-headerPc-child__pages {
  justify-self: stretch;
  border-top: 1px solid #929292;
  padding-top: 7px;
  margin-top: 10px;
  display: grid;
  place-content: center;
  row-gap: 1px;
}

.l-headerPc-child__page--link {
  --iconSize: 11px;
  display: grid;
  grid-template-columns: var(--iconSize) auto;
  column-gap: 3px;
  align-items: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: 15px;
  line-height: 1.5;
  transition: all 0.3s ease;
  transition-property: color, grid-template-columns;
}
.l-headerPc-child__page--link::before {
  content: "";
  aspect-ratio: 1;
  width: var(--iconSize);
  background: url("../img/common/common_icon_right2_white.png") no-repeat center center/contain;
  transition: all 0.3s ease;
  transition-property: background-image;
}
.l-headerPc-child__page--link:focus-visible {
  --iconSize: 12px;
  color: var(--color-bg-primary);
}
.l-headerPc-child__page--link:focus-visible::before {
  background-image: url("../img/common/common_icon_check_primary.png");
}
@media (any-hover: hover) {
  .l-headerPc-child__page--link:hover {
    --iconSize: 12px;
    color: var(--color-bg-primary);
  }
  .l-headerPc-child__page--link:hover::before {
    background-image: url("../img/common/common_icon_check_primary.png");
  }
}

.l-headerSp {
  display: none;
  z-index: var(--z-index-header);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background-color: rgba(99, 99, 99, 0.368627451);
  transition: all 0.3s ease;
  transition-property: background-color;
}
@media screen and (max-width: 949px) {
  .l-headerSp {
    display: block;
  }
}
.l-headerSp.isActive {
  background-color: #636363;
}
.l-headerSp.isOpen {
  background-color: #636363;
}
.l-headerSp.isActive.isOpen {
  background-color: #636363;
}

.l-headerSp__inner {
  min-height: var(--header-height);
  display: grid;
  align-items: center;
  grid-template-columns: 73px 1fr 28px;
  column-gap: 15px;
  padding-left: 17px;
  padding-right: 13px;
}

.l-headerSp__cta {
  justify-content: end;
  display: flex;
  align-items: end;
  column-gap: 8px;
}

.l-headerSp__cta--item:nth-of-type(1) .l-headerSp__cta--btn {
  grid-template-rows: 23px auto;
  row-gap: 2px;
}
.l-headerSp__cta--item:nth-of-type(1) .l-headerSp__cta--icon {
  height: 23px;
}
.l-headerSp__cta--item:nth-of-type(2) .l-headerSp__cta--btn {
  grid-template-rows: 27px auto;
  row-gap: 1px;
}
.l-headerSp__cta--item:nth-of-type(2) .l-headerSp__cta--icon {
  height: 27px;
}

.l-headerSp__cta--btn {
  display: grid;
  justify-items: center;
}

.l-headerSp__cta--icon {
  aspect-ratio: 1;
}
.l-headerSp__cta--icon > img {
  height: 100%;
}

.l-headerSp__cta--txt {
  text-align: center;
  color: var(--color-txt-white);
  font-size: 9px;
}

.l-headerSp__menu {
  aspect-ratio: 1;
  position: relative;
  background-color: var(--color-bg-primary);
  border-radius: 3px;
}

.l-headerSp__menu--line {
  position: absolute;
  background-color: var(--color-bg-white);
  width: 14px;
  height: 2px;
  left: 50%;
  translate: -50% -50%;
  transition: all 0.3s ease;
  transition-property: opacity, rotate, top, left;
}
.l-headerSp__menu--line:nth-of-type(1) {
  top: calc(50% - 5px);
}
.l-headerSp__menu--line:nth-of-type(2) {
  top: 50%;
}
.l-headerSp__menu--line:nth-of-type(3) {
  top: calc(50% + 5px);
}

.l-headerSp__menu.isActive .l-headerSp__menu--line:nth-of-type(1) {
  rotate: -45deg;
  top: 50%;
  left: 50%;
}
.l-headerSp__menu.isActive .l-headerSp__menu--line:nth-of-type(2) {
  opacity: 0;
}
.l-headerSp__menu.isActive .l-headerSp__menu--line:nth-of-type(3) {
  rotate: 45deg;
  top: 50%;
  left: 50%;
}

.l-spMenu {
  z-index: var(--z-index-header);
  position: fixed;
  opacity: 0;
  top: var(--header-height);
  left: 0;
  translate: 110% 0;
  width: 100%;
  height: calc(100vh - var(--header-height));
  background-color: #636363;
  transition: all 0.3s ease;
  transition-property: translate, opacity;
}
.l-spMenu.isActive {
  opacity: 1;
  translate: 0 0;
}

.l-spMenu__inner {
  padding: 20px;
  display: grid;
  height: 100%;
  align-content: start;
}

.l-spMenu__nav {
  overflow-y: auto;
  padding-inline: 15px;
}

.l-spMenu__nav--list {
  display: grid;
  align-items: start;
  row-gap: 30px;
}

.l-spMenu__nav--link {
  display: grid;
  grid-template-columns: 1fr 12px;
  column-gap: 1em;
  align-items: center;
  color: var(--color-txt-white);
  font-weight: bold;
  font-size: 13px;
  border-bottom: 1px solid var(--color-border-white);
  padding-left: 5px;
  padding-bottom: 10px;
}
.l-spMenu__nav--link::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_right_white.png") no-repeat center center/contain;
}

.l-spMenu__nav--parent {
  grid-template-columns: 1fr;
}
.l-spMenu__nav--parent::after {
  content: none;
}

.l-spMenu__nav--child {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 17px;
  row-gap: 10px;
  margin-top: 17px;
}

.l-spMenu__navChild--item {
  justify-self: start;
}

.l-spMenu__navChild--link {
  display: grid;
  grid-template-columns: 8px auto;
  column-gap: 5px;
  align-items: center;
  color: var(--color-txt-white);
  font-weight: 500;
  font-size: 13px;
}
.l-spMenu__navChild--link::before {
  content: "";
  aspect-ratio: 8/1;
  background-color: var(--color-bg-white);
}

.l-spMenu__cta {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 169px), 1fr));
  gap: 11px;
  margin-top: 58px;
}

.l-spMenu__cta--link {
  --iconSize: 22px;
  --iconArrowSize: 13px;
  display: grid;
  grid-template-columns: var(--iconSize) 1fr var(--iconArrowSize);
  align-items: center;
  column-gap: 6px;
  min-height: 46px;
  background-color: var(--color-bg-primary);
  padding-left: 11px;
  padding-right: 7px;
}
.l-spMenu__cta--link::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_arrow_right_white.png") no-repeat center center/contain;
}

.l-spMenu__cta--icon {
  aspect-ratio: 1;
}
.l-spMenu__cta--icon > img {
  height: 100%;
}

.l-spMenu__cta--txt {
  color: var(--color-txt-white);
  font-weight: bold;
  font-size: 13px;
}

.l-spMenu__cta--black {
  background-color: var(--color-bg-black);
}

.l-header__space {
  height: var(--header-service-height);
}

.l-header__top {
  z-index: var(--z-index-header);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  position: fixed;
  bottom: 37px;
  right: 33px;
  display: grid;
  place-content: center;
  aspect-ratio: 1;
  width: 60px;
  background-color: #FAF9F9;
  border-radius: calc(infinity * 1px);
  transition: all 0.3s ease;
  transition-property: opacity, visibility;
}
@media screen and (max-width: 949px) {
  .l-header__top {
    display: none;
  }
}
.l-header__top.isActive {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.l-header__top > img {
  width: 26px;
}

.l-headerService {
  z-index: var(--z-index-header);
  position: fixed;
  top: 0;
  left: 0;
  width: calc(100% - 350px);
  background-color: #636363;
  transition: all 0.3s ease;
  transition-property: background-color;
}
@media screen and (max-width: 949px) {
  .l-headerService {
    display: none;
  }
}

.l-headerService__inner {
  min-height: var(--header-service-height);
  display: grid;
  align-items: center;
  grid-template-columns: clamp(80px, 6.9444444444vw, 100px) 1fr auto;
  column-gap: clamp(10px, 1.3541666667vw, 26px);
  padding-inline: 15px;
  padding-top: 14px;
  padding-bottom: 13px;
}

.l-headerService__nav {
  justify-self: end;
}

.l-headerService__nav--list {
  display: flex;
  column-gap: clamp(4px, 0.9895833333vw, 19px);
  row-gap: 5px;
  align-items: center;
  flex-wrap: wrap;
}

.l-headerService__nav--item {
  position: relative;
}

.l-headerService__nav--link {
  position: relative;
  display: block;
  font-size: 15px;
  line-height: 1.5;
  color: var(--color-txt-white);
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 1400px) {
  .l-headerService__nav--link {
    font-size: 13px;
  }
}
.l-headerService__nav--link:focus-visible {
  color: var(--color-txt-primary);
}
@media (any-hover: hover) {
  .l-headerService__nav--link:hover {
    color: var(--color-txt-primary);
  }
}

.l-headerService__cta {
  display: flex;
  align-items: center;
  column-gap: clamp(4px, 0.7291666667vw, 14px);
}

.l-headerService__cta--item {
  position: relative;
}

.l-headerService__cta--btn {
  display: block;
  min-width: 122px;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: 500;
  line-height: 1.5;
  font-size: 15px;
  border-radius: 3px;
  padding-inline: 5px;
  padding-block: 9px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 949px) {
  .l-headerService__cta--btn {
    min-width: unset;
    font-size: 13px;
  }
}
.l-headerService__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-headerService__cta--btn:hover {
    opacity: 0.8;
  }
}

.l-footer {
  background-color: #636363;
  padding-top: 129px;
  padding-bottom: 36px;
}
@media screen and (max-width: 767px) {
  .l-footer {
    padding-top: 46px;
    padding-bottom: 8px;
  }
}

.l-footer__container {
  --logoSize: clamp(200px, 355 / 1920 * 100vw, 355px);
  display: grid;
  grid-template: "logo nav" auto ". nav" 30px "sns nav" auto ". nav" 22px "tel nav" auto ". ." clamp(40px, 4.375vw, 84px) "cta cta" auto ". ." 22px/var(--logoSize) 1fr;
  column-gap: clamp(20px, 2.9166666667vw, 56px);
}
@media screen and (max-width: 767px) {
  .l-footer__container {
    grid-template: "logo" auto "." 2px "tel" auto "." 20px "sns" auto "." 36px "cta" auto "." 56px "nav" auto/1fr;
  }
}

.l-footer__logo {
  grid-area: logo;
}
@media screen and (max-width: 767px) {
  .l-footer__logo {
    width: min(100%, 163px);
    justify-self: center;
  }
}

.l-footer__sns {
  grid-area: sns;
}

.l-footer__sns--link {
  display: block;
  width: min(100%, 264px);
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .l-footer__sns--link {
    width: min(100%, 187px);
    margin-inline: auto;
  }
}
.l-footer__sns--link:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-footer__sns--link:hover {
    opacity: 0.8;
  }
}
.l-footer__sns--link > img {
  height: 100%;
}

.l-footer__nav {
  grid-area: nav;
}

.l-footer__nav--list {
  display: grid;
  grid-template-columns: auto auto auto;
  grid-template-rows: auto 1fr;
  column-gap: clamp(10px, 1.8229166667vw, 35px);
  row-gap: clamp(20px, 2.4305555556vw, 35px);
}
@media screen and (max-width: 767px) {
  .l-footer__nav--list {
    grid-template-columns: 1fr;
    row-gap: 23px;
  }
}

.l-footer__nav--item {
  --dotSize: 7px;
}
.l-footer__nav--item:nth-of-type(1) {
  grid-row: 1/-1;
}

.l-footer__nav--link {
  display: grid;
  grid-template-columns: var(--dotSize) auto;
  align-items: center;
  column-gap: 10px;
  font-weight: bold;
  font-size: 15px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .l-footer__nav--link {
    grid-template-columns: 1fr 12px;
    column-gap: 1em;
    align-items: center;
    font-size: 13px;
    border-bottom: 1px solid var(--color-border-white);
    padding-left: 5px;
    padding-bottom: 10px;
  }
}
.l-footer__nav--link::before {
  content: "";
  aspect-ratio: 1;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-white);
  box-shadow: 0 0 4px #4B95AF;
  transition: all 0.3s ease;
  transition-property: background-color;
}
@media screen and (max-width: 767px) {
  .l-footer__nav--link::before {
    content: none;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav--link::after {
    content: "";
    aspect-ratio: 1;
    background: url("../img/common/common_icon_right_white.png") no-repeat center center/contain;
  }
}
.l-footer__nav--link:focus-visible:not(.l-footer__nav--parent) {
  color: var(--color-txt-primary-light);
}
.l-footer__nav--link:focus-visible:not(.l-footer__nav--parent)::before {
  background-color: var(--color-bg-primary-light);
}
@media (any-hover: hover) {
  .l-footer__nav--link:hover:not(.l-footer__nav--parent) {
    color: var(--color-txt-primary-light);
  }
  .l-footer__nav--link:hover:not(.l-footer__nav--parent)::before {
    background-color: var(--color-bg-primary-light);
  }
}

@media screen and (max-width: 767px) {
  .l-footer__nav--parent {
    grid-template-columns: 1fr;
  }
  .l-footer__nav--parent::after {
    content: none;
  }
}

.l-footer__nav--child {
  margin-top: 8px;
  display: grid;
  align-items: start;
  row-gap: 6px;
  margin-left: calc(var(--dotSize) + 10px);
}
@media screen and (max-width: 767px) {
  .l-footer__nav--child {
    grid-template-columns: auto 1fr;
    column-gap: 17px;
    row-gap: 10px;
    margin-top: 17px;
    margin-left: 0;
  }
}

@media screen and (max-width: 767px) {
  .l-footer__navChild--item {
    justify-self: start;
  }
}

.l-footer__navChild--link {
  display: grid;
  grid-template-columns: 8px 1fr;
  column-gap: 5px;
  align-items: center;
  font-size: 13px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .l-footer__navChild--link {
    grid-template-columns: 8px auto;
    font-weight: 500;
  }
}
.l-footer__navChild--link::before {
  content: "";
  aspect-ratio: 8/1;
  background-color: var(--color-bg-white);
  transition: all 0.3s ease;
  transition-property: background-color;
}
.l-footer__navChild--link:focus-visible {
  color: var(--color-txt-primary-light);
}
.l-footer__navChild--link:focus-visible::before {
  background-color: var(--color-bg-primary-light);
}
@media (any-hover: hover) {
  .l-footer__navChild--link:hover {
    color: var(--color-txt-primary-light);
  }
  .l-footer__navChild--link:hover::before {
    background-color: var(--color-bg-primary-light);
  }
}

.l-footer__cta {
  grid-area: cta;
  display: flex;
  column-gap: clamp(20px, 4.4444444444vw, 64px);
}
@media screen and (max-width: 767px) {
  .l-footer__cta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}
@media screen and (max-width: 400px) {
  .l-footer__cta {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 165px), 1fr));
  }
}

.l-footer__cta--link {
  --iconSize: 29px;
  --iconArrowSize: 19px;
  display: grid;
  grid-template-columns: var(--iconSize) 1fr var(--iconArrowSize);
  align-items: center;
  justify-content: center;
  column-gap: 9px;
  min-height: 100px;
  width: 309px;
  background-color: var(--color-bg-primary);
  padding-inline: 21px;
  padding-left: 30px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .l-footer__cta--link {
    width: min(100%, 309px);
    --iconSize: 13px;
    --iconArrowSize: 13px;
    min-height: 46px;
    padding-inline: 7px;
    margin-inline: auto;
  }
}
.l-footer__cta--link:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-footer__cta--link:hover {
    opacity: 0.8;
  }
}
.l-footer__cta--link::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_arrow_right_white.png") no-repeat center center/contain;
}

.l-footer__cta--icon {
  aspect-ratio: 1;
}
.l-footer__cta--icon > img {
  height: 100%;
  object-fit: contain;
}

.l-footer__cta--txt {
  color: var(--color-txt-white);
  font-weight: bold;
  font-size: clamp(13px, 1.25vw, 18px);
}
@media screen and (max-width: 767px) {
  .l-footer__cta--txt {
    font-size: 13px;
  }
}

.l-footer__cta--black {
  padding-left: 40px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .l-footer__cta--black {
    padding-inline: 7px;
  }
}

.l-footer__tel {
  grid-area: tel;
}

.l-footer__tel--link {
  --iconSize: 30px;
  display: grid;
  align-items: center;
  grid-template-columns: var(--iconSize) auto;
  column-gap: clamp(7px, 0.6944444444vw, 10px);
  width: fit-content;
  font-weight: bold;
  font-size: 25px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .l-footer__tel--link {
    --iconSize: 15px;
    font-size: 18px;
    justify-content: center;
    margin-inline: auto;
  }
}
.l-footer__tel--link:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-footer__tel--link:hover {
    opacity: 0.8;
  }
}
.l-footer__tel--link::before {
  position: relative;
  content: "";
  top: 2px;
  aspect-ratio: 1;
  background: url("../img/common/common_icon_tel_white.png") no-repeat center center/contain;
}

.l-footer__bottom {
  margin-top: clamp(36px, 7.9166666667vw, 114px);
}

.l-footer__policy {
  text-align: center;
  font-weight: 300;
  font-size: 11px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
.l-footer__policy:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-footer__policy:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__policy {
    font-size: 10px;
  }
}

.l-footer__copy {
  display: block;
  text-align: center;
  font-weight: 300;
  font-size: 17px;
  margin-top: 2px;
}
@media screen and (max-width: 767px) {
  .l-footer__copy {
    font-size: 10px;
  }
}

.l-footer__copy--link {
  transition: all 0.3s ease;
  transition-property: opacity;
}
.l-footer__copy--link:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-footer__copy--link:hover {
    opacity: 0.8;
  }
}

.l-container {
  width: min(100%, 1240px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-container__1400 {
  width: min(100%, 1440px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-container__1300 {
  width: min(100%, 1340px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-container__1100 {
  width: min(100%, 1140px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-container__1000 {
  width: min(100%, 1040px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-container__920 {
  width: min(100%, 960px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-container__820 {
  width: min(100%, 860px);
  padding-inline: 20px;
  margin-inline: auto;
}

.l-pageMv {
  --height: calc((100svh - var(--header-height)) * 0.8);
  position: relative;
  height: var(--height);
  max-height: 675px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .l-pageMv {
    max-height: 450px;
  }
}

.l-pageMv__bg {
  z-index: -1;
  position: absolute;
  inset: 0;
}
.l-pageMv__bg > img {
  height: 100%;
}

.l-pageMv__ttl {
  display: grid;
  place-content: center;
  height: 100%;
  text-align: center;
}

.l-pageMv__ttl--en {
  font-family: "din-2014", sans-serif;
  font-size: clamp(30px, 3.4722222222vw, 50px);
}
@media screen and (max-width: 767px) {
  .l-pageMv__ttl--en {
    font-size: 30px;
  }
}

.l-pageMv__ttl--ja {
  font-size: clamp(18px, 1.7361111111vw, 25px);
  position: relative;
  padding-top: 19px;
  margin-top: 12px;
}
@media screen and (max-width: 767px) {
  .l-pageMv__ttl--ja {
    font-size: 16px;
  }
}
.l-pageMv__ttl--ja::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  width: 38px;
  height: 3px;
  background-color: var(--color-bg-white);
}

.l-pageMv--medium {
  --height: calc((100svh - var(--header-height)) * 0.55);
}

.l-pageMv--small {
  --height: calc((100svh - var(--header-height)) * 0.4);
}
@media screen and (max-width: 767px) {
  .l-pageMv--small {
    --height: calc((100svh - var(--header-height)) * 0.55);
  }
}

.l-pageMv--positionTop .l-pageMv__bg > img {
  object-position: top;
}

.wp-pagenavi {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  column-gap: 17px;
  row-gap: 10px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .wp-pagenavi {
    column-gap: 11px;
    margin-top: 48px;
  }
}
.wp-pagenavi > * {
  border: 1px solid var(--color-border-white);
  display: grid;
  place-content: center;
  min-width: 25px;
  min-height: 23px;
  font-size: 15px;
  line-height: 1;
  padding-bottom: 2px;
}
@media screen and (max-width: 767px) {
  .wp-pagenavi > * {
    font-size: 10px;
    min-width: 17px;
    min-height: 15px;
    padding-bottom: 0;
  }
}
.wp-pagenavi .current {
  background-color: var(--color-bg-white);
  color: var(--color-txt-black);
}
.wp-pagenavi .page {
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
.wp-pagenavi .page:focus-visible {
  background-color: var(--color-bg-white);
  color: var(--color-txt-black);
}
@media (any-hover: hover) {
  .wp-pagenavi .page:hover {
    background-color: var(--color-bg-white);
    color: var(--color-txt-black);
  }
}

.l-breadcrumb {
  position: relative;
  display: flex;
  flex-wrap: flex;
  padding-top: 100px;
  column-gap: 8px;
  row-gap: 5px;
  padding-inline: clamp(20px, 5.2083333333vw, 100px);
}
@media screen and (max-width: 767px) {
  .l-breadcrumb {
    padding-top: 25px;
    padding-inline: 20px;
  }
}
.l-breadcrumb > * {
  width: fit-content;
}
.l-breadcrumb > span:last-of-type {
  flex: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  /* 制限したい行数を指定 */
  overflow: hidden;
}

.l-service {
  display: grid;
  grid-template-columns: 1fr 350px;
  align-content: start;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 949px) {
  .l-service {
    display: block;
  }
}

.l-service-sp__contact {
  display: none;
}
@media screen and (max-width: 949px) {
  .l-service-sp__contact {
    z-index: var(--z-service-contact-btn);
    --iconSize: 16px;
    position: fixed;
    top: calc(var(--header-height) + 20px);
    right: 0;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto var(--iconSize);
    row-gap: 20px;
    justify-content: center;
    align-items: center;
    column-gap: 20px;
    border-radius: 3px 0 0 3px;
    background-color: var(--color-bg-primary);
    color: var(--color-txt-white);
    font-weight: bold;
    font-size: 14px;
    padding: 18px 12px;
    min-height: 178px;
    letter-spacing: 0.2em;
  }
  .l-service-sp__contact::after {
    content: "";
    aspect-ratio: 1;
    background: url("../img/common/common_icon_circle_right.png") no-repeat center top/cover;
  }
  .l-service-sp__contact > span {
    writing-mode: vertical-lr;
  }
}

.l-service__form {
  overflow-y: auto;
  position: sticky;
  top: 0;
  height: 100svh;
  background-color: var(--color-bg-gray);
  padding-top: 60px;
  padding-inline: 25px;
}
@media screen and (max-width: 949px) {
  .l-service__form {
    overflow: unset;
    z-index: var(--z-service-contact-form);
    position: fixed;
    top: var(--header-height);
    right: 0;
    width: 80vw;
    height: calc(100vh - var(--header-height));
    translate: 110% 0;
    background-color: rgba(1, 102, 201, 0.9);
    padding: 20px;
    transition: all 0.3s ease;
    transition-property: translate;
    display: grid;
    grid-template-rows: auto auto 1fr;
  }
  .l-service__form.isActive {
    translate: 0 0;
  }
}

.l-service-sp__close {
  display: none;
}
@media screen and (max-width: 949px) {
  .l-service-sp__close {
    position: absolute;
    top: 40px;
    left: 0;
    translate: -100% 0;
    display: block;
    border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
    aspect-ratio: 28/41;
    width: 28px;
    background-color: rgba(1, 102, 201, 0.9);
  }
  .l-service-sp__close::before {
    position: absolute;
    top: 50%;
    left: 80%;
    translate: -50% -50%;
    content: "";
    background-color: var(--color-bg-white);
    aspect-ratio: 11/14;
    width: 11px;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
  }
}

.l-service__form--name {
  text-align: center;
  color: var(--color-txt-black);
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 20px;
}
@media screen and (max-width: 949px) {
  .l-service__form--name {
    font-size: 13px;
    color: var(--color-txt-white);
  }
}

.l-service__form--txt {
  text-align: center;
  color: var(--color-txt-black);
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 25px;
}
@media screen and (max-width: 949px) {
  .l-service__form--txt {
    color: var(--color-txt-white);
    font-size: 15px;
  }
}

.l-service__form--wrap {
  margin-top: 40px;
}
@media screen and (max-width: 949px) {
  .l-service__form--wrap {
    height: 100%;
    overflow-y: auto;
  }
}
@media screen and (max-width: 767px) {
  .l-service__form--wrap {
    margin-top: 30px;
  }
}

.l-service-contact__wrap {
  display: grid;
  align-items: start;
  row-gap: 8px;
  overflow-y: auto;
  height: min(566px, 70vh);
  border-radius: 3px;
  background-color: var(--color-bg-primary);
  padding-inline: 18px;
  padding-block: 20px;
}
@media screen and (max-width: 949px) {
  .l-service-contact__wrap {
    height: min(500px, 55vh);
    background-color: transparent;
    padding-block: 0px;
    padding-inline: 0px;
    padding-right: 5px;
  }
}
.l-service-contact__wrap::-webkit-scrollbar {
  background-color: var(--color-bg-black);
  width: 7px;
  border-radius: calc(infinity * 1px);
}
.l-service-contact__wrap::-webkit-scrollbar-thumb {
  background: var(--color-bg-white);
  border-radius: calc(infinity * 1px);
}

.l-service-contact__form--row {
  display: grid;
  row-gap: 4px;
  width: min(100%, 720px);
  margin-inline: auto;
}

.l-service-contact__form--label {
  text-align: left;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-size: clamp(12px, 1.0416666667vw, 15px);
  color: var(--color-txt-white);
}
@media screen and (max-width: 767px) {
  .l-service-contact__form--label {
    font-size: 12px;
  }
}

.l-service-contact__form--body {
  color: var(--color-txt-black);
}

.l-service-contact__confirm {
  width: fit-content;
  margin-top: 12px;
}
@media screen and (max-width: 949px) {
  .l-service-contact__confirm input[type=checkbox] + span {
    color: var(--color-txt-white);
  }
}

.l-service-contact__privacy {
  font-weight: bold;
  line-height: 1.4;
  display: inline-block;
  border-bottom: 1px solid #FF0000;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 949px) {
  .l-service-contact__privacy {
    color: var(--color-txt-white);
  }
}
.l-service-contact__privacy:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .l-service-contact__privacy:hover {
    opacity: 0.8;
  }
}

.l-service-contact__submit {
  margin-top: 30px;
}
.l-service-contact__submit input {
  border-radius: 10px;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  padding-block: 9px;
  width: min(100%, 176px);
}
@media screen and (max-width: 949px) {
  .l-service-contact__submit input {
    background-color: var(--color-bg-white);
    color: var(--color-txt-black);
  }
}

.c-btnA {
  position: relative;
  display: grid;
  grid-template-columns: auto 7px;
  column-gap: 30px;
  justify-content: center;
  align-items: center;
  background-color: var(--color-bg-primary);
  font-family: "din-2014", sans-serif;
  color: var(--color-txt-white);
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1;
  border-radius: 2px;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  width: min(100%, 200px);
  height: 51px;
  transition: all 0.3s ease;
  transition-property: color, background-color;
}
@media screen and (max-width: 767px) {
  .c-btnA {
    width: min(100%, 152px);
    height: 30px;
  }
}
.c-btnA::after {
  content: "";
  aspect-ratio: 7/12;
  background-color: var(--color-bg-white);
  transition: all 0.3s ease;
  transition-property: background-color;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.c-btnA:focus-visible {
  color: var(--color-txt-primary);
  background-color: var(--color-bg-white);
}
.c-btnA:focus-visible::after {
  background-color: var(--color-bg-primary);
}
@media (any-hover: hover) {
  .c-btnA:hover {
    color: var(--color-txt-primary);
    background-color: var(--color-bg-white);
  }
  .c-btnA:hover::after {
    background-color: var(--color-bg-primary);
  }
}

.c-btnA--large {
  font-size: clamp(13px, 1.3888888889vw, 20px);
}

.c-btnA--center {
  margin-inline: auto;
}

.c-btnA--right {
  margin-left: auto;
}

.c-btnB {
  --lineSize: 36px;
  --translateSize: -15px;
  --hoverMoveSize: 5px;
  display: block;
  position: relative;
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border-primary-light2);
  width: min(100%, 200px);
  color: var(--color-txt-black);
  text-align: center;
  font-family: "din-2014", sans-serif;
  font-weight: bold;
  font-size: clamp(15px, 1.3888888889vw, 20px);
  letter-spacing: 0.08em;
  padding-top: 15px;
  padding-inline: 14px;
  padding-bottom: 14px;
  transition: all 0.3s ease;
  transition-property: color, background-color, border-color;
}
@media screen and (max-width: 767px) {
  .c-btnB {
    --lineSize: 22px;
    --translateSize: -11px;
    --hoverMoveSize: 3px;
    width: min(100%, 110px);
    padding-top: 10px;
    padding-inline: 5px;
    padding-bottom: 6px;
  }
}
.c-btnB::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  width: var(--lineSize);
  height: 1px;
  translate: var(--translateSize) -50%;
  background-color: var(--color-bg-primary-light2);
  transition: all 0.3s ease;
  transition-property: left, background-color;
}
.c-btnB:focus-visible {
  color: var(--color-txt-white);
  background-color: var(--color-bg-primary);
  border-color: var(--color-border-primary);
}
.c-btnB:focus-visible::after {
  left: calc(100% + var(--hoverMoveSize));
  background-color: var(--color-bg-primary);
}
@media (any-hover: hover) {
  .c-btnB:hover {
    color: var(--color-txt-white);
    background-color: var(--color-bg-primary);
    border-color: var(--color-border-primary);
  }
  .c-btnB:hover::after {
    left: calc(100% + var(--hoverMoveSize));
    background-color: var(--color-bg-primary);
  }
}

.c-btnB--center {
  margin-inline: auto;
}

.c-btnC {
  display: grid;
  place-content: center;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  border-radius: 5px;
  width: min(100%, 240px);
  height: 64px;
  font-size: clamp(15px, 1.3888888889vw, 20px);
  box-shadow: 0 0 7px rgba(179, 155, 70, 0.5);
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 767px) {
  .c-btnC {
    width: 180px;
    height: 38px;
  }
}
.c-btnC:focus-visible {
  color: var(--color-txt-primary);
  background-color: var(--color-bg-white);
}
@media (any-hover: hover) {
  .c-btnC:hover {
    color: var(--color-txt-primary);
    background-color: var(--color-bg-white);
  }
}

.c-btnC--center {
  margin-inline: auto;
}

.c-sectionTtlA {
  text-align: center;
}

.c-sectionTtlA__en {
  position: relative;
  font-weight: 500;
  font-size: clamp(25px, 2.7777777778vw, 40px);
  letter-spacing: 0.05em;
  padding-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .c-sectionTtlA__en {
    letter-spacing: unset;
  }
}
.c-sectionTtlA__en::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 50%;
  translate: -50% 0;
  background-color: var(--color-bg-white);
  width: 40px;
  height: 1px;
}

.c-sectionTtlA__ja {
  font-weight: 500;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .c-sectionTtlA__ja {
    margin-top: 11px;
  }
}

.c-sectionTtlA--black {
  color: var(--color-txt-black);
}
.c-sectionTtlA--black .c-sectionTtlA__en::before {
  background-color: var(--color-bg-black);
}

.c-sectionTtlB {
  position: relative;
  padding-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .c-sectionTtlB {
    padding-bottom: 5px;
    margin-inline: 10px;
  }
}
.c-sectionTtlB::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background-color: var(--color-bg-white);
  border-radius: calc(infinity * 1px);
}
@media screen and (max-width: 767px) {
  .c-sectionTtlB::after {
    margin-top: 13px;
    height: 2px;
  }
}

.c-sectionTtlB_en {
  font-weight: bold;
  font-weight: bold;
  letter-spacing: 0.16em;
  font-family: "din-2014", sans-serif;
  color: rgba(1, 102, 201, 0.22);
  line-height: 1;
  font-size: clamp(39px, 5.5555555556vw, 80px);
}

.c-sectionTtlB__ja {
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(23px, 2.2222222222vw, 32px);
  margin-top: -0.8em;
}

.c-sectionTtlC {
  text-align: center;
  width: fit-content;
  margin-inline: auto;
}

.c-sectionTtlC_en {
  font-family: "din-2014", sans-serif;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.16em;
  font-size: clamp(50px, 4.8611111111vw, 70px);
  color: rgba(1, 102, 201, 0.22);
}
@media screen and (max-width: 767px) {
  .c-sectionTtlC_en {
    font-size: 50px;
  }
}

.c-sectionTtlC__ja {
  color: var(--color-txt-white);
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.16em;
  font-size: clamp(25px, 2.4305555556vw, 35px);
  margin-top: -20px;
}

.c-sectionTtlC--border {
  position: relative;
  padding-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .c-sectionTtlC--border {
    padding-bottom: 0;
  }
}
.c-sectionTtlC--border::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50% 0;
  width: 80px;
  height: 3px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 767px) {
  .c-sectionTtlC--border::after {
    content: none;
  }
}

.c-pageTtlA {
  position: relative;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--color-border-white);
  width: fit-content;
  padding-right: 1em;
}

.c-pageTtlA__en {
  font-family: "din-2014", sans-serif;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.16em;
  font-size: clamp(30px, 6.9444444444vw, 100px);
  color: #22405E;
}
@media screen and (max-width: 767px) {
  .c-pageTtlA__en {
    font-size: 30px;
  }
}

.c-pageTtlA__ja {
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.16em;
  font-size: clamp(15px, 3.125vw, 45px);
  color: var(--color-txt-white);
  margin-top: -0.6em;
}
@media screen and (max-width: 767px) {
  .c-pageTtlA__ja {
    font-size: 15px;
  }
}

.c-pageTtlA--noborder {
  border-bottom: none;
}

.c-pageTtlA--small .c-pageTtlA__en {
  font-size: clamp(25px, 3.4722222222vw, 50px);
}
.c-pageTtlA--small .c-pageTtlA__ja {
  font-size: clamp(18px, 2.0833333333vw, 30px);
}

.c-pageTtlA--w100p {
  width: 100%;
}

.c-dot {
  --dotSize: 21px;
  position: absolute;
  aspect-ratio: 1;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary-light);
  width: var(--dotSize);
  box-shadow: 0 0 64px #59A1BE;
}
@media screen and (max-width: 767px) {
  .c-dot {
    --dotSize: 9px;
  }
}

.c-dot--mid {
  --dotSize: 27px;
}
@media screen and (max-width: 767px) {
  .c-dot--mid {
    --dotSize: 10px;
  }
}

.c-dot--large {
  --dotSize: 22px;
}
@media screen and (max-width: 767px) {
  .c-dot--large {
    --dotSize: 12px;
  }
}

.c-company-info {
  --minusMargin: 57px;
  --gapSize: 30px;
  --minusTotal: calc(var(--minusMargin) + var(--gapSize));
}
@media screen and (max-width: 767px) {
  .c-company-info {
    --minusMargin: 7px;
    --gapSize: 9px;
  }
}

.c-company-info__img {
  margin-top: 43px;
  margin-left: calc(50% - 50vw);
  padding-right: clamp(180px, 15.9722222222vw, 230px);
}
@media screen and (max-width: 767px) {
  .c-company-info__img {
    padding-right: 36px;
    margin-top: 36px;
  }
}

.c-company-info__info {
  z-index: 1;
  position: relative;
  display: grid;
  background-color: var(--color-bg-gray);
  border: 2px solid var(--color-border-primary);
  border-radius: 3px;
  color: var(--color-txt-black);
  padding-top: clamp(16px, 3.6458333333vw, 70px);
  padding-inline: clamp(20px, 2.6041666667vw, 50px);
  padding-bottom: clamp(20px, 5.2083333333vw, 100px);
  margin-top: calc(-1 * var(--minusMargin));
}
@media screen and (max-width: 767px) {
  .c-company-info__info {
    border: none;
  }
}

.c-company-info__info--dl {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 2;
  column-gap: clamp(20px, 6.25vw, 120px);
  padding-left: clamp(20px, 3.3333333333vw, 48px);
  padding-block: clamp(16px, 2.0833333333vw, 30px);
}
@media screen and (max-width: 767px) {
  .c-company-info__info--dl {
    grid-template-columns: 1fr;
    row-gap: 4px;
    padding-left: 0;
  }
}
.c-company-info__info--dl:not(:first-of-type) {
  border-top: 1px solid #8AB2DA;
}

.c-company-info__info--dt {
  font-weight: 500;
  font-size: clamp(15px, 1.1805555556vw, 17px);
}
@media screen and (max-width: 767px) {
  .c-company-info__info--dt {
    font-size: 15px;
  }
}

.c-company-info__info--dd {
  font-size: clamp(12px, 1.1805555556vw, 17px);
}

.c-company-info__info--address {
  display: grid;
  grid-template-columns: auto 1fr;
}
@media screen and (max-width: 767px) {
  .c-company-info__info--address {
    grid-template-columns: 1fr;
  }
}

.c-news-card__link {
  --arrowWidthSize: 15px;
  position: relative;
  display: block;
  padding-bottom: 16px;
  padding-left: 19px;
  padding-right: var(--arrowWidthSize);
}
@media screen and (max-width: 767px) {
  .c-news-card__link {
    --arrowWidthSize: 12px;
    padding-bottom: 8px;
    padding-left: 10px;
  }
}
.c-news-card__link::after {
  position: absolute;
  top: 50%;
  right: 0;
  translate: 0 -50%;
  content: "";
  aspect-ratio: 1;
  width: var(--arrowWidthSize);
  background: url("../img/common/common_icon_arrow_right_white.png") no-repeat center top/cover;
}

.c-news-card__date {
  font-size: 14px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .c-news-card__date {
    font-size: 13px;
  }
}

.c-news-card__link:focus-visible .c-news-card__date {
  opacity: 0.6;
}
@media (any-hover: hover) {
  .c-news-card__link:hover .c-news-card__date {
    opacity: 0.6;
  }
}

.c-news-card__ttl {
  font-weight: bold;
  font-size: clamp(15px, 1.1805555556vw, 17px);
  margin-top: 7px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .c-news-card__ttl {
    margin-top: 5px;
  }
}

.c-news-card__link:focus-visible .c-news-card__ttl {
  opacity: 0.6;
}
@media (any-hover: hover) {
  .c-news-card__link:hover .c-news-card__ttl {
    opacity: 0.6;
  }
}

.c-news-card__categories {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 6px;
}
@media screen and (max-width: 767px) {
  .c-news-card__categories {
    gap: 5px;
  }
}

.c-news-card__category {
  min-width: 87px;
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border-primary);
  border-radius: 5px;
  color: var(--color-txt-black);
  text-align: center;
  font-size: 13px;
  line-height: 1.2;
  padding-inline: 5px;
  padding-block: 6px;
}
@media screen and (max-width: 767px) {
  .c-news-card__category {
    font-size: 11px;
    min-width: 60px;
    padding-block: 2px;
  }
}

.c-news-card__body {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  /* 制限したい行数を指定 */
  overflow: hidden;
  line-height: 1.4;
  font-size: 15px;
  margin-top: 16px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .c-news-card__body {
    font-size: 13px;
    margin-top: 11px;
  }
}

.c-news-card__link:focus-visible .c-news-card__body {
  color: var(--color-border-primary-light);
}
@media (any-hover: hover) {
  .c-news-card__link:hover .c-news-card__body {
    color: var(--color-border-primary-light);
  }
}

.p-index-mv {
  overflow: hidden;
  --height: 100svh;
  position: relative;
  min-height: var(--height);
}

.p-index-mv__bg {
  position: relative;
  z-index: -1;
  position: absolute;
  inset: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-index-mv__bg::after {
  z-index: -1;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(99, 99, 99, 0.3);
}

.p-index-mv__bg--mv {
  z-index: -2;
  position: absolute;
  inset: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-index-mv__inner {
  display: grid;
  place-content: center;
  justify-items: center;
  min-height: var(--height);
}

.p-index-mv__icon {
  width: 28px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-index-mv__icon {
    margin-top: 40px;
  }
}

.p-index-mv__ttl {
  width: min(100%, 700px);
  margin-inline: 20px;
  margin-top: 162px;
}
@media screen and (max-width: 767px) {
  .p-index-mv__ttl {
    width: min(100%, 310px);
    margin-top: 60px;
  }
}

.p-index-mv__desc {
  text-align: center;
  font-weight: 500;
  font-size: clamp(13px, 1.25vw, 18px);
  margin-top: 140px;
}
@media screen and (max-width: 767px) {
  .p-index-mv__desc {
    margin-top: 100px;
  }
}

.p-index-mission {
  overflow: hidden;
  margin-top: clamp(70px, 12.2395833333vw, 235px);
}

.p-index-mission__inner {
  display: grid;
  grid-template-columns: min(450px, 50%) 1fr;
  column-gap: clamp(20px, 4.0277777778vw, 58px);
  align-items: start;
  margin-right: calc(50% - 50vw);
}
@media screen and (max-width: 949px) {
  .p-index-mission__inner {
    grid-template-columns: 1fr;
    row-gap: 32px;
    margin-right: 0;
  }
}

.p-index-mission__box {
  --circleSize: 21px;
  --gapSize: 21px;
  padding-left: calc(var(--circleSize) + var(--gapSize));
}
@media screen and (max-width: 767px) {
  .p-index-mission__box {
    --circleSize: 9px;
    --gapSize: 7px;
    padding-left: 0;
  }
}

.p-index-mission__ttl {
  display: grid;
  grid-template-columns: var(--circleSize) 1fr;
  column-gap: var(--gapSize);
  align-items: center;
  font-weight: bold;
  font-family: "din-2014", sans-serif;
  letter-spacing: 0.07em;
  font-size: clamp(25px, 4.5138888889vw, 65px);
  line-height: 1;
  margin-left: calc(-1 * (var(--circleSize) + var(--gapSize)));
}
@media screen and (max-width: 767px) {
  .p-index-mission__ttl {
    margin-left: 0;
  }
}
.p-index-mission__ttl::before {
  content: "";
  aspect-ratio: 1;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  box-shadow: 0 0 64px #0166C9;
}

.p-index-mission__ttl--ja {
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-index-mission__ttl--ja {
    padding-left: calc(var(--circleSize) + var(--gapSize));
    margin-top: 0px;
  }
}

.p-index-mission__head {
  font-weight: bold;
  font-size: clamp(17px, 1.5972222222vw, 23px);
  margin-top: 18px;
}
@media screen and (max-width: 767px) {
  .p-index-mission__head {
    margin-top: 21px;
  }
}

.p-index-mission__body {
  letter-spacing: 0.05em;
  font-size: 14px;
  margin-top: 28px;
}
@media screen and (max-width: 767px) {
  .p-index-mission__body {
    font-size: 13px;
    margin-top: 13px;
  }
}

.p-index-mission__btn {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-index-mission__btn {
    margin-top: 20px;
  }
}

.p-index-mission__img {
  height: 400px;
}
.p-index-mission__img > img {
  height: 100%;
}
@media screen and (max-width: 949px) {
  .p-index-mission__img {
    max-height: 183px;
    margin-right: calc(50% - 50vw);
  }
}

.p-index-solution {
  margin-top: 222px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-index-solution {
    margin-top: 83px;
  }
}

.p-index-solution__desc {
  width: min(100%, 393px);
  text-align: center;
  line-height: 1.6;
  letter-spacing: 0.05em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: clamp(22px, 3.6111111111vw, 52px);
  margin-inline: auto;
}

.p-index-solution__sec1 {
  position: relative;
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  padding-right: calc(50vw - 50%);
  padding-left: calc(50vw - 50%);
  margin-top: 53px;
}
@media screen and (max-width: 767px) {
  .p-index-solution__sec1 {
    margin-top: 20px;
  }
}

.p-index-solution-sec1__dot1 {
  top: 10%;
  right: 10%;
}

.p-index-solution-sec1__dot2 {
  bottom: 0%;
  left: 18%;
}

.p-index-solution-sec1__txt {
  position: absolute;
  bottom: 0%;
  left: 0;
  width: 100%;
}

.p-index-solution-sec1__inner {
  position: relative;
  width: min(100%, 750px);
  aspect-ratio: 1;
  margin-inline: auto;
}

.p-index-solution-sec1__img1,
.p-index-solution-sec1__img2 {
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: min(100%, 540px);
  aspect-ratio: 1;
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec1__img1,
  .p-index-solution-sec1__img2 {
    width: 90%;
  }
}
.p-index-solution-sec1__img1 > img,
.p-index-solution-sec1__img2 > img {
  height: 100%;
}

.p-index-solution-sec1__img1 {
  z-index: 2;
  animation: spin 5s linear infinite;
}

.p-index-solution-sec1__img2 {
  z-index: 1;
}

.p-index-solution-sec1__head {
  z-index: 3;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  aspect-ratio: 1;
  background-color: var(--color-bg-primary);
  border-radius: calc(infinity * 1px);
  width: clamp(102px, 27.9vw, 279px);
  text-align: center;
  display: grid;
  align-content: center;
}

.p-index-solution-sec1__head--en {
  font-family: "din-2014", sans-serif;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.07em;
  font-size: clamp(30px, 4vw, 40px);
}

.p-index-solution-sec1__head--ja {
  font-weight: bold;
  line-height: 1.2;
  font-size: clamp(10px, 3vw, 30px);
}

.p-index-solution-sec1__item {
  --iconSize: clamp(36px, 53 / 1000 * 100vw, 53px);
  z-index: 3;
  position: absolute;
  aspect-ratio: 1;
  width: clamp(110px, 19vw, 190px);
  border-radius: calc(infinity * 1px);
  overflow: hidden;
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 10px;
  justify-items: center;
  align-content: center;
  background: linear-gradient(154deg, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 34%, rgb(209, 223, 237) 65%, rgba(102, 164, 223, 0.8) 100%);
  box-shadow: 0 0 58px rgba(1, 102, 201, 0.5);
}
.p-index-solution-sec1__item:nth-of-type(1) {
  --iconSize: clamp(36px, 40 / 1000 * 100vw, 40px);
  top: 0;
  left: 50%;
  translate: -50% 0;
}
.p-index-solution-sec1__item:nth-of-type(2) {
  top: 50%;
  right: 0;
  translate: 0 -50%;
}
.p-index-solution-sec1__item:nth-of-type(3) {
  bottom: 0;
  left: 50%;
  translate: -50% 0;
}
.p-index-solution-sec1__item:nth-of-type(4) {
  top: 50%;
  left: 0;
  translate: 0 -50%;
}

.p-index-solution-sec1__icon {
  aspect-ratio: 1;
  height: 100%;
}
.p-index-solution-sec1__icon > img {
  height: 100%;
  object-fit: contain;
}

.p-index-solution-sec1__ttl {
  text-align: center;
  color: var(--color-txt-primary);
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: clamp(11px, 1.2vw, 12px);
}

.p-index-solution__sec2 {
  position: relative;
  margin-top: 220px;
}
@media screen and (max-width: 767px) {
  .p-index-solution__sec2 {
    margin-top: 52px;
  }
}

.p-index-solution-sec2__container {
  --marginLeftSize: 48px;
  --paddingSize: 20px;
  padding-left: var(--marginLeftSize);
  margin-top: 53px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__container {
    --marginLeftSize: 30px;
    overflow-x: auto;
    padding-right: var(--marginLeftSize);
    padding-bottom: var(--marginLeftSize);
    margin-right: calc(50% - 50vw);
  }
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec2__container {
    margin-top: 20px;
  }
}

.p-index-solution-sec2__inner {
  position: relative;
  padding-block: var(--paddingSize);
  box-shadow: 0 0 21px 8px rgba(1, 102, 201, 0.5);
  background: url("../img/index/index_solution_bg.jpg") no-repeat center center/cover;
  color: var(--color-txt-primary);
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__inner {
    width: 1000px;
  }
}

.p-index-solution-sec2__list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding-inline: var(--paddingSize);
}

.p-index-solution-sec2__list1 > li:not(:nth-of-type(2)),
.p-index-solution-sec2__list2 > li:not(:nth-of-type(2)),
.p-index-solution-sec2__list3 > li:not(:nth-of-type(2)) {
  border-left: 1px dotted var(--color-border-primary);
}

.p-index-solution-sec2__list2 > *,
.p-index-solution-sec2__list3 > * {
  border-top: 1px dotted var(--color-border-primary);
}

.p-index-solution-sec2__list1 {
  min-height: 180px;
}

.p-index-solution-sec2__ttl {
  position: absolute;
  top: 50%;
  left: calc(-1 * var(--marginLeftSize));
  translate: 0 -50%;
  display: grid;
  place-content: center;
  height: 80%;
  width: clamp(48px, 4.1666666667vw, 60px);
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  writing-mode: tb;
  text-align: center;
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.04em;
  line-height: 1;
  padding-block: 19px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__ttl {
    font-size: 15px;
    width: 46px;
  }
}

.p-index-solution-sec2__list1--item {
  --iconSize: clamp(48px, 80 / 1440 * 100vw, 80px);
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 10px;
  align-content: center;
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec2__list1--item {
    --iconSize: 48px;
  }
}

.p-index-solution-sec2__list1--img {
  aspect-ratio: 1;
  justify-self: center;
  width: var(--iconSize);
  height: var(--iconSize);
}
.p-index-solution-sec2__list1--img > img {
  height: 100%;
  object-fit: contain;
}

.p-index-solution-sec2__list1--ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: 17px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__list1--ttl {
    font-size: 15px;
  }
}

.p-index-solution-sec2__list2 {
  min-height: 190px;
}

.p-index-solution-sec2__list2--item {
  display: grid;
  place-items: center;
}

.p-index-solution-sec2__list2--ttl {
  text-align: center;
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__list2--ttl {
    font-size: 15px;
  }
}

.p-index-solution-sec2__list3 {
  min-height: 180px;
}

.p-index-solution-sec2__list3--item {
  display: grid;
  align-content: start;
  row-gap: 15px;
  padding-inline: 19px;
  padding-top: 10%;
}

.p-index-solution-sec2__list3--head {
  display: grid;
  grid-template-columns: 12px auto;
  column-gap: 10px;
  font-weight: bold;
  font-size: 16px;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__list3--head {
    font-size: 15px;
  }
}
.p-index-solution-sec2__list3--head::before {
  content: "";
  aspect-ratio: 1;
  background-color: var(--color-bg-primary);
  margin-top: 0.5em;
}

.p-index-solution-sec2__list3--body {
  font-size: 14px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec2__list3--body {
    font-size: 13px;
  }
}

.p-index-solution_sec2__btns {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-index-solution_sec2__btns {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    margin-top: 8px;
  }
}

.p-index-solution_sec2__btn {
  aspect-ratio: 1;
  width: 26px;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  box-shadow: 0 0 3px #4B95AF;
  background: url("../img/common/common_icon_arrow_right_primary.png") no-repeat center center/contain;
  background-color: var(--color-bg-white);
  background-size: 12px;
}

.p-index-solution_sec2__btn--left {
  rotate: 180deg;
}

.p-index-solution__sec3 {
  position: relative;
  padding-bottom: 286px;
  margin-top: 176px;
}
@media screen and (max-width: 767px) {
  .p-index-solution__sec3 {
    padding-bottom: 86px;
    margin-top: 128px;
  }
}

.p-index-solution__sec3__dot1 {
  bottom: 15%;
  left: 2%;
}

.p-index-solution__sec3__dot2 {
  top: -6%;
  right: 6%;
}

.p-index-solution-sec3__list {
  counter-reset: number 0;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  margin-top: 53px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__list {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec3__list {
    margin-top: 20px;
  }
}

.p-index-solution-sec3__item {
  counter-increment: number 1;
  grid-column: span 2;
  border: 1px solid var(--color-border-primary);
  padding-top: clamp(9px, 1.0416666667vw, 15px);
  padding-inline: clamp(14px, 3.125vw, 45px);
  padding-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec3__item {
    padding-bottom: 50px;
  }
}
.p-index-solution-sec3__item::before {
  display: block;
  font-weight: 300;
  content: counter(number, decimal-leading-zero);
  font-size: clamp(13px, 1.1805555556vw, 17px);
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec3__item::before {
    text-align: center;
    margin-bottom: 8px;
  }
}
.p-index-solution-sec3__item:nth-of-type(2) {
  margin-left: -1px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item:nth-of-type(2) {
    margin-top: -1px;
  }
}
.p-index-solution-sec3__item:nth-of-type(3) {
  margin-left: -1px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item:nth-of-type(3) {
    margin-left: 0;
    margin-top: -1px;
  }
}
.p-index-solution-sec3__item:nth-of-type(4) {
  grid-column: 2/4;
  margin-top: -1px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item:nth-of-type(4) {
    margin-left: -1px;
    grid-column: span 2;
  }
}
.p-index-solution-sec3__item:nth-of-type(5) {
  grid-column: 4/6;
  margin-top: -1px;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item:nth-of-type(5) {
    grid-column: 2/4;
  }
}

.p-index-solution-sec3__item--link {
  position: relative;
  display: block;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item--link {
    box-shadow: 0 0 8px rgba(161, 224, 231, 0.5);
  }
}
.p-index-solution-sec3__item--link::after {
  --backgroundSize: 20px;
  z-index: 1;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  translate: 18px 25%;
  display: grid;
  place-content: center;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: 52px;
  background: url("../img/common/common_icon_arrow_right_white.png") no-repeat center center/contain;
  background-color: var(--color-bg-primary);
  background-size: var(--backgroundSize);
  transition: all 0.3s ease;
  transition-property: scale, background-color, background-image;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item--link::after {
    --backgroundSize: 10px;
    width: 24px;
    top: calc(100% + 8px);
    left: 50%;
    translate: -50% 0;
  }
}
.p-index-solution-sec3__item--link:focus-visible {
  opacity: 0.8;
}
.p-index-solution-sec3__item--link:focus-visible::after {
  scale: 1.1;
  background-color: var(--color-bg-white);
  background-image: url("../img/common/common_icon_arrow_right_primary.png");
  background-size: calc(1.1 * var(--backgroundSize));
}
@media (any-hover: hover) {
  .p-index-solution-sec3__item--link:hover {
    opacity: 0.8;
  }
  .p-index-solution-sec3__item--link:hover::after {
    scale: 1.1;
    background-color: var(--color-bg-white);
    background-image: url("../img/common/common_icon_arrow_right_primary.png");
    background-size: calc(1.1 * var(--backgroundSize));
  }
}

.p-index-solution-sec3__item--img {
  overflow: hidden;
  height: 200px;
}
@media screen and (max-width: 767px) {
  .p-index-solution-sec3__item--img {
    height: 90px;
  }
}
.p-index-solution-sec3__item--img > img {
  height: 100%;
}

.p-index-solution-sec3__item--ttl {
  position: relative;
  text-align: right;
  background-color: var(--color-bg-primary);
  font-weight: 300;
  font-size: clamp(12px, 1.1805555556vw, 17px);
  padding-block: 3px;
  padding-left: 10px;
  padding-right: 68px;
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 949px) {
  .p-index-solution-sec3__item--ttl {
    text-align: center;
    padding-inline: 10px;
  }
}

.p-index-solution-sec3__item--link:focus-visible .p-index-solution-sec3__item--ttl {
  background-color: var(--color-bg-white);
  color: var(--color-txt-primary);
}

@media (any-hover: hover) {
  .p-index-solution-sec3__item--link:hover .p-index-solution-sec3__item--ttl {
    background-color: var(--color-bg-white);
    color: var(--color-txt-primary);
  }
}
.p-index-news {
  background: url("../img/index/index_news_bg.jpg") no-repeat center center/cover;
  padding-block: 140px;
}
@media screen and (max-width: 949px) {
  .p-index-news {
    padding-block: 40px;
  }
}

.p-index-news__splide2 {
  margin-top: 44px;
  margin-left: -100px;
}
@media screen and (max-width: 767px) {
  .p-index-news__splide2 {
    margin-top: 24px;
  }
}

.p-index-news__splide1 .splide__slide > img,
.p-index-news__splide2 .splide__slide > img {
  height: 100%;
}

.p-index-news__list {
  --gapSize: 25px;
  display: grid;
  align-items: start;
  row-gap: var(--gapSize);
  margin-top: 75px;
}
@media screen and (max-width: 767px) {
  .p-index-news__list {
    --gapSize: 17px;
    margin-top: 66px;
  }
}

.p-index-news__item {
  --dotSize: 7px;
  --spaceSize: 10px;
}
.p-index-news__item:not(:first-of-type) {
  border-top: 1px solid #CBCACA;
}

.p-index-news__item--link {
  --arrowSize: 20px;
  display: grid;
  grid-template-areas: "date ttl arrow" "body body arrow";
  grid-template-columns: auto 1fr var(--arrowSize);
  column-gap: 30px;
  row-gap: 8px;
  color: var(--color-txt-white);
  padding-top: var(--gapSize);
  padding-left: calc(var(--dotSize) + var(--spaceSize));
  margin-inline: auto;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-index-news__item--link {
    --arrowSize: 15px;
    grid-template: "date arrow" auto ". arrow" 1px "ttl arrow" auto ". arrow" 7px "body arrow" auto/1fr 15px;
    row-gap: 0;
    padding-left: 0;
  }
}
.p-index-news__item--link::after {
  grid-area: arrow;
  align-self: center;
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_arrow_right_white.png") no-repeat center top/cover;
}
.p-index-news__item--link:focus-visible {
  opacity: 0.6;
}
@media (any-hover: hover) {
  .p-index-news__item--link:hover {
    opacity: 0.6;
  }
}

.p-index-news__item--date {
  grid-area: date;
  align-self: center;
  display: grid;
  grid-template-columns: var(--dotSize) auto;
  column-gap: var(--spaceSize);
  align-items: center;
  font-size: 14px;
  margin-left: calc(-1 * (var(--dotSize) + var(--spaceSize)));
}
@media screen and (max-width: 767px) {
  .p-index-news__item--date {
    font-size: 12px;
    margin-left: 0;
  }
}
.p-index-news__item--date::before {
  content: "";
  aspect-ratio: 1;
  border-radius: calc(infinity * 1px);
  width: var(--dotSize);
  background-color: var(--color-bg-primary);
  box-shadow: 0 0 8px #A1E0E7;
}

.p-index-news__item--ttl {
  grid-area: ttl;
  align-self: center;
  font-weight: bold;
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-index-news__item--ttl {
    font-size: 13px;
  }
}

.p-index-news__item--body {
  grid-area: body;
  font-size: clamp(13px, 1.25vw, 18px);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-index-news__item--body {
    -webkit-line-clamp: 2;
  }
}

.p-index-news__btn {
  margin-top: 96px;
}
@media screen and (max-width: 767px) {
  .p-index-news__btn {
    margin-top: 60px;
  }
}

.p-index-sns {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .p-index-sns {
    margin-top: 40px;
  }
}

.p-index-sns__ttl {
  text-align: center;
  font-weight: 500;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .p-index-sns__ttl {
    font-size: 13px;
    font-weight: normal;
  }
}

.p-index-sns__link {
  display: block;
  width: min(100%, 600px);
  margin-inline: auto;
  margin-top: 32px;
  box-shadow: 0 0 29px rgba(1, 102, 201, 0.4);
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-index-sns__link {
    width: min(100%, 264px);
    margin-top: 12px;
  }
}
.p-index-sns__link:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-index-sns__link:hover {
    opacity: 0.8;
  }
}

.p-index-company {
  padding-bottom: 301px;
  margin-top: 166px;
}
@media screen and (max-width: 767px) {
  .p-index-company {
    padding-bottom: 130px;
    margin-top: 90px;
  }
}

.p-index-company__btn {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-index-company__btn {
    margin-top: 32px;
  }
}

.p-error404 {
  height: 80svh;
  text-align: center;
  display: grid;
  align-content: center;
}

.p-error404__tx1 {
  color: var(--color-txt-primary);
  font-weight: bold;
  line-height: 1;
  font-size: clamp(80px, 11.1111111111vw, 160px);
}
@media screen and (max-width: 767px) {
  .p-error404__tx1 {
    font-size: 80px;
  }
}

.p-error404__tx2 {
  color: var(--color-txt-primary);
  font-weight: bold;
  line-height: 1;
  font-size: clamp(24px, 2.7777777778vw, 40px);
}

.p-error404__tx3 {
  font-size: clamp(16px, 1.3888888889vw, 20px);
}

.p-error404__btn--link {
  display: block;
  border: 1px solid var(--color-border-primary);
  text-align: center;
  width: min(100%, 300px);
  font-weight: bold;
  font-size: clamp(16px, 1.3888888889vw, 20px);
  line-height: 1.4;
  padding-inline: 10px;
  padding-block: 20px;
  margin-inline: auto;
  transition: all 0.3s ease;
  transition-property: opacity;
}
.p-error404__btn--link:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-error404__btn--link:hover {
    opacity: 0.8;
  }
}

.p-company-sec1 {
  overflow: hidden;
  padding-top: 140px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1 {
    padding-top: 65px;
  }
}

.p-company-sec1__list {
  --dotSize: 21px;
  --row-gap: 140px;
  --columnGapSize: 40px;
  --marginLeftSize: calc(var(--dotSize) + var(--columnGapSize));
}
@media screen and (max-width: 767px) {
  .p-company-sec1__list {
    --dotSize: 10px;
    --columnGapSize: 17px;
    --row-gap: 70px;
  }
}

.p-company-sec1__item {
  --paddingLeftSize: 8px;
  margin-left: var(--marginLeftSize);
}
.p-company-sec1__item:not(:first-of-type) {
  margin-top: var(--row-gap);
}
@media screen and (max-width: 767px) {
  .p-company-sec1__item {
    --paddingLeftSize: 3px;
  }
}

.p-company-sec1__ttl {
  position: relative;
  font-weight: bold;
  font-family: "din-2014", sans-serif;
  line-height: 1;
  letter-spacing: 0.07em;
  font-size: clamp(25px, 2.7777777778vw, 40px);
  padding-left: var(--paddingLeftSize);
  padding-bottom: 11px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__ttl {
    padding-left: 0;
    padding-bottom: 14px;
  }
}
.p-company-sec1__ttl::before {
  --primaryWidth: 115px;
  content: "";
  position: absolute;
  height: 3px;
  width: 100%;
  background: linear-gradient(to right, var(--color-bg-primary) 0, var(--color-bg-primary) 115px, var(--color-bg-white) 115px, var(--color-bg-white) 100%);
  left: 0;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__ttl::before {
    --primaryWidth: 45px;
  }
}
.p-company-sec1__ttl::after {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  width: 21px;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  left: calc(-1 * var(--marginLeftSize));
  top: 50%;
  translate: 0 -50%;
  box-shadow: 0 0 64px #0166C9;
}

.p-company-sec1__head {
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.4;
  font-size: clamp(15px, 1.7361111111vw, 25px);
  padding-left: var(--paddingLeftSize);
  margin-top: 36px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__head {
    line-height: 1.2;
    margin-top: 25px;
  }
}

.p-company-sec1__body {
  font-size: clamp(13px, 1.1805555556vw, 17px);
  letter-spacing: 0.05em;
  padding-left: var(--paddingLeftSize);
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__body {
    letter-spacing: normal;
  }
}

.p-company-sec1__card {
  padding-left: 19px;
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__card {
    overflow: hidden;
    padding-left: var(--paddingLeftSize);
    padding-right: calc(20px + var(--marginLeftSize) - 13px);
    margin-top: 40px;
    margin-right: calc(50% - 50vw);
  }
  .p-company-sec1__card .splide__track {
    overflow: visible;
  }
}
.p-company-sec1__card:not(.is-active) {
  visibility: visible;
  overflow: visible;
}
.p-company-sec1__card:not(.is-active) .splide__list:not(#_) {
  display: flex;
  column-gap: clamp(13px, 3.2638888889vw, 47px);
}
.p-company-sec1__card:not(.is-active) .p-company-sec1__card--item:not(#_) {
  width: min(100%, 289px);
  flex: 1;
  max-width: 289px;
}
.p-company-sec1__card:not(.is-active) .splide__pagination:not(#_) {
  display: none;
}

.p-company-sec1__card--pagination {
  margin-top: 22px;
  justify-items: center;
}

.p-company-sec1__card--item {
  background: url("../img/company/company_img_01.jpg") no-repeat center center/cover;
  border: 2px solid var(--color-border-primary);
  color: var(--color-txt-black);
  padding: 13px 20px;
  padding-bottom: clamp(20px, 4.9305555556vw, 71px);
}
@media screen and (max-width: 767px) {
  .p-company-sec1__card--item {
    padding-top: 4px;
    padding-inline: 14px;
    padding-bottom: 20px;
  }
}

.p-company-sec1__card--num {
  position: relative;
  display: inline-block;
  font-family: "din-2014", sans-serif;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-size: 23px;
}
.p-company-sec1__card--num::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50% 0;
  width: 12px;
  height: 1px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .p-company-sec1__card--num::after {
    width: 9px;
    font-size: 18px;
  }
}

.p-company-sec1__card--ttl {
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.05em;
  font-size: 22px;
  margin-top: 9px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__card--ttl {
    line-height: 1.2;
    font-size: 15px;
    margin-top: 11px;
  }
}

.p-company-sec1__card--body {
  line-height: 1.3;
  letter-spacing: 0.05em;
  font-size: 15px;
  margin-top: 15px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__card--body {
    font-size: 13px;
    margin-top: 11px;
    line-height: 1.5;
  }
}

.p-company-sec1__message {
  --paddingLeftSize: clamp(3px, 25 / 1440 * 100vw, 25px);
  color: var(--color-txt-black);
  background-color: rgba(255, 255, 255, 0.9);
  padding-left: clamp(20px, 5vw, 72px);
  padding-top: clamp(20px, 4.5833333333vw, 66px);
  padding-right: calc(50vw - 50%);
  padding-bottom: clamp(40px, 5.7638888889vw, 83px);
  margin-top: 180px;
  margin-right: calc(50% - 50vw);
}
@media screen and (max-width: 767px) {
  .p-company-sec1__message {
    --paddingLeftSize: 3px;
    padding-top: 20px;
    padding-inline: 20px;
    padding-bottom: 40px;
    margin-top: 90px;
  }
}

.p-company-sec1__message--ttl {
  position: relative;
  font-family: "din-2014", sans-serif;
  font-weight: bold;
  line-height: 1.1;
  letter-spacing: 0.07em;
  font-size: clamp(25px, 2.7777777778vw, 40px);
  padding-left: var(--paddingLeftSize);
  padding-bottom: 7px;
  padding-right: calc(50vw - 50%);
  margin-right: calc(50% - 50vw);
}
@media screen and (max-width: 767px) {
  .p-company-sec1__message--ttl {
    padding-right: 0;
    margin-right: 0;
  }
}
.p-company-sec1__message--ttl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: rgba(var(--color-bg-primary), 0.4);
  background-color: rgba(1, 102, 201, 0.4);
}

.p-company-sec1__message--head {
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-weight: bold;
  font-size: clamp(15px, 1.5277777778vw, 22px);
  padding-left: var(--paddingLeftSize);
  margin-top: 30px;
}

.p-company-sec1__message--body {
  line-height: 1.8;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  padding-left: var(--paddingLeftSize);
  margin-top: 33px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__message--body {
    line-height: 1.5;
    margin-top: 21px;
  }
}

.p-company-sec1__message--name {
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.4;
  font-size: clamp(11px, 0.9027777778vw, 13px);
  padding-left: var(--paddingLeftSize);
  margin-top: 46px;
}
@media screen and (max-width: 767px) {
  .p-company-sec1__message--name {
    line-height: 2;
    font-size: 11px;
    margin-top: 18px;
  }
}

.p-company-sec2 {
  margin-top: 218px;
}
@media screen and (max-width: 767px) {
  .p-company-sec2 {
    margin-top: 67px;
  }
}

.p-company-sec3 {
  margin-top: 232px;
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .p-company-sec3 {
    margin-top: 107px;
    margin-bottom: 93px;
  }
}

.p-company-sec3__list {
  margin-top: 95px;
}
@media screen and (max-width: 767px) {
  .p-company-sec3__list {
    margin-top: 63px;
  }
}

.p-company-sec3__item:not(:first-of-type) {
  margin-top: 59px;
}
@media screen and (max-width: 767px) {
  .p-company-sec3__item:not(:first-of-type) {
    margin-top: 50px;
  }
}

.p-company-sec3__place {
  font-weight: bold;
  letter-spacing: 0.08em;
  font-size: clamp(15px, 1.3888888889vw, 20px);
  line-height: 1.4;
}

.p-company-sec3__address {
  font-size: clamp(13px, 1.25vw, 18px);
  margin-top: 10px;
}

.p-company-sec3__access {
  letter-spacing: 0.08em;
  font-size: clamp(12px, 1.1111111111vw, 16px);
  line-height: 1.8;
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  .p-company-sec3__access {
    line-height: 1.6;
  }
}

.p-company-sec3__map {
  aspect-ratio: 920/370;
  max-height: 370px;
  margin-top: 30px;
}
.p-company-sec3__map > iframe {
  height: 100%;
  filter: grayscale(100%);
}
@media screen and (max-width: 767px) {
  .p-company-sec3__map {
    max-height: 130px;
    margin-top: 16px;
    width: 100%;
  }
}

.p-company-sec3__btn {
  margin-top: 150px;
}
@media screen and (max-width: 767px) {
  .p-company-sec3__btn {
    margin-top: 65px;
  }
}

.p-news-archive {
  padding-top: 146px;
  padding-bottom: 130px;
}
@media screen and (max-width: 767px) {
  .p-news-archive {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}

.p-news-archive__category--ttl {
  position: relative;
  font-weight: bold;
  display: inline-block;
  font-size: 20px;
  padding-bottom: 11px;
}
@media screen and (max-width: 767px) {
  .p-news-archive__category--ttl {
    font-size: 15px;
    padding-bottom: 5px;
  }
}
.p-news-archive__category--ttl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(to right, var(--color-bg-white) 0, var(--color-bg-white) 50%, var(--color-bg-primary) 50%, var(--color-bg-primary) 100%);
}

.p-news-archive__category--list {
  display: flex;
  flex-wrap: wrap;
  column-gap: 33px;
  row-gap: 20px;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-news-archive__category--list {
    gap: 10px;
    margin-top: 24px;
  }
}

.p-news-archive__category--link {
  display: block;
  min-width: 149px;
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border-primary);
  border-radius: 5px;
  color: var(--color-txt-black);
  text-align: center;
  font-size: 20px;
  line-height: 1.2;
  padding-inline: 5px;
  padding-block: 12px;
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 767px) {
  .p-news-archive__category--link {
    min-width: 66px;
    font-size: 11px;
    padding-block: 3px;
  }
}
.p-news-archive__category--link:focus-visible {
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
}
@media (any-hover: hover) {
  .p-news-archive__category--link:hover {
    background-color: var(--color-bg-primary);
    color: var(--color-txt-white);
  }
}
.p-news-archive__category--link.isActive {
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
}

.p-news-archive__list {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .p-news-archive__list {
    margin-top: 64px;
  }
}

.p-news-archive__item {
  border-left: 2px solid var(--color-border-white);
}
.p-news-archive__item:not(:first-of-type) {
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .p-news-archive__item:not(:first-of-type) {
    margin-top: 32px;
  }
}
.p-news-archive__item:nth-of-type(even) {
  border-color: var(--color-border-primary);
}

.p-news-single-sec1 {
  padding-top: 110px;
}
@media screen and (max-width: 767px) {
  .p-news-single-sec1 {
    padding-top: 80px;
  }
}

.p-news-single-sec1__ttl {
  position: relative;
  font-weight: bold;
  font-size: clamp(25px, 2.4305555556vw, 35px);
  line-height: 1.2;
  padding-bottom: 16px;
}
.p-news-single-sec1__ttl::before, .p-news-single-sec1__ttl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 1px;
  box-shadow: 0 0 4px rgba(1, 102, 201, 0.81);
}
.p-news-single-sec1__ttl::before {
  z-index: 1;
  width: 100%;
  background-color: var(--color-bg-primary);
}
.p-news-single-sec1__ttl::after {
  z-index: 2;
  width: clamp(80px, 15.5555555556vw, 224px);
  background-color: var(--color-bg-white);
}

.p-news-single-sec1__box {
  display: flex;
  justify-content: space-between;
  padding-right: 10px;
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  .p-news-single-sec1__box {
    padding-right: 3px;
    margin-top: 4px;
  }
}

.p-news-single-sec1__date {
  display: block;
  font-weight: 500;
  font-size: clamp(11px, 1.25vw, 18px);
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .p-news-single-sec1__date {
    margin-top: 8px;
  }
}

.p-news-single__categories {
  display: flex;
  flex-wrap: wrap;
  column-gap: 16px;
  row-gap: 5px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-news-single__categories {
    column-gap: 5px;
    margin-top: 7px;
  }
}

.p-news-single__category {
  color: var(--color-txt-black);
  background-color: var(--color-bg-white);
  border: 3px solid var(--color-border-primary);
  border-radius: 3px;
  text-align: center;
  line-height: 1.25;
  font-size: clamp(11px, 1.25vw, 18px);
  min-width: 110px;
  padding: 6px 10px 7px;
}
@media screen and (max-width: 767px) {
  .p-news-single__category {
    padding: 2px 7px 2px;
    min-width: 60px;
  }
}

.p-news-single-thumbnail {
  margin-top: 80px;
  width: min(100%, 600px);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-news-single-thumbnail {
    margin-top: 60px;
  }
}

.p-news-single-thumbnail__caption {
  font-weight: 300;
  font-size: 12px;
  letter-spacing: 0.04em;
  margin-top: 10px;
}

.p-news-single-content {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .p-news-single-content {
    margin-top: 60px;
  }
}

.p-news-single-sec2 {
  padding-bottom: 100px;
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  .p-news-single-sec2 {
    margin-top: 64px;
    padding-bottom: 80px;
  }
}

.p-news-single-sec2__back--link {
  display: grid;
  grid-template-columns: 16px auto;
  justify-content: center;
  align-items: center;
  column-gap: 8px;
  min-width: 254px;
  text-align: center;
  border-radius: 5px;
  line-height: 1.2;
  font-weight: bold;
  color: var(--color-txt-black);
  font-size: 20px;
  background-color: var(--color-bg-white);
  padding-block: 22px;
  padding-inline: 1em;
  width: fit-content;
  margin-inline: auto;
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 767px) {
  .p-news-single-sec2__back--link {
    grid-template-columns: 13px auto;
    column-gap: 4px;
    min-width: 115px;
    font-size: 13px;
    padding-block: 11px;
  }
}
.p-news-single-sec2__back--link::before {
  content: "";
  background: url("../img/common/common_icon_arrow_left_black.png") no-repeat center center/contain;
  aspect-ratio: 1;
  transition: all 0.3s ease;
  transition-property: background-image;
}
.p-news-single-sec2__back--link:focus-visible {
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
}
.p-news-single-sec2__back--link:focus-visible::before {
  background-image: url("../img/common/common_icon_arrow_left_white.png");
}
@media (any-hover: hover) {
  .p-news-single-sec2__back--link:hover {
    background-color: var(--color-bg-primary);
    color: var(--color-txt-white);
  }
  .p-news-single-sec2__back--link:hover::before {
    background-image: url("../img/common/common_icon_arrow_left_white.png");
  }
}

.p-recruit {
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-recruit {
    margin-top: 50px;
  }
}

/*タブ用スタイル*/
.p-recruit__tabList {
  display: flex;
  column-gap: clamp(10px, 2.0833333333vw, 30px);
  row-gap: 10px;
  flex-wrap: wrap;
  margin-top: 46px;
}
@media screen and (max-width: 767px) {
  .p-recruit__tabList {
    gap: 10px;
    margin-top: 33px;
  }
}

.p-recruit__tabItem {
  cursor: pointer;
  background-color: var(--color-bg-white);
  color: var(--color-txt-black);
  border: 1px solid var(--color-border-primary);
  border-radius: 5px;
  line-height: 1;
  font-weight: 500;
  font-size: clamp(12px, 1.25vw, 18px);
  padding-inline: 24px;
  padding-block: 13px;
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 767px) {
  .p-recruit__tabItem {
    padding: 6px 10px 7px;
  }
}
.p-recruit__tabItem.isActive {
  cursor: default;
  color: var(--color-txt-white);
  background-color: var(--color-bg-primary);
}
.p-recruit__tabItem:focus-visible {
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
}
@media (any-hover: hover) {
  .p-recruit__tabItem:hover {
    background-color: var(--color-bg-primary);
    color: var(--color-txt-white);
  }
}

/*タブコンテンツ用スタイル*/
.p-recruit__tabContent {
  visibility: hidden;
  display: none;
  opacity: 0;
  line-height: 2;
  margin-top: 170px;
}
@media screen and (max-width: 767px) {
  .p-recruit__tabContent {
    line-height: 1.4;
    margin-top: 80px;
  }
}
.p-recruit__tabContent.isShow {
  visibility: visible;
  opacity: 1;
  display: block;
}

.p-recruit__dl {
  --dotSize: 12px;
  --gapSize: 16px;
  padding-left: calc(var(--dotSize) + var(--gapSize));
  padding-block: 33px;
}
@media screen and (max-width: 767px) {
  .p-recruit__dl {
    --gapSize: 11px;
    padding-block: 20px;
  }
}
.p-recruit__dl:not(:first-of-type) {
  border-top: 1px solid rgba(255, 255, 255, 0.3);
}
.p-recruit__dl:first-of-type {
  padding-top: 0;
}
.p-recruit__dl:last-of-type {
  padding-bottom: 0;
}

.p-recruit__dt {
  font-weight: bold;
  font-size: clamp(16px, 1.3888888889vw, 20px);
  letter-spacing: 0.16em;
  display: grid;
  grid-template-columns: var(--dotSize) 1fr;
  column-gap: var(--gapSize);
  align-items: center;
  margin-left: calc(-1 * (var(--dotSize) + var(--gapSize)));
}
.p-recruit__dt::before {
  content: "";
  aspect-ratio: 1;
  background-color: var(--color-bg-white);
}

.p-recruit__dd {
  font-weight: 500;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  letter-spacing: 0.16em;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .p-recruit__dd {
    margin-top: 8px;
  }
}

.p-recruit__dd--item {
  padding-left: 1em;
  text-indent: -1em;
}
.p-recruit__dd--item::before {
  content: "・";
}

.p-recruit-entry {
  margin-top: 200px;
  margin-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-recruit-entry {
    margin-top: 75px;
    margin-bottom: 100px;
  }
}

.p-recruit-entry__body {
  font-weight: bold;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  letter-spacing: 0.16em;
}

.p-recruit-entry__list {
  display: grid;
  grid-template-columns: repeat(2, 259px);
  justify-content: start;
  column-gap: 64px;
  row-gap: 18px;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .p-recruit-entry__list {
    margin-top: 54px;
    grid-template-columns: 1fr;
    justify-items: center;
  }
}

.p-recruit-entry__item {
  max-width: 345px;
}
.p-recruit-entry__item > a {
  padding-inline: 1em;
  width: min(100%, 345px);
}
@media screen and (max-width: 767px) {
  .p-recruit-entry__item > a {
    min-width: 155px;
  }
}

.p-recruit-entry__item--tel {
  border-top: 5px solid var(--color-border-primary);
  border-bottom: 5px solid var(--color-border-primary);
  min-height: 85px;
  display: grid;
  grid-template-columns: 16px auto;
  justify-content: center;
  align-items: center;
  column-gap: 7px;
  font-size: clamp(14px, 1.3888888889vw, 20px);
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-recruit-entry__item--tel {
    grid-template-columns: 10px auto;
    min-height: 40px;
    border-top-width: 1px;
    border-bottom-width: 1px;
  }
}
.p-recruit-entry__item--tel::before {
  content: "";
  background: url("../img/common/common_icon_tel_white.png") no-repeat center center/contain;
  aspect-ratio: 1;
  transition: all 0.3s ease;
  transition-property: background-image;
}
.p-recruit-entry__item--tel:focus-visible {
  color: var(--color-txt-primary);
}
.p-recruit-entry__item--tel:focus-visible::before {
  background-image: url(../img/common/common_icon_tel_primary.png);
}
@media (any-hover: hover) {
  .p-recruit-entry__item--tel:hover {
    color: var(--color-txt-primary);
  }
  .p-recruit-entry__item--tel:hover::before {
    background-image: url(../img/common/common_icon_tel_primary.png);
  }
}

.p-recruit-entry__item--contact {
  color: var(--color-txt-white);
  background-color: var(--color-bg-primary);
  min-height: 85px;
  display: grid;
  grid-template-columns: 23px auto;
  justify-content: center;
  align-items: center;
  column-gap: 9px;
  font-size: clamp(14px, 1.3888888889vw, 20px);
  border: 3px solid var(--color-border-primary);
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 767px) {
  .p-recruit-entry__item--contact {
    grid-template-columns: 14px auto;
    column-gap: 4px;
    min-height: 40px;
  }
}
.p-recruit-entry__item--contact::before {
  content: "";
  background: url("../img/common/common_icon_mail_white.png") no-repeat center center/contain;
  aspect-ratio: 1;
  transition: all 0.3s ease;
  transition-property: background-image;
}
.p-recruit-entry__item--contact:focus-visible {
  color: var(--color-txt-black);
  background-color: var(--color-bg-white);
}
.p-recruit-entry__item--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_mail_black.png");
}
@media (any-hover: hover) {
  .p-recruit-entry__item--contact:hover {
    color: var(--color-txt-black);
    background-color: var(--color-bg-white);
  }
  .p-recruit-entry__item--contact:hover::before {
    background-image: url("../img/common/common_icon_mail_black.png");
  }
}

.p-recruit-form {
  position: relative;
  margin-top: 100px;
  margin-bottom: 100px;
}

.p-recruit-form__inner {
  color: var(--color-txt-black);
  border: 2px solid var(--color-border-primary);
  padding-top: 70px;
  padding-inline: 20px;
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__inner {
    padding-top: 30px;
    padding-bottom: 40px;
  }
}

.p-recruit-form__logo {
  width: min(100%, 400px);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__logo {
    width: min(100%, 180px);
  }
}

.p-recruit-form__ttl {
  text-align: center;
  font-size: clamp(17px, 2.0833333333vw, 30px);
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__ttl {
    margin-top: 24px;
  }
}

.p-recruit-form__desc {
  position: relative;
  text-align: center;
  font-size: clamp(12px, 1.0416666667vw, 15px);
  padding-top: 15px;
  margin-top: 15px;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__desc {
    padding-top: 8px;
    margin-top: 10px;
  }
}
.p-recruit-form__desc::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  background-color: var(--color-bg-black);
  width: 35px;
  height: 1px;
}

.p-recruit-form__form {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__form {
    margin-top: 50px;
  }
}

.p-recruit-form__dot1 {
  right: 10%;
  top: 20%;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__dot1 {
    display: none;
  }
}

.p-recruit-form__dot2 {
  left: 10%;
  bottom: 5%;
}
@media screen and (max-width: 767px) {
  .p-recruit-form__dot2 {
    display: none;
  }
}

.p-recruit-form-thanks {
  position: relative;
}

.p-recruit-form-thanks__inner {
  min-height: 80svh;
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
}

.p-recruit-form-thanks__en {
  font-size: clamp(15px, 1.3888888889vw, 20px);
}

.p-recruit-form-thanks__head {
  font-size: clamp(20px, 2.7777777778vw, 40px);
  margin-top: 27px;
}
@media screen and (max-width: 767px) {
  .p-recruit-form-thanks__head {
    margin-top: 17px;
  }
}

.p-recruit-form-thanks__body {
  line-height: 2;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-recruit-form-thanks__body {
    margin-top: 20px;
  }
}

.p-recruit-form-thanks__dot1 {
  right: 10%;
  top: 20%;
}
@media screen and (max-width: 767px) {
  .p-recruit-form-thanks__dot1 {
    display: none;
  }
}

.p-recruit-form-thanks__dot2 {
  left: 20%;
  bottom: 5%;
}
@media screen and (max-width: 767px) {
  .p-recruit-form-thanks__dot2 {
    display: none;
  }
}

.p-privacy {
  padding-top: 200px;
  padding-bottom: 300px;
}
@media screen and (max-width: 767px) {
  .p-privacy {
    padding-top: 100px;
    padding-bottom: 100px;
  }
}

.p-privacy__ttl--ja {
  font-size: clamp(17px, 2.4305555556vw, 35px);
}

.p-privacy__ttl--en {
  font-size: clamp(12px, 1.0416666667vw, 15px);
}

.p-privacy__inner {
  border-radius: 6px;
  background-color: rgba(255, 255, 255, 0.9);
  color: var(--color-txt-black);
  padding-top: 100px;
  padding-inline: clamp(20px, 5.2083333333vw, 100px);
  padding-bottom: 100px;
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-privacy__inner {
    font-size: 12px;
    padding-inline: 17px;
    padding-block: 20px;
    margin-top: 100px;
  }
}

.p-privacy__body {
  margin-top: 1.5em;
  padding-top: 1.5em;
  border-top: 1px dotted var(--color-border-primary);
}

.p-thanks__inner {
  min-height: 80svh;
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
}

.p-thanks__img {
  width: 135px;
}
@media screen and (max-width: 767px) {
  .p-thanks__img {
    width: 56px;
  }
}
.p-thanks__img > img {
  height: 100%;
}

.p-thanks__en {
  font-size: clamp(15px, 1.7361111111vw, 25px);
  margin-top: 27px;
}
@media screen and (max-width: 767px) {
  .p-thanks__en {
    font-size: 15px;
    margin-top: 33px;
  }
}

.p-thanks__head {
  font-size: clamp(25px, 3.4722222222vw, 50px);
  margin-top: 27px;
}
@media screen and (max-width: 767px) {
  .p-thanks__head {
    font-size: 20px;
    margin-top: 17px;
  }
}

.p-thanks__body {
  line-height: 2;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-thanks__body {
    font-size: 13px;
    margin-top: 20px;
  }
}

.p-download {
  padding-top: 160px;
  padding-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-download {
    padding-top: 50px;
    padding-bottom: 70px;
  }
}

.p-download__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  column-gap: clamp(20px, 2.7777777778vw, 40px);
  row-gap: clamp(20px, 4.1666666667vw, 60px);
  margin-top: 75px;
}
@media screen and (max-width: 767px) {
  .p-download__list {
    grid-template-columns: 1fr;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
    row-gap: 45px;
    margin-top: 45px;
  }
}

.p-download__item {
  grid-column: span 2;
}
@media screen and (max-width: 767px) {
  .p-download__item {
    grid-column: auto;
  }
}
.p-download__item:nth-of-type(4) {
  grid-column: 2/4;
}
@media screen and (max-width: 767px) {
  .p-download__item:nth-of-type(4) {
    grid-column: auto;
  }
}
.p-download__item:nth-of-type(5) {
  grid-column: 4/6;
}
@media screen and (max-width: 767px) {
  .p-download__item:nth-of-type(5) {
    grid-column: auto;
  }
}

.p-download__item--link {
  display: block;
}

.p-download__item--img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 354/214;
  max-height: 220px;
  width: 100%;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-download__item--img {
    max-height: 170px;
  }
}
.p-download__item--img > img {
  position: absolute;
  inset: 0;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  transition: all 0.3s ease;
  transition-property: scale;
}

.p-download__item--link:focus-visible .p-download__item--img {
  opacity: 0.6;
}
.p-download__item--link:focus-visible .p-download__item--img > img {
  scale: 1.05;
}
@media (any-hover: hover) {
  .p-download__item--link:hover .p-download__item--img {
    opacity: 0.6;
  }
  .p-download__item--link:hover .p-download__item--img > img {
    scale: 1.05;
  }
}

.p-download__item--tag {
  display: inline-block;
  background-color: var(--color-bg-primary);
  text-align: center;
  font-weight: bold;
  line-height: 1.2;
  font-size: clamp(11px, 0.9027777778vw, 13px);
  min-width: 104px;
  border-radius: 3px;
  padding: 7px 12px;
  margin-top: 35px;
}
@media screen and (max-width: 767px) {
  .p-download__item--tag {
    min-width: 82px;
    padding: 6px 11px;
    margin-top: 18px;
  }
}

.p-download__item--ttl {
  font-weight: bold;
  letter-spacing: 0.06em;
  line-height: 1.2;
  font-size: clamp(20px, 1.7361111111vw, 25px);
  margin-top: 10px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-download__item--ttl {
    margin-top: 9px;
  }
}

.p-download__item--body {
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.7;
  font-size: clamp(11px, 0.9027777778vw, 13px);
  margin-top: 10px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-download__item--body {
    margin-top: 6px;
  }
}

.p-download-form {
  padding-top: 200px;
  padding-bottom: 260px;
}
@media screen and (max-width: 949px) {
  .p-download-form {
    padding-top: 65px;
    padding-bottom: 55px;
  }
}

.p-download-form__ttl {
  font-size: clamp(17px, 2.4305555556vw, 35px);
}

.p-download-form__head {
  font-size: clamp(12px, 1.0416666667vw, 15px);
}
.p-download-form__head::after {
  height: 1px;
}

.p-download-form__inner {
  position: relative;
  margin-top: 90px;
}
@media screen and (max-width: 949px) {
  .p-download-form__inner {
    margin-top: 40px;
  }
}

.p-download-form__dot1 {
  right: 0;
  top: 20%;
}

.p-download-form__dot2 {
  left: 0;
  bottom: 2%;
}

.p-download-form__form {
  border: 4px solid var(--color-border-primary);
  background-color: var(--color-bg-gray);
  border-radius: 3px;
  padding-top: 74px;
  padding-bottom: 63px;
}
@media screen and (max-width: 767px) {
  .p-download-form__form {
    border: none;
    padding: 36px;
    padding-bottom: 50px;
  }
}

.p-download-thanks {
  padding-top: 200px;
  padding-bottom: 300px;
}
@media screen and (max-width: 949px) {
  .p-download-thanks {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-download-thanks__inner {
  text-align: center;
}

.p-download-thanks__img {
  width: 135px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks__img {
    width: 56px;
  }
}
.p-download-thanks__img > img {
  height: 100%;
}

.p-download-thanks__en {
  font-size: clamp(15px, 1.3888888889vw, 20px);
  margin-top: 27px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks__en {
    margin-top: 33px;
  }
}

.p-download-thanks__head {
  font-size: clamp(20px, 2.7777777778vw, 40px);
  margin-top: 27px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks__head {
    margin-top: 17px;
  }
}

.p-download-thanks__body {
  line-height: 2;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks__body {
    margin-top: 20px;
  }
}

.p-download-thanks-guide {
  color: var(--color-txt-black);
  padding-top: 64px;
  padding-bottom: 78px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks-guide {
    padding-top: 45px;
    padding-bottom: 57px;
  }
}

.p-download-thanks-guide__head {
  text-align: center;
  line-height: 1.4;
  font-weight: 500;
  font-size: clamp(20px, 2.7777777778vw, 40px);
}

.p-download-thanks-guide__body {
  text-align: center;
  line-height: 2;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 29px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks-guide__body {
    line-height: 1.6;
    margin-top: 27px;
  }
}

.p-download-thanks-guide__list {
  display: grid;
  grid-template-columns: repeat(2, 259px);
  justify-content: center;
  column-gap: 64px;
  row-gap: 18px;
  margin-top: 53px;
}
@media screen and (max-width: 767px) {
  .p-download-thanks-guide__list {
    margin-top: 60px;
    grid-template-columns: 1fr;
    justify-items: center;
  }
}

.p-download-thanks-guide__item {
  max-width: 345px;
}
.p-download-thanks-guide__item > a {
  padding-inline: 1em;
  width: min(100%, 345px);
}
@media screen and (max-width: 767px) {
  .p-download-thanks-guide__item > a {
    min-width: 152px;
  }
}

.p-download-thanks-guide__item--tel {
  border-top: 5px solid var(--color-border-primary);
  border-bottom: 5px solid var(--color-border-primary);
  min-height: 85px;
  display: grid;
  grid-template-columns: 16px auto;
  justify-content: center;
  align-items: center;
  column-gap: 7px;
  font-size: clamp(14px, 1.3888888889vw, 20px);
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-download-thanks-guide__item--tel {
    border-top-width: 1px;
    border-bottom-width: 1px;
    grid-template-columns: 15px auto;
    min-height: 40px;
  }
}
.p-download-thanks-guide__item--tel::before {
  content: "";
  background: url("../img/common/common_icon_tel_black.png") no-repeat center center/contain;
  aspect-ratio: 1;
  transition: all 0.3s ease;
  transition-property: background-image;
}
.p-download-thanks-guide__item--tel:focus-visible {
  color: var(--color-txt-primary);
}
.p-download-thanks-guide__item--tel:focus-visible::before {
  background-image: url(../img/common/common_icon_tel_primary.png);
}
@media (any-hover: hover) {
  .p-download-thanks-guide__item--tel:hover {
    color: var(--color-txt-primary);
  }
  .p-download-thanks-guide__item--tel:hover::before {
    background-image: url(../img/common/common_icon_tel_primary.png);
  }
}

.p-download-thanks-guide__item--contact {
  color: var(--color-txt-white);
  background-color: var(--color-bg-primary);
  min-height: 85px;
  display: grid;
  grid-template-columns: 23px auto;
  justify-content: center;
  align-items: center;
  column-gap: 9px;
  font-size: clamp(14px, 1.3888888889vw, 20px);
  border: 3px solid var(--color-border-primary);
  transition: all 0.3s ease;
  transition-property: background-color, color;
}
@media screen and (max-width: 767px) {
  .p-download-thanks-guide__item--contact {
    grid-template-columns: 14px auto;
    column-gap: 4px;
    min-height: 40px;
  }
}
.p-download-thanks-guide__item--contact::before {
  content: "";
  background: url("../img/common/common_icon_mail_white.png") no-repeat center center/contain;
  aspect-ratio: 1;
  transition: all 0.3s ease;
  transition-property: background-image;
}
.p-download-thanks-guide__item--contact:focus-visible {
  color: var(--color-txt-black);
  background-color: transparent;
}
.p-download-thanks-guide__item--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_mail_black.png");
}
@media (any-hover: hover) {
  .p-download-thanks-guide__item--contact:hover {
    color: var(--color-txt-black);
    background-color: transparent;
  }
  .p-download-thanks-guide__item--contact:hover::before {
    background-image: url("../img/common/common_icon_mail_black.png");
  }
}

.p-service-shared-mv {
  position: relative;
  display: grid;
  align-items: center;
  min-height: calc(100svh - var(--header-height));
  height: fit-content;
  padding-block: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-mv {
    padding-block: 20px;
  }
}

.p-service-shared-mv__bg {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-service-shared-mv__bg > img {
  height: 100%;
}

.p-service-shared-mv__inner {
  z-index: 1;
  position: relative;
  color: var(--color-txt-white);
  padding-left: 6vw;
  padding-right: 20px;
}

.p-service-shared-mv__name {
  color: rgba(1, 102, 201, 0.15);
  line-height: 1;
  font-weight: bold;
  letter-spacing: 0.08em;
  font-size: clamp(50px, 8.3333333333vw, 120px);
  margin-bottom: -40px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-mv__name {
    font-size: 35px;
    margin-bottom: 0;
  }
}

.p-service-shared-mv__head {
  position: relative;
  display: inline;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.08em;
  color: var(--color-txt-white);
  font-size: clamp(23px, 2.4305555556vw, 35px);
  background-image: linear-gradient(to right, #0166C9 0%, #91C9FF 57%, #2287EB 100%);
  background-repeat: no-repeat;
  background-position: left 100%;
  background-size: 0 clamp(13px, 1.8055555556vw, 26px);
  animation: expand 1.2s forwards;
  animation-delay: 400ms;
}
.p-service-shared-mv__head::before {
  content: "“";
  position: absolute;
  top: 0;
  left: 0;
  translate: -100% -20%;
  color: var(--color-txt-white);
  font-weight: bold;
  line-height: 1;
  font-size: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-mv__head::before {
    translate: -30% -60%;
    font-size: 50px;
  }
}

@keyframes expand {
  from {
    background-size: 0% clamp(13px, 1.8055555556vw, 26px);
  }
  to {
    background-size: 100% clamp(13px, 1.8055555556vw, 26px);
  }
}
.p-service-shared-mv__body {
  color: var(--color-txt-white);
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 17px;
  margin-top: 28px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-mv__body {
    line-height: 1.8;
    font-size: 15px;
    margin-top: 20px;
  }
}

.p-service-shared-mv__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-mv__cta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-shared-mv__cta {
    display: flex;
  }
}

.p-service-shared-mv__cta--btn {
  display: block;
  position: relative;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: bold;
  line-height: 1;
  width: min(100%, 240px);
  font-size: clamp(15px, 1.3888888889vw, 20px);
  border-radius: 3px;
  padding-block: 21px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-service-shared-mv__cta--btn {
    font-size: 15px;
    padding-block: 16px;
    width: min(100%, 152px);
  }
}
.p-service-shared-mv__cta--btn::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  height: 100%;
  border-left: 1px solid var(--color-border-primary);
  border-bottom: 1px solid var(--color-border-primary);
  top: 6px;
  left: -6px;
}
.p-service-shared-mv__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-service-shared-mv__cta--btn:hover {
    opacity: 0.8;
  }
}

.p-service-shared-mv__scroll {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-shared-mv__scroll {
    --barHeightSize: 40px;
    display: grid;
    grid-template-rows: var(--barHeightSize) auto;
    row-gap: 3px;
    justify-items: center;
    margin-top: 50px;
  }
}

.p-service-shared-mv__scroll--bar {
  position: relative;
  background-color: var(--color-bg-primary);
  width: 2px;
  border-radius: calc(infinity * 1px);
}
.p-service-shared-mv__scroll--bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: 6px;
  box-shadow: 0 0 2px 3px rgba(1, 102, 201, 0.22);
  background-color: var(--color-bg-primary);
  animation: scrollBall linear 4s infinite;
}

@keyframes scrollBall {
  0% {
    opacity: 1;
    top: 0%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 100%;
  }
}
.p-service-shared-mv__scroll--txt {
  text-align: center;
  color: var(--color-txt-primary);
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.p-service-shared-about {
  margin-top: 200px;
}
@media screen and (max-width: 576px) {
  .p-service-shared-about {
    margin-top: 50px;
  }
}

.p-service-shared-about__box1 {
  --circleSize: 230px;
  display: grid;
  grid-template-areas: "icon head" "icon desc";
  grid-template-columns: var(--circleSize) 1fr;
  column-gap: 50px;
  row-gap: 27px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about__box1 {
    --circleSize: 160px;
    row-gap: 0;
    padding-inline: 0;
    grid-template: "icon" auto "." 25px "head" auto "." 14px "desc" auto/1fr;
  }
}

.p-service-shared-about-box1__icon {
  --iconSize: 93px;
  grid-area: icon;
  align-self: center;
  position: relative;
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 18px;
  place-content: center;
  border-radius: calc(infinity * 1px);
  background: url("../img/service/service_about_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box1__icon {
    --iconSize: 46px;
    justify-self: center;
  }
}
.p-service-shared-about-box1__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  aspect-ratio: 1;
  width: calc(var(--circleSize) + 50px);
  border: 1px solid var(--color-border-primary);
  border-radius: calc(infinity * 1px);
  clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);
  animation: spin 5s linear infinite;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box1__icon::before {
    width: calc(var(--circleSize) + 25px);
  }
}

.p-service-shared-about-box1__icon--img {
  height: 100%;
  aspect-ratio: 1;
  justify-self: center;
}
.p-service-shared-about-box1__icon--img > img {
  height: 100%;
  object-fit: contain;
}

.p-service-shared-about-box1__ttl {
  text-align: center;
  line-height: 1.4;
  font-weight: bold;
  color: var(--color-txt-primary);
  letter-spacing: 0.02em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box1__ttl {
    text-align: center;
    font-size: 12px;
  }
}

.p-service-shared-about-box2__head {
  grid-area: head;
  font-weight: bold;
  line-height: 1.2;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2__head {
    text-align: center;
  }
}

.p-service-shared-about-box2__desc {
  grid-area: desc;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2__desc {
    font-size: 13px;
    line-height: 2.3;
    padding-inline: 19px;
  }
}

.p-service-shared-about-box2 {
  color: var(--color-txt-black);
  background: url("../img/service/service_about_bg_02.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  padding-inline: 20px;
  padding-block: clamp(30px, 3.4722222222vw, 50px);
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2 {
    margin-top: 50px;
  }
}

.p-service-shared-about-box2__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-shared-about-box2__wrap {
  max-width: 660px;
  border-top: 1px solid var(--color-border-black);
  display: grid;
  grid-template-columns: repeat(3, auto);
  justify-content: center;
  column-gap: 20px;
  align-items: center;
  padding-top: 14px;
  margin-top: 17px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2__wrap {
    text-align: center;
    grid-template-columns: 1fr;
    row-gap: 8px;
    justify-items: center;
  }
}

.p-service-shared-about-box2__txt1 {
  --rectangleSize: 11px;
  --columnGapSize: 6px;
  display: grid;
  grid-template-columns: var(--rectangleSize) auto;
  column-gap: var(--columnGapSize);
  align-items: center;
  font-weight: bold;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2__txt1 {
    display: block;
  }
}
.p-service-shared-about-box2__txt1::before {
  content: "";
  display: block;
  background-color: var(--color-bg-black);
  aspect-ratio: 1;
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2__txt1::before {
    content: none;
  }
}

.p-service-shared-about-box2__line {
  width: 59px;
  height: 2px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .p-service-shared-about-box2__line {
    width: 2px;
    height: 15px;
  }
}

.p-service-shared-about-box2__txt2 {
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;
  max-width: 325px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-shared-issue {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-issue {
    margin-top: 160px;
  }
}

.p-service-shared-issue__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-shared-issue__ttl > span {
  z-index: 1;
  display: inline;
  background: linear-gradient(transparent 70%, var(--color-bg-primary) 0%);
  position: relative;
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-shared-issue__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(24px, 3.4722222222vw, 50px);
  max-width: 885px;
  margin-top: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-shared-issue__list {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 30px;
  }
}

.p-service-shared-issue__item {
  display: grid;
  grid-column: span 2;
  grid-template-rows: subgrid;
  grid-template-columns: 1fr;
  grid-row: span 2;
  row-gap: 20px;
  border-radius: 3px;
  background-color: var(--color-bg-gray);
  border: 3px solid var(--color-border-primary);
  color: var(--color-txt-black);
  justify-items: center;
  padding-top: clamp(10px, 1.7361111111vw, 25px);
  padding-bottom: clamp(20px, 3.8194444444vw, 55px);
}
@media screen and (max-width: 767px) {
  .p-service-shared-issue__item {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .p-service-shared-issue__item:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-shared-issue__head {
  text-align: center;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  align-self: center;
}

.p-service-shared-issue__icon {
  aspect-ratio: 1;
  width: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-issue__icon {
    width: 80px;
  }
}

.p-service-shared-issue__desc {
  font-weight: 500px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 2.4;
  text-align: center;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-issue__desc {
    line-height: 1.5;
    margin-top: 30px;
  }
}

.p-service-shared-solution {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-solution {
    margin-top: 160px;
  }
}

.p-service-shared-solution__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-shared-solution__ttl > span {
  z-index: 1;
  display: inline-block;
  position: relative;
  font-size: 23px;
}

.p-service-shared-solution__inner {
  --dotSize: 13px;
  --columnGapSize: 18px;
  padding-left: calc(var(--dotSize) + var(--columnGapSize));
  display: grid;
  grid-template-columns: 1fr clamp(200px, 27.7777777778vw, 400px);
  gap: 27px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-solution__inner {
    --dotSize: 8px;
    grid-template-columns: 1fr;
    margin-top: 24px;
    padding-right: 30px;
  }
}

.p-service-shared-solution__head {
  display: grid;
  grid-template-columns: var(--dotSize) 1fr;
  column-gap: var(--columnGapSize);
  margin-left: calc(-1 * (var(--dotSize) + var(--columnGapSize)));
  font-size: clamp(17px, 1.7361111111vw, 25px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-service-shared-solution__head {
    align-items: center;
  }
}
.p-service-shared-solution__head::before {
  content: "";
  position: relative;
  top: 0.5em;
  aspect-ratio: 1;
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 79%);
}
@media screen and (max-width: 767px) {
  .p-service-shared-solution__head::before {
    top: 0;
    background-color: var(--color-bg-primary);
    box-shadow: 0 0 7px rgba(1, 102, 201, 0.5);
    background-image: none;
  }
}

.p-service-shared-solution__body {
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 1.8;
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-solution__body {
    margin-top: 11px;
  }
}

.p-service-shared-solution__r {
  aspect-ratio: 400/265;
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
  max-height: 265px;
}
.p-service-shared-solution__r > img {
  height: 100%;
}

.p-service-shared-solution__cta {
  display: flex;
  justify-content: center;
  column-gap: 28px;
  row-gap: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-solution__cta {
    flex-direction: column;
    align-items: center;
    margin-top: 32px;
  }
}

.p-service-shared-feature {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature {
    margin-top: 160px;
  }
}

.p-service-shared-feature__list {
  display: grid;
  row-gap: 100px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__list {
    row-gap: 60px;
    padding-inline: 30px;
    margin-top: 40px;
  }
}

.p-service-shared-feature__item {
  --numberFontSize: clamp(30px, 70 / 1440 * 100vw, 70px);
  --columnGapSize: 40px;
}

.p-service-shared-feature__top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__top {
    grid-template-columns: 1fr;
    row-gap: 20px;
  }
}

.p-service-shared-feature__num {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: var(--numberFontSize);
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  padding-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__num {
    width: fit-content;
  }
}
.p-service-shared-feature__num::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 0;
  height: 2px;
  width: 26px;
  background-color: var(--color-bg-primary);
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__num::before {
    width: 19px;
  }
}

.p-service-shared-feature__ttl {
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.16em;
}

.p-service-shared-feature__ttl--head {
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-shared-feature__ttl--desc {
  font-size: clamp(13px, 1.1805555556vw, 17px);
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__ttl--desc {
    margin-top: 10px;
  }
}

.p-service-shared-feature__btm {
  --bodyWidthSize: 363px;
  --imgWidthSize: min(100%, 360px);
  display: flex;
  column-gap: 40px;
  padding-left: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__btm {
    --bodyWidthSize: 100%;
    flex-direction: column;
    row-gap: 18px;
    padding-left: 0;
    margin-top: 20px;
  }
}

.p-service-shared-feature__item:nth-of-type(even) .p-service-shared-feature__btm {
  flex-direction: row-reverse;
  justify-content: start;
  padding-left: calc(var(--columnGapSize) + var(--numberFontSize) * 1.2);
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__item:nth-of-type(even) .p-service-shared-feature__btm {
    flex-direction: column;
    padding-left: 0;
  }
}

.p-service-shared-feature__img {
  border-radius: 3px;
  overflow: hidden;
  width: var(--imgWidthSize);
  aspect-ratio: 360/215;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-shared-feature__img {
    justify-self: center;
  }
}
.p-service-shared-feature__img > img {
  height: 100%;
}

.p-service-shared-feature__body {
  width: var(--bodyWidthSize);
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-shared-function {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-function {
    margin-top: 160px;
  }
}

.p-service-shared-function-sec1__wrap {
  position: relative;
  padding-top: 60px;
  margin-top: 40px;
  padding-bottom: 30px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__wrap {
    width: min(100%, 300px);
    display: grid;
    row-gap: 10px;
    padding-block: 0;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec1__wrap {
    margin-top: 30px;
  }
}

.p-service-shared-function-sec1__item {
  z-index: 3;
  filter: drop-shadow(0 0 10px rgba(1, 102, 201, 0.58));
  position: absolute;
  display: grid;
  align-items: center;
  --numWidthSize: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__item {
    --numWidthSize: 44px;
    position: relative;
    top: unset;
    right: unset;
    bottom: unset;
    left: unset;
    width: fit-content;
  }
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec1__item {
    --numWidthSize: 44px;
  }
}
.p-service-shared-function-sec1__item:nth-of-type(1), .p-service-shared-function-sec1__item:nth-of-type(4) {
  grid-template-columns: fit-content(100%) var(--numWidthSize);
  grid-template-areas: "head num";
}
.p-service-shared-function-sec1__item:nth-of-type(2), .p-service-shared-function-sec1__item:nth-of-type(5), .p-service-shared-function-sec1__item:nth-of-type(6) {
  grid-template-columns: var(--numWidthSize) fit-content(100%);
  grid-template-areas: "num head";
}
.p-service-shared-function-sec1__item:nth-of-type(1) {
  top: 12%;
  left: 0.018%;
}
.p-service-shared-function-sec1__item:nth-of-type(2) {
  top: 0;
  right: 7%;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__item:nth-of-type(2) {
    grid-template-columns: fit-content(100%) var(--numWidthSize);
    grid-template-areas: "head num";
    margin-inline: auto;
  }
}
.p-service-shared-function-sec1__item:nth-of-type(4) {
  top: 65%;
  left: 0;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__item:nth-of-type(4) {
    grid-template-columns: var(--numWidthSize) fit-content(100%);
    grid-template-areas: "num head";
    margin-left: auto;
  }
}
.p-service-shared-function-sec1__item:nth-of-type(5) {
  top: 37%;
  right: 0;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__item:nth-of-type(5) {
    margin-inline: auto;
  }
}
.p-service-shared-function-sec1__item:nth-of-type(6) {
  bottom: 0;
  right: 3%;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__item:nth-of-type(1), .p-service-shared-function-sec1__item:nth-of-type(2), .p-service-shared-function-sec1__item:nth-of-type(4), .p-service-shared-function-sec1__item:nth-of-type(5), .p-service-shared-function-sec1__item:nth-of-type(6) {
    inset: unset;
  }
}

.p-service-shared-function-sec1__head {
  grid-area: head;
  background-color: #0A5BAA;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.5;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  padding-block: 16px;
  min-width: clamp(150px, 14.5833333333vw, 280px);
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__head {
    font-size: 12px;
    min-width: 155px;
    padding-block: 8px;
  }
}

.p-service-shared-function-sec1__item:nth-of-type(1) .p-service-shared-function-sec1__head, .p-service-shared-function-sec1__item:nth-of-type(4) .p-service-shared-function-sec1__head {
  border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  margin-right: -15px;
}
.p-service-shared-function-sec1__item:nth-of-type(2) .p-service-shared-function-sec1__head, .p-service-shared-function-sec1__item:nth-of-type(5) .p-service-shared-function-sec1__head, .p-service-shared-function-sec1__item:nth-of-type(6) .p-service-shared-function-sec1__head {
  border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  margin-left: -15px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__item:nth-of-type(2) .p-service-shared-function-sec1__head {
    border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
    margin-left: 0px;
    margin-right: -15px;
  }
  .p-service-shared-function-sec1__item:nth-of-type(4) .p-service-shared-function-sec1__head {
    border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
    margin-right: 0px;
    margin-left: -15px;
  }
}

.p-service-shared-function-sec1__num {
  grid-area: num;
  aspect-ratio: 1;
  background-color: #0A5BAA;
  border-radius: calc(infinity * 1px);
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(12px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec1__num {
    font-size: 12px;
  }
}

.p-service-shared-function-sec1__center {
  --circleSize: 25%;
  --circleSizeMax: max(130px, var(--circleSize));
  position: relative;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__center {
    --circleSize: 130px;
  }
}
.p-service-shared-function-sec1__center::after {
  z-index: 2;
  content: "";
  position: absolute;
  top: 44%;
  left: 49.5%;
  translate: -50% -50%;
  aspect-ratio: 330/300;
  width: 330px;
  width: auto;
  height: 110%;
  background: url("../img/service/service_function_bg_02.png") no-repeat center center/contain;
}

.p-service-shared-function-sec1__center--lines {
  z-index: 1;
  position: absolute;
  top: 49%;
  left: 50%;
  translate: -50% -50%;
  display: block;
  aspect-ratio: 488/363;
  width: auto;
  height: 135%;
}
@media screen and (max-width: 949px) {
  .p-service-shared-function-sec1__center--lines {
    display: none;
  }
}

.p-service-shared-function-sec1__center--txt {
  position: relative;
  z-index: 2;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  display: grid;
  place-content: center;
  text-align: center;
  line-height: 1;
  color: var(--color-txt-black);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  background: url("../img/service/service_function_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec1__center--txt {
    --circleSize: 130px;
    font-size: 21px;
    width: var(--circleSize);
  }
}

.p-service-shared-function-sec1__center--shadow {
  z-index: 1;
  position: absolute;
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  animation: pulseMotion 2.4s linear infinite;
}

.p-service-shared-function-sec2__list {
  counter-reset: number 0;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec2__list {
    margin-top: 40px;
    padding-inline: 20px;
  }
}

.p-service-shared-function-sec2__item {
  --numberSize: auto;
  --iconSize: 30px;
  counter-increment: number 1;
  display: grid;
  grid-template-columns: var(--numberSize) 1fr var(--iconSize);
  column-gap: clamp(20px, 3.125vw, 45px);
  color: var(--color-txt-black);
  padding-top: 20px;
  padding-right: 20px;
  padding-bottom: 20px;
  padding-left: 30px;
  transition: all 0.3s ease;
  transition-property: padding;
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec2__item {
    --iconSize: 10px;
  }
}
.p-service-shared-function-sec2__item::before {
  content: counter(number, decimal-leading-zero);
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: 30px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec2__item::before {
    font-size: 17px;
  }
}
.p-service-shared-function-sec2__item::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/contain;
  transition: all 0.3s ease;
  transition-property: rotate;
}
.p-service-shared-function-sec2__item.isActive {
  padding-bottom: 30px;
}
.p-service-shared-function-sec2__item.isActive::after {
  rotate: -180deg;
}
.p-service-shared-function-sec2__item:nth-of-type(1) {
  background-color: #fff;
}
.p-service-shared-function-sec2__item:nth-of-type(2) {
  background-color: rgba(255, 255, 255, 0.8);
}
.p-service-shared-function-sec2__item:nth-of-type(3) {
  background-color: rgba(255, 255, 255, 0.7);
}
.p-service-shared-function-sec2__item:nth-of-type(4) {
  background-color: rgba(255, 255, 255, 0.6);
}
.p-service-shared-function-sec2__item:nth-of-type(5) {
  background-color: rgba(255, 255, 255, 0.5);
}
.p-service-shared-function-sec2__item:nth-of-type(6) {
  background-color: rgba(255, 255, 255, 0.4);
}
.p-service-shared-function-sec2__item:nth-of-type(7) {
  background-color: rgba(255, 255, 255, 0.3);
}

.p-service-shared-function-sec2__item--txt {
  cursor: pointer;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  align-self: center;
  font-size: clamp(12px, 1.1805555556vw, 17px);
}

.p-service-shared-function-sec2__item.isActive .p-service-shared-function-sec2__item--txt {
  display: block;
}

.p-service-shared-function-sec2__cta {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-function-sec2__cta {
    margin-top: 40px;
  }
}

.p-service-shared-price {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price {
    margin-top: 160px;
  }
}

.p-service-shared-price__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__list {
    grid-template-columns: 1fr;
    row-gap: 24px;
    padding-inline: 50px;
    margin-top: 40px;
  }
}

.p-service-shared-price__item {
  position: relative;
  background: url("../img/service/service_price_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  grid-column: span 2;
  border: 2px solid var(--color-bg-primary);
  border-radius: 3px;
  padding: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__item {
    grid-column: span 1;
    padding: 20px;
  }
}
.p-service-shared-price__item:nth-of-type(3) {
  grid-column: 2/4;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__item:nth-of-type(3) {
    grid-area: span 1;
  }
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__item::after {
    content: "";
    position: absolute;
    top: 15px;
    right: 11px;
    aspect-ratio: 1;
    width: 12px;
    background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
    transition: all 0.3s ease;
    transition-property: rotate;
  }
}
.p-service-shared-price__item.isActive::after {
  rotate: -180deg;
}

.p-service-shared-price__head {
  display: block;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(17px, 1.3888888889vw, 20px);
  width: min(100%, 250px);
  border-radius: 3px;
  padding: 15px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__head {
    width: min(100%, 160px);
  }
}

@media screen and (max-width: 767px) {
  .p-service-shared-price__body {
    display: grid;
    grid-template-rows: 0fr;
    transition: all 0.3s ease;
    transition-property: grid-template-rows;
  }
}

@media screen and (max-width: 767px) {
  .p-service-shared-price__item.isActive .p-service-shared-price__body {
    grid-template-rows: 1fr;
  }
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__body--inner {
    overflow: hidden;
  }
}
.p-service-shared-price__body--inner2 {
  color: var(--color-txt-black);
  padding-top: 25px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__body--inner2 {
    padding-top: 15px;
    padding-bottom: 20px;
  }
}

.p-service-shared-price__body--price {
  display: flex;
  align-items: end;
  justify-content: center;
  font-weight: bold;
  column-gap: 10px;
  line-height: 1.5;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__body--price {
    font-size: 15px;
  }
}

.p-service-shared-price__price--strong {
  font-size: clamp(17px, 1.7361111111vw, 25px);
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__price--strong {
    font-size: 25px;
  }
}

.p-service-shared-price__body--list {
  display: grid;
  row-gap: 10px;
  justify-content: center;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__body--list {
    margin-top: 20px;
  }
}

.p-service-shared-price__body--item {
  --squareSize: 14px;
  --columnGapSize: 17px;
  font-weight: bold;
  line-height: 1.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  display: grid;
  grid-template-columns: var(--squareSize) auto;
  align-items: center;
  column-gap: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-shared-price__body--item {
    --squareSize: 6px;
    --columnGapSize: 3px;
    font-size: 15px;
  }
}
.p-service-shared-price__body--item::before {
  content: "";
  aspect-ratio: 1;
  background-color: var(--color-bg-black);
}

.p-service-shared-flow {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow {
    margin-top: 160px;
  }
}

.p-service-shared-flow__list {
  --rowGapSize: 60px;
  --paddingEmptySize: clamp(0px, 150 / 1440 * 100vw, 150px);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: clamp(20px, 4.8611111111vw, 70px);
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__list {
    grid-template-columns: 1fr;
    row-gap: var(--rowGapSize);
  }
}
.p-service-shared-flow__list:nth-of-type(1) {
  padding-right: var(--paddingEmptySize);
  margin-top: 100px;
  margin-left: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__list:nth-of-type(1) {
    margin-top: 80px;
    margin-left: 0;
  }
}
.p-service-shared-flow__list:nth-of-type(2) {
  padding-left: var(--paddingEmptySize);
  margin-top: var(--rowGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__list:nth-of-type(1), .p-service-shared-flow__list:nth-of-type(2) {
    padding-inline: 0;
  }
}

.p-service-shared-flow__item {
  position: relative;
  background: url("../img/service/service_flow_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border: 2px solid var(--color-bg-primary);
  border-radius: 3px;
  padding-block: 38px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__item {
    width: min(100%, 230px);
    margin-inline: auto;
  }
}

.p-service-shared-flow__body {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__body {
    line-height: 1.5;
  }
}

.p-service-shared-flow__count {
  --circleSize: 97px;
  position: absolute;
  top: 0;
  left: 0;
  translate: -26% -43%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  place-content: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__count {
    --circleSize: 58px;
  }
}

.p-service-shared-flow__count--txt {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(13px, 1.0416666667vw, 15px);
}
@media screen and (max-width: 767px) {
  .p-service-shared-flow__count--txt {
    font-size: 14px;
  }
}

.p-service-shared-flow__count--num {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(17px, 2.2222222222vw, 32px);
}

.p-service-shared-contact {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-contact {
    padding-inline: 20px;
    margin-top: 160px;
  }
}

.p-service-shared-contact__body {
  font-weight: bold;
  text-align: center;
  line-height: 2.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-contact__body {
    line-height: 1.6;
    margin-top: 20px;
  }
}

.p-service-shared-contact__wrap {
  border: 2px solid var(--color-border-primary);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-contact__wrap {
    margin-top: 50px;
  }
}

.p-service-shared-faq {
  margin-top: 200px;
  margin-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-faq {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-service-shared-faq__list {
  display: grid;
  row-gap: clamp(20px, 2.7777777778vw, 40px);
  background-color: var(--color-bg-gray);
  border-radius: 17px;
  padding-inline: clamp(20px, 3.4722222222vw, 50px);
  padding-block: clamp(20px, 3.4722222222vw, 50px);
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-faq__list {
    margin-top: 20px;
    border-radius: 3px;
    margin-inline: 20px;
  }
}

.p-service-shared-faq__item {
  --columnGapSize: 20px;
  --iconFontSize: 50px;
  cursor: pointer;
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__item {
    --columnGapSize: 8px;
    --iconFontSize: 25px;
  }
}

.p-service-shared-faq__item--q {
  --iconSize: 20px;
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr var(--iconSize);
  align-items: center;
  column-gap: var(--columnGapSize);
  color: var(--color-txt-black);
  padding: 16px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__item--q {
    --iconSize: 10px;
    padding: 16px 10px;
  }
}
.p-service-shared-faq__item--q::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
  transition: all 0.3s ease;
  transition-property: rotate;
}

.p-service-shared-faq__item.isActive .p-service-shared-faq__item--q::after {
  rotate: -180deg;
}

.p-service-shared-faq__q--txt {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__q--txt {
    font-size: 15px;
  }
}
.p-service-shared-faq__q--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 23px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__q--txt::after {
    height: 17px;
  }
}

.p-service-shared-faq__q--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-faq__q--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-shared-faq__item--a {
  display: grid;
  grid-template-rows: 0fr;
  transition: all 0.3s ease;
  transition-property: grid-template-rows;
}

.p-service-shared-faq__item.isActive .p-service-shared-faq__item--a {
  grid-template-rows: 1fr;
}

.p-service-shared-faq__a--inner {
  overflow: hidden;
}

.p-service-shared-faq__a--inner2 {
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  border-radius: 3px;
  padding: 32px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__a--inner2 {
    padding: 12px 10px;
  }
}

.p-service-shared-faq__a--txt {
  position: relative;
  font-weight: bold;
  color: var(--color-txt-white);
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__a--txt {
    font-size: 15px;
  }
}
.p-service-shared-faq__a--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 40px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 949px) {
  .p-service-shared-faq__a--txt::after {
    height: 17px;
  }
}

.p-service-shared-faq__a--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-faq__a--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-shared-faq__cta {
  display: flex;
  justify-content: center;
  column-gap: 42px;
  row-gap: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-shared-faq__cta {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: center;
    row-gap: 20px;
    margin-top: 80px;
  }
}

.p-service-shared-faq__cta--link {
  --iconSize: 20px;
  --textWidthSize: auto;
  display: grid;
  grid-template-columns: var(--iconSize) var(--textWidthSize);
  align-items: center;
  justify-content: center;
  column-gap: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(15px, 1.25vw, 18px);
  width: min(100%, 309px);
  height: 100px;
  border-radius: 3px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-service-shared-faq__cta--link {
    --iconSize: 14px;
    --textWidthSize: 165px;
    font-size: 15px;
    height: 67px;
    justify-content: center;
  }
}
.p-service-shared-faq__cta--link::before {
  content: "";
  aspect-ratio: 1;
  transition: all 0.4s ease;
  transition-property: background-image;
}
.p-service-shared-faq__cta--link:focus-visible {
  background-color: var(--color-bg-white);
  color: var(--color);
}
@media (any-hover: hover) {
  .p-service-shared-faq__cta--link:hover {
    background-color: var(--color-bg-white);
    color: var(--color);
  }
}

.p-service-shared-faq__cta--contact {
  --color: var(--color-primary);
  background-color: var(--color);
}
.p-service-shared-faq__cta--contact::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-shared-faq__cta--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
}
@media (any-hover: hover) {
  .p-service-shared-faq__cta--contact:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
  }
}

.p-service-shared-faq__cta--download {
  --color: #636363;
  background-color: var(--color);
}
.p-service-shared-faq__cta--download::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-shared-faq__cta--download:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
}
@media (any-hover: hover) {
  .p-service-shared-faq__cta--download:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
  }
}

.p-service-infinity-mv {
  position: relative;
  display: grid;
  align-items: center;
  min-height: calc(100svh - var(--header-height));
  height: fit-content;
  padding-block: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-mv {
    padding-block: 20px;
  }
}

.p-service-infinity-mv__bg {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-service-infinity-mv__bg > img {
  height: 100%;
}

.p-service-infinity-mv__inner {
  z-index: 1;
  position: relative;
  color: var(--color-txt-white);
  padding-left: 6vw;
  padding-right: 20px;
}

.p-service-infinity-mv__name {
  color: rgba(1, 102, 201, 0.15);
  line-height: 1;
  font-weight: bold;
  letter-spacing: 0.08em;
  font-size: clamp(50px, 8.3333333333vw, 120px);
  margin-bottom: -40px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-mv__name {
    font-size: 35px;
    margin-bottom: 0;
  }
}

.p-service-infinity-mv__head {
  position: relative;
  display: inline;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.08em;
  color: var(--color-txt-white);
  font-size: clamp(23px, 2.4305555556vw, 35px);
  background-image: linear-gradient(to right, #0166C9 0%, #91C9FF 57%, #2287EB 100%);
  background-repeat: no-repeat;
  background-position: left 100%;
  background-size: 0 clamp(13px, 1.8055555556vw, 26px);
  animation: expand 1.2s forwards;
  animation-delay: 400ms;
}
.p-service-infinity-mv__head::before {
  content: "“";
  position: absolute;
  top: 0;
  left: 0;
  translate: -100% -20%;
  color: var(--color-txt-white);
  font-weight: bold;
  line-height: 1;
  font-size: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-mv__head::before {
    translate: -30% -60%;
    font-size: 50px;
  }
}

@keyframes expand {
  from {
    background-size: 0% clamp(13px, 1.8055555556vw, 26px);
  }
  to {
    background-size: 100% clamp(13px, 1.8055555556vw, 26px);
  }
}
.p-service-infinity-mv__body {
  color: var(--color-txt-white);
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 17px;
  margin-top: 28px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-mv__body {
    line-height: 1.8;
    font-size: 15px;
    margin-top: 20px;
  }
}

.p-service-infinity-mv__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-mv__cta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-infinity-mv__cta {
    display: flex;
  }
}

.p-service-infinity-mv__cta--btn {
  display: block;
  position: relative;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: bold;
  line-height: 1;
  width: min(100%, 240px);
  font-size: clamp(15px, 1.3888888889vw, 20px);
  border-radius: 3px;
  padding-block: 21px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-mv__cta--btn {
    font-size: 15px;
    padding-block: 16px;
    width: min(100%, 152px);
  }
}
.p-service-infinity-mv__cta--btn::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  height: 100%;
  border-left: 1px solid var(--color-border-primary);
  border-bottom: 1px solid var(--color-border-primary);
  top: 6px;
  left: -6px;
}
.p-service-infinity-mv__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-service-infinity-mv__cta--btn:hover {
    opacity: 0.8;
  }
}

.p-service-infinity-mv__scroll {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-mv__scroll {
    --barHeightSize: 40px;
    display: grid;
    grid-template-rows: var(--barHeightSize) auto;
    row-gap: 3px;
    justify-items: center;
    margin-top: 50px;
  }
}

.p-service-infinity-mv__scroll--bar {
  position: relative;
  background-color: var(--color-bg-primary);
  width: 2px;
  border-radius: calc(infinity * 1px);
}
.p-service-infinity-mv__scroll--bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: 6px;
  box-shadow: 0 0 2px 3px rgba(1, 102, 201, 0.22);
  background-color: var(--color-bg-primary);
  animation: scrollBall linear 4s infinite;
}

@keyframes scrollBall {
  0% {
    opacity: 1;
    top: 0%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 100%;
  }
}
.p-service-infinity-mv__scroll--txt {
  text-align: center;
  color: var(--color-txt-primary);
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.p-service-infinity-about {
  margin-top: 200px;
}
@media screen and (max-width: 576px) {
  .p-service-infinity-about {
    margin-top: 50px;
  }
}

.p-service-infinity-about__box1 {
  --circleSize: 230px;
  display: grid;
  grid-template-areas: "icon head" "icon desc";
  grid-template-columns: var(--circleSize) 1fr;
  column-gap: 50px;
  row-gap: 27px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about__box1 {
    --circleSize: 160px;
    row-gap: 0;
    padding-inline: 0;
    grid-template: "icon" auto "." 25px "head" auto "." 14px "desc" auto/1fr;
  }
}

.p-service-infinity-about-box1__icon {
  --iconSize: 93px;
  grid-area: icon;
  align-self: center;
  position: relative;
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 18px;
  place-content: center;
  border-radius: calc(infinity * 1px);
  background: url("../img/service/service_about_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box1__icon {
    --iconSize: 46px;
    justify-self: center;
  }
}
.p-service-infinity-about-box1__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  aspect-ratio: 1;
  width: calc(var(--circleSize) + 50px);
  border: 1px solid var(--color-border-primary);
  border-radius: calc(infinity * 1px);
  clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);
  animation: spin 5s linear infinite;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box1__icon::before {
    width: calc(var(--circleSize) + 25px);
  }
}

.p-service-infinity-about-box1__icon--img {
  height: 100%;
  aspect-ratio: 1;
  justify-self: center;
}
.p-service-infinity-about-box1__icon--img > img {
  height: 100%;
  object-fit: contain;
}

.p-service-infinity-about-box1__ttl {
  text-align: center;
  line-height: 1.4;
  font-weight: bold;
  color: var(--color-txt-primary);
  letter-spacing: 0.02em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box1__ttl {
    text-align: center;
    font-size: 12px;
  }
}

.p-service-infinity-about-box2__head {
  grid-area: head;
  font-weight: bold;
  line-height: 1.2;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  letter-spacing: 0.08em;
  align-self: end;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2__head {
    text-align: center;
  }
}

.p-service-infinity-about-box2__desc {
  grid-area: desc;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2__desc {
    font-size: 13px;
    line-height: 2.3;
    padding-inline: 19px;
  }
}

.p-service-infinity-about-box2 {
  color: var(--color-txt-black);
  background: url("../img/service/service_about_bg_02.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  padding-inline: 20px;
  padding-block: clamp(30px, 3.4722222222vw, 50px);
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2 {
    margin-top: 50px;
  }
}

.p-service-infinity-about-box2__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-infinity-about-box2__wrap {
  max-width: 660px;
  border-top: 1px solid var(--color-border-black);
  display: grid;
  grid-template-columns: repeat(3, auto);
  justify-content: center;
  column-gap: 20px;
  align-items: center;
  padding-top: 14px;
  margin-top: 17px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2__wrap {
    text-align: center;
    grid-template-columns: 1fr;
    row-gap: 8px;
    justify-items: center;
  }
}

.p-service-infinity-about-box2__txt1 {
  --rectangleSize: 11px;
  --columnGapSize: 6px;
  display: grid;
  grid-template-columns: var(--rectangleSize) auto;
  column-gap: var(--columnGapSize);
  align-items: center;
  font-weight: bold;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2__txt1 {
    display: block;
  }
}
.p-service-infinity-about-box2__txt1::before {
  content: "";
  display: block;
  background-color: var(--color-bg-black);
  aspect-ratio: 1;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2__txt1::before {
    content: none;
  }
}

.p-service-infinity-about-box2__line {
  width: 59px;
  height: 2px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about-box2__line {
    width: 2px;
    height: 15px;
  }
}

.p-service-infinity-about-box2__txt2 {
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;
  max-width: 325px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-infinity-about-box2__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
  margin-top: 27px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-about-box2__list {
    grid-template-columns: repeat(4, 1fr);
  }
  .p-service-infinity-about-box2__list > * {
    grid-column: span 2;
  }
  .p-service-infinity-about-box2__list > *:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-infinity-about-box2__item {
  display: grid;
}
.p-service-infinity-about-box2__item > * {
  margin-top: 0;
  align-content: center;
}

.p-service-infinity-about-box2__ttl2 {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.3;
  font-size: clamp(13px, 1.25vw, 18px);
}

.p-service-infinity-about__cta {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-about__cta {
    margin-top: 40px;
  }
}

.p-service-infinity-issue {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-issue {
    margin-top: 160px;
  }
}

.p-service-infinity-issue__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-infinity-issue__ttl > span {
  z-index: 1;
  display: inline;
  background: linear-gradient(transparent 70%, var(--color-bg-primary) 0%);
  position: relative;
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-infinity-issue__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(24px, 3.4722222222vw, 50px);
  max-width: 885px;
  margin-top: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-issue__list {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 30px;
  }
}

.p-service-infinity-issue__item {
  display: grid;
  grid-column: span 2;
  grid-template-rows: subgrid;
  grid-template-columns: 1fr;
  grid-row: span 3;
  row-gap: 20px;
  border-radius: 3px;
  background-color: var(--color-bg-gray);
  border: 3px solid var(--color-border-primary);
  color: var(--color-txt-black);
  justify-items: center;
  padding-top: clamp(10px, 1.7361111111vw, 25px);
  padding-bottom: clamp(20px, 3.8194444444vw, 55px);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-issue__item {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .p-service-infinity-issue__item:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-infinity-issue__head {
  text-align: center;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  align-self: center;
}

.p-service-infinity-issue__icon {
  aspect-ratio: 1;
  width: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-issue__icon {
    width: 80px;
  }
}

.p-service-infinity-issue__body {
  text-align: center;
  letter-spacing: 0.08em;
  line-height: 1.2;
  font-size: clamp(11px, 1.0416666667vw, 15px);
}

.p-service-infinity-issue__desc {
  font-weight: 500px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 2.4;
  text-align: center;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-issue__desc {
    line-height: 1.5;
    margin-top: 30px;
  }
}

.p-service-infinity-solution {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-solution {
    margin-top: 160px;
  }
}

.p-service-infinity-solution__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-infinity-solution__ttl > span {
  z-index: 1;
  display: inline-block;
  position: relative;
  font-size: 23px;
}

.p-service-infinity-solution__inner {
  --dotSize: 13px;
  --columnGapSize: 18px;
  padding-left: calc(var(--dotSize) + var(--columnGapSize));
  display: grid;
  grid-template-columns: 1fr clamp(200px, 27.7777777778vw, 400px);
  gap: 27px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-solution__inner {
    --dotSize: 8px;
    grid-template-columns: 1fr;
    margin-top: 24px;
    padding-right: 30px;
  }
}

.p-service-infinity-solution__head {
  display: grid;
  grid-template-columns: var(--dotSize) 1fr;
  column-gap: var(--columnGapSize);
  margin-left: calc(-1 * (var(--dotSize) + var(--columnGapSize)));
  font-size: clamp(17px, 1.7361111111vw, 25px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-solution__head {
    align-items: center;
  }
}
.p-service-infinity-solution__head::before {
  content: "";
  position: relative;
  top: 0.5em;
  aspect-ratio: 1;
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 79%);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-solution__head::before {
    top: 0;
    background-color: var(--color-bg-primary);
    box-shadow: 0 0 7px rgba(1, 102, 201, 0.5);
    background-image: none;
  }
}

.p-service-infinity-solution__body {
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 1.8;
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-solution__body {
    margin-top: 11px;
  }
}

.p-service-infinity-solution__r {
  aspect-ratio: 400/265;
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
  max-height: 265px;
}
.p-service-infinity-solution__r > img {
  height: 100%;
}

.p-service-infinity-solution__cta {
  display: flex;
  justify-content: center;
  column-gap: 28px;
  row-gap: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-solution__cta {
    flex-direction: column;
    align-items: center;
    margin-top: 32px;
  }
}

.p-service-infinity-feature {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature {
    margin-top: 160px;
  }
}

.p-service-infinity-feature__list {
  display: grid;
  row-gap: 100px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__list {
    row-gap: 60px;
    padding-inline: 30px;
    margin-top: 40px;
  }
}

.p-service-infinity-feature__item {
  --numberFontSize: clamp(30px, 70 / 1440 * 100vw, 70px);
  --columnGapSize: 40px;
}

.p-service-infinity-feature__top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__top {
    grid-template-columns: 1fr;
    row-gap: 20px;
  }
}

.p-service-infinity-feature__num {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: var(--numberFontSize);
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  padding-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__num {
    width: fit-content;
  }
}
.p-service-infinity-feature__num::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 0;
  height: 2px;
  width: 26px;
  background-color: var(--color-bg-primary);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__num::before {
    width: 19px;
  }
}

.p-service-infinity-feature__ttl {
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.16em;
}

.p-service-infinity-feature__ttl--head {
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-infinity-feature__ttl--desc {
  font-size: clamp(13px, 1.1805555556vw, 17px);
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__ttl--desc {
    margin-top: 10px;
  }
}

.p-service-infinity-feature__btm {
  --bodyWidthSize: 363px;
  --imgWidthSize: min(100%, 360px);
  display: flex;
  column-gap: 40px;
  padding-left: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__btm {
    --bodyWidthSize: 100%;
    flex-direction: column;
    row-gap: 10px;
    padding-left: 0;
    margin-top: 20px;
  }
}

.p-service-infinity-feature__item:nth-of-type(even) .p-service-infinity-feature__btm {
  flex-direction: row-reverse;
  justify-content: start;
  padding-left: calc(var(--columnGapSize) + var(--numberFontSize) * 1.2);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__item:nth-of-type(even) .p-service-infinity-feature__btm {
    flex-direction: column;
    padding-left: 0;
  }
}

.p-service-infinity-feature__img {
  border-radius: 3px;
  overflow: hidden;
  width: var(--imgWidthSize);
  aspect-ratio: 360/215;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-feature__img {
    justify-self: center;
  }
}
.p-service-infinity-feature__img > img {
  height: 100%;
}

.p-service-infinity-feature__body {
  width: var(--bodyWidthSize);
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-infinity-tool {
  margin-top: 200px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-tool {
    margin-top: 160px;
  }
}

.p-service-infinity-tool__container {
  --paddingSize: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-tool__container {
    margin-top: 44px;
    overflow-x: auto;
    padding-right: 20px;
    margin-right: calc(50% - 50vw);
  }
}

.p-service-infinity-tool__inner {
  position: relative;
  box-shadow: 0 0 2px rgba(1, 102, 201, 0.55);
  border-radius: 3px;
  border: 1px solid var(--color-border-primary);
  background: url("../img/service/service_tools_bg_01.png") no-repeat center center/cover;
  background-position: right bottom;
  padding: var(--paddingSize);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-tool__inner {
    width: 1000px;
  }
}

.p-service-infinity-tool__dl {
  position: relative;
  display: grid;
  grid-template-columns: 280px 1fr;
}
.p-service-infinity-tool__dl:not(:first-of-type) {
  border-top: 1px dotted var(--color-border-white);
}

.p-service-infinity-tool__dt {
  color: var(--color-txt-white);
  align-self: center;
  display: grid;
  place-content: center;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.16em;
  line-height: 1.3;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  padding-inline: 17px;
  padding-block: 40px;
}

.p-service-infinity-tool__dd {
  align-content: center;
  height: 100%;
  color: var(--color-txt-black);
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.4;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  border-left: 1px solid var(--color-border-white);
  padding-left: 20px;
  padding-block: 10px;
}

.p-service-infinity-tool__dt--slash {
  color: var(--color-txt-primary);
}

.p-service-infinity-tool__btns {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-tool__btns {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    margin-top: 8px;
  }
}

.p-service-infinity-tool__btn {
  aspect-ratio: 1;
  width: 26px;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  box-shadow: 0 0 3px #4B95AF;
  background: url("../img/common/common_icon_arrow_right_primary.png") no-repeat center center/contain;
  background-color: var(--color-bg-white);
  background-size: 12px;
}

.p-service-infinity-tool__btn--left {
  rotate: 180deg;
}

.p-service-infinity-function {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function {
    margin-top: 160px;
  }
}

.p-service-infinity-function-sec1__wrap {
  position: relative;
  padding-top: 60px;
  margin-top: 40px;
  padding-bottom: 30px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__wrap {
    width: min(100%, 300px);
    display: grid;
    row-gap: 10px;
    padding-block: 0;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec1__wrap {
    margin-top: 30px;
  }
}

.p-service-infinity-function-sec1__item {
  z-index: 3;
  filter: drop-shadow(0 0 10px rgba(1, 102, 201, 0.58));
  position: absolute;
  display: grid;
  align-items: center;
  --numWidthSize: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__item {
    --numWidthSize: 44px;
    position: relative;
    top: unset;
    right: unset;
    bottom: unset;
    left: unset;
    width: fit-content;
  }
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec1__item {
    --numWidthSize: 44px;
  }
}
.p-service-infinity-function-sec1__item:nth-of-type(1), .p-service-infinity-function-sec1__item:nth-of-type(4) {
  grid-template-columns: fit-content(100%) var(--numWidthSize);
  grid-template-areas: "head num";
}
.p-service-infinity-function-sec1__item:nth-of-type(2), .p-service-infinity-function-sec1__item:nth-of-type(5), .p-service-infinity-function-sec1__item:nth-of-type(6) {
  grid-template-columns: var(--numWidthSize) fit-content(100%);
  grid-template-areas: "num head";
}
.p-service-infinity-function-sec1__item:nth-of-type(1) {
  top: 12%;
  left: 0.018%;
}
.p-service-infinity-function-sec1__item:nth-of-type(2) {
  top: 0;
  right: 7%;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__item:nth-of-type(2) {
    grid-template-columns: fit-content(100%) var(--numWidthSize);
    grid-template-areas: "head num";
    margin-inline: auto;
  }
}
.p-service-infinity-function-sec1__item:nth-of-type(4) {
  top: 65%;
  left: 0;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__item:nth-of-type(4) {
    grid-template-columns: var(--numWidthSize) fit-content(100%);
    grid-template-areas: "num head";
    margin-left: auto;
  }
}
.p-service-infinity-function-sec1__item:nth-of-type(5) {
  top: 37%;
  right: 0;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__item:nth-of-type(5) {
    margin-inline: auto;
  }
}
.p-service-infinity-function-sec1__item:nth-of-type(6) {
  bottom: 0;
  right: 3%;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__item:nth-of-type(1), .p-service-infinity-function-sec1__item:nth-of-type(2), .p-service-infinity-function-sec1__item:nth-of-type(4), .p-service-infinity-function-sec1__item:nth-of-type(5), .p-service-infinity-function-sec1__item:nth-of-type(6) {
    inset: unset;
  }
}

.p-service-infinity-function-sec1__head {
  z-index: -1;
  grid-area: head;
  display: grid;
  place-content: center;
  min-height: 48px;
  background-color: #0A5BAA;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  min-width: clamp(150px, 14.5833333333vw, 280px);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__head {
    font-size: 12px;
    min-width: 155px;
    min-height: 34px;
  }
}

.p-service-infinity-function-sec1__head--s {
  font-size: clamp(10px, 0.9027777778vw, 13px);
}

.p-service-infinity-function-sec1__item:nth-of-type(1) .p-service-infinity-function-sec1__head, .p-service-infinity-function-sec1__item:nth-of-type(4) .p-service-infinity-function-sec1__head {
  border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  margin-right: -15px;
}
.p-service-infinity-function-sec1__item:nth-of-type(2) .p-service-infinity-function-sec1__head, .p-service-infinity-function-sec1__item:nth-of-type(5) .p-service-infinity-function-sec1__head, .p-service-infinity-function-sec1__item:nth-of-type(6) .p-service-infinity-function-sec1__head {
  border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  margin-left: -15px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__item:nth-of-type(2) .p-service-infinity-function-sec1__head {
    border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
    margin-left: 0px;
    margin-right: -15px;
  }
  .p-service-infinity-function-sec1__item:nth-of-type(4) .p-service-infinity-function-sec1__head {
    border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
    margin-right: 0px;
    margin-left: -15px;
  }
}

.p-service-infinity-function-sec1__num {
  grid-area: num;
  aspect-ratio: 1;
  background-color: #0A5BAA;
  border-radius: calc(infinity * 1px);
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(12px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec1__num {
    font-size: 12px;
  }
}

.p-service-infinity-function-sec1__center {
  --circleSize: 25%;
  --circleSizeMax: max(130px, var(--circleSize));
  position: relative;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__center {
    --circleSize: 130px;
  }
}
.p-service-infinity-function-sec1__center::after {
  z-index: 2;
  content: "";
  position: absolute;
  top: 44%;
  left: 49.5%;
  translate: -50% -50%;
  aspect-ratio: 330/300;
  width: 330px;
  width: auto;
  height: 110%;
  background: url("../img/service/service_function_bg_02.png") no-repeat center center/contain;
}

.p-service-infinity-function-sec1__center--lines {
  z-index: 1;
  position: absolute;
  top: 49%;
  left: 50%;
  translate: -50% -50%;
  display: block;
  aspect-ratio: 488/363;
  width: auto;
  height: 135%;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-function-sec1__center--lines {
    display: none;
  }
}

.p-service-infinity-function-sec1__center--txt {
  position: relative;
  z-index: 2;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  display: grid;
  place-content: center;
  text-align: center;
  line-height: 1;
  color: var(--color-txt-black);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  background: url("../img/service/service_function_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec1__center--txt {
    --circleSize: 130px;
    font-size: 16px;
    width: var(--circleSize);
  }
}

.p-service-infinity-function-sec1__center--shadow {
  z-index: 1;
  position: absolute;
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  animation: pulseMotion 2.4s linear infinite;
}

.p-service-infinity-function-sec2__list {
  counter-reset: number 0;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec2__list {
    margin-top: 40px;
    padding-inline: 20px;
  }
}

.p-service-infinity-function-sec2__item {
  --numberSize: auto;
  --iconSize: 30px;
  counter-increment: number 1;
  display: grid;
  grid-template-columns: var(--numberSize) 1fr var(--iconSize);
  column-gap: clamp(20px, 3.125vw, 45px);
  color: var(--color-txt-black);
  padding-top: 20px;
  padding-right: 20px;
  padding-bottom: 20px;
  padding-left: 30px;
  transition: all 0.3s ease;
  transition-property: padding;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec2__item {
    --iconSize: 10px;
  }
}
.p-service-infinity-function-sec2__item::before {
  content: counter(number, decimal-leading-zero);
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: 30px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec2__item::before {
    font-size: 17px;
  }
}
.p-service-infinity-function-sec2__item::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/contain;
  transition: all 0.3s ease;
  transition-property: rotate;
}
.p-service-infinity-function-sec2__item.isActive {
  padding-bottom: 30px;
}
.p-service-infinity-function-sec2__item.isActive::after {
  rotate: -180deg;
}
.p-service-infinity-function-sec2__item:nth-of-type(1) {
  background-color: #fff;
}
.p-service-infinity-function-sec2__item:nth-of-type(2) {
  background-color: rgba(255, 255, 255, 0.8);
}
.p-service-infinity-function-sec2__item:nth-of-type(3) {
  background-color: rgba(255, 255, 255, 0.7);
}
.p-service-infinity-function-sec2__item:nth-of-type(4) {
  background-color: rgba(255, 255, 255, 0.6);
}
.p-service-infinity-function-sec2__item:nth-of-type(5) {
  background-color: rgba(255, 255, 255, 0.5);
}
.p-service-infinity-function-sec2__item:nth-of-type(6) {
  background-color: rgba(255, 255, 255, 0.4);
}
.p-service-infinity-function-sec2__item:nth-of-type(7) {
  background-color: rgba(255, 255, 255, 0.3);
}

.p-service-infinity-function-sec2__item--txt {
  cursor: pointer;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  align-self: center;
  font-size: clamp(12px, 1.1805555556vw, 17px);
}

.p-service-infinity-function-sec2__item.isActive .p-service-infinity-function-sec2__item--txt {
  display: block;
}

.p-service-infinity-function-sec2__cta {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-function-sec2__cta {
    margin-top: 40px;
  }
}

.p-service-infinity-compare {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-compare {
    margin-top: 160px;
  }
}

.p-service-infinity-compare__container {
  --paddingSize: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-compare__container {
    margin-top: 44px;
    overflow-x: auto;
    padding-right: 20px;
    margin-right: calc(50% - 50vw);
  }
}

.p-service-infinity-compare__inner {
  position: relative;
  box-shadow: 0 0 2px rgba(1, 102, 201, 0.54);
  border-radius: 3px;
  border: 1px solid var(--color-border-primary);
  background: url("../img/service/service_compare_bg_01.png") no-repeat center center/cover;
  background-position: right bottom;
  padding: var(--paddingSize);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-compare__inner {
    width: 1000px;
  }
}

.p-service-infinity-compare__table {
  display: grid;
}
.p-service-infinity-compare__table thead,
.p-service-infinity-compare__table tbody,
.p-service-infinity-compare__table tfoot,
.p-service-infinity-compare__table tr {
  display: contents;
}
.p-service-infinity-compare__table th,
.p-service-infinity-compare__table td {
  display: block;
  letter-spacing: 0.16em;
}
.p-service-infinity-compare__table th {
  text-align: center;
  font-weight: bold;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  line-height: 1.5;
  padding-block: 20px;
}
.p-service-infinity-compare__table td {
  color: var(--color-txt-black);
  font-weight: 500;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  line-height: 1.5;
  padding-block: 20px;
  padding-left: 30px;
  padding-right: 10px;
}
.p-service-infinity-compare__table {
  /* 列をつくる */
  grid-template-columns: repeat(3, auto);
  --border: 1px dotted var(--color-border-white);
}
.p-service-infinity-compare__table th:not(:first-of-type) {
  border-left: var(--border);
}
.p-service-infinity-compare__table td:first-of-type {
  border-top: var(--border);
}
.p-service-infinity-compare__table td:not(:first-of-type) {
  border-top: var(--border);
  border-left: var(--border);
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--center {
  text-align: center;
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--good {
  display: grid;
  grid-template-columns: 27px 1fr;
  column-gap: 10px;
  align-items: center;
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--good::before {
  content: "";
  aspect-ratio: 1;
  background: url("../img/service/service_icon_good.png") no-repeat center center/contain;
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--bad {
  display: grid;
  grid-template-columns: 23px 1fr;
  column-gap: 7px;
  align-items: center;
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--bad::before {
  content: "";
  aspect-ratio: 1;
  background: url("../img/service/service_icon_bad.png") no-repeat center center/contain;
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--small {
  font-size: 13px;
}
.p-service-infinity-compare__table .p-service-infinity-compare__table--lh1 {
  line-height: 1;
}

.p-service-infinity-compare__btns {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-compare__btns {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    margin-top: 8px;
  }
}

.p-service-infinity-compare__btn {
  aspect-ratio: 1;
  width: 26px;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  box-shadow: 0 0 3px #4B95AF;
  background: url("../img/common/common_icon_arrow_right_primary.png") no-repeat center center/contain;
  background-color: var(--color-bg-white);
  background-size: 12px;
}

.p-service-infinity-compare__btn--left {
  rotate: 180deg;
}

.p-service-infinity-compare__body {
  line-height: 1.6;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-compare__body {
    margin-top: 32px;
  }
}

.p-service-infinity-compare__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-compare__cta {
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-infinity-compare__cta {
    display: flex;
    flex-direction: column;
    row-gap: 14px;
  }
}

.p-service-infinity-case {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-case {
    margin-top: 160px;
  }
}

.p-service-infinity-case__list {
  counter-reset: number 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: clamp(10px, 1.6666666667vw, 32px);
  margin-top: 90px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-case__list {
    margin-top: 80px;
    display: flex;
    flex-direction: column;
    row-gap: 57px;
    align-items: center;
  }
}

.p-service-infinity-case__item {
  counter-increment: number 1;
  position: relative;
  border: 1px solid var(--color-border-primary);
  background-color: rgba(255, 255, 255, 0.9);
  color: var(--color-txt-black);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-case__item {
    width: min(100%, 250px);
  }
}
.p-service-infinity-case__item::before {
  position: absolute;
  top: 0;
  left: 50%;
  aspect-ratio: 1;
  width: 62px;
  translate: -50% -50%;
  content: counter(number, decimal-leading-zero);
  color: var(--color-txt-white);
  display: grid;
  place-content: center;
  background-color: var(--color-bg-primary);
  border-radius: calc(infinity * 1px);
  font-weight: bold;
  font-size: 20px;
  line-height: 1;
}

.p-service-infinity-case__ttl {
  font-weight: bold;
  text-align: center;
  font-size: clamp(23px, 1.7361111111vw, 25px);
  letter-spacing: 0.16em;
  line-height: 1;
}

.p-service-infinity-case__img {
  aspect-ratio: 188/103;
  max-width: 188px;
  margin-inline: auto;
  margin-top: 26px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-case__img {
    margin-top: 14px;
  }
}

.p-service-infinity-case__body {
  text-align: center;
  font-weight: 500;
  line-height: 1.6;
  font-size: 15px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-case__body {
    margin-top: 15px;
  }
}

.p-service-infinity-price {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price {
    margin-top: 160px;
  }
}

.p-service-infinity-price__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__list {
    grid-template-columns: 1fr;
    row-gap: 24px;
    padding-inline: 50px;
    margin-top: 40px;
  }
}

.p-service-infinity-price__item {
  position: relative;
  background: url("../img/service/service_price_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  grid-column: span 2;
  border: 2px solid var(--color-bg-primary);
  border-radius: 3px;
  padding: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__item {
    grid-column: span 1;
    padding: 20px;
  }
}
.p-service-infinity-price__item:nth-of-type(3) {
  grid-column: 2/4;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__item:nth-of-type(3) {
    grid-area: span 1;
  }
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__item::after {
    content: "";
    position: absolute;
    top: 15px;
    right: 11px;
    aspect-ratio: 1;
    width: 12px;
    background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
    transition: all 0.3s ease;
    transition-property: rotate;
  }
}
.p-service-infinity-price__item.isActive::after {
  rotate: -180deg;
}

.p-service-infinity-price__head {
  display: block;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(17px, 1.3888888889vw, 20px);
  width: min(100%, 250px);
  border-radius: 3px;
  padding: 15px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__head {
    width: min(100%, 160px);
  }
}

@media screen and (max-width: 767px) {
  .p-service-infinity-price__body {
    display: grid;
    grid-template-rows: 0fr;
    transition: all 0.3s ease;
    transition-property: grid-template-rows;
  }
}

@media screen and (max-width: 767px) {
  .p-service-infinity-price__item.isActive .p-service-infinity-price__body {
    grid-template-rows: 1fr;
  }
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__body--inner {
    overflow: hidden;
  }
}
.p-service-infinity-price__body--inner2 {
  color: var(--color-txt-black);
  padding-top: 25px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__body--inner2 {
    padding-top: 15px;
    padding-bottom: 20px;
  }
}

.p-service-infinity-price__body--price {
  display: flex;
  align-items: end;
  justify-content: center;
  font-weight: bold;
  column-gap: 10px;
  line-height: 1.5;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__body--price {
    font-size: 15px;
  }
}

.p-service-infinity-price__price--strong {
  font-size: clamp(17px, 1.7361111111vw, 25px);
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__price--strong {
    font-size: 25px;
  }
}

.p-service-infinity-price__body--list {
  display: grid;
  row-gap: 10px;
  justify-content: center;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__body--list {
    margin-top: 20px;
  }
}

.p-service-infinity-price__body--item {
  font-weight: bold;
  line-height: 1.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-price__body--item {
    font-size: 15px;
  }
}

.p-service-infinity-price__body--large {
  font-size: clamp(15px, 1.25vw, 18px);
  line-height: 2;
  text-align: center;
  font-weight: bold;
}

.p-service-infinity-flow {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow {
    margin-top: 160px;
  }
}

.p-service-infinity-flow__list {
  --rowGapSize: 60px;
  --columnGapSize: -26px;
  --paddingEmptySize: clamp(0px, 150 / 1440 * 100vw, 150px);
  display: flex;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__list {
    grid-template-columns: 1fr;
    row-gap: var(--rowGapSize);
    flex-direction: column;
  }
}
.p-service-infinity-flow__list:nth-of-type(1) {
  padding-right: var(--paddingEmptySize);
  margin-top: 100px;
  margin-left: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__list:nth-of-type(1) {
    margin-top: 80px;
    margin-left: 0;
  }
}
.p-service-infinity-flow__list:nth-of-type(2) {
  justify-items: end;
  padding-left: var(--paddingEmptySize);
  margin-top: var(--rowGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__list:nth-of-type(1), .p-service-infinity-flow__list:nth-of-type(2) {
    padding-inline: 0;
  }
}
.p-service-infinity-flow__list > *:nth-of-type(2) {
  margin-left: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__list > *:nth-of-type(2) {
    margin-left: auto;
  }
}

.p-service-infinity-flow__item {
  width: min(100%, 364px);
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__item {
    width: min(100%, 230px);
    margin-inline: auto;
  }
}

.p-service-infinity-flow__item--wrap {
  display: grid;
  align-content: center;
  background: url("../img/service/service_flow_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  clip-path: polygon(0 0, calc(100% - 55px) 0, 100% 50%, calc(100% - 55px) 100%, 0 100%);
  height: 100%;
  min-height: 250px;
  padding-block: 20px;
  padding-right: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__item--wrap {
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 20px), 50% 100%, 0 calc(100% - 20px));
    min-height: 156px;
    padding-top: 24px;
    padding-bottom: 30px;
    padding-inline: 10px;
  }
}

@media screen and (max-width: 767px) {
  .p-service-infinity-flow__list:last-of-type .p-service-infinity-flow__item:last-of-type .p-service-infinity-flow__item--wrap {
    clip-path: none;
  }
}
.p-service-infinity-flow__body {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__body {
    line-height: 1.5;
  }
}

.p-service-infinity-flow__desc {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 14px;
}

.p-service-infinity-flow__count {
  z-index: 1;
  --circleSize: 97px;
  position: absolute;
  top: 0;
  left: calc(50% - 20px);
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  place-content: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__count {
    --circleSize: 58px;
    left: 0;
    translate: -25% -45%;
  }
}

.p-service-infinity-flow__count--txt {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(13px, 1.0416666667vw, 15px);
}
@media screen and (max-width: 767px) {
  .p-service-infinity-flow__count--txt {
    font-size: 14px;
  }
}

.p-service-infinity-flow__count--num {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(17px, 2.2222222222vw, 32px);
}

.p-service-infinity-contact {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-contact {
    padding-inline: 20px;
    margin-top: 160px;
  }
}

.p-service-infinity-contact__body {
  font-weight: bold;
  text-align: center;
  line-height: 2.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-contact__body {
    line-height: 1.6;
    margin-top: 20px;
  }
}

.p-service-infinity-contact__wrap {
  border: 2px solid var(--color-border-primary);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-contact__wrap {
    margin-top: 50px;
  }
}

.p-service-infinity-faq {
  margin-top: 200px;
  margin-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-faq {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-service-infinity-faq__list {
  display: grid;
  row-gap: clamp(20px, 2.7777777778vw, 40px);
  background-color: var(--color-bg-gray);
  border-radius: 17px;
  padding-inline: clamp(20px, 3.4722222222vw, 50px);
  padding-block: clamp(20px, 3.4722222222vw, 50px);
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-faq__list {
    margin-top: 20px;
    border-radius: 3px;
    margin-inline: 20px;
  }
}

.p-service-infinity-faq__item {
  --columnGapSize: 20px;
  --iconFontSize: 50px;
  cursor: pointer;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__item {
    --columnGapSize: 8px;
    --iconFontSize: 25px;
  }
}

.p-service-infinity-faq__item--q {
  --iconSize: 20px;
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr var(--iconSize);
  align-items: center;
  column-gap: var(--columnGapSize);
  color: var(--color-txt-black);
  padding: 16px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__item--q {
    --iconSize: 10px;
    padding: 16px 10px;
  }
}
.p-service-infinity-faq__item--q::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
  transition: all 0.3s ease;
  transition-property: rotate;
}

.p-service-infinity-faq__item.isActive .p-service-infinity-faq__item--q::after {
  rotate: -180deg;
}

.p-service-infinity-faq__q--txt {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__q--txt {
    font-size: 15px;
  }
}
.p-service-infinity-faq__q--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 23px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__q--txt::after {
    height: 17px;
  }
}

.p-service-infinity-faq__q--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-faq__q--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-infinity-faq__item--a {
  display: grid;
  grid-template-rows: 0fr;
  transition: all 0.3s ease;
  transition-property: grid-template-rows;
}

.p-service-infinity-faq__item.isActive .p-service-infinity-faq__item--a {
  grid-template-rows: 1fr;
}

.p-service-infinity-faq__a--inner {
  overflow: hidden;
}

.p-service-infinity-faq__a--inner2 {
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  border-radius: 3px;
  padding: 32px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__a--inner2 {
    padding: 12px 10px;
  }
}

.p-service-infinity-faq__a--txt {
  position: relative;
  font-weight: bold;
  color: var(--color-txt-white);
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__a--txt {
    font-size: 15px;
  }
}
.p-service-infinity-faq__a--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 40px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 949px) {
  .p-service-infinity-faq__a--txt::after {
    height: 17px;
  }
}

.p-service-infinity-faq__a--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-faq__a--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-infinity-faq__cta {
  display: flex;
  justify-content: center;
  column-gap: 42px;
  row-gap: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-faq__cta {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: center;
    row-gap: 20px;
    margin-top: 80px;
  }
}

.p-service-infinity-faq__cta--link {
  --iconSize: 20px;
  --textWidthSize: auto;
  display: grid;
  grid-template-columns: var(--iconSize) var(--textWidthSize);
  align-items: center;
  justify-content: center;
  column-gap: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(15px, 1.25vw, 18px);
  width: min(100%, 309px);
  height: 100px;
  border-radius: 3px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-service-infinity-faq__cta--link {
    --iconSize: 14px;
    --textWidthSize: 165px;
    font-size: 15px;
    height: 67px;
    justify-content: center;
  }
}
.p-service-infinity-faq__cta--link::before {
  content: "";
  aspect-ratio: 1;
  transition: all 0.4s ease;
  transition-property: background-image;
}
.p-service-infinity-faq__cta--link:focus-visible {
  background-color: var(--color-bg-white);
  color: var(--color);
}
@media (any-hover: hover) {
  .p-service-infinity-faq__cta--link:hover {
    background-color: var(--color-bg-white);
    color: var(--color);
  }
}

.p-service-infinity-faq__cta--contact {
  --color: var(--color-primary);
  background-color: var(--color);
}
.p-service-infinity-faq__cta--contact::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-infinity-faq__cta--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
}
@media (any-hover: hover) {
  .p-service-infinity-faq__cta--contact:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
  }
}

.p-service-infinity-faq__cta--download {
  --color: #636363;
  background-color: var(--color);
}
.p-service-infinity-faq__cta--download::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-infinity-faq__cta--download:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
}
@media (any-hover: hover) {
  .p-service-infinity-faq__cta--download:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
  }
}

.p-service-harmony-mv {
  position: relative;
  display: grid;
  align-items: center;
  min-height: calc(100svh - var(--header-height));
  height: fit-content;
  padding-block: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-mv {
    padding-block: 20px;
  }
}

.p-service-harmony-mv__bg {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-service-harmony-mv__bg > img {
  height: 100%;
}

.p-service-harmony-mv__inner {
  z-index: 1;
  position: relative;
  color: var(--color-txt-white);
  padding-left: 6vw;
  padding-right: 20px;
}

.p-service-harmony-mv__name {
  color: rgba(1, 102, 201, 0.15);
  line-height: 1;
  font-weight: bold;
  letter-spacing: 0.08em;
  font-size: clamp(50px, 8.3333333333vw, 120px);
  margin-bottom: -40px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-mv__name {
    font-size: 35px;
    margin-bottom: 0;
  }
}

.p-service-harmony-mv__head {
  position: relative;
  display: inline;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.08em;
  color: var(--color-txt-white);
  font-size: clamp(23px, 2.4305555556vw, 35px);
  background-image: linear-gradient(to right, #0166C9 0%, #91C9FF 57%, #2287EB 100%);
  background-repeat: no-repeat;
  background-position: left 100%;
  background-size: 0 clamp(13px, 1.8055555556vw, 26px);
  animation: expand 1.2s forwards;
  animation-delay: 400ms;
}
.p-service-harmony-mv__head::before {
  content: "“";
  position: absolute;
  top: 0;
  left: 0;
  translate: -100% -20%;
  color: var(--color-txt-white);
  font-weight: bold;
  line-height: 1;
  font-size: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-mv__head::before {
    translate: -30% -60%;
    font-size: 50px;
  }
}

@keyframes expand {
  from {
    background-size: 0% clamp(13px, 1.8055555556vw, 26px);
  }
  to {
    background-size: 100% clamp(13px, 1.8055555556vw, 26px);
  }
}
.p-service-harmony-mv__body {
  color: var(--color-txt-white);
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 17px;
  margin-top: 28px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-mv__body {
    line-height: 1.8;
    font-size: 15px;
    margin-top: 20px;
  }
}

.p-service-harmony-mv__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-mv__cta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-harmony-mv__cta {
    display: flex;
  }
}

.p-service-harmony-mv__cta--btn {
  display: block;
  position: relative;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: bold;
  line-height: 1;
  width: min(100%, 240px);
  font-size: clamp(15px, 1.3888888889vw, 20px);
  border-radius: 3px;
  padding-block: 21px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-mv__cta--btn {
    font-size: 15px;
    padding-block: 16px;
    width: min(100%, 152px);
  }
}
.p-service-harmony-mv__cta--btn::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  height: 100%;
  border-left: 1px solid var(--color-border-primary);
  border-bottom: 1px solid var(--color-border-primary);
  top: 6px;
  left: -6px;
}
.p-service-harmony-mv__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-service-harmony-mv__cta--btn:hover {
    opacity: 0.8;
  }
}

.p-service-harmony-mv__scroll {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-mv__scroll {
    --barHeightSize: 40px;
    display: grid;
    grid-template-rows: var(--barHeightSize) auto;
    row-gap: 3px;
    justify-items: center;
    margin-top: 50px;
  }
}

.p-service-harmony-mv__scroll--bar {
  position: relative;
  background-color: var(--color-bg-primary);
  width: 2px;
  border-radius: calc(infinity * 1px);
}
.p-service-harmony-mv__scroll--bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: 6px;
  box-shadow: 0 0 2px 3px rgba(1, 102, 201, 0.22);
  background-color: var(--color-bg-primary);
  animation: scrollBall linear 4s infinite;
}

@keyframes scrollBall {
  0% {
    opacity: 1;
    top: 0%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 100%;
  }
}
.p-service-harmony-mv__scroll--txt {
  text-align: center;
  color: var(--color-txt-primary);
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.p-service-harmony-about {
  margin-top: 200px;
}
@media screen and (max-width: 576px) {
  .p-service-harmony-about {
    margin-top: 50px;
  }
}

.p-service-harmony-about__box1 {
  --circleSize: 230px;
  display: grid;
  grid-template-areas: "icon head" "icon desc";
  grid-template-columns: var(--circleSize) 1fr;
  column-gap: 50px;
  row-gap: 27px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about__box1 {
    --circleSize: 160px;
    row-gap: 0;
    padding-inline: 0;
    grid-template: "icon" auto "." 25px "head" auto "." 14px "desc" auto/1fr;
  }
}

.p-service-harmony-about-box1__icon {
  --iconSize: 93px;
  grid-area: icon;
  align-self: center;
  position: relative;
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 18px;
  place-content: center;
  border-radius: calc(infinity * 1px);
  background: url("../img/service/service_about_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box1__icon {
    --iconSize: 46px;
    justify-self: center;
  }
}
.p-service-harmony-about-box1__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  aspect-ratio: 1;
  width: calc(var(--circleSize) + 50px);
  border: 1px solid var(--color-border-primary);
  border-radius: calc(infinity * 1px);
  clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);
  animation: spin 5s linear infinite;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box1__icon::before {
    width: calc(var(--circleSize) + 25px);
  }
}

.p-service-harmony-about-box1__icon--img {
  height: 100%;
  aspect-ratio: 1;
  justify-self: center;
}
.p-service-harmony-about-box1__icon--img > img {
  height: 100%;
  object-fit: contain;
}

.p-service-harmony-about-box1__ttl {
  text-align: center;
  line-height: 1.4;
  font-weight: bold;
  color: var(--color-txt-primary);
  letter-spacing: 0.02em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box1__ttl {
    text-align: center;
    font-size: 12px;
  }
}

.p-service-harmony-about-box2__head {
  grid-area: head;
  font-weight: bold;
  line-height: 1;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  letter-spacing: 0.08em;
  align-self: end;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__head {
    text-align: center;
    line-height: 1.2;
  }
}
.p-service-harmony-about-box2__head > span {
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__head > span {
    text-align: center;
    line-height: 1;
  }
}

.p-service-harmony-about-box2__desc {
  grid-area: desc;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__desc {
    font-size: 13px;
    line-height: 2.3;
    padding-inline: 19px;
  }
}

.p-service-harmony-about-box2 {
  color: var(--color-txt-black);
  background: url("../img/service/service_about_bg_02.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  padding-inline: 20px;
  padding-block: clamp(30px, 3.4722222222vw, 50px);
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2 {
    margin-top: 50px;
  }
}

.p-service-harmony-about-box2__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-harmony-about-box2__wrap {
  max-width: 660px;
  border-top: 1px solid var(--color-border-black);
  display: grid;
  grid-template-columns: repeat(3, auto);
  justify-content: center;
  column-gap: 20px;
  align-items: center;
  padding-top: 14px;
  margin-top: 17px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__wrap {
    text-align: center;
    grid-template-columns: 1fr;
    row-gap: 8px;
    justify-items: center;
  }
}

.p-service-harmony-about-box2__txt1 {
  --rectangleSize: 11px;
  --columnGapSize: 6px;
  display: grid;
  grid-template-columns: var(--rectangleSize) auto;
  column-gap: var(--columnGapSize);
  align-items: center;
  font-weight: bold;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__txt1 {
    display: block;
  }
}
.p-service-harmony-about-box2__txt1::before {
  content: "";
  display: block;
  background-color: var(--color-bg-black);
  aspect-ratio: 1;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__txt1::before {
    content: none;
  }
}

.p-service-harmony-about-box2__line {
  width: 59px;
  height: 2px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box2__line {
    width: 2px;
    height: 15px;
  }
}

.p-service-harmony-about-box2__txt2 {
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;
  max-width: 325px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-harmony-about-box2__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
  margin-top: 27px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-about-box2__list {
    grid-template-columns: repeat(4, 1fr);
  }
  .p-service-harmony-about-box2__list > * {
    grid-column: span 2;
  }
  .p-service-harmony-about-box2__list > *:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-harmony-about-box2__item {
  display: grid;
}
.p-service-harmony-about-box2__item > * {
  margin-top: 0;
  align-content: center;
}

.p-service-harmony-about-box2__ttl2 {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.3;
  font-size: clamp(13px, 1.25vw, 18px);
}

.p-service-harmony-about-box3 {
  text-align: center;
  margin-top: 66px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about-box3 {
    border-radius: 30px 0 30px 0;
    padding-top: 27px;
    padding-inline: 20px;
    padding-bottom: 54px;
    margin-top: 48px;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    background: linear-gradient(135deg, rgba(1, 102, 201, 0.75) 0%, rgba(209, 235, 255, 0.75) 100%);
  }
}

.p-service-harmony-about__txt1 {
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.25;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-harmony-about__txt2 {
  position: relative;
  font-weight: 500;
  line-height: 2;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  margin-top: 18px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about__txt2 {
    padding-top: 11px;
    margin-top: 15px;
  }
  .p-service-harmony-about__txt2::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    translate: -50% 0;
    width: 28px;
    height: 1px;
    background-color: var(--color-bg-white);
  }
}

.p-service-harmony-about__cta {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-about__cta {
    margin-top: 0;
    translate: 0 -50%;
  }
}

.p-service-harmony-issue {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-issue {
    margin-top: 160px;
  }
}

.p-service-harmony-issue__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-harmony-issue__ttl > span {
  z-index: 1;
  display: inline;
  background: linear-gradient(transparent 70%, var(--color-bg-primary) 0%);
  position: relative;
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-harmony-issue__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(24px, 3.4722222222vw, 50px);
  max-width: 885px;
  margin-top: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-issue__list {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 30px;
  }
}

.p-service-harmony-issue__item {
  display: grid;
  grid-column: span 2;
  grid-template-rows: subgrid;
  grid-template-columns: 1fr;
  grid-row: span 3;
  row-gap: 20px;
  border-radius: 3px;
  background-color: var(--color-bg-gray);
  border: 3px solid var(--color-border-primary);
  color: var(--color-txt-black);
  justify-items: center;
  padding-top: clamp(10px, 1.7361111111vw, 25px);
  padding-bottom: clamp(20px, 3.8194444444vw, 55px);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-issue__item {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .p-service-harmony-issue__item:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-harmony-issue__head {
  text-align: center;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  align-self: center;
}

.p-service-harmony-issue__icon {
  aspect-ratio: 1;
  width: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-issue__icon {
    width: 80px;
  }
}

.p-service-harmony-issue__body {
  text-align: center;
  letter-spacing: 0.08em;
  line-height: 1.2;
  font-size: clamp(11px, 1.0416666667vw, 15px);
}

.p-service-harmony-issue__desc {
  font-weight: 500px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 2.4;
  text-align: center;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-issue__desc {
    line-height: 1.5;
    margin-top: 30px;
  }
}

.p-service-harmony-solution {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-solution {
    margin-top: 160px;
  }
}

.p-service-harmony-solution__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-harmony-solution__ttl > span {
  z-index: 1;
  display: inline-block;
  position: relative;
  font-size: 23px;
}

.p-service-harmony-solution__inner {
  --dotSize: 13px;
  --columnGapSize: 18px;
  padding-left: calc(var(--dotSize) + var(--columnGapSize));
  display: grid;
  grid-template-columns: 1fr clamp(200px, 27.7777777778vw, 400px);
  gap: 27px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-solution__inner {
    --dotSize: 8px;
    grid-template-columns: 1fr;
    margin-top: 24px;
    padding-right: 30px;
  }
}

.p-service-harmony-solution__head {
  display: grid;
  grid-template-columns: var(--dotSize) 1fr;
  column-gap: var(--columnGapSize);
  margin-left: calc(-1 * (var(--dotSize) + var(--columnGapSize)));
  font-size: clamp(17px, 1.7361111111vw, 25px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-solution__head {
    align-items: center;
  }
}
.p-service-harmony-solution__head::before {
  content: "";
  position: relative;
  top: 0.5em;
  aspect-ratio: 1;
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 79%);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-solution__head::before {
    top: 0;
    background-color: var(--color-bg-primary);
    box-shadow: 0 0 7px rgba(1, 102, 201, 0.5);
    background-image: none;
  }
}

.p-service-harmony-solution__body {
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 1.8;
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-solution__body {
    margin-top: 11px;
  }
}

.p-service-harmony-solution__r {
  aspect-ratio: 400/265;
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
  max-height: 265px;
}
.p-service-harmony-solution__r > img {
  height: 100%;
}

.p-service-harmony-solution__cta {
  display: flex;
  justify-content: center;
  column-gap: 28px;
  row-gap: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-solution__cta {
    flex-direction: column;
    align-items: center;
    margin-top: 32px;
  }
}

.p-service-harmony-feature {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature {
    margin-top: 160px;
  }
}

.p-service-harmony-feature__list {
  display: grid;
  row-gap: 100px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__list {
    row-gap: 60px;
    padding-inline: 30px;
    margin-top: 40px;
  }
}

.p-service-harmony-feature__item {
  --numberFontSize: clamp(30px, 70 / 1440 * 100vw, 70px);
  --columnGapSize: 40px;
}

.p-service-harmony-feature__top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__top {
    grid-template-columns: 1fr;
    row-gap: 20px;
  }
}

.p-service-harmony-feature__num {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: var(--numberFontSize);
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  padding-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__num {
    width: fit-content;
  }
}
.p-service-harmony-feature__num::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 0;
  height: 2px;
  width: 26px;
  background-color: var(--color-bg-primary);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__num::before {
    width: 19px;
  }
}

.p-service-harmony-feature__ttl {
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.16em;
}

.p-service-harmony-feature__ttl--head {
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-harmony-feature__ttl--desc {
  font-size: clamp(13px, 1.1805555556vw, 17px);
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__ttl--desc {
    margin-top: 10px;
  }
}

.p-service-harmony-feature__btm {
  --bodyWidthSize: 363px;
  --imgWidthSize: min(100%, 360px);
  display: flex;
  column-gap: 40px;
  padding-left: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__btm {
    --bodyWidthSize: 100%;
    flex-direction: column;
    row-gap: 10px;
    padding-left: 0;
    margin-top: 20px;
  }
}

.p-service-harmony-feature__item:nth-of-type(even) .p-service-harmony-feature__btm {
  flex-direction: row-reverse;
  justify-content: start;
  padding-left: calc(var(--columnGapSize) + var(--numberFontSize) * 1.2);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__item:nth-of-type(even) .p-service-harmony-feature__btm {
    flex-direction: column;
    padding-left: 0;
  }
}

.p-service-harmony-feature__img {
  border-radius: 3px;
  overflow: hidden;
  width: var(--imgWidthSize);
  aspect-ratio: 360/215;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-feature__img {
    justify-self: center;
  }
}
.p-service-harmony-feature__img > img {
  height: 100%;
}

.p-service-harmony-feature__body {
  width: var(--bodyWidthSize);
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-harmony-tool {
  margin-top: 200px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-tool {
    margin-top: 160px;
  }
}

.p-service-harmony-tool__container {
  --paddingSize: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-tool__container {
    margin-top: 44px;
    overflow-x: auto;
    padding-right: 20px;
    margin-right: calc(50% - 50vw);
  }
}

.p-service-harmony-tool__inner {
  position: relative;
  box-shadow: 0 0 2px rgba(1, 102, 201, 0.55);
  border-radius: 3px;
  border: 1px solid var(--color-border-primary);
  background: url("../img/service/service_tools_bg_01.png") no-repeat center center/cover;
  background-position: right bottom;
  padding: var(--paddingSize);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-tool__inner {
    width: 1000px;
  }
}

.p-service-harmony-tool__dl {
  position: relative;
  display: grid;
  grid-template-columns: 280px 1fr;
}
.p-service-harmony-tool__dl:not(:first-of-type) {
  border-top: 1px dotted var(--color-border-white);
}

.p-service-harmony-tool__dt {
  color: var(--color-txt-white);
  align-self: center;
  display: grid;
  place-content: center;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.16em;
  line-height: 1;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  padding-inline: 17px;
  padding-block: 40px;
}

.p-service-harmony-tool__dd {
  align-content: center;
  height: 100%;
  color: var(--color-txt-black);
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.4;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  border-left: 1px solid var(--color-border-white);
  padding-left: 20px;
  padding-block: 10px;
}

.p-service-harmony-tool__dt--slash {
  color: var(--color-txt-primary);
}

.p-service-harmony-tool__btns {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-tool__btns {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    margin-top: 8px;
  }
}

.p-service-harmony-tool__btn {
  aspect-ratio: 1;
  width: 26px;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  box-shadow: 0 0 3px #4B95AF;
  background: url("../img/common/common_icon_arrow_right_primary.png") no-repeat center center/contain;
  background-color: var(--color-bg-white);
  background-size: 12px;
}

.p-service-harmony-tool__btn--left {
  rotate: 180deg;
}

.p-service-harmony-function {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function {
    margin-top: 160px;
  }
}

.p-service-harmony-function-sec1__wrap {
  position: relative;
  padding-top: 60px;
  margin-top: 40px;
  padding-bottom: 30px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__wrap {
    width: min(100%, 300px);
    display: grid;
    row-gap: 10px;
    padding-block: 0;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec1__wrap {
    margin-top: 30px;
  }
}

.p-service-harmony-function-sec1__item {
  z-index: 3;
  filter: drop-shadow(0 0 10px rgba(1, 102, 201, 0.58));
  position: absolute;
  display: grid;
  align-items: center;
  --numWidthSize: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__item {
    --numWidthSize: 44px;
    position: relative;
    top: unset;
    right: unset;
    bottom: unset;
    left: unset;
    width: fit-content;
  }
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec1__item {
    --numWidthSize: 44px;
  }
}
.p-service-harmony-function-sec1__item:nth-of-type(1), .p-service-harmony-function-sec1__item:nth-of-type(4) {
  grid-template-columns: fit-content(100%) var(--numWidthSize);
  grid-template-areas: "head num";
}
.p-service-harmony-function-sec1__item:nth-of-type(2), .p-service-harmony-function-sec1__item:nth-of-type(5), .p-service-harmony-function-sec1__item:nth-of-type(6) {
  grid-template-columns: var(--numWidthSize) fit-content(100%);
  grid-template-areas: "num head";
}
.p-service-harmony-function-sec1__item:nth-of-type(1) {
  top: 12%;
  left: 0.018%;
}
.p-service-harmony-function-sec1__item:nth-of-type(2) {
  top: 0;
  right: 7%;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__item:nth-of-type(2) {
    grid-template-columns: fit-content(100%) var(--numWidthSize);
    grid-template-areas: "head num";
    margin-inline: auto;
  }
}
.p-service-harmony-function-sec1__item:nth-of-type(4) {
  top: 65%;
  left: 0;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__item:nth-of-type(4) {
    grid-template-columns: var(--numWidthSize) fit-content(100%);
    grid-template-areas: "num head";
    margin-left: auto;
  }
}
.p-service-harmony-function-sec1__item:nth-of-type(5) {
  top: 37%;
  right: 0;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__item:nth-of-type(5) {
    margin-inline: auto;
  }
}
.p-service-harmony-function-sec1__item:nth-of-type(6) {
  bottom: 0;
  right: 3%;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__item:nth-of-type(1), .p-service-harmony-function-sec1__item:nth-of-type(2), .p-service-harmony-function-sec1__item:nth-of-type(4), .p-service-harmony-function-sec1__item:nth-of-type(5), .p-service-harmony-function-sec1__item:nth-of-type(6) {
    inset: unset;
  }
}

.p-service-harmony-function-sec1__head {
  z-index: -1;
  grid-area: head;
  display: grid;
  place-content: center;
  min-height: 48px;
  background-color: #0A5BAA;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  min-width: clamp(150px, 14.5833333333vw, 280px);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__head {
    font-size: 12px;
    min-width: 155px;
    min-height: 34px;
  }
}

.p-service-harmony-function-sec1__head--s {
  font-size: clamp(10px, 0.9027777778vw, 13px);
}

.p-service-harmony-function-sec1__item:nth-of-type(1) .p-service-harmony-function-sec1__head, .p-service-harmony-function-sec1__item:nth-of-type(4) .p-service-harmony-function-sec1__head {
  border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  margin-right: -15px;
}
.p-service-harmony-function-sec1__item:nth-of-type(2) .p-service-harmony-function-sec1__head, .p-service-harmony-function-sec1__item:nth-of-type(5) .p-service-harmony-function-sec1__head, .p-service-harmony-function-sec1__item:nth-of-type(6) .p-service-harmony-function-sec1__head {
  border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  margin-left: -15px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__item:nth-of-type(2) .p-service-harmony-function-sec1__head {
    border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
    margin-left: 0px;
    margin-right: -15px;
  }
  .p-service-harmony-function-sec1__item:nth-of-type(4) .p-service-harmony-function-sec1__head {
    border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
    margin-right: 0px;
    margin-left: -15px;
  }
}

.p-service-harmony-function-sec1__num {
  grid-area: num;
  aspect-ratio: 1;
  background-color: #0A5BAA;
  border-radius: calc(infinity * 1px);
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(12px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec1__num {
    font-size: 12px;
  }
}

.p-service-harmony-function-sec1__center {
  --circleSize: 25%;
  --circleSizeMax: max(130px, var(--circleSize));
  position: relative;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__center {
    --circleSize: 130px;
  }
}
.p-service-harmony-function-sec1__center::after {
  z-index: 2;
  content: "";
  position: absolute;
  top: 44%;
  left: 49.5%;
  translate: -50% -50%;
  aspect-ratio: 330/300;
  width: 330px;
  width: auto;
  height: 110%;
  background: url("../img/service/service_function_bg_02.png") no-repeat center center/contain;
}

.p-service-harmony-function-sec1__center--lines {
  z-index: 1;
  position: absolute;
  top: 49%;
  left: 50%;
  translate: -50% -50%;
  display: block;
  aspect-ratio: 488/363;
  width: auto;
  height: 135%;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-function-sec1__center--lines {
    display: none;
  }
}

.p-service-harmony-function-sec1__center--txt {
  position: relative;
  z-index: 2;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  display: grid;
  place-content: center;
  text-align: center;
  line-height: 1;
  color: var(--color-txt-black);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  background: url("../img/service/service_function_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec1__center--txt {
    --circleSize: 130px;
    font-size: 16px;
    width: var(--circleSize);
  }
}

.p-service-harmony-function-sec1__center--shadow {
  z-index: 1;
  position: absolute;
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  animation: pulseMotion 2.4s linear infinite;
}

.p-service-harmony-function-sec2__list {
  counter-reset: number 0;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec2__list {
    margin-top: 40px;
    padding-inline: 20px;
  }
}

.p-service-harmony-function-sec2__item {
  --numberSize: auto;
  --iconSize: 30px;
  counter-increment: number 1;
  display: grid;
  grid-template-columns: var(--numberSize) 1fr var(--iconSize);
  column-gap: clamp(20px, 3.125vw, 45px);
  color: var(--color-txt-black);
  padding-top: 20px;
  padding-right: 20px;
  padding-bottom: 20px;
  padding-left: 30px;
  transition: all 0.3s ease;
  transition-property: padding;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec2__item {
    --iconSize: 10px;
  }
}
.p-service-harmony-function-sec2__item::before {
  content: counter(number, decimal-leading-zero);
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: 30px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec2__item::before {
    font-size: 17px;
  }
}
.p-service-harmony-function-sec2__item::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/contain;
  transition: all 0.3s ease;
  transition-property: rotate;
}
.p-service-harmony-function-sec2__item.isActive {
  padding-bottom: 30px;
}
.p-service-harmony-function-sec2__item.isActive::after {
  rotate: -180deg;
}
.p-service-harmony-function-sec2__item:nth-of-type(1) {
  background-color: #fff;
}
.p-service-harmony-function-sec2__item:nth-of-type(2) {
  background-color: rgba(255, 255, 255, 0.8);
}
.p-service-harmony-function-sec2__item:nth-of-type(3) {
  background-color: rgba(255, 255, 255, 0.7);
}
.p-service-harmony-function-sec2__item:nth-of-type(4) {
  background-color: rgba(255, 255, 255, 0.6);
}
.p-service-harmony-function-sec2__item:nth-of-type(5) {
  background-color: rgba(255, 255, 255, 0.5);
}
.p-service-harmony-function-sec2__item:nth-of-type(6) {
  background-color: rgba(255, 255, 255, 0.4);
}
.p-service-harmony-function-sec2__item:nth-of-type(7) {
  background-color: rgba(255, 255, 255, 0.3);
}

.p-service-harmony-function-sec2__item--txt {
  cursor: pointer;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  align-self: center;
  font-size: clamp(12px, 1.1805555556vw, 17px);
}

.p-service-harmony-function-sec2__item.isActive .p-service-harmony-function-sec2__item--txt {
  display: block;
}

.p-service-harmony-function-sec2__cta {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-function-sec2__cta {
    margin-top: 40px;
  }
}

.p-service-harmony-compare {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-compare {
    margin-top: 160px;
  }
}

.p-service-harmony-compare__container {
  --paddingSize: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-compare__container {
    margin-top: 44px;
    overflow-x: auto;
    padding-right: 20px;
    margin-right: calc(50% - 50vw);
  }
}

.p-service-harmony-compare__inner {
  position: relative;
  box-shadow: 0 0 2px rgba(1, 102, 201, 0.54);
  border-radius: 3px;
  border: 1px solid var(--color-border-primary);
  background: url("../img/service/service_compare_bg_01.png") no-repeat center center/cover;
  background-position: right bottom;
  padding: var(--paddingSize);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-compare__inner {
    width: 1000px;
  }
}

.p-service-harmony-compare__table {
  display: grid;
}
.p-service-harmony-compare__table thead,
.p-service-harmony-compare__table tbody,
.p-service-harmony-compare__table tfoot,
.p-service-harmony-compare__table tr {
  display: contents;
}
.p-service-harmony-compare__table th,
.p-service-harmony-compare__table td {
  display: block;
  letter-spacing: 0.16em;
}
.p-service-harmony-compare__table th {
  text-align: center;
  font-weight: bold;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  line-height: 1.5;
  padding-block: 20px;
}
.p-service-harmony-compare__table td {
  color: var(--color-txt-black);
  font-weight: 500;
  font-size: clamp(18px, 1.3888888889vw, 20px);
  line-height: 1.5;
  padding-block: 20px;
  padding-left: 30px;
  padding-right: 10px;
}
.p-service-harmony-compare__table {
  /* 列をつくる */
  grid-template-columns: repeat(3, auto);
  --border: 1px dotted var(--color-border-white);
}
.p-service-harmony-compare__table th:not(:first-of-type) {
  border-left: var(--border);
}
.p-service-harmony-compare__table td:first-of-type {
  border-top: var(--border);
}
.p-service-harmony-compare__table td:not(:first-of-type) {
  border-top: var(--border);
  border-left: var(--border);
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--center {
  text-align: center;
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--good {
  display: grid;
  grid-template-columns: 27px 1fr;
  column-gap: 10px;
  align-items: center;
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--good::before {
  content: "";
  aspect-ratio: 1;
  background: url("../img/service/service_icon_good.png") no-repeat center center/contain;
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--bad {
  display: grid;
  grid-template-columns: 23px 1fr;
  column-gap: 7px;
  align-items: center;
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--bad::before {
  content: "";
  aspect-ratio: 1;
  background: url("../img/service/service_icon_bad.png") no-repeat center center/contain;
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--small {
  font-size: 13px;
}
.p-service-harmony-compare__table .p-service-harmony-compare__table--lh1 {
  line-height: 1;
}

.p-service-harmony-compare__btns {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-compare__btns {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    margin-top: 8px;
  }
}

.p-service-harmony-compare__btn {
  aspect-ratio: 1;
  width: 26px;
  border-radius: calc(infinity * 1px);
  border: 1px solid var(--color-border-primary);
  box-shadow: 0 0 3px #4B95AF;
  background: url("../img/common/common_icon_arrow_right_primary.png") no-repeat center center/contain;
  background-color: var(--color-bg-white);
  background-size: 12px;
}

.p-service-harmony-compare__btn--left {
  rotate: 180deg;
}

.p-service-harmony-compare__body {
  line-height: 1.6;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-compare__body {
    margin-top: 32px;
  }
}

.p-service-harmony-compare__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-compare__cta {
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-harmony-compare__cta {
    display: flex;
    flex-direction: column;
    row-gap: 14px;
  }
}

.p-service-harmony-case {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-case {
    margin-top: 160px;
  }
}

.p-service-harmony-case__list {
  counter-reset: number 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: clamp(10px, 1.6666666667vw, 32px);
  margin-top: 90px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-case__list {
    margin-top: 80px;
    display: flex;
    flex-direction: column;
    row-gap: 57px;
    align-items: center;
  }
}

.p-service-harmony-case__item {
  counter-increment: number 1;
  position: relative;
  border: 1px solid var(--color-border-primary);
  background-color: rgba(255, 255, 255, 0.9);
  color: var(--color-txt-black);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-case__item {
    width: min(100%, 300px);
  }
}
.p-service-harmony-case__item::before {
  position: absolute;
  top: 0;
  left: 50%;
  aspect-ratio: 1;
  width: 62px;
  translate: -50% -50%;
  content: counter(number, decimal-leading-zero);
  color: var(--color-txt-white);
  display: grid;
  place-content: center;
  background-color: var(--color-bg-primary);
  border-radius: calc(infinity * 1px);
  font-weight: bold;
  font-size: 20px;
  line-height: 1;
}

.p-service-harmony-case__ttl {
  font-weight: bold;
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.16em;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-case__ttl {
    font-size: 23px;
  }
}

.p-service-harmony-case__img {
  aspect-ratio: 188/103;
  max-width: 188px;
  margin-inline: auto;
  margin-top: 26px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-case__img {
    margin-top: 14px;
  }
}

.p-service-harmony-case__body {
  text-align: center;
  font-weight: 500;
  line-height: 1.6;
  font-size: 15px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-case__body {
    margin-top: 15px;
  }
}

.p-service-harmony-price {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-price {
    margin-top: 160px;
  }
}

.p-service-harmony-price__item {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 251px;
  column-gap: 10px;
  background: url("../img/service/service_price_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border: 2px solid var(--color-bg-primary);
  width: min(100%, 840px);
  border-radius: 3px;
  padding-block: 30px;
  padding-left: 70px;
  padding-right: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-price__item {
    grid-template-columns: 1fr;
    padding: 20px;
    width: min(100%, 300px);
    margin-inline: auto;
    margin-top: 60px;
  }
}

.p-service-harmony-price__item--left {
  width: 280px;
  display: grid;
  align-content: center;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-price__item--left {
    width: min(100%, 280px);
    margin-inline: auto;
    justify-items: center;
  }
}

.p-service-harmony-price__head {
  display: block;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(17px, 1.3888888889vw, 20px);
  width: min(100%, 278px);
  border-radius: 3px;
  padding: 15px;
}

.p-service-harmony-price__body--price {
  display: flex;
  align-items: end;
  justify-content: center;
  color: var(--color-txt-black);
  font-weight: bold;
  column-gap: 10px;
  line-height: 1.5;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-price__body--price {
    font-size: 15px;
    margin-top: 24px;
  }
}

.p-service-harmony-price__price--strong {
  font-size: clamp(17px, 1.7361111111vw, 25px);
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-price__price--strong {
    font-size: 25px;
  }
}

.p-service-harmony-price__item--img {
  aspect-ratio: 251/174;
  max-width: 251px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-price__item--img {
    margin-top: 16px;
  }
}
.p-service-harmony-price__item--img > img {
  height: 100%;
}

.p-service-harmony-flow {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow {
    margin-top: 160px;
  }
}

.p-service-harmony-flow__list {
  --rowGapSize: 60px;
  --columnGapSize: -26px;
  --paddingEmptySize: clamp(0px, 150 / 1440 * 100vw, 150px);
  display: flex;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__list {
    grid-template-columns: 1fr;
    row-gap: var(--rowGapSize);
    flex-direction: column;
  }
}
.p-service-harmony-flow__list:nth-of-type(1) {
  padding-right: var(--paddingEmptySize);
  margin-top: 100px;
  margin-left: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__list:nth-of-type(1) {
    margin-top: 80px;
    margin-left: 0;
  }
}
.p-service-harmony-flow__list:nth-of-type(2) {
  justify-items: end;
  padding-left: var(--paddingEmptySize);
  margin-top: var(--rowGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__list:nth-of-type(1), .p-service-harmony-flow__list:nth-of-type(2) {
    padding-inline: 0;
  }
}
.p-service-harmony-flow__list > *:nth-of-type(2) {
  margin-left: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__list > *:nth-of-type(2) {
    margin-left: auto;
  }
}

.p-service-harmony-flow__item {
  width: min(100%, 364px);
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__item {
    width: min(100%, 230px);
    margin-inline: auto;
  }
}

.p-service-harmony-flow__item--wrap {
  display: grid;
  align-content: center;
  background: url("../img/service/service_flow_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  clip-path: polygon(0 0, calc(100% - 55px) 0, 100% 50%, calc(100% - 55px) 100%, 0 100%);
  height: 100%;
  min-height: 250px;
  padding-block: 20px;
  padding-right: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__item--wrap {
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 20px), 50% 100%, 0 calc(100% - 20px));
    min-height: 156px;
    padding-top: 24px;
    padding-bottom: 30px;
    padding-inline: 10px;
    padding-right: 0;
  }
}

@media screen and (max-width: 767px) {
  .p-service-harmony-flow__list:last-of-type .p-service-harmony-flow__item:last-of-type .p-service-harmony-flow__item--wrap {
    clip-path: none;
  }
}
.p-service-harmony-flow__body {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__body {
    line-height: 1.5;
  }
}

.p-service-harmony-flow__desc {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 14px;
}

.p-service-harmony-flow__count {
  z-index: 1;
  --circleSize: 97px;
  position: absolute;
  top: 0;
  left: calc(50% - 20px);
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  place-content: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__count {
    --circleSize: 58px;
    left: 0;
    translate: -25% -45%;
  }
}

.p-service-harmony-flow__count--txt {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(13px, 1.0416666667vw, 15px);
}
@media screen and (max-width: 767px) {
  .p-service-harmony-flow__count--txt {
    font-size: 14px;
  }
}

.p-service-harmony-flow__count--num {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(17px, 2.2222222222vw, 32px);
}

.p-service-harmony-contact {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-contact {
    padding-inline: 20px;
    margin-top: 160px;
  }
}

.p-service-harmony-contact__body {
  font-weight: bold;
  text-align: center;
  line-height: 2.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-contact__body {
    line-height: 1.6;
    margin-top: 20px;
  }
}

.p-service-harmony-contact__wrap {
  border: 2px solid var(--color-border-primary);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-contact__wrap {
    margin-top: 50px;
  }
}

.p-service-harmony-faq {
  margin-top: 200px;
  margin-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-faq {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-service-harmony-faq__list {
  display: grid;
  row-gap: clamp(20px, 2.7777777778vw, 40px);
  background-color: var(--color-bg-gray);
  border-radius: 17px;
  padding-inline: clamp(20px, 3.4722222222vw, 50px);
  padding-block: clamp(20px, 3.4722222222vw, 50px);
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-faq__list {
    margin-top: 20px;
    border-radius: 3px;
    margin-inline: 20px;
  }
}

.p-service-harmony-faq__item {
  --columnGapSize: 20px;
  --iconFontSize: 50px;
  cursor: pointer;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__item {
    --columnGapSize: 8px;
    --iconFontSize: 25px;
  }
}

.p-service-harmony-faq__item--q {
  --iconSize: 20px;
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr var(--iconSize);
  align-items: center;
  column-gap: var(--columnGapSize);
  color: var(--color-txt-black);
  padding: 16px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__item--q {
    --iconSize: 10px;
    padding: 16px 10px;
  }
}
.p-service-harmony-faq__item--q::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
  transition: all 0.3s ease;
  transition-property: rotate;
}

.p-service-harmony-faq__item.isActive .p-service-harmony-faq__item--q::after {
  rotate: -180deg;
}

.p-service-harmony-faq__q--txt {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__q--txt {
    font-size: 15px;
  }
}
.p-service-harmony-faq__q--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 23px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__q--txt::after {
    height: 17px;
  }
}

.p-service-harmony-faq__q--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-faq__q--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-harmony-faq__item--a {
  display: grid;
  grid-template-rows: 0fr;
  transition: all 0.3s ease;
  transition-property: grid-template-rows;
}

.p-service-harmony-faq__item.isActive .p-service-harmony-faq__item--a {
  grid-template-rows: 1fr;
}

.p-service-harmony-faq__a--inner {
  overflow: hidden;
}

.p-service-harmony-faq__a--inner2 {
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  border-radius: 3px;
  padding: 32px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__a--inner2 {
    padding: 12px 10px;
  }
}

.p-service-harmony-faq__a--txt {
  position: relative;
  font-weight: bold;
  color: var(--color-txt-white);
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__a--txt {
    font-size: 15px;
  }
}
.p-service-harmony-faq__a--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 40px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 949px) {
  .p-service-harmony-faq__a--txt::after {
    height: 17px;
  }
}

.p-service-harmony-faq__a--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-faq__a--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-harmony-faq__cta {
  display: flex;
  justify-content: center;
  column-gap: 42px;
  row-gap: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-faq__cta {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: center;
    row-gap: 20px;
    margin-top: 80px;
  }
}

.p-service-harmony-faq__cta--link {
  --iconSize: 20px;
  --textWidthSize: auto;
  display: grid;
  grid-template-columns: var(--iconSize) var(--textWidthSize);
  align-items: center;
  justify-content: center;
  column-gap: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(15px, 1.25vw, 18px);
  width: min(100%, 309px);
  height: 100px;
  border-radius: 3px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-service-harmony-faq__cta--link {
    --iconSize: 14px;
    --textWidthSize: 165px;
    font-size: 15px;
    height: 67px;
    justify-content: center;
  }
}
.p-service-harmony-faq__cta--link::before {
  content: "";
  aspect-ratio: 1;
  transition: all 0.4s ease;
  transition-property: background-image;
}
.p-service-harmony-faq__cta--link:focus-visible {
  background-color: var(--color-bg-white);
  color: var(--color);
}
@media (any-hover: hover) {
  .p-service-harmony-faq__cta--link:hover {
    background-color: var(--color-bg-white);
    color: var(--color);
  }
}

.p-service-harmony-faq__cta--contact {
  --color: var(--color-primary);
  background-color: var(--color);
}
.p-service-harmony-faq__cta--contact::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-harmony-faq__cta--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
}
@media (any-hover: hover) {
  .p-service-harmony-faq__cta--contact:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
  }
}

.p-service-harmony-faq__cta--download {
  --color: #636363;
  background-color: var(--color);
}
.p-service-harmony-faq__cta--download::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-harmony-faq__cta--download:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
}
@media (any-hover: hover) {
  .p-service-harmony-faq__cta--download:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
  }
}

.p-service-deep-mv {
  position: relative;
  display: grid;
  align-items: center;
  min-height: calc(100svh - var(--header-height));
  height: fit-content;
  padding-block: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-mv {
    padding-block: 20px;
  }
}

.p-service-deep-mv__bg {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-service-deep-mv__bg > img {
  height: 100%;
}

.p-service-deep-mv__inner {
  z-index: 1;
  position: relative;
  color: var(--color-txt-white);
  padding-left: 6vw;
  padding-right: 20px;
}

.p-service-deep-mv__name {
  color: rgba(1, 102, 201, 0.15);
  line-height: 1;
  font-weight: bold;
  letter-spacing: 0.08em;
  font-size: clamp(50px, 8.3333333333vw, 120px);
  margin-bottom: -40px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-mv__name {
    font-size: 35px;
    margin-bottom: 0;
  }
}

.p-service-deep-mv__head {
  position: relative;
  display: inline;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.08em;
  color: var(--color-txt-white);
  font-size: clamp(23px, 2.4305555556vw, 35px);
  background-image: linear-gradient(to right, #0166C9 0%, #91C9FF 57%, #2287EB 100%);
  background-repeat: no-repeat;
  background-position: left 100%;
  background-size: 0 clamp(13px, 1.8055555556vw, 26px);
  animation: expand 1.2s forwards;
  animation-delay: 400ms;
}
.p-service-deep-mv__head::before {
  content: "“";
  position: absolute;
  top: 0;
  left: 0;
  translate: -100% -20%;
  color: var(--color-txt-white);
  font-weight: bold;
  line-height: 1;
  font-size: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-mv__head::before {
    translate: -30% -60%;
    font-size: 50px;
  }
}

@keyframes expand {
  from {
    background-size: 0% clamp(13px, 1.8055555556vw, 26px);
  }
  to {
    background-size: 100% clamp(13px, 1.8055555556vw, 26px);
  }
}
.p-service-deep-mv__body {
  color: var(--color-txt-white);
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 17px;
  margin-top: 28px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-mv__body {
    line-height: 1.8;
    font-size: 15px;
    margin-top: 20px;
  }
}

.p-service-deep-mv__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-mv__cta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-deep-mv__cta {
    display: flex;
  }
}

.p-service-deep-mv__cta--btn {
  display: block;
  position: relative;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: bold;
  line-height: 1;
  width: min(100%, 240px);
  font-size: clamp(15px, 1.3888888889vw, 20px);
  border-radius: 3px;
  padding-block: 21px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-service-deep-mv__cta--btn {
    font-size: 15px;
    padding-block: 16px;
    width: min(100%, 152px);
  }
}
.p-service-deep-mv__cta--btn::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  height: 100%;
  border-left: 1px solid var(--color-border-primary);
  border-bottom: 1px solid var(--color-border-primary);
  top: 6px;
  left: -6px;
}
.p-service-deep-mv__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-service-deep-mv__cta--btn:hover {
    opacity: 0.8;
  }
}

.p-service-deep-mv__scroll {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-deep-mv__scroll {
    --barHeightSize: 40px;
    display: grid;
    grid-template-rows: var(--barHeightSize) auto;
    row-gap: 3px;
    justify-items: center;
    margin-top: 50px;
  }
}

.p-service-deep-mv__scroll--bar {
  position: relative;
  background-color: var(--color-bg-primary);
  width: 2px;
  border-radius: calc(infinity * 1px);
}
.p-service-deep-mv__scroll--bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: 6px;
  box-shadow: 0 0 2px 3px rgba(1, 102, 201, 0.22);
  background-color: var(--color-bg-primary);
  animation: scrollBall linear 4s infinite;
}

@keyframes scrollBall {
  0% {
    opacity: 1;
    top: 0%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 100%;
  }
}
.p-service-deep-mv__scroll--txt {
  text-align: center;
  color: var(--color-txt-primary);
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.p-service-deep-about {
  margin-top: 200px;
}
@media screen and (max-width: 576px) {
  .p-service-deep-about {
    margin-top: 50px;
  }
}

.p-service-deep-about__box1 {
  --circleSize: 230px;
  display: grid;
  grid-template-areas: "icon head" "icon desc";
  grid-template-columns: var(--circleSize) 1fr;
  column-gap: 50px;
  row-gap: 27px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about__box1 {
    --circleSize: 160px;
    row-gap: 0;
    padding-inline: 0;
    grid-template: "icon" auto "." 25px "head" auto "." 14px "desc" auto/1fr;
  }
}

.p-service-deep-about-box1__icon {
  --iconSize: 93px;
  grid-area: icon;
  align-self: center;
  position: relative;
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 18px;
  place-content: center;
  border-radius: calc(infinity * 1px);
  background: url("../img/service/service_about_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box1__icon {
    --iconSize: 46px;
    justify-self: center;
  }
}
.p-service-deep-about-box1__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  aspect-ratio: 1;
  width: calc(var(--circleSize) + 50px);
  border: 1px solid var(--color-border-primary);
  border-radius: calc(infinity * 1px);
  clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);
  animation: spin 5s linear infinite;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box1__icon::before {
    width: calc(var(--circleSize) + 25px);
  }
}

.p-service-deep-about-box1__icon--img {
  height: 100%;
  aspect-ratio: 1;
  justify-self: center;
}
.p-service-deep-about-box1__icon--img > img {
  height: 100%;
  object-fit: contain;
}

.p-service-deep-about-box1__ttl {
  text-align: center;
  line-height: 1.4;
  font-weight: bold;
  color: var(--color-txt-primary);
  letter-spacing: 0.02em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box1__ttl {
    text-align: center;
    font-size: 12px;
  }
}

.p-service-deep-about-box2__head {
  grid-area: head;
  font-weight: bold;
  line-height: 1.2;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  letter-spacing: 0.08em;
  align-self: end;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__head {
    text-align: center;
  }
}
.p-service-deep-about-box2__head > span {
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__head > span {
    text-align: center;
    line-height: 1;
  }
}

.p-service-deep-about-box2__desc {
  grid-area: desc;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__desc {
    font-size: 13px;
    line-height: 2.3;
    padding-inline: 19px;
  }
}

.p-service-deep-about-box2 {
  color: var(--color-txt-black);
  background: url("../img/service/service_about_bg_02.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  padding-inline: 20px;
  padding-block: clamp(30px, 3.4722222222vw, 50px);
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2 {
    margin-top: 50px;
  }
}

.p-service-deep-about-box2__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-deep-about-box2__wrap {
  max-width: 660px;
  border-top: 1px solid var(--color-border-black);
  display: grid;
  grid-template-columns: repeat(3, auto);
  justify-content: center;
  column-gap: 20px;
  align-items: center;
  padding-top: 14px;
  margin-top: 17px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__wrap {
    text-align: center;
    grid-template-columns: 1fr;
    row-gap: 8px;
    justify-items: center;
  }
}

.p-service-deep-about-box2__txt1 {
  --rectangleSize: 11px;
  --columnGapSize: 6px;
  display: grid;
  grid-template-columns: var(--rectangleSize) auto;
  column-gap: var(--columnGapSize);
  align-items: center;
  font-weight: bold;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__txt1 {
    display: block;
  }
}
.p-service-deep-about-box2__txt1::before {
  content: "";
  display: block;
  background-color: var(--color-bg-black);
  aspect-ratio: 1;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__txt1::before {
    content: none;
  }
}

.p-service-deep-about-box2__line {
  width: 59px;
  height: 2px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .p-service-deep-about-box2__line {
    width: 2px;
    height: 15px;
  }
}

.p-service-deep-about-box2__txt2 {
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;
  max-width: 325px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-deep-about__cta {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-about__cta {
    margin-top: 32px;
  }
}

.p-service-deep-issue {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-issue {
    margin-top: 160px;
  }
}

.p-service-deep-issue__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-deep-issue__ttl > span {
  z-index: 1;
  display: inline;
  background: linear-gradient(transparent 70%, var(--color-bg-primary) 0%);
  position: relative;
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-deep-issue__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(24px, 3.4722222222vw, 50px);
  max-width: 885px;
  margin-top: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-deep-issue__list {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 30px;
  }
}

.p-service-deep-issue__item {
  display: grid;
  grid-column: span 2;
  grid-template-rows: subgrid;
  grid-template-columns: 1fr;
  grid-row: span 3;
  row-gap: 20px;
  border-radius: 3px;
  background-color: var(--color-bg-gray);
  border: 3px solid var(--color-border-primary);
  color: var(--color-txt-black);
  justify-items: center;
  padding-top: clamp(10px, 1.7361111111vw, 25px);
  padding-inline: 10px;
  padding-bottom: clamp(20px, 3.8194444444vw, 55px);
}
@media screen and (max-width: 767px) {
  .p-service-deep-issue__item {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .p-service-deep-issue__item:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-deep-issue__head {
  text-align: center;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  align-self: center;
}

.p-service-deep-issue__icon {
  aspect-ratio: 1;
  width: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-issue__icon {
    width: 80px;
  }
}

.p-service-deep-issue__body {
  text-align: center;
  letter-spacing: 0.08em;
  line-height: 1.2;
  font-size: clamp(11px, 1.0416666667vw, 15px);
}

.p-service-deep-issue__desc {
  font-weight: 500px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 2.4;
  text-align: center;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-issue__desc {
    line-height: 1.5;
    margin-top: 30px;
  }
}

.p-service-deep-solution {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-solution {
    margin-top: 160px;
  }
}

.p-service-deep-solution__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-deep-solution__ttl > span {
  z-index: 1;
  display: inline-block;
  position: relative;
  font-size: 23px;
}

.p-service-deep-solution__inner {
  --dotSize: 13px;
  --columnGapSize: 18px;
  padding-left: calc(var(--dotSize) + var(--columnGapSize));
  display: grid;
  grid-template-columns: 1fr clamp(200px, 27.7777777778vw, 400px);
  gap: 27px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-solution__inner {
    --dotSize: 8px;
    grid-template-columns: 1fr;
    margin-top: 24px;
    padding-right: 30px;
  }
}

.p-service-deep-solution__head {
  display: grid;
  grid-template-columns: var(--dotSize) 1fr;
  column-gap: var(--columnGapSize);
  margin-left: calc(-1 * (var(--dotSize) + var(--columnGapSize)));
  font-size: clamp(17px, 1.7361111111vw, 25px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-service-deep-solution__head {
    align-items: center;
  }
}
.p-service-deep-solution__head::before {
  content: "";
  position: relative;
  top: 0.5em;
  aspect-ratio: 1;
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 79%);
}
@media screen and (max-width: 767px) {
  .p-service-deep-solution__head::before {
    top: 0;
    background-color: var(--color-bg-primary);
    box-shadow: 0 0 7px rgba(1, 102, 201, 0.5);
    background-image: none;
  }
}

.p-service-deep-solution__body {
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 1.8;
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-solution__body {
    margin-top: 11px;
  }
}

.p-service-deep-solution__r {
  aspect-ratio: 400/265;
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
  max-height: 265px;
}
.p-service-deep-solution__r > img {
  height: 100%;
}

.p-service-deep-solution__cta {
  display: flex;
  justify-content: center;
  column-gap: 28px;
  row-gap: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-solution__cta {
    flex-direction: column;
    align-items: center;
    margin-top: 32px;
  }
}

.p-service-deep-feature {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature {
    margin-top: 160px;
  }
}

.p-service-deep-feature__list {
  display: grid;
  row-gap: 100px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__list {
    row-gap: 60px;
    padding-inline: 30px;
    margin-top: 40px;
  }
}

.p-service-deep-feature__top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  align-items: center;
  column-gap: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__top {
    grid-template-columns: 1fr;
    row-gap: 20px;
  }
}

.p-service-deep-feature__num {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: clamp(30px, 4.8611111111vw, 70px);
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  padding-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__num {
    width: fit-content;
  }
}
.p-service-deep-feature__num::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 0;
  height: 2px;
  width: 26px;
  background-color: var(--color-bg-primary);
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__num::before {
    width: 19px;
  }
}

.p-service-deep-feature__ttl {
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.16em;
}

.p-service-deep-feature__ttl--head {
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-deep-feature__ttl--desc {
  font-size: clamp(13px, 1.1805555556vw, 17px);
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__ttl--desc {
    margin-top: 10px;
  }
}

.p-service-deep-feature__btm {
  --bodyWidthSize: 363px;
  --imgWidthSize: min(100%, 360px);
  display: flex;
  column-gap: 40px;
  padding-left: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__btm {
    --bodyWidthSize: 100%;
    flex-direction: column;
    row-gap: 10px;
    padding-left: 0;
    margin-top: 20px;
  }
}

.p-service-deep-feature__item:nth-of-type(even) .p-service-deep-feature__btm {
  flex-direction: row-reverse;
  justify-content: end;
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__item:nth-of-type(even) .p-service-deep-feature__btm {
    flex-direction: column;
  }
}

.p-service-deep-feature__img {
  border-radius: 3px;
  overflow: hidden;
  width: var(--imgWidthSize);
  aspect-ratio: 360/215;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-deep-feature__img {
    justify-self: center;
  }
}
.p-service-deep-feature__img > img {
  height: 100%;
}

.p-service-deep-feature__body {
  flex: 1;
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-deep-function {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function {
    margin-top: 160px;
  }
}

.p-service-deep-function-sec1__wrap {
  position: relative;
  padding-top: 60px;
  margin-top: 40px;
  padding-bottom: 30px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__wrap {
    width: min(100%, 300px);
    display: grid;
    row-gap: 10px;
    padding-block: 0;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec1__wrap {
    margin-top: 30px;
  }
}

.p-service-deep-function-sec1__item {
  --textBoxSize: fit-content(100%);
  z-index: 3;
  filter: drop-shadow(0 0 10px rgba(1, 102, 201, 0.58));
  position: absolute;
  display: grid;
  align-items: center;
  --numWidthSize: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__item {
    --numWidthSize: 44px;
    --textBoxSize: 165px;
    position: relative;
    top: unset;
    right: unset;
    bottom: unset;
    left: unset;
    width: fit-content;
  }
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec1__item {
    --numWidthSize: 44px;
  }
}
.p-service-deep-function-sec1__item:nth-of-type(1), .p-service-deep-function-sec1__item:nth-of-type(4) {
  grid-template-columns: var(--textBoxSize) var(--numWidthSize);
  grid-template-areas: "head num";
}
.p-service-deep-function-sec1__item:nth-of-type(2), .p-service-deep-function-sec1__item:nth-of-type(5), .p-service-deep-function-sec1__item:nth-of-type(6) {
  grid-template-columns: var(--numWidthSize) var(--textBoxSize);
  grid-template-areas: "num head";
}
.p-service-deep-function-sec1__item:nth-of-type(1) {
  top: 12%;
  left: 0.018%;
}
.p-service-deep-function-sec1__item:nth-of-type(2) {
  top: 0;
  right: 7%;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__item:nth-of-type(2) {
    grid-template-columns: var(--textBoxSize) var(--numWidthSize);
    grid-template-areas: "head num";
    margin-inline: auto;
  }
}
.p-service-deep-function-sec1__item:nth-of-type(4) {
  top: 65%;
  left: 0;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__item:nth-of-type(4) {
    grid-template-columns: var(--numWidthSize) var(--textBoxSize);
    grid-template-areas: "num head";
    margin-left: auto;
  }
}
.p-service-deep-function-sec1__item:nth-of-type(5) {
  top: 37%;
  right: 0;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__item:nth-of-type(5) {
    margin-inline: auto;
  }
}
.p-service-deep-function-sec1__item:nth-of-type(6) {
  bottom: 0;
  right: 3%;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__item:nth-of-type(1), .p-service-deep-function-sec1__item:nth-of-type(2), .p-service-deep-function-sec1__item:nth-of-type(4), .p-service-deep-function-sec1__item:nth-of-type(5), .p-service-deep-function-sec1__item:nth-of-type(6) {
    inset: unset;
  }
}

.p-service-deep-function-sec1__head {
  grid-area: head;
  background-color: #0A5BAA;
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  min-height: 48px;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  min-width: clamp(150px, 14.5833333333vw, 280px);
  max-width: 280px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__head {
    font-size: 12px;
    min-width: 155px;
    min-height: 34px;
    padding-block: 8px;
  }
}

.p-service-deep-function-sec1__item:nth-of-type(1) .p-service-deep-function-sec1__head, .p-service-deep-function-sec1__item:nth-of-type(4) .p-service-deep-function-sec1__head {
  border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  margin-right: -15px;
}
.p-service-deep-function-sec1__item:nth-of-type(2) .p-service-deep-function-sec1__head, .p-service-deep-function-sec1__item:nth-of-type(5) .p-service-deep-function-sec1__head, .p-service-deep-function-sec1__item:nth-of-type(6) .p-service-deep-function-sec1__head {
  border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  margin-left: -15px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__item:nth-of-type(2) .p-service-deep-function-sec1__head {
    border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
    margin-left: 0px;
    margin-right: -15px;
  }
  .p-service-deep-function-sec1__item:nth-of-type(4) .p-service-deep-function-sec1__head {
    border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
    margin-right: 0px;
    margin-left: -15px;
  }
}

.p-service-deep-function-sec1__num {
  grid-area: num;
  aspect-ratio: 1;
  background-color: #0A5BAA;
  border-radius: calc(infinity * 1px);
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(12px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec1__num {
    font-size: 12px;
  }
}

.p-service-deep-function-sec1__center {
  --circleSize: 25%;
  --circleSizeMax: max(130px, var(--circleSize));
  position: relative;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__center {
    --circleSize: 130px;
  }
}
.p-service-deep-function-sec1__center::after {
  z-index: 2;
  content: "";
  position: absolute;
  top: 44%;
  left: 49.5%;
  translate: -50% -50%;
  aspect-ratio: 330/300;
  width: 330px;
  width: auto;
  height: 110%;
  background: url("../img/service/service_function_bg_02.png") no-repeat center center/contain;
}

.p-service-deep-function-sec1__center--lines {
  z-index: 1;
  position: absolute;
  top: 49%;
  left: 50%;
  translate: -50% -50%;
  display: block;
  aspect-ratio: 488/363;
  width: auto;
  height: 135%;
}
@media screen and (max-width: 949px) {
  .p-service-deep-function-sec1__center--lines {
    display: none;
  }
}

.p-service-deep-function-sec1__center--txt {
  position: relative;
  z-index: 2;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  display: grid;
  place-content: center;
  text-align: center;
  line-height: 1;
  color: var(--color-txt-black);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  background: url("../img/service/service_function_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec1__center--txt {
    --circleSize: 130px;
    font-size: 21px;
    width: var(--circleSize);
  }
}

.p-service-deep-function-sec1__center--shadow {
  z-index: 1;
  position: absolute;
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  animation: pulseMotion 2.4s linear infinite;
}

.p-service-deep-function-sec2__list {
  counter-reset: number 0;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec2__list {
    margin-top: 40px;
    padding-inline: 20px;
  }
}

.p-service-deep-function-sec2__item {
  --numberSize: auto;
  --iconSize: 30px;
  counter-increment: number 1;
  display: grid;
  grid-template-columns: var(--numberSize) 1fr var(--iconSize);
  column-gap: clamp(20px, 3.125vw, 45px);
  color: var(--color-txt-black);
  padding-top: 20px;
  padding-right: 20px;
  padding-bottom: 20px;
  padding-left: 30px;
  transition: all 0.3s ease;
  transition-property: padding;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec2__item {
    --iconSize: 10px;
  }
}
.p-service-deep-function-sec2__item::before {
  content: counter(number, decimal-leading-zero);
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: 30px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec2__item::before {
    font-size: 17px;
  }
}
.p-service-deep-function-sec2__item::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/contain;
  transition: all 0.3s ease;
  transition-property: rotate;
}
.p-service-deep-function-sec2__item.isActive {
  padding-bottom: 30px;
}
.p-service-deep-function-sec2__item.isActive::after {
  rotate: -180deg;
}
.p-service-deep-function-sec2__item:nth-of-type(1) {
  background-color: #fff;
}
.p-service-deep-function-sec2__item:nth-of-type(2) {
  background-color: rgba(255, 255, 255, 0.8);
}
.p-service-deep-function-sec2__item:nth-of-type(3) {
  background-color: rgba(255, 255, 255, 0.7);
}
.p-service-deep-function-sec2__item:nth-of-type(4) {
  background-color: rgba(255, 255, 255, 0.6);
}
.p-service-deep-function-sec2__item:nth-of-type(5) {
  background-color: rgba(255, 255, 255, 0.5);
}
.p-service-deep-function-sec2__item:nth-of-type(6) {
  background-color: rgba(255, 255, 255, 0.4);
}
.p-service-deep-function-sec2__item:nth-of-type(7) {
  background-color: rgba(255, 255, 255, 0.3);
}

.p-service-deep-function-sec2__item--txt {
  cursor: pointer;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  align-self: center;
  font-size: clamp(12px, 1.1805555556vw, 17px);
}

.p-service-deep-function-sec2__item.isActive .p-service-deep-function-sec2__item--txt {
  display: block;
}

.p-service-deep-function-sec2__cta {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function-sec2__cta {
    margin-top: 40px;
  }
}

.p-service-deep-function__head {
  font-size: clamp(13px, 1.3888888889vw, 20px);
  margin-top: 42px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__head {
    margin-top: 30px;
  }
}

.p-service-deep-function__list {
  display: grid;
  row-gap: 120px;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__list {
    row-gap: 40px;
    margin-top: 40px;
  }
}

.p-service-deep-function__item {
  --numberHeightSize: 265px;
  position: relative;
  padding-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__item {
    --numberHeightSize: 115px;
    padding-top: calc(var(--numberHeightSize) - 15px);
    padding-bottom: 0;
  }
}
.p-service-deep-function__item::after {
  z-index: 1;
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  height: var(--numberHeightSize);
  aspect-ratio: 324/262;
  background: url("../img/service/deep/service_deep_preferred_svg_01.svg") no-repeat center top/contain;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__item::after {
    top: 0;
    left: -30px;
    bottom: unset;
    right: unset;
  }
}

.p-service-deep-function__item:nth-of-type(2)::after {
  background-image: url("../img/service/deep/service_deep_preferred_svg_02.svg");
  aspect-ratio: 365/256;
}

.p-service-deep-function__item:nth-of-type(3)::after {
  background-image: url("../img/service/deep/service_deep_preferred_svg_03.svg");
  aspect-ratio: 377/257;
}

.p-service-deep-function__item:nth-of-type(4)::after {
  background-image: url("../img/service/deep/service_deep_preferred_svg_04.svg");
  aspect-ratio: 380/260;
}

.p-service-deep-function__item:nth-of-type(5)::after {
  background-image: url("../img/service/deep/service_deep_preferred_svg_05.svg");
  aspect-ratio: 398/257;
}

.p-service-deep-function__item--ttl {
  background-color: rgba(1, 102, 201, 0.8);
  box-shadow: 0 0 8px rgba(1, 102, 201, 0.73);
  width: fit-content;
  font-weight: bold;
  font-size: clamp(15px, 1.3888888889vw, 20px);
  padding-inline: 30px;
  padding-block: 12px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__item--ttl {
    padding-inline: 16px;
  }
}

.p-service-deep-function__dl {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__dl {
    margin-top: 24px;
  }
}

.p-service-deep-function__dt {
  color: var(--color-txt-primary);
  background: url(../img/service/service_price_bg_01.png) no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  width: fit-content;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  letter-spacing: 0.16em;
  padding-inline: 14px;
  padding-block: 8px;
}
.p-service-deep-function__dt:not(:first-of-type) {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-function__dt:not(:first-of-type) {
    margin-top: 20px;
  }
}

.p-service-deep-function__dd {
  width: min(100%, 700px);
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 14px;
}

.p-service-deep-price {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-price {
    margin-top: 160px;
  }
}

.p-service-deep-price__item {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr clamp(200px, 18.2291666667vw, 350px);
  column-gap: clamp(10px, 2.0833333333vw, 40px);
  background: url("../img/service/service_price_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border: 2px solid var(--color-bg-primary);
  border-radius: 3px;
  padding-block: 30px;
  padding-left: 70px;
  padding-right: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-price__item {
    grid-template-columns: 1fr;
    padding: 20px;
    width: min(100%, 300px);
    margin-inline: auto;
    margin-top: 60px;
  }
}

.p-service-deep-price__item--left {
  max-width: 180px;
  display: grid;
  align-content: center;
}
@media screen and (max-width: 767px) {
  .p-service-deep-price__item--left {
    width: min(100%, 280px);
    padding-top: 0;
    margin-inline: auto;
    justify-items: center;
  }
  .p-service-deep-price__item--left:nth-of-type(2) {
    margin-top: 20px;
  }
}

.p-service-deep-price__head {
  display: block;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(17px, 1.3888888889vw, 20px);
  width: min(100%, 278px);
  border-radius: 3px;
  padding: 15px;
}

.p-service-deep-price__txt1 {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: bold;
  font-size: clamp(12px, 1.1111111111vw, 16px);
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-price__txt1 {
    margin-top: 5px;
  }
}

.p-service-deep-price__body--price {
  display: flex;
  align-items: end;
  justify-content: center;
  color: var(--color-txt-black);
  font-weight: bold;
  column-gap: 5px;
  line-height: 1.2;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}

.p-service-deep-price__price--strong {
  line-height: 1;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-deep-price__item--img {
  aspect-ratio: 354/214;
  max-width: 354px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-deep-price__item--img {
    margin-top: 16px;
  }
}
.p-service-deep-price__item--img > img {
  height: 100%;
}

.p-service-deep-flow {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-flow {
    margin-top: 160px;
  }
}

.p-service-deep-flow__list {
  display: grid;
  row-gap: 60px;
  margin-top: 86px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-flow__list {
    row-gap: 20px;
    margin-top: 64px;
  }
}

.p-service-deep-flow__item {
  display: grid;
  grid-template-columns: max-content 1fr;
  align-items: center;
  column-gap: 24px;
  border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
  box-shadow: 0 0 9px rgba(1, 102, 201, 0.47);
  padding-left: 30px;
  padding-block: 16px;
  margin-right: calc(50% - 50vw);
  padding-right: calc(50vw - 50%);
}
@media screen and (max-width: 767px) {
  .p-service-deep-flow__item {
    column-gap: 12px;
    padding-left: 16px;
  }
}
.p-service-deep-flow__item:nth-of-type(1) {
  background-color: rgba(1, 102, 201, 0.8);
}
.p-service-deep-flow__item:nth-of-type(2) {
  background-color: rgba(1, 102, 201, 0.7);
}
.p-service-deep-flow__item:nth-of-type(3) {
  background-color: rgba(1, 102, 201, 0.6);
}
.p-service-deep-flow__item:nth-of-type(4) {
  background-color: rgba(1, 102, 201, 0.5);
}
.p-service-deep-flow__item:nth-of-type(5) {
  background-color: rgba(1, 102, 201, 0.4);
}

.p-service-deep-flow__count {
  font-weight: bold;
  text-align: center;
  line-height: 1;
}

.p-service-deep-flow__count--txt {
  font-size: clamp(11px, 1.0416666667vw, 15px);
}

.p-service-deep-flow__count--num {
  font-size: clamp(20px, 2.2222222222vw, 32px);
}

.p-service-deep-flow__head {
  font-weight: bold;
  font-size: clamp(17px, 1.3888888889vw, 20px);
}

.p-service-deep-flow__body {
  font-weight: 500;
  font-size: clamp(12px, 1.1111111111vw, 16px);
  margin-top: 3px;
}

.p-service-deep-contact {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-contact {
    padding-inline: 20px;
    margin-top: 160px;
  }
}

.p-service-deep-contact__body {
  font-weight: bold;
  text-align: center;
  line-height: 2.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-contact__body {
    line-height: 1.6;
    margin-top: 20px;
  }
}

.p-service-deep-contact__wrap {
  border: 2px solid var(--color-border-primary);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-contact__wrap {
    margin-top: 50px;
  }
}

.p-service-deep-faq {
  margin-top: 200px;
  margin-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-faq {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-service-deep-faq__list {
  display: grid;
  row-gap: clamp(20px, 2.7777777778vw, 40px);
  background-color: var(--color-bg-gray);
  border-radius: 17px;
  padding-inline: clamp(20px, 3.4722222222vw, 50px);
  padding-block: clamp(20px, 3.4722222222vw, 50px);
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-faq__list {
    margin-top: 20px;
    border-radius: 3px;
    margin-inline: 20px;
  }
}

.p-service-deep-faq__item {
  --columnGapSize: 20px;
  --iconFontSize: 50px;
  cursor: pointer;
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__item {
    --columnGapSize: 8px;
    --iconFontSize: 25px;
  }
}

.p-service-deep-faq__item--q {
  --iconSize: 20px;
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr var(--iconSize);
  align-items: center;
  column-gap: var(--columnGapSize);
  color: var(--color-txt-black);
  padding: 16px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__item--q {
    --iconSize: 10px;
    padding: 16px 10px;
  }
}
.p-service-deep-faq__item--q::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
  transition: all 0.3s ease;
  transition-property: rotate;
}

.p-service-deep-faq__item.isActive .p-service-deep-faq__item--q::after {
  rotate: -180deg;
}

.p-service-deep-faq__q--txt {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__q--txt {
    font-size: 15px;
  }
}
.p-service-deep-faq__q--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 23px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__q--txt::after {
    height: 17px;
  }
}

.p-service-deep-faq__q--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-faq__q--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-deep-faq__item--a {
  display: grid;
  grid-template-rows: 0fr;
  transition: all 0.3s ease;
  transition-property: grid-template-rows;
}

.p-service-deep-faq__item.isActive .p-service-deep-faq__item--a {
  grid-template-rows: 1fr;
}

.p-service-deep-faq__a--inner {
  overflow: hidden;
}

.p-service-deep-faq__a--inner2 {
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  border-radius: 3px;
  padding: 32px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__a--inner2 {
    padding: 12px 10px;
  }
}

.p-service-deep-faq__a--txt {
  position: relative;
  font-weight: bold;
  color: var(--color-txt-white);
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__a--txt {
    font-size: 15px;
  }
}
.p-service-deep-faq__a--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 40px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 949px) {
  .p-service-deep-faq__a--txt::after {
    height: 17px;
  }
}

.p-service-deep-faq__a--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-faq__a--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-deep-faq__cta {
  display: flex;
  justify-content: center;
  column-gap: 42px;
  row-gap: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-deep-faq__cta {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: center;
    row-gap: 20px;
    margin-top: 80px;
  }
}

.p-service-deep-faq__cta--link {
  --iconSize: 20px;
  --textWidthSize: auto;
  display: grid;
  grid-template-columns: var(--iconSize) var(--textWidthSize);
  align-items: center;
  justify-content: center;
  column-gap: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(15px, 1.25vw, 18px);
  width: min(100%, 309px);
  height: 100px;
  border-radius: 3px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-service-deep-faq__cta--link {
    --iconSize: 14px;
    --textWidthSize: 165px;
    font-size: 15px;
    height: 67px;
    justify-content: center;
  }
}
.p-service-deep-faq__cta--link::before {
  content: "";
  aspect-ratio: 1;
  transition: all 0.4s ease;
  transition-property: background-image;
}
.p-service-deep-faq__cta--link:focus-visible {
  background-color: var(--color-bg-white);
  color: var(--color);
}
@media (any-hover: hover) {
  .p-service-deep-faq__cta--link:hover {
    background-color: var(--color-bg-white);
    color: var(--color);
  }
}

.p-service-deep-faq__cta--contact {
  --color: var(--color-primary);
  background-color: var(--color);
}
.p-service-deep-faq__cta--contact::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-deep-faq__cta--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
}
@media (any-hover: hover) {
  .p-service-deep-faq__cta--contact:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
  }
}

.p-service-deep-faq__cta--download {
  --color: #636363;
  background-color: var(--color);
}
.p-service-deep-faq__cta--download::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-deep-faq__cta--download:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
}
@media (any-hover: hover) {
  .p-service-deep-faq__cta--download:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
  }
}

.p-service-active-mv {
  position: relative;
  display: grid;
  align-items: center;
  min-height: calc(100svh - var(--header-height));
  height: fit-content;
  padding-block: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-mv {
    padding-block: 20px;
  }
}

.p-service-active-mv__bg {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-service-active-mv__bg > img {
  height: 100%;
}

.p-service-active-mv__inner {
  z-index: 1;
  position: relative;
  color: var(--color-txt-white);
  padding-left: 6vw;
  padding-right: 20px;
}

.p-service-active-mv__name {
  color: rgba(1, 102, 201, 0.15);
  line-height: 1;
  font-weight: bold;
  letter-spacing: 0.08em;
  font-size: clamp(50px, 8.3333333333vw, 120px);
  margin-bottom: -40px;
}
@media screen and (max-width: 949px) {
  .p-service-active-mv__name {
    font-size: 35px;
    margin-bottom: 0;
  }
}

.p-service-active-mv__head {
  position: relative;
  display: inline;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.08em;
  color: var(--color-txt-white);
  font-size: clamp(23px, 2.4305555556vw, 35px);
  background-image: linear-gradient(to right, #0166C9 0%, #91C9FF 57%, #2287EB 100%);
  background-repeat: no-repeat;
  background-position: left 100%;
  background-size: 0 clamp(13px, 1.8055555556vw, 26px);
  animation: expand 1.2s forwards;
  animation-delay: 400ms;
}
.p-service-active-mv__head::before {
  content: "“";
  position: absolute;
  top: 0;
  left: 0;
  translate: -100% -20%;
  color: var(--color-txt-white);
  font-weight: bold;
  line-height: 1;
  font-size: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-active-mv__head::before {
    translate: -30% -60%;
    font-size: 50px;
  }
}

@keyframes expand {
  from {
    background-size: 0% clamp(13px, 1.8055555556vw, 26px);
  }
  to {
    background-size: 100% clamp(13px, 1.8055555556vw, 26px);
  }
}
.p-service-active-mv__body {
  color: var(--color-txt-white);
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 17px;
  margin-top: 28px;
}
@media screen and (max-width: 949px) {
  .p-service-active-mv__body {
    line-height: 1.8;
    font-size: 15px;
    margin-top: 20px;
  }
}

.p-service-active-mv__cta {
  display: flex;
  align-items: center;
  column-gap: 30px;
  margin-top: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-active-mv__cta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 14px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-active-mv__cta {
    display: flex;
  }
}

.p-service-active-mv__cta--btn {
  display: block;
  position: relative;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  font-weight: bold;
  line-height: 1;
  width: min(100%, 240px);
  font-size: clamp(15px, 1.3888888889vw, 20px);
  border-radius: 3px;
  padding-block: 21px;
  transition: all 0.3s ease;
  transition-property: opacity;
}
@media screen and (max-width: 767px) {
  .p-service-active-mv__cta--btn {
    font-size: 15px;
    padding-block: 16px;
    width: min(100%, 152px);
  }
}
.p-service-active-mv__cta--btn::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  height: 100%;
  border-left: 1px solid var(--color-border-primary);
  border-bottom: 1px solid var(--color-border-primary);
  top: 6px;
  left: -6px;
}
.p-service-active-mv__cta--btn:focus-visible {
  opacity: 0.8;
}
@media (any-hover: hover) {
  .p-service-active-mv__cta--btn:hover {
    opacity: 0.8;
  }
}

.p-service-active-mv__scroll {
  display: none;
}
@media screen and (max-width: 949px) {
  .p-service-active-mv__scroll {
    --barHeightSize: 40px;
    display: grid;
    grid-template-rows: var(--barHeightSize) auto;
    row-gap: 3px;
    justify-items: center;
    margin-top: 50px;
  }
}

.p-service-active-mv__scroll--bar {
  position: relative;
  background-color: var(--color-bg-primary);
  width: 2px;
  border-radius: calc(infinity * 1px);
}
.p-service-active-mv__scroll--bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: 6px;
  box-shadow: 0 0 2px 3px rgba(1, 102, 201, 0.22);
  background-color: var(--color-bg-primary);
  animation: scrollBall linear 4s infinite;
}

@keyframes scrollBall {
  0% {
    opacity: 1;
    top: 0%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 100%;
  }
}
.p-service-active-mv__scroll--txt {
  text-align: center;
  color: var(--color-txt-primary);
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.p-service-active-about {
  margin-top: 200px;
}
@media screen and (max-width: 576px) {
  .p-service-active-about {
    margin-top: 50px;
  }
}

.p-service-active-about__box1 {
  --circleSize: 230px;
  display: grid;
  grid-template-areas: "icon head" "icon desc";
  grid-template-columns: var(--circleSize) 1fr;
  column-gap: 50px;
  row-gap: 27px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .p-service-active-about__box1 {
    --circleSize: 160px;
    row-gap: 0;
    padding-inline: 0;
    grid-template: "icon" auto "." 25px "head" auto "." 14px "desc" auto/1fr;
  }
}

.p-service-active-about-box1__icon {
  --iconSize: 93px;
  grid-area: icon;
  align-self: center;
  position: relative;
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  grid-template-rows: var(--iconSize) auto;
  row-gap: 18px;
  place-content: center;
  border-radius: calc(infinity * 1px);
  background: url("../img/service/service_about_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box1__icon {
    --iconSize: 46px;
    justify-self: center;
  }
}
.p-service-active-about-box1__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  aspect-ratio: 1;
  width: calc(var(--circleSize) + 50px);
  border: 1px solid var(--color-border-primary);
  border-radius: calc(infinity * 1px);
  clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);
  animation: spin 5s linear infinite;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box1__icon::before {
    width: calc(var(--circleSize) + 25px);
  }
}

.p-service-active-about-box1__icon--img {
  height: 100%;
  aspect-ratio: 1;
  justify-self: center;
}
.p-service-active-about-box1__icon--img > img {
  height: 100%;
  object-fit: contain;
}

.p-service-active-about-box1__ttl {
  text-align: center;
  line-height: 1.4;
  font-weight: bold;
  color: var(--color-txt-primary);
  letter-spacing: 0.02em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box1__ttl {
    text-align: center;
    font-size: 12px;
  }
}

.p-service-active-about-box2__head {
  grid-area: head;
  font-weight: bold;
  line-height: 1.2;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  letter-spacing: 0.08em;
  align-self: end;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__head {
    text-align: center;
  }
}
.p-service-active-about-box2__head > span {
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__head > span {
    text-align: center;
    line-height: 1;
  }
}

.p-service-active-about-box2__desc {
  grid-area: desc;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__desc {
    font-size: 13px;
    line-height: 2.3;
    padding-inline: 19px;
  }
}

.p-service-active-about-box2 {
  color: var(--color-txt-black);
  background: url("../img/service/service_about_bg_02.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  padding-inline: 20px;
  padding-block: clamp(30px, 3.4722222222vw, 50px);
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2 {
    margin-top: 50px;
  }
}

.p-service-active-about-box2__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-active-about-box2__wrap {
  max-width: 660px;
  border-top: 1px solid var(--color-border-black);
  display: grid;
  grid-template-columns: repeat(3, auto);
  justify-content: center;
  column-gap: 20px;
  align-items: center;
  padding-top: 14px;
  margin-top: 17px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__wrap {
    text-align: center;
    grid-template-columns: 1fr;
    row-gap: 8px;
    justify-items: center;
  }
}

.p-service-active-about-box2__txt1 {
  --rectangleSize: 11px;
  --columnGapSize: 6px;
  display: grid;
  grid-template-columns: var(--rectangleSize) auto;
  column-gap: var(--columnGapSize);
  align-items: center;
  font-weight: bold;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__txt1 {
    display: block;
  }
}
.p-service-active-about-box2__txt1::before {
  content: "";
  display: block;
  background-color: var(--color-bg-black);
  aspect-ratio: 1;
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__txt1::before {
    content: none;
  }
}

.p-service-active-about-box2__line {
  width: 59px;
  height: 2px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 767px) {
  .p-service-active-about-box2__line {
    width: 2px;
    height: 15px;
  }
}

.p-service-active-about-box2__txt2 {
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;
  max-width: 330px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-active-about__cta {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-active-about__cta {
    margin-top: 32px;
  }
}

.p-service-active-issue {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-issue {
    margin-top: 160px;
  }
}

.p-service-active-issue__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-active-issue__ttl > span {
  z-index: 1;
  display: inline;
  background: linear-gradient(transparent 70%, var(--color-bg-primary) 0%);
  position: relative;
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-active-issue__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(15px, 3.4722222222vw, 50px);
  max-width: 885px;
  margin-top: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-active-issue__list {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 30px;
  }
}

.p-service-active-issue__item {
  display: grid;
  grid-column: span 2;
  grid-template-rows: subgrid;
  grid-template-columns: 1fr;
  grid-row: span 2;
  row-gap: 20px;
  border-radius: 3px;
  background-color: var(--color-bg-gray);
  border: 3px solid var(--color-border-primary);
  color: var(--color-txt-black);
  justify-items: center;
  padding-top: clamp(10px, 1.7361111111vw, 25px);
  padding-inline: 10px;
  padding-bottom: clamp(20px, 3.8194444444vw, 55px);
}
@media screen and (max-width: 767px) {
  .p-service-active-issue__item {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .p-service-active-issue__item:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-active-issue__head {
  text-align: center;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  align-self: center;
}

.p-service-active-issue__icon {
  aspect-ratio: 1;
  width: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-issue__icon {
    width: 80px;
  }
}

.p-service-active-issue__desc {
  font-weight: 500px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 2.4;
  text-align: center;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-active-issue__desc {
    line-height: 1.5;
    margin-top: 30px;
  }
}

.p-service-active-solution {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-solution {
    margin-top: 160px;
  }
}

.p-service-active-solution__ttl {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4;
  font-size: clamp(13px, 1.3888888889vw, 20px);
}
.p-service-active-solution__ttl > span {
  z-index: 1;
  display: inline-block;
  position: relative;
  font-size: 23px;
}

.p-service-active-solution__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(15px, 3.4722222222vw, 50px);
  max-width: 885px;
  margin-top: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-active-solution__list {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 30px;
  }
}

.p-service-active-solution__item {
  display: grid;
  grid-column: span 2;
  grid-template-rows: subgrid;
  grid-template-columns: 1fr;
  grid-row: span 2;
  row-gap: 20px;
  border-radius: 3px;
  background-color: var(--color-bg-gray);
  border: 3px solid var(--color-border-primary);
  color: var(--color-txt-black);
  justify-items: center;
  padding-top: clamp(10px, 1.7361111111vw, 25px);
  padding-inline: 5px;
  padding-bottom: clamp(20px, 3.8194444444vw, 55px);
}
@media screen and (max-width: 767px) {
  .p-service-active-solution__item {
    padding-top: 10px;
    padding-bottom: 20px;
    padding-inline: 3px;
  }
  .p-service-active-solution__item:nth-of-type(3) {
    grid-column: 2/4;
  }
}

.p-service-active-solution__head {
  text-align: center;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  align-self: center;
}

.p-service-active-solution__icon {
  aspect-ratio: 1;
  width: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-solution__icon {
    width: 80px;
  }
}

.p-service-active-solution__desc {
  font-weight: 500px;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  line-height: 2.4;
  text-align: center;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-active-solution__desc {
    line-height: 1.5;
    margin-top: 30px;
  }
}

.p-service-active-solution__cta {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-service-active-solution__cta {
    margin-top: 32px;
  }
}

.p-service-active-feature {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature {
    margin-top: 160px;
  }
}

.p-service-active-feature__list {
  display: grid;
  row-gap: 100px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__list {
    row-gap: 60px;
    padding-inline: 30px;
    margin-top: 40px;
  }
}

.p-service-active-feature__top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__top {
    grid-template-columns: 1fr;
    row-gap: 20px;
  }
}

.p-service-active-feature__num {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: clamp(30px, 4.8611111111vw, 70px);
  background: linear-gradient(to bottom, #0166C9 0%, #D1E8FF 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  padding-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__num {
    width: fit-content;
  }
}
.p-service-active-feature__num::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 0;
  height: 2px;
  width: 26px;
  background-color: var(--color-bg-primary);
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__num::before {
    width: 19px;
  }
}

.p-service-active-feature__ttl {
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.16em;
}

.p-service-active-feature__ttl--head {
  font-size: clamp(23px, 2.0833333333vw, 30px);
}

.p-service-active-feature__ttl--desc {
  font-size: clamp(13px, 1.1805555556vw, 17px);
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__ttl--desc {
    margin-top: 10px;
  }
}

.p-service-active-feature__btm {
  --bodyWidthSize: 363px;
  --imgWidthSize: min(100%, 360px);
  display: flex;
  column-gap: 40px;
  padding-left: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__btm {
    --bodyWidthSize: 100%;
    flex-direction: column;
    row-gap: 10px;
    padding-left: 0;
    margin-top: 20px;
  }
}

.p-service-active-feature__item:nth-of-type(even) .p-service-active-feature__btm {
  flex-direction: row-reverse;
  justify-content: end;
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__item:nth-of-type(even) .p-service-active-feature__btm {
    flex-direction: column;
  }
}

.p-service-active-feature__img {
  border-radius: 3px;
  overflow: hidden;
  width: var(--imgWidthSize);
  aspect-ratio: 360/215;
  box-shadow: 0 0 11px rgba(161, 224, 231, 0.5);
}
@media screen and (max-width: 767px) {
  .p-service-active-feature__img {
    justify-self: center;
  }
}
.p-service-active-feature__img > img {
  height: 100%;
}

.p-service-active-feature__body {
  flex: 1;
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: clamp(13px, 0.9722222222vw, 14px);
}

.p-service-active-function {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-function {
    margin-top: 160px;
  }
}

.p-service-active-function-sec1__wrap {
  position: relative;
  padding-top: 60px;
  margin-top: 40px;
  padding-bottom: 30px;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__wrap {
    width: min(100%, 300px);
    display: grid;
    row-gap: 10px;
    padding-block: 0;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec1__wrap {
    margin-top: 30px;
  }
}

.p-service-active-function-sec1__item {
  z-index: 3;
  filter: drop-shadow(0 0 10px rgba(1, 102, 201, 0.58));
  position: absolute;
  display: grid;
  align-items: center;
  --numWidthSize: 64px;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__item {
    --numWidthSize: 44px;
    position: relative;
    top: unset;
    right: unset;
    bottom: unset;
    left: unset;
    width: fit-content;
  }
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec1__item {
    --numWidthSize: 44px;
  }
}
.p-service-active-function-sec1__item:nth-of-type(1), .p-service-active-function-sec1__item:nth-of-type(4) {
  grid-template-columns: fit-content(100%) var(--numWidthSize);
  grid-template-areas: "head num";
}
.p-service-active-function-sec1__item:nth-of-type(2), .p-service-active-function-sec1__item:nth-of-type(5), .p-service-active-function-sec1__item:nth-of-type(6) {
  grid-template-columns: var(--numWidthSize) fit-content(100%);
  grid-template-areas: "num head";
}
.p-service-active-function-sec1__item:nth-of-type(1) {
  top: 12%;
  left: 0.018%;
}
.p-service-active-function-sec1__item:nth-of-type(2) {
  top: 0;
  right: 7%;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__item:nth-of-type(2) {
    grid-template-columns: fit-content(100%) var(--numWidthSize);
    grid-template-areas: "head num";
    margin-inline: auto;
  }
}
.p-service-active-function-sec1__item:nth-of-type(4) {
  top: 65%;
  left: 0;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__item:nth-of-type(4) {
    grid-template-columns: var(--numWidthSize) fit-content(100%);
    grid-template-areas: "num head";
    margin-left: auto;
  }
}
.p-service-active-function-sec1__item:nth-of-type(5) {
  top: 37%;
  right: 0;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__item:nth-of-type(5) {
    margin-inline: auto;
  }
}
.p-service-active-function-sec1__item:nth-of-type(6) {
  bottom: 0;
  right: 3%;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__item:nth-of-type(1), .p-service-active-function-sec1__item:nth-of-type(2), .p-service-active-function-sec1__item:nth-of-type(4), .p-service-active-function-sec1__item:nth-of-type(5), .p-service-active-function-sec1__item:nth-of-type(6) {
    inset: unset;
  }
}

.p-service-active-function-sec1__head {
  grid-area: head;
  background-color: #0A5BAA;
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  min-height: 48px;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  min-width: clamp(150px, 14.5833333333vw, 280px);
  max-width: 280px;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__head {
    font-size: 12px;
    min-width: 155px;
    min-height: 34px;
    padding-block: 8px;
  }
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec1__head {
    max-width: 190px;
  }
}

.p-service-active-function-sec1__item:nth-of-type(1) .p-service-active-function-sec1__head, .p-service-active-function-sec1__item:nth-of-type(4) .p-service-active-function-sec1__head {
  border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  margin-right: -15px;
}
.p-service-active-function-sec1__item:nth-of-type(2) .p-service-active-function-sec1__head, .p-service-active-function-sec1__item:nth-of-type(5) .p-service-active-function-sec1__head, .p-service-active-function-sec1__item:nth-of-type(6) .p-service-active-function-sec1__head {
  border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
  padding-right: clamp(16px, 1.7361111111vw, 25px);
  padding-left: clamp(16px, 2.0833333333vw, 30px);
  margin-left: -15px;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__item:nth-of-type(2) .p-service-active-function-sec1__head {
    border-radius: calc(infinity * 1px) 0 0 calc(infinity * 1px);
    margin-left: 0px;
    margin-right: -15px;
  }
  .p-service-active-function-sec1__item:nth-of-type(4) .p-service-active-function-sec1__head {
    border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
    margin-right: 0px;
    margin-left: -15px;
  }
}

.p-service-active-function-sec1__num {
  grid-area: num;
  aspect-ratio: 1;
  background-color: #0A5BAA;
  border-radius: calc(infinity * 1px);
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(12px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec1__num {
    font-size: 12px;
  }
}

.p-service-active-function-sec1__center {
  --circleSize: 25%;
  --circleSizeMax: max(130px, var(--circleSize));
  position: relative;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__center {
    --circleSize: 130px;
  }
}
.p-service-active-function-sec1__center::after {
  z-index: 2;
  content: "";
  position: absolute;
  top: 44%;
  left: 49.5%;
  translate: -50% -50%;
  aspect-ratio: 330/300;
  width: 330px;
  width: auto;
  height: 110%;
  background: url("../img/service/service_function_bg_02.png") no-repeat center center/contain;
}

.p-service-active-function-sec1__center--lines {
  z-index: 1;
  position: absolute;
  top: 49%;
  left: 50%;
  translate: -50% -50%;
  display: block;
  aspect-ratio: 488/363;
  width: auto;
  height: 135%;
}
@media screen and (max-width: 949px) {
  .p-service-active-function-sec1__center--lines {
    display: none;
  }
}

.p-service-active-function-sec1__center--txt {
  position: relative;
  z-index: 2;
  border-radius: calc(infinity * 1px);
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  display: grid;
  place-content: center;
  text-align: center;
  line-height: 1;
  color: var(--color-txt-black);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-size: clamp(20px, 2.0833333333vw, 30px);
  background: url("../img/service/service_function_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  box-shadow: 0 0 24px rgba(1, 102, 201, 0.5);
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec1__center--txt {
    --circleSize: 130px;
    font-size: 21px;
    width: var(--circleSize);
  }
}

.p-service-active-function-sec1__center--shadow {
  z-index: 1;
  position: absolute;
  aspect-ratio: 1;
  width: var(--circleSizeMax);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  animation: pulseMotion 2.4s linear infinite;
}

.p-service-active-function-sec2__list {
  counter-reset: number 0;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec2__list {
    margin-top: 40px;
    padding-inline: 20px;
  }
}

.p-service-active-function-sec2__item {
  --numberSize: auto;
  --iconSize: 30px;
  counter-increment: number 1;
  display: grid;
  grid-template-columns: var(--numberSize) 1fr var(--iconSize);
  column-gap: clamp(20px, 3.125vw, 45px);
  color: var(--color-txt-black);
  padding-top: 20px;
  padding-right: 20px;
  padding-bottom: 20px;
  padding-left: 30px;
  transition: all 0.3s ease;
  transition-property: padding;
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec2__item {
    --iconSize: 10px;
  }
}
.p-service-active-function-sec2__item::before {
  content: counter(number, decimal-leading-zero);
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: 30px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec2__item::before {
    font-size: 17px;
  }
}
.p-service-active-function-sec2__item::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/contain;
  transition: all 0.3s ease;
  transition-property: rotate;
}
.p-service-active-function-sec2__item.isActive {
  padding-bottom: 30px;
}
.p-service-active-function-sec2__item.isActive::after {
  rotate: -180deg;
}
.p-service-active-function-sec2__item:nth-of-type(1) {
  background-color: #fff;
}
.p-service-active-function-sec2__item:nth-of-type(2) {
  background-color: rgba(255, 255, 255, 0.8);
}
.p-service-active-function-sec2__item:nth-of-type(3) {
  background-color: rgba(255, 255, 255, 0.7);
}
.p-service-active-function-sec2__item:nth-of-type(4) {
  background-color: rgba(255, 255, 255, 0.6);
}
.p-service-active-function-sec2__item:nth-of-type(5) {
  background-color: rgba(255, 255, 255, 0.5);
}
.p-service-active-function-sec2__item:nth-of-type(6) {
  background-color: rgba(255, 255, 255, 0.4);
}
.p-service-active-function-sec2__item:nth-of-type(7) {
  background-color: rgba(255, 255, 255, 0.3);
}

.p-service-active-function-sec2__item--txt {
  cursor: pointer;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  align-self: center;
  font-size: clamp(12px, 1.1805555556vw, 17px);
}

.p-service-active-function-sec2__item.isActive .p-service-active-function-sec2__item--txt {
  display: block;
}

.p-service-active-function-sec2__cta {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-active-function-sec2__cta {
    margin-top: 40px;
  }
}

.p-service-active-price {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-price {
    margin-top: 160px;
  }
}

.p-service-active-price__item {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr clamp(200px, 18.2291666667vw, 350px);
  column-gap: clamp(10px, 2.0833333333vw, 40px);
  background: url("../img/service/service_price_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border: 2px solid var(--color-bg-primary);
  border-radius: 3px;
  padding-block: 30px;
  padding-left: 70px;
  padding-right: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-price__item {
    grid-template-columns: 1fr;
    padding: 20px;
    width: min(100%, 300px);
    margin-inline: auto;
    margin-top: 60px;
  }
}

.p-service-active-price__item--left {
  max-width: 180px;
  display: grid;
  align-content: center;
}
@media screen and (max-width: 767px) {
  .p-service-active-price__item--left {
    width: min(100%, 280px);
    padding-top: 0;
    margin-inline: auto;
    justify-items: center;
  }
  .p-service-active-price__item--left:nth-of-type(2) {
    margin-top: 20px;
  }
}

.p-service-active-price__head {
  display: block;
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  text-align: center;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(17px, 1.3888888889vw, 20px);
  width: min(100%, 278px);
  border-radius: 3px;
  padding: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-active-price__head {
    width: min(100%, 160px);
  }
}

.p-service-active-price__body--price {
  display: flex;
  align-items: end;
  justify-content: center;
  color: var(--color-txt-black);
  font-weight: bold;
  column-gap: 5px;
  line-height: 1.2;
  font-size: clamp(13px, 1.3888888889vw, 20px);
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-active-price__body--price {
    margin-top: 15px;
  }
}

.p-service-active-price__price--strong {
  line-height: 1;
  font-size: clamp(20px, 2.0833333333vw, 30px);
}

.p-service-active-price__txt1 {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: bold;
  font-size: 10px;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .p-service-active-price__txt1 {
    margin-top: 5px;
  }
}

.p-service-active-price__item--img {
  aspect-ratio: 354/214;
  max-width: 354px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-service-active-price__item--img {
    margin-top: 16px;
  }
}
.p-service-active-price__item--img > img {
  height: 100%;
}

.p-service-active-flow {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow {
    margin-top: 160px;
  }
}

.p-service-active-flow__list {
  --rowGapSize: 60px;
  --columnGapSize: -26px;
  --paddingEmptySize: clamp(0px, 150 / 1440 * 100vw, 150px);
  display: flex;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__list {
    grid-template-columns: 1fr;
    row-gap: var(--rowGapSize);
    flex-direction: column;
  }
}
.p-service-active-flow__list:nth-of-type(1) {
  padding-right: var(--paddingEmptySize);
  margin-top: 100px;
  margin-left: 40px;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__list:nth-of-type(1) {
    margin-top: 80px;
    margin-left: 0;
  }
}
.p-service-active-flow__list:nth-of-type(2) {
  justify-items: end;
  padding-left: var(--paddingEmptySize);
  margin-top: var(--rowGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__list:nth-of-type(1), .p-service-active-flow__list:nth-of-type(2) {
    padding-inline: 0;
  }
}
.p-service-active-flow__list > *:nth-of-type(2) {
  margin-left: var(--columnGapSize);
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__list > *:nth-of-type(2) {
    margin-left: auto;
  }
}

.p-service-active-flow__item {
  width: min(100%, 364px);
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__item {
    width: min(100%, 230px);
    margin-inline: auto;
  }
}

.p-service-active-flow__item--wrap {
  display: grid;
  align-content: center;
  background: url("../img/service/service_flow_bg_01.png") no-repeat center center/contain;
  background-size: 100% 100%;
  background-color: var(--color-bg-white);
  border-radius: 3px;
  clip-path: polygon(0 0, calc(100% - 55px) 0, 100% 50%, calc(100% - 55px) 100%, 0 100%);
  height: 100%;
  min-height: 250px;
  padding-block: 20px;
  padding-right: 30px;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__item--wrap {
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 20px), 50% 100%, 0 calc(100% - 20px));
    min-height: 156px;
    padding-top: 24px;
    padding-bottom: 30px;
    padding-inline: 10px;
    padding-right: 0;
  }
}

@media screen and (max-width: 767px) {
  .p-service-active-flow__list:last-of-type .p-service-active-flow__item:last-of-type .p-service-active-flow__item--wrap {
    clip-path: none;
  }
}
.p-service-active-flow__body {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: 17px;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__body {
    line-height: 1.5;
  }
}

.p-service-active-flow__desc {
  color: var(--color-txt-black);
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1.5;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  margin-top: 14px;
}

.p-service-active-flow__count {
  z-index: 1;
  --circleSize: 97px;
  position: absolute;
  top: 0;
  left: calc(50% - 20px);
  translate: -50% -50%;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-bg-primary);
  aspect-ratio: 1;
  width: var(--circleSize);
  display: grid;
  place-content: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__count {
    --circleSize: 58px;
    left: 0;
    translate: -25% -45%;
  }
}

.p-service-active-flow__count--txt {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(13px, 1.0416666667vw, 15px);
}
@media screen and (max-width: 767px) {
  .p-service-active-flow__count--txt {
    font-size: 14px;
  }
}

.p-service-active-flow__count--num {
  font-weight: bold;
  line-height: 1;
  font-size: clamp(17px, 2.2222222222vw, 32px);
}

.p-service-active-contact {
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-contact {
    padding-inline: 20px;
    margin-top: 160px;
  }
}

.p-service-active-contact__body {
  font-weight: bold;
  text-align: center;
  line-height: 2.5;
  font-size: clamp(13px, 0.9722222222vw, 14px);
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-active-contact__body {
    line-height: 1.6;
    margin-top: 20px;
  }
}

.p-service-active-contact__wrap {
  border: 2px solid var(--color-border-primary);
  border-radius: 3px;
  padding-top: 50px;
  padding-inline: 20px;
  padding-bottom: 20px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .p-service-active-contact__wrap {
    padding-inline: 20px;
    margin-top: 50px;
  }
}

.p-service-active-faq {
  margin-top: 200px;
  margin-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-service-active-faq {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-service-active-faq__list {
  display: grid;
  row-gap: clamp(20px, 2.7777777778vw, 40px);
  background-color: var(--color-bg-gray);
  border-radius: 17px;
  padding-inline: clamp(20px, 3.4722222222vw, 50px);
  padding-block: clamp(20px, 3.4722222222vw, 50px);
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .p-service-active-faq__list {
    margin-top: 20px;
    border-radius: 3px;
    margin-inline: 20px;
  }
}

.p-service-active-faq__item {
  --columnGapSize: 20px;
  --iconFontSize: 50px;
  cursor: pointer;
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__item {
    --columnGapSize: 8px;
    --iconFontSize: 25px;
  }
}

.p-service-active-faq__item--q {
  --iconSize: 20px;
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr var(--iconSize);
  align-items: center;
  column-gap: var(--columnGapSize);
  color: var(--color-txt-black);
  padding: 16px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__item--q {
    --iconSize: 10px;
    padding: 16px 10px;
  }
}
.p-service-active-faq__item--q::after {
  content: "";
  aspect-ratio: 1;
  background: url("../img/common/common_icon_option_bottom_black.png") no-repeat center top/cover;
  transition: all 0.3s ease;
  transition-property: rotate;
}

.p-service-active-faq__item.isActive .p-service-active-faq__item--q::after {
  rotate: -180deg;
}

.p-service-active-faq__q--txt {
  position: relative;
  font-weight: bold;
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__q--txt {
    font-size: 15px;
  }
}
.p-service-active-faq__q--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 23px;
  background-color: var(--color-bg-black);
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__q--txt::after {
    height: 17px;
  }
}

.p-service-active-faq__q--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .p-service-active-faq__q--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-active-faq__item--a {
  display: grid;
  grid-template-rows: 0fr;
  transition: all 0.3s ease;
  transition-property: grid-template-rows;
}

.p-service-active-faq__item.isActive .p-service-active-faq__item--a {
  grid-template-rows: 1fr;
}

.p-service-active-faq__a--inner {
  overflow: hidden;
}

.p-service-active-faq__a--inner2 {
  display: grid;
  grid-template-columns: var(--iconFontSize) 1fr;
  align-items: center;
  column-gap: var(--columnGapSize);
  background-color: var(--color-bg-primary);
  color: var(--color-txt-white);
  border-radius: 3px;
  padding: 32px 28px;
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__a--inner2 {
    padding: 12px 10px;
  }
}

.p-service-active-faq__a--txt {
  position: relative;
  font-weight: bold;
  color: var(--color-txt-white);
  line-height: 1;
  font-size: 18px;
  padding-right: var(--columnGapSize);
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__a--txt {
    font-size: 15px;
  }
}
.p-service-active-faq__a--txt::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 1px;
  height: 40px;
  background-color: var(--color-bg-white);
}
@media screen and (max-width: 949px) {
  .p-service-active-faq__a--txt::after {
    height: 17px;
  }
}

.p-service-active-faq__a--body {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.08em;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-service-active-faq__a--body {
    font-size: 13px;
    line-height: 1.2;
  }
}

.p-service-active-faq__cta {
  display: flex;
  justify-content: center;
  column-gap: 42px;
  row-gap: 50px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-service-active-faq__cta {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: center;
    row-gap: 20px;
    margin-top: 80px;
  }
}

.p-service-active-faq__cta--link {
  --iconSize: 20px;
  --textWidthSize: auto;
  display: grid;
  grid-template-columns: var(--iconSize) var(--textWidthSize);
  align-items: center;
  justify-content: center;
  column-gap: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  font-size: clamp(15px, 1.25vw, 18px);
  width: min(100%, 309px);
  height: 100px;
  border-radius: 3px;
  transition: all 0.3s ease;
  transition-property: color;
}
@media screen and (max-width: 767px) {
  .p-service-active-faq__cta--link {
    --iconSize: 14px;
    --textWidthSize: 165px;
    font-size: 15px;
    height: 67px;
    justify-content: center;
  }
}
.p-service-active-faq__cta--link::before {
  content: "";
  aspect-ratio: 1;
  transition: all 0.4s ease;
  transition-property: background-image;
}
.p-service-active-faq__cta--link:focus-visible {
  background-color: var(--color-bg-white);
  color: var(--color);
}
@media (any-hover: hover) {
  .p-service-active-faq__cta--link:hover {
    background-color: var(--color-bg-white);
    color: var(--color);
  }
}

.p-service-active-faq__cta--contact {
  --color: var(--color-primary);
  background-color: var(--color);
}
.p-service-active-faq__cta--contact::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-active-faq__cta--contact:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
}
@media (any-hover: hover) {
  .p-service-active-faq__cta--contact:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_primary.png");
  }
}

.p-service-active-faq__cta--download {
  --color: #636363;
  background-color: var(--color);
}
.p-service-active-faq__cta--download::before {
  background: url("../img/common/common_icon_circle_arrow_right_white.png") no-repeat center top/cover;
}
.p-service-active-faq__cta--download:focus-visible::before {
  background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
}
@media (any-hover: hover) {
  .p-service-active-faq__cta--download:hover::before {
    background-image: url("../img/common/common_icon_circle_arrow_right_gray.png");
  }
}

.p-contact {
  padding-top: 160px;
  padding-bottom: 200px;
}
@media screen and (max-width: 767px) {
  .p-contact {
    padding-top: 50px;
    padding-bottom: 70px;
  }
}

.p-contact__inner {
  border: 4px solid var(--color-border-primary);
  background-color: var(--color-bg-gray);
  border-radius: 3px;
  padding-top: 74px;
  padding-bottom: 63px;
  margin-top: 90px;
}
@media screen and (max-width: 767px) {
  .p-contact__inner {
    border: none;
    padding: 36px;
    padding-bottom: 50px;
    margin-top: 35px;
  }
}

.u-spNone {
  display: block;
}

.u-pcNone {
  display: none;
  visibility: hidden;
}

@media screen and (max-width: 767px) {
  .u-spNone {
    display: none;
    visibility: hidden;
  }
  .u-pcNone {
    display: block;
    visibility: visible;
  }
}
.u-ti1em {
  padding-left: 1em;
  text-indent: -1em;
}

.u-ti2em {
  padding-left: 2em;
  text-indent: -2em;
}

.u-ti3em {
  padding-left: 3em;
  text-indent: -3em;
}

.u-ti4em {
  padding-left: 4em;
  text-indent: -4em;
}

.u-ti5em {
  padding-left: 5em;
  text-indent: -5em;
}

.u-bg-gray {
  background-color: var(--color-bg-gray);
}

.u-color-black {
  color: var(--color-txt-black);
}

/*# sourceMappingURL=style.css.map */
