/**
 * File Name : common.css
 * Version : 1.0
 * Description : 全ページ共通CSSファイル
 * Since : 2023-3-29
 *
 * ---- Table of Contents ----
 *
 * 1.0 - Foundation
 *    1.1 - Reset
 *    1.2 - Base
 *
 * 2.0 - Layout
 *    2.1 - Centering
 *    2.2 - Header
 *    2.3 - Global Nav
 *    2.4 - Main
 *    2.5 - Breadcrumb
 *    2.6 - Footer
 *
 * 3.0 - Object
 *    3.1 - Component
 *
 */
/* =====================================================
  1.0 - Foundation
===================================================== */

/*
  1.1 - Reset
-----------------------------------------------------*/
/*
  Reset
----------------------------------------------- */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
main,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section {
  display: block;
}
body {
  line-height: 1;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
a {
  text-decoration: none;
}

/*
  1.2 - Base
-----------------------------------------------------*/

*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  color: #333;
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, sans-serif;
  line-height: 2;
  letter-spacing: 0;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 0.9375rem;
  }
}

img {
  vertical-align: bottom;
  pointer-events: none;
}

a {
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

[lang="en"] {
  font-family: "poppins", sans-serif;
}

a:hover {
  opacity: 0.7;
}

/* =====================================================
  2.0 - Layout
===================================================== */

/*
  2.1 - Centerng
-----------------------------------------------------*/
/*
.l-container {
  display: flex;
  width: 100%;
  position: relative;
  left: 0;
  overflow: hidden;
}
*/

.l-contents {
  max-width: 1290px;
  margin: 0 auto;
}

@media screen and (max-width: 1400px) {
  .l-contents {
    width: 90%;
  }
}

@media screen and (max-width: 768px) {
  .l-contents {
    width: 85%;
  }
}

.l-contents.-features {
  max-width: 910px;
  margin: 0 auto;
}

.l-contents.-case {
  max-width: 1200px;
  margin: 0 auto;
}

.l-contents.-subscription {
  max-width: 1100px;
  margin: 0 auto;
}

.l-contents.-cta {
  max-width: 1100px;
  margin: 0 auto;
}

.l-contents.-topics {
  max-width: 1000px;
  margin: 0 auto;
}

.l-contents.-heading {
  max-width: 1292px;
  margin: 0 auto;
}

.l-contents.-faq {
  max-width: 1200px;
  margin: 0 auto;
}

.l-contents.-enviroment {
  max-width: 980px;
  margin: 0 auto;
}

.l-contents.-voice {
  max-width: 1200px;
  margin: auto;
}

.l-contents.-comparison {
  max-width: 1100px;
  margin: auto;
}

.l-contents.-price {
  max-width: 980px;
  margin: auto;
}

.l-contents.-step {
  max-width: 800px;
  margin: auto;
}

.l-contents.-contact {
  max-width: 1100px;
  margin: auto;
}

.l-contents.-application {
  max-width: 1000px;
  margin: auto;
}

.l-spacer.-primary {
  /* padding: 3.125rem 0 6.875rem; */
  padding: 6.25rem 0 6.875rem;
}

@media screen and (max-width: 768px) {
  .l-spacer.-primary {
    padding: 1.25rem 0 3.75rem;
  }
}

.l-spacer.-cando {
  padding: 9.375rem 0;
}

@media screen and (max-width: 992px) {
  .l-spacer.-cando {
    padding: 5rem 0 5.625rem;
  }
}

@media screen and (max-width: 768px) {
  .l-spacer.-cando {
    padding: 5rem 0 1.875rem;
  }
}

@media screen and (max-width: 576px) {
  .l-spacer.-cando {
    padding: 3.125rem 0 1rem;
  }
}

@media screen and (max-width: 360px) {
  .l-spacer.-cando {
    padding: 2.5rem 0 0.625rem;
  }
}

.l-spacer.-secondary {
  padding-top: 3.125rem;
}

@media screen and (max-width: 768px) {
  .l-spacer.-secondary {
    padding-top: 2.125rem;
  }
}

@media screen and (max-width: 576px) {
  .l-spacer.-secondary {
    padding-top: 1.75rem;
  }
}

.l-spacer.-contact {
  padding: 60px 0;
}

@media screen and (max-width: 768px) {
  .l-spacer.-contact {
    padding: 40px 0;
  }
}

/*
  2.2 - Header
-----------------------------------------------------*/

/*
  2.3 - Global Nav
-----------------------------------------------------*/

/*
  2.4 - Main
-----------------------------------------------------*/
.l-main {
  width: 75%;
  position: relative;
}

@media screen and (max-width: 1200px) {
  .l-main {
    width: 100%;
  }
}

/*
  2.5 - Breadcrumbs
-----------------------------------------------------*/

/*
  2.6 - Footer
-----------------------------------------------------*/

/* =====================================================
  3.0 - Object
===================================================== */

/*
  3.1 - Component
-----------------------------------------------------*/
/*
  Accessibility
*/
.screen-reader-text {
  position: absolute;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  width: 1px;
  height: 1px;
}

/*
  none
*/

@media screen and (min-width: 769px) {
  .-pc_none {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .-tab_none {
    display: none;
  }
}

@media screen and (min-width: 991px) {
  .-xl_none {
    display: none;
  }
}

@media screen and (max-width: 991px) {
  .-lg_none {
    display: none;
  }
}

@media screen and (min-width: 577px) {
  .sp_br {
    display: none;
  }
}

/*
  角丸
*/
.c-box {
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
}

/*
  丸
*/
.c-circle {
  background-color: #f4f8f9;
  border-radius: 50%;
  width: 150px;
  height: 150px;
  margin: auto;
  box-shadow: 0px 3px 10px 0px rgba(0, 0, 0, 0.16);
}

@media screen and (max-width: 1700px) {
  .c-circle {
    width: 8.5vw;
    height: 8.5vw;
  }
}

@media screen and (max-width: 1200px) {
  .c-circle {
    width: 10vw;
    height: 10vw;
  }
}

@media screen and (max-width: 992px) {
  .c-circle {
    width: 13vw;
    height: 13vw;
  }
}

@media screen and (max-width: 768px) {
  .c-circle {
    width: 15vw;
    height: 15vw;
  }
}

@media screen and (max-width: 576px) {
  .c-circle {
    width: 30vw;
    height: 30vw;
  }
}

/*
  ボタン
*/
.c-button {
  border-radius: 60px;
  font-size: 0.875rem;
  font-weight: bold;
  text-align: center;
  min-width: auto;
  display: inline-block;
  letter-spacing: 0.1em;
}

.c-button img {
  vertical-align: middle;
  padding-right: 6px;
  display: inline-block;
}

@media screen and (max-width: 768px) {
  .c-button {
    background-size: 12px 15px;
  }
}

.c-button.-download {
  background-color: #00428d;
  font-weight: bold;
  padding: 1rem 1.4375rem;
  line-height: 1.2;
  color: #fff;
  border: 2px solid #11488b;
}

@media screen and (max-width: 1200px) {
  .c-button.-download {
    padding: 1.5rem 1.875rem;
  }
}

@media screen and (max-width: 768px) {
  .c-button.-download {
    padding: 1rem 0;
  }
}

.c-button.-documents {
  background-color: #00428d;
  font-weight: bold;
  color: #fff;
  padding: 0.9375rem 4.125rem;
  line-height: 1.4;
  font-size: 1rem;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 768px) {
  .c-button.-documents {
    margin: auto;
    width: 100%;
    padding: 0.9375rem 0;
  }
}

.c-button.-documents_lite {
  background-color: #e7235f;
  font-weight: bold;
  color: #fff;
  padding: 0.9375rem 4.125rem;
  line-height: 1.4;
  font-size: 1rem;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 768px) {
  .c-button.-documents_lite {
    margin: auto;
    width: 100%;
    padding: 0.9375rem 0;
  }
}

.c-button.-contact {
  background-color: #fff;
  border: 2px solid #11488b;
  padding: 1rem 2.25rem;
  line-height: 1.2;
  color: #11488b;
}

@media screen and (max-width: 1200px) {
  .c-button.-contact {
    padding: 1.5rem 1.875rem;
  }
}

@media screen and (max-width: 768px) {
  .c-button.-contact {
    padding: 1rem 0;
  }
}

.c-button.-features {
  background-color: #fff;
  font-weight: bold;
  color: #e7235f;
  border: 2px solid #e7235f;
  font-size: 1rem;
  padding: 0.625rem 5.5625rem;
  line-height: 1.8;
  position: relative;
}

@media screen and (max-width: 360px) {
  .c-button.-features {
    padding: 0.625rem 0;
    width: 100%;
  }
}

.c-button.-subscription {
  background-color: #e7235f;
  font-weight: bold;
  color: #fff;
  font-size: 1rem;
  padding: 0.9375rem 4.25rem;
  line-height: 1.8;
  position: relative;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
}

@media screen and (max-width: 576px) {
  .c-button.-subscription {
    padding: 0.9375rem 0;
    width: 100%;
  }
}

.c-button.-cta {
  background-color: #fff;
  font-weight: bold;
  font-size: 1rem;
  letter-spacing: 0.1em;
  color: #11488b;
  padding: 0.9375rem 0;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.2);
  position: relative;
  width: 85%;
}

@media screen and (max-width: 768px) {
  .c-button.-cta {
    font-size: 0.9375rem;
    width: 90%;
  }
}

@media screen and (max-width: 576px) {
  .c-button.-cta {
    width: 100%;
    padding: 0.875rem 0;
  }
}

.c-button.-cta::after {
  position: absolute;
  content: "";
  background-image: url(../image/front/icon-next-bl.svg);
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 10%;
}

.c-button.-useful {
  background-color: #11488b;
  color: #fff;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.06em;
  padding: 0.625rem 0;
  position: relative;
  width: 100%;
}

@media screen and (max-width: 1200px) {
  .c-button.-useful {
    font-size: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .c-button.-useful {
    font-size: 0.9375rem;
  }
}

.c-button.-qcone {
  background-color: #11488b;
  color: #fff;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.06em;
  padding: 0.625rem 0;
  position: relative;
  width: 80%;
}

@media screen and (max-width: 768px) {
  .c-button.-qcone {
    font-size: 0.9375rem;
    padding: 0.625rem 0;
    width: 100%;
  }
}

.c-button.-qconeLite {
  background-color: #e7235f;
  color: #fff;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.06em;
  padding: 0.625rem 0;
  position: relative;
  width: 80%;
}

@media screen and (max-width: 768px) {
  .c-button.-qconeLite {
    font-size: 0.9375rem;
    padding: 0.625rem 0;
    width: 100%;
  }
}

.c-button.-litepoint {
  background-color: #e7235f;
  color: #fff;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.06em;
  padding: 0.625rem 0;
  position: relative;
  width: 32%;
  margin-top: 30px;
}

@media screen and (max-width: 768px) {
  .c-button.-litepoint {
    font-size: 0.9375rem;
    padding: 0.625rem 0;
    width: 90%;
    margin-top: 0px;
  }
}

.c-button.-suport {
  background-color: #e7235f;
  color: #fff;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.06em;
  padding: 0.625rem 0;
  position: relative;
  width: 40%;
}

@media screen and (max-width: 768px) {
  .c-button.-suport {
    font-size: 0.9375rem;
    padding: 0.625rem 0;
    width: 100%;
  }
}

.btn_next {
  padding-left: 0.75rem;
  vertical-align: middle;
}

.c-link {
  text-align: right;
}

.c-link a {
  display: inline-block;
  font-weight: 500;
  color: #333;
  padding: 0.625rem 2.8125rem;
  border: 1px solid #333;
  position: relative;
}

.c-link a::after {
  position: absolute;
  background-image: url(../image/icon/icon-next.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 8%;
}

.c-link__next {
  vertical-align: middle;
  padding-left: 1.875rem;
}

/*
  センター
*/
.u-text.-center {
  text-align: center;
}

/*
  改行
*/
.new-line {
  display: inline-block;
}

/*
  カラー
*/
.main-color {
  color: #e7235f;
}

.sub-color {
  color: #11488b;
}

/*
  フォント
*/
.font-bold {
  font-weight: bold;
}

/*
  Heading
*/
.is-active-drawer .overlay {
  background-color: #212121;
  opacity: 0.5;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120%;
  width: 100%;
  overflow: hidden;
}

/*
  Humburger
*/

.button-humburger {
  display: none;
}

@media screen and (max-width: 1200px) {
  .button-humburger {
    display: block;
    position: absolute;
    top: 0;
    right: 4%;
    bottom: 0;
    left: auto;
    margin: auto 0;
    width: 48px;
    height: 48px;
    border: 0;
    outline: 0;
    padding: 0;
    background-color: transparent;
    cursor: pointer;
    z-index: 10000000;
  }
}

@media screen and (max-width: 768px) {
  .button-humburger {
    right: 2.5%;
  }
}

.humburger {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  display: block;
  width: 24px;
  height: 2px;
  background-color: #e7235f;
  margin: auto;
  border-radius: 4px;
}

.humburger:before,
.humburger:after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 4px;
  background-color: inherit;
  transition: all 0.3s ease-in-out;
}

.humburger:before {
  top: -8px;
}

.humburger:after {
  bottom: -8px;
}

/*
  Header
*/

.p-header {
  width: 100%;
  background-color: #fff;
  box-shadow: 0px 10px 10px -5px rgba(112, 104, 104, 0.1);
}

.js-header.change-color {
  position: fixed;
  background: #fff;
  top: 0;
  box-shadow: 0px 6px 6px -4px rgba(0, 0, 0, 0.1);
  animation-name: headerAnimation;
  animation-duration: 0.5s;
  animation-timing-function: ease-out;
  z-index: 1000000;
}

@keyframes headerAnimation {
  0% {
    top: -10%;
  }
  100% {
    top: 0;
  }
}

@media screen and (max-width: 1200px) {
  .js-header.change-color {
    background-color: #fff;
    padding: 0px;
    box-shadow: 0px 6px 6px -4px rgba(0, 0, 0, 0.1);
  }
}

@media screen and (max-width: 1200px) {
  .p-header {
    position: relative;
    background-color: #fff;
    left: 0;
    width: 100%;
    top: 0;
    transform: none;
    -webkit-transform: translateX(none);
    -ms-transform: translateX(none);
    z-index: 10000;
  }
}

.p-header__title figure {
  width: 150px;
  vertical-align: middle;
}

.p-header__title figure img {
  width: 100%;
  vertical-align: middle;
}

@media screen and (max-width: 768px) {
  .p-header__title figure {
    width: 75%;
  }
}

.p-header__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 95%;
  max-width: 1400px;
  margin: auto;
  padding: 1.0625rem 0;
}

@media screen and (max-width: 1200px) {
  .p-header__body {
    margin: 0 1rem;
    padding: 1.125rem 0;
    width: 90%;
    margin: auto;
    /* box-shadow: 0px 6px 6px -4px rgba(0, 0, 0, 0.1); */
  }
}

@media screen and (max-width: 768px) {
  .p-header__body {
    padding: 0.875rem 0;
    width: 90%;
    margin: auto;
  }
}

.p-global__box {
  display: flex;
  align-items: center;
}

@media screen and (max-width: 1400px) {
  .p-global__box {
    padding-left: 0;
  }
}

.p-global-nav {
  display: flex;
  transform: translateX(0);
  align-items: center;
  position: relative;
}

@media screen and (max-width: 1200px) {
  .p-global-nav {
    overflow-y: scroll;
    position: fixed;
    -webkit-overflow-scrolling: touch;
    top: 0;
    /* left: 0; */
    right: 0;
    bottom: 0;
    /* width: 100%; */
    width: 80%;
    height: 120%;
    background: #fff;
    z-index: 1000;
    display: block;
    transition: transform 0.3s ease-in-out;
    transform: translateX(100%);
    -webkit-transform: translateX(100%); /* Android, Brackberry  */
    -ms-transform: translateX(100%); /* IE9 */
    padding: 6.25rem 0;
  }

  .is-active-drawer .p-global-nav {
    -webkit-transform: translateX(0); /* Android, Brackberry  */
    -ms-transform: translateX(0); /* IE9 */
    transform: translateX(0);
  }

  .is-active-drawer .humburger {
    background-color: transparent;
  }

  .is-active-drawer .humburger:before,
  .is-active-drawer .humburger:after {
    top: 0;
    bottom: 0;
    background-color: #e7235f;
  }

  .is-active-drawer .humburger:before {
    transform: rotate(-45deg);
  }

  .is-active-drawer .humburger:after {
    transform: rotate(45deg);
  }

  .is-active-drawer .drawer_bg {
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    background-color: rgba(51, 51, 51, 0.6);
  }

  .fixed {
    width: 100%;
    height: 100%;
    position: fixed;
  }
}

@media screen and (max-width: 576px) {
  .p-global-nav {
    padding: 3.375rem 0 10rem;
  }
}

.p-global-nav__item {
  position: relative;
  margin-right: 3.125rem;
}

.p-global-nav__hasitem {
  position: relative;
  padding-right: 4.375rem;
}

@media screen and (max-width: 1200px) {
  .p-global-nav__hasitem {
    /* border-top: 1px solid #e6e6e6; */
    border-bottom: 1px solid #e6e6e6;
    font-weight: bold;
    padding: 1.875rem 2.5rem;
    font-size: 1.125rem;
    background-position: 90% center;
  }

  .p-global-nav__hasitem:hover {
    background-position: 90% center;
  }

  .p-global-nav__item {
    margin-right: 0;
    border-bottom: 1px solid #e6e6e6;
  }
}

@media screen and (max-width: 576px) {
  .p-global-nav__hasitem {
    padding: 0;
  }
}

.p-global-nav__item a,
.p-global-nav__hasitem a {
  display: block;
  font-size: 0.875rem;
  color: #222;
  position: relative;
}

@media screen and (max-width: 1200px) {
  .p-global-nav__item a,
  .p-global-nav__hasitem a {
    font-weight: bold;
    padding: 1.875rem 2.5rem;
    font-size: 1.125rem;
  }

  .p-global-nav__hasitem a {
    padding: 0;
  }
}

@media screen and (max-width: 768px) {
  .p-global-nav__hasitem a {
    padding: 0 0 10px 1.25rem;
    font-size: 0.875rem;
  }
}

@media screen and (max-width: 768px) {
  .p-global-nav__item a {
    padding: 10px 0 10px 1.25rem;
    font-size: 0.875rem;
  }
}

/*headerの矢印*/
.p-global-nav__hasitem::before {
  content: "";
  position: absolute;
  left: 60%;
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 6px;
  border-top: 2px solid#e7235f;
  border-right: 2px solid#e7235f;
  transform: rotate(135deg);
}

/*2階層目のul*/
.p-global-nav__subitem {
  position: absolute;
  left: 0;
  top: 50px;
  z-index: 1000;
  background: #e7235f;
  width: 180px;
  visibility: hidden;
  opacity: 0;
  transition: all 0.3s;
}

/*hoverしたら2階層目を表示させる*/
.p-global-nav__hasitem:hover > ul,
.p-global-nav__hasitem:active > ul {
  visibility: visible;
  opacity: 1;
}

/*表示させたaタグのデザイン*/
.p-global-nav__subitem li a {
  color: #fff;
  border-bottom: 1px solid #fff;
  padding: 0.625rem 1rem;
  z-index: 1000;
}

@media screen and (max-width: 1200px) {
  .p-global-nav__hasitem::before {
    left: 85%;
    width: 10px;
    height: 10px;
  }

  .p-global-nav__subitem {
    position: static;
    left: 0;
    top: 0;
    width: 100%;
    visibility: visible;
    opacity: 1;
    transition: none;
    margin: 30px 0 20px;
  }

  .p-global-nav__hasitem.active::before {
    transform: rotate(-45deg);
  }

  .p-global-nav__subitem li a {
    border-bottom: 10px solid #fff;
  }
}

@media screen and (max-width: 768px) {
  .p-global-nav__subitem {
    width: 90%;
    margin: 0px auto 10px;
  }
}

/*
  Hero
*/
.p-hero {
  background-image: url("../image/front/hero-bg@2x.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.p-hero {
  padding: 5rem 0;
}

@media screen and (max-width: 768px) {
  .p-hero {
    padding: 30px 0 60px;
  }
}

/* @media screen and (max-width: 1800px) {
  .swiper.swiper1 {
    padding: 5em 0 1.875rem;
  }
}

@media screen and (max-width: 1400px) {
  .swiper.swiper1 {
    padding: 4.0625rem 0 3.125rem;
  }
}

@media screen and (max-width: 1200px) {
  .swiper.swiper1 {
    padding: 9.375rem 0 3.125rem;
  }
}

@media screen and (max-width: 992px) {
  .swiper.swiper1 {
    padding: 8.125rem 0 4.375rem;
  }
}

@media screen and (max-width: 576px) {
  .swiper.swiper1 {
    padding: 6.25rem 0 2.5rem;
  }
} */

.p-hero__inner {
  position: relative;
}

:root {
  --swiper-pagination-top: 100%;
}

@media screen and (max-width: 768px) {
  :root {
    --swiper-pagination-top: 102%;
  }
}

.swiper-wrapper.swiper-slide {
  height: auto;
}

.swiper-pagination-swiper1,
.swiper-pagination-swiper2 {
  text-align: center;
}

.swiper-pagination-swiper2 {
  margin-top: 20px;
}

.swiper-pagination-swiper2 > .swiper-pagination-bullet {
  height: 10px;
  width: 10px;
}

.swiper-button-prev.swiper-button-prev2,
.swiper-button-next.swiper-button-next2 {
  width: 32px;
  height: 32px;
  margin-top: -16px;
}
.swiper-button-prev.swiper-button-prev2 {
  left: -3%;
  background: url(../image/front/icon-prev.png) no-repeat center center / contain;
}

@media screen and (max-width: 768px) {
  .swiper-button-prev.swiper-button-prev2 {
    background: none;
  }
}

.swiper-button-prev.swiper-button-prev2::after {
  content: "";
}

.swiper-button-next.swiper-button-next2 {
  right: -3%;
  background: url(../image/front/icon-next.png) no-repeat center center / contain;
}

@media screen and (max-width: 768px) {
  .swiper-button-next.swiper-button-next2 {
    background: none;
  }
}

.swiper-button-next.swiper-button-next2::after {
  content: "";
}

.swiper-container {
  position: relative;
}

.p-hero__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  margin: auto;
  width: 66%;
}

@media screen and (max-width: 1800px) {
  .p-hero__body {
    width: 83%;
  }
}

@media screen and (max-width: 1400px) {
  .p-hero__body {
    width: 90%;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__body {
    display: block;
    width: 90%;
  }
}

.p-hero__left {
  width: 48%;
  padding-right: 2%;
}

@media screen and (max-width: 1400px) {
  .p-hero__left {
    width: 50%;
    padding-right: 1%;
  }
}

@media screen and (max-width: 992px) {
  .p-hero__left {
    width: 55%;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__left {
    width: 100%;
    padding-right: 0%;
  }
}

.p-hero__right {
  width: 50%;
}

@media screen and (max-width: 1400px) {
  .p-hero__right {
    width: 49%;
  }
}

@media screen and (max-width: 992px) {
  .p-hero__right {
    width: 44%;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__right {
    width: 65%;
    padding-bottom: 0.9375rem;
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__right {
    width: 80%;
  }
}

@media screen and (max-width: 360px) {
  .p-hero__right {
    width: 95%;
  }
}

.p-hero__subttl {
  display: flex;
  padding: 2.0625rem 0;
  justify-content: space-between;
}

@media screen and (max-width: 1200px) {
  .p-hero__subttl {
    padding: 1.5rem 0;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__subttl {
    padding: 1.125rem 0;
  }
}

.p-hero__subttl li + li {
  padding-left: 1.875rem;
}

@media screen and (max-width: 768px) {
  .p-hero__subttl li + li {
    padding-left: 0;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__subttl li + li {
    padding-left: 0.875rem;
  }
}

.p-hero__litetext {
  font-size: 1rem;
  line-height: 1.75;
  padding: 1rem 0 2rem;
}

@media screen and (max-width: 992px) {
  .p-hero__litetext {
    font-size: 0.9375rem;
    padding-bottom: 0rem;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__litetext {
    font-size: 1.0625rem;
    text-align: center;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__litetext {
    font-size: 0.875rem;
    width: 100%;
    padding: 0.625rem 0;
  }
}

.p-hero__text {
  font-size: 1rem;
  line-height: 1.75;
  padding: 2rem 0 2.75rem;
}

@media screen and (max-width: 992px) {
  .p-hero__text {
    font-size: 0.9375rem;
    padding-bottom: 2.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__text {
    font-size: 1.0625rem;
    text-align: center;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__text {
    font-size: 0.875rem;
    width: 100%;
    padding: 0.625rem 0;
  }
}

.p-hero__litelogo {
  padding-bottom: 1.75rem;
}

@media screen and (max-width: 992px) {
  .p-hero__litelogo {
    padding-bottom: 1.25rem;
    width: 20%;
  }

  .p-hero__litelogo img {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__litelogo {
    padding-bottom: 1.25rem;
    width: 20%;
    margin: auto;
  }

  .p-hero__litelogo img {
    width: 100%;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__litelogo {
    padding-bottom: 1rem;
    width: 30%;
    margin: auto;
  }

  .p-hero__litelogo img {
    width: 100%;
  }
}

.p-hero__litesub {
  font-size: 1.3125rem;
  font-weight: bold;
}

@media screen and (max-width: 576px) {
  .p-hero__litesub {
    font-size: 1.125rem;
  }
}

.p-hero__img img {
  width: 100%;
}

.p-hero__copy {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  line-height: 1.625;
}

@media screen and (max-width: 992px) {
  .p-hero__copy {
    font-size: 1.75rem;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__copy {
    font-size: 2.125rem;
    text-align: center;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__copy {
    font-size: 1.6875rem;
    line-height: 1.4;
  }
}

@media screen and (max-width: 360px) {
  .p-hero__copy {
    font-size: 1.625rem;
  }
}

.p-hero__copyimg {
  width: 100%;
}

@media screen and (max-width: 1400px) {
  .p-hero__copyimg {
    width: 35vw;
  }
}

@media screen and (max-width: 1200px) {
  .p-hero__copyimg {
    width: 40vw;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__copyimg {
    width: 100%;
  }
}

@media screen and (max-width: 576px) {
  .p-hero__copy {
    width: 100%;
  }

  .p-hero__copyimg {
    width: 100%;
  }
}

@media screen and (max-width: 1400px) {
  .p-hero__subttl {
    width: 34vw;
  }

  .p-hero__subimg {
    width: 100%;
  }
}

@media screen and (max-width: 1200px) {
  .p-hero__subimg {
    width: 11vw;
  }
}

@media screen and (max-width: 1200px) {
  .p-header__cta {
    text-align: center;
    padding-top: 2.5rem;
  }

  .p-header__cta a {
    width: 80%;
  }
}

@media screen and (max-width: 768px) {
  .p-header__cta {
    padding-top: 1.25rem;
  }
}

.p-header__cta:nth-of-type(2) {
  padding-left: 10px;
}

@media screen and (max-width: 1200px) {
  .p-header__cta:nth-of-type(2) {
    padding-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .p-hero__subttl {
    width: 65%;
    margin: auto;
  }

  .p-hero__cta {
    width: 80%;
    margin: auto;
  }

  .p-hero__cta a {
    width: 100%;
  }

  .p-header__cta {
    width: 90%;
    margin: auto;
    padding-top: 0.75rem;
  }

  .p-header__cta a {
    width: 100%;
  }
}

/*
  Heading
*/
.heading-primary {
  font-size: 2.125rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.015rem;
}

@media screen and (max-width: 1200px) {
  .heading-primary {
    font-size: 2rem;
  }
}

@media screen and (max-width: 992px) {
  .heading-primary {
    font-size: 1.625rem;
  }
}

@media screen and (max-width: 768px) {
  .heading-primary {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .heading-primary {
    font-size: 1.375rem;
    line-height: 1.5;
  }
}

.heading-secondry {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.4;
}

@media screen and (max-width: 992px) {
  .heading-secondry {
    text-align: center;
  }
}

@media screen and (max-width: 576px) {
  .heading-secondry {
    font-size: 1.625rem;
    line-height: 1.4;
  }
}

.heading-secondry span {
  font-size: 1.3125rem;
  font-weight: 500;
  display: block;
  padding-bottom: 1rem;
}

@media screen and (max-width: 576px) {
  .heading-secondry span {
    font-size: 1.125rem;
    padding-bottom: 0.625rem;
  }
}

.sub-ttl {
  font-size: 1.0625rem;
  font-weight: bold;
  padding-bottom: 1.4375rem;
  letter-spacing: 0.06em;
  display: inline-block;
}

.sub-ttl.-white {
  color: #fff;
}

@media screen and (max-width: 576px) {
  .sub-ttl {
    padding-bottom: 0.3125rem;
  }
}

/*
  common
*/
.secondry-text {
  padding: 2.75rem 0;
}

@media screen and (max-width: 576px) {
  .secondry-text {
    padding: 1.625rem 0;
  }
}

.image-mockup {
  width: 100%;
}

@media screen and (max-width: 992px) {
  .image-mockup {
    width: 70%;
  }
}

@media screen and (max-width: 576px) {
  .image-mockup {
    padding-top: 0;
    width: 90%;
  }
}

/*
  企業ロゴ
*/
.p-logo__container {
  padding: 4.625rem 0;
}

@media screen and (max-width: 576px) {
  .p-logo__container {
    padding: 3.125rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-logo__container {
    padding: 2.5rem 0;
  }
}

.p-logo__item {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  gap: calc(25 / 16 * 1rem) calc(25 / 16 * 1rem);
}

@media screen and (max-width: 768px) {
  .p-logo__item {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: calc(5 / 16 * 1rem) calc(5 / 16 * 1rem);
  }
}

.p-logo__item li figure img {
  width: 100%;
}

/*
  worries
*/

.p-worries {
  position: relative;
  background-color: #f7f8fa;
  box-shadow: 0px 10px 10px -5px rgba(112, 104, 104, 0.1);
}

.p-worries__box::after {
  position: absolute;
  content: "";
  background-image: url(../image/front/problem-bg.svg);
  width: 143px;
  height: 134px;
  background-repeat: no-repeat;
  background-size: contain;
  top: 12%;
  right: 17.5%;
}

@media screen and (max-width: 1200px) {
  .p-worries__box::after {
    right: 10%;
  }
}

@media screen and (max-width: 992px) {
  .p-worries__box::after {
    width: 13%;
    top: 10%;
  }
}

@media screen and (max-width: 576px) {
  .p-worries__box::after {
    top: 18%;
  }
}

.p-worries::after {
  position: absolute;
  content: "";
  box-shadow: 0px 10px 10px -5px rgba(0, 0, 0, 0.1);
  width: 100%;
}

.p-worries__container {
  display: flex;
  max-width: 1038px;
  margin: auto;
  align-items: center;
  padding-top: 3.5rem;
}

@media screen and (max-width: 768px) {
  .p-worries__container {
    padding-top: 3.75rem;
    display: block;
  }
}

@media screen and (max-width: 576px) {
  .p-worries__container {
    padding-top: 1.875rem;
  }
}

.p-worries__container::before {
  position: absolute;
  content: "";
  width: 150px;
  height: 100px;
  background-color: #f7f8fa;
  bottom: 0%;
  display: inline-block;
  z-index: 6;
  left: 50%;
  transform: translateX(-50%);
}

@media screen and (max-width: 992px) {
  .p-worries__container::before {
    height: 50px;
    bottom: 0%;
  }
}

.p-worries__container::after {
  position: absolute;
  content: "";
  /* width: 50px;
  height: 50px; */
  width: 110px;
  height: 110px;
  background-color: #f7f8fa;
  /* bottom: -2%; */
  bottom: -4%;
  left: 50%;
  transform: translate(-50%, 0) rotate(-45deg);
  display: inline-block;
  z-index: 5;
  box-shadow: -14px 13px 12px -5px rgba(112, 104, 104, 0.1);
}

@media screen and (max-width: 992px) {
  .p-worries__container::after {
    width: 50px;
    height: 50px;
    bottom: -4%;
  }
}

@media screen and (max-width: 768px) {
  .p-worries__container::after {
    bottom: -2%;
  }
}

.p-worries__container figure {
  width: 26%;
  margin-right: 9%;
}

@media screen and (max-width: 768px) {
  .p-worries__container figure {
    width: 30%;
    margin-right: 0%;
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-worries__container figure {
    width: 40%;
  }
}

.p-worries__container figure img {
  width: 100%;
}

.p-worries__list {
  width: 65%;
}

@media screen and (max-width: 768px) {
  .p-worries__list {
    width: 100%;
  }
}

.p-worries__list li {
  background-color: #fff;
  padding: 1.25rem 0 1.25rem 2.8125rem;
  font-size: 1.4375rem;
  font-weight: bold;
  letter-spacing: 0.015em;
  line-height: 1.5;
  vertical-align: middle;
}

@media screen and (max-width: 992px) {
  .p-worries__list li {
    font-size: 1.25rem;
    padding: 1.25rem 1.25rem 1.25rem 1.875rem;
  }
}

@media screen and (max-width: 768px) {
  .p-worries__list li {
    font-size: 1.125rem;
    width: 90%;
    margin: auto;
    margin-top: 1.875rem;
  }
}

@media screen and (max-width: 576px) {
  .p-worries__list li {
    width: 100%;
    font-size: 1.0625rem;
    padding: 1.25rem 1.4375rem;
  }
}

.p-worries__list li + li {
  margin-top: 0.875rem;
}

.p-worries__list li img {
  padding-right: 1.125rem;
  vertical-align: middle;
}

@media screen and (max-width: 576px) {
  .p-worries__list li img {
    padding-right: 0.625rem;
    width: 35px;
  }
}

/*
  problem
*/

.p-problem__message {
  font-size: 2.3125rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  text-align: center;
}

@media screen and (max-width: 992px) {
  .p-problem__message {
    font-size: 1.75rem;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__message {
    font-size: 1.5rem;
    line-height: 1;
  }
}

.p-problem__message img {
  vertical-align: middle;
}

@media screen and (max-width: 576px) {
  .p-problem__message img {
    width: 120px;
  }
}

.p-problem__message span {
  font-size: 3rem;
}

@media screen and (max-width: 992px) {
  .p-problem__message span {
    font-size: 2.3125rem;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__message span {
    font-size: 1.875rem;
  }
}

.p-problem__box {
  background: #fff;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.16);
  margin-top: 100px;
  padding: 4.25rem 6.0625rem 3.375rem 12.1875rem;
}

@media screen and (max-width: 1200px) {
  .p-problem__box {
    padding: 4.25rem 3.375rem;
  }
}

@media screen and (max-width: 992px) {
  .p-problem__box {
    padding: 4.25rem 1.875rem 2.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-problem__box {
    padding: 3.125rem 1.875rem 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__box {
    margin-top: 1.875rem;
    padding: 2.5rem 1.4375rem;
  }
}

.p-problem__text {
  font-size: 1.8125rem;
  font-weight: bold;
  line-height: 1.7;
  text-align: center;
}

@media screen and (max-width: 992px) {
  .p-problem__text {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__text {
    font-size: 1.25rem;
  }
}

.p-problem__text span {
  font-size: 2.1875rem;
}

@media screen and (max-width: 992px) {
  .p-problem__text span {
    font-size: 1.875rem;
  }
}

@media screen and (max-width: 768px) {
  .p-problem__text span {
    font-size: 1.75rem;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__text span {
    font-size: 1.4375rem;
  }
}

.p-problem__inner {
  position: relative;
  display: flex;
  padding-top: 2.3125rem;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 768px) {
  .p-problem__inner {
    display: block;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__inner {
    padding-top: 1.4375rem;
  }
}

.p-problem__inner figure img {
  width: 100%;
}

@media screen and (max-width: 1200px) {
  .p-problem__inner figure {
    width: 45%;
  }
}

@media screen and (max-width: 1200px) {
  .p-problem__inner figure {
    width: 35%;
  }
}

@media screen and (max-width: 768px) {
  .p-problem__inner figure {
    width: 80%;
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__inner figure {
    width: 100%;
  }
}

.p-problem__inner::before {
  position: absolute;
  content: "";
  background-image: url(../image/front/problem-bg02.svg);
  top: -3%;
  left: -13%;
  width: 144px;
  height: 244px;
}

@media screen and (max-width: 1200px) {
  .p-problem__inner::before {
    position: absolute;
    content: "";
    background-image: none;
  }
}

.p-problem__right {
  padding-left: 2.9375rem;
}

@media screen and (max-width: 992px) {
  .p-problem__right {
    padding-left: 1.25rem;
  }
}

@media screen and (max-width: 768px) {
  .p-problem__right {
    padding-top: 1.875rem;
    padding-left: 0;
    width: 90%;
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__right {
    width: 100%;
  }
}

.p-problem__result {
  font-size: 1.875rem;
  font-weight: bold;
  border-left: 4px solid #e7235f;
  padding-left: 1.875rem;
}

@media screen and (max-width: 992px) {
  .p-problem__result {
    font-size: 1.625rem;
    line-height: 1.5;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__result {
    font-size: 1.375rem;
    line-height: 1.5;
    padding-left: 1rem;
    border-left: 3px solid #e7235f;
  }
}

.p-problem__item {
  border-left: 4px solid #d7d7d7;
  padding: 2.0625rem 0 1.125rem 1.875rem;
}

@media screen and (max-width: 768px) {
  .p-problem__item {
    padding: 1.125rem 0 1.125rem 1.875rem;
  }
}

@media screen and (max-width: 576px) {
  .p-problem__item {
    padding: 1rem 0 1rem 1.25rem;
    border-left: 3px solid #d7d7d7;
  }
}

.p-problem__item li + li {
  padding-top: 0.625rem;
}

.p-problem__item li img {
  padding-right: 0.625rem;
}

.p-point {
  padding-top: 2.5rem;
}

@media screen and (max-width: 768px) {
  .p-point {
    padding-top: 0;
  }
}

.p-point__contents {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4.0625rem 7.1875rem;
}

@media screen and (max-width: 1200px) {
  .p-point__contents {
    padding: 4.0625rem 3.375rem;
  }
}

@media screen and (max-width: 992px) {
  .p-point__contents {
    padding: 3rem 3.375rem;
  }
}

@media screen and (max-width: 768px) {
  .p-point__contents {
    display: block;
    padding: 4.0625rem 1.25rem;
  }
}

@media screen and (max-width: 576px) {
  .p-point__contents {
    padding: 2.5rem 1rem;
  }
}

.p-point__contents.-reverse {
  flex-direction: row-reverse;
  background-color: #fafafa;
}

.p-point__text {
  padding-right: 12.1875rem;
}

@media screen and (max-width: 1200px) {
  .p-point__text {
    padding-right: 6.25rem;
  }
}

@media screen and (max-width: 992px) {
  .p-point__text {
    padding-right: 3.75rem;
  }
}

@media screen and (max-width: 768px) {
  .p-point__text {
    padding-right: 0;
  }
}

.p-point__text.-reverse {
  padding-right: 0;
  padding-left: 11.25rem;
}

@media screen and (max-width: 1200px) {
  .p-point__text.-reverse {
    padding-right: 0;
    padding-left: 6.25rem;
  }
}

@media screen and (max-width: 768px) {
  .p-point__text.-reverse {
    padding-left: 0;
  }
}

.p-point__primary {
  font-size: 2rem;
  letter-spacing: 0.015em;
  line-height: 1.7;
  border-left: 4px solid #e7235f;
  padding-left: 1.875rem;
}

@media screen and (max-width: 1200px) {
  .p-point__primary {
    font-size: 1.875rem;
  }
}

@media screen and (max-width: 992px) {
  .p-point__primary {
    font-size: 1.625rem;
    line-height: 1.5;
  }
}

@media screen and (max-width: 768px) {
  .p-point__primary {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-point__primary {
    font-size: 1.375rem;
    padding-left: 1rem;
    border-left: 3px solid #e7235f;
  }
}

.p-point__primary span {
  font-size: 1.0625rem;
  letter-spacing: 0.06em;
}

@media screen and (max-width: 768px) {
  .p-point__primary span {
    font-size: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .p-point__image {
    padding-top: 1.25rem;
    width: 40%;
    margin: auto;
  }

  .p-point__image img {
    width: 100%;
  }
}

@media screen and (max-width: 576px) {
  .p-point__image {
    padding-top: 0;
  }
}

.p-point p {
  border-left: 4px solid #d7d7d7;
  padding: 1.125rem 0 1.125rem 1.875rem;
  line-height: 1.75;
}

@media screen and (max-width: 768px) {
  .p-point p {
    padding: 1.125rem 0 1rem 1.25rem;
  }
}

@media screen and (max-width: 576px) {
  .p-point p {
    padding-left: 1rem;
    border-left: 3px solid #d7d7d7;
  }
}

.p-point p.p-point__wt {
  border-left: 4px solid #fff;
}

@media screen and (max-width: 576px) {
  .p-point p.p-point__wh {
    border-left: 3px solid #fff;
  }
}

/*
  features
*/
.p-features {
  background-color: #fafafa;
}

.p-features__contents li {
  background: #fff;
  padding: 4.25rem 0 3rem;
  font-size: 1.25rem;
  font-weight: bold;
  letter-spacing: 0.015em;
  text-align: center;
}

@media screen and (max-width: 576px) {
  .p-features__contents li {
    font-size: 1rem;
    padding: 2.125rem 0 1.85rem;
    flex-direction: column;
  }
}

.p-features__contents li figure {
  width: 120px;
  margin: auto;
  padding-bottom: 2.5rem;
}

@media screen and (max-width: 576px) {
  .p-features__contents li figure {
    padding-bottom: 1rem;
    width: 40%;
    margin: auto;
  }

  .p-features__contents li figure img {
    width: 100%;
  }
}

.p-features__btn {
  padding-top: 5rem;
}

@media screen and (max-width: 992px) {
  .p-features__btn {
    padding-top: 3.125rem;
  }
}

.p-features__btn a::after {
  position: absolute;
  background-image: url(../image/front/icon-contact.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 10%;
}

.p-features__contents p {
  margin-top: auto;
}

/*
  reason
*/
.p-reason__contents {
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
}

.p-reason__ttl {
  font-size: 1.0625rem;
  letter-spacing: 0.06em;
  font-weight: bold;
  color: #b8b8b8;
  display: inline-block;
  line-height: 1.3;
}

@media screen and (max-width: 576px) {
  .p-reason__ttl {
    font-size: 1rem;
  }
}

.p-reason__ttl span {
  font-size: 2.75rem;
  color: #11488b;
  padding-left: 7px;
  display: inline-block;
}

@media screen and (max-width: 576px) {
  .p-reason__ttl span {
    font-size: 2.125rem;
  }
}
.p-reason__box {
  position: relative;
  background-color: #f7f8fa;
  padding: 4.375rem 2.875rem 5.125rem;
  margin-top: 5.9375rem;
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
}

@media screen and (max-width: 1200px) {
  .p-reason__box {
    padding: 4.375rem 1.875rem 5.125rem;
  }
}

@media screen and (max-width: 768px) {
  .p-reason__box {
    margin-top: 3.125rem;
  }
}

@media screen and (max-width: 576px) {
  .p-reason__box {
    padding: 3rem 2.5rem 2.5rem;
    margin-top: 3.125rem;
  }
}

.p-reason__box.-box01::before {
  position: absolute;
  content: "";
  background-image: url(../image/front/reason01.svg);
  width: 126px;
  height: 126px;
  top: -20%;
  left: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateX(-50%);
}

@media screen and (max-width: 1200px) {
  .p-reason__box.-box01::before {
    top: -20%;
  }
}

@media screen and (max-width: 992px) {
  .p-reason__box.-box01::before {
    top: -30%;
  }
}

@media screen and (max-width: 576px) {
  .p-reason__box.-box01::before {
    width: 100px;
    height: 100px;
  }
}

@media screen and (max-width: 360px) {
  .p-reason__box.-box01::before {
    top: -20%;
  }
}

.p-reason__box.-box02::before {
  position: absolute;
  content: "";
  background-image: url(../image/front/reason02.svg);
  width: 150px;
  height: 121px;
  top: -20%;
  left: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateX(-50%);
}

@media screen and (max-width: 1200px) {
  .p-reason__box.-box02::before {
    top: -18%;
  }
}

@media screen and (max-width: 992px) {
  .p-reason__box.-box02::before {
    top: -25%;
  }
}

@media screen and (max-width: 576px) {
  .p-reason__box.-box02::before {
    width: 100px;
    height: 100px;
    top: -17%;
  }
}

@media screen and (max-width: 360px) {
  .p-reason__box.-box02::before {
    top: -15%;
  }
}

.p-reason__box.-box03::before {
  position: absolute;
  content: "";
  background-image: url(../image/front/reason03.svg);
  width: 118px;
  height: 128px;
  top: -20%;
  left: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateX(-50%);
}

@media screen and (max-width: 992px) {
  .p-reason__box.-box03::before {
    top: -25%;
  }
}

@media screen and (max-width: 576px) {
  .p-reason__box.-box03::before {
    width: 100px;
    height: 100px;
  }
}

@media screen and (max-width: 360px) {
  .p-reason__box.-box03::before {
    top: -16%;
  }
}

.p-reason__box h3 {
  font-size: 1.625rem;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}

@media screen and (max-width: 576px) {
  .p-reason__box h3 {
    font-size: 1.375rem;
  }
}

.p-reason__box p {
  padding-top: 1.75rem;
  line-height: 1.75;
}

@media screen and (max-width: 576px) {
  .p-reason__box p {
    padding-top: 1.25rem;
  }
}

@media screen and (max-width: 768px) {
  .p-reason__item.-reason02 {
    padding: 40px 0;
  }
}

@media screen and (max-width: 576px) {
  .p-reason__item.-reason02 {
    padding: 20px 0;
  }
}

/*
  case
*/
.p-case {
  background-color: #f7f8fa;
}

.p-case__box {
  background-color: #fff;
  padding: 2.375rem 2.8125rem 3.125rem;
  flex-direction: column;
  display: flex;
  flex: 1 0 auto;
}

@media screen and (max-width: 992px) {
  .p-case__box {
    padding: 2.375rem 1.4375rem 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-case__box {
    padding: 1.25rem 1.4375rem 1.875rem;
  }
}

.p-case__image img {
  width: 100%;
}

.p-case__box h3 {
  background-color: #f7f8fa;
  color: #11488b;
  padding: 0.4375rem 0.75rem;
  font-weight: bold;
  width: fit-content;
}

@media screen and (max-width: 992px) {
  .p-case__box h3 {
    text-align: center;
    width: 100%;
  }
}

.p-case__box p {
  font-size: 1.5625rem;
  line-height: 1.6;
  font-weight: bold;
  letter-spacing: 0.015em;
  padding: 1.125rem 0 1.5rem;
  text-align: left;
}

@media screen and (max-width: 992px) {
  .p-case__box p {
    font-size: 1.4375rem;
  }
}

@media screen and (max-width: 576px) {
  .p-case__box p {
    font-size: 1.25rem;
    padding: 1rem 0;
  }
}

.p-case__logo {
  margin-top: auto;
}

@media screen and (max-width: 360px) {
  .p-case__logo {
    width: 40%;
  }
}

.p-case__btn {
  padding-top: 3.375rem;
}

.p-case__btn a::after {
  position: absolute;
  background-image: url(../image/front/icon-contact.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 10%;
}

@media screen and (max-width: 768px) {
  .p-case__item02 {
    padding-top: 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-case__item02 {
    padding-top: 1.875rem;
  }
}

@media screen and (max-width: 360px) {
  .p-case__logo img {
    width: 100%;
  }
}

.p-case__logo {
  margin-top: auto;
}

/*
  flow
*/

.p-flow__item {
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
  background-color: #fff;
  padding: 2.9375rem 0;
  text-align: center;
  box-shadow: 0px 0px 6px rgb(0, 0, 0, 0.16);
}

@media screen and (max-width: 576px) {
  .p-flow__item {
    padding: 1.25rem 0;
  }
}

.p-flow__item figure {
  padding: 1.5rem 0 2.125rem;
}

@media screen and (max-width: 576px) {
  .p-flow__item figure {
    padding: 0.625rem 0;
    width: 35%;
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-flow__item figure img {
    width: 100%;
  }
}

.p-flow__ttl {
  font-size: 1.1875rem;
  letter-spacing: 0.06em;
}

@media screen and (max-width: 576px) {
  .p-flow__ttl {
    font-size: 1rem;
  }
}

.p-flow__text {
  font-size: 1.25rem;
  letter-spacing: 0.015em;
}

@media screen and (max-width: 992px) {
  .p-flow__text {
    margin-top: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-flow__text {
    font-size: 1rem;
  }
}

.p-flow__contents li + li {
  position: relative;
}

.p-flow__contents li + li::before {
  position: absolute;
  content: "";
  background-image: url(../image/qconeLite/qconelite-flow-icon.svg);
  width: 37px;
  height: 23px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  left: -20%;
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (max-width: 992px) {
  .p-flow__contents li + li::before {
    left: -13%;
  }

  .p-flow__contents li:nth-child(4):before {
    display: none;
  }
}

@media screen and (max-width: 576px) {
  .p-flow__contents li + li::before {
    left: -15%;
    width: 28px;
  }
}

/*
  subscription
*/

.p-subscription {
  background-image: url("../image/front/qconelite-bg.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.p-subscription p {
  font-size: 1.75rem;
  letter-spacing: 0.015em;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 992px) {
  .p-subscription p {
    font-size: 1.5rem;
    line-height: 1.6;
  }
}

.p-subscription__box {
  background: #fff;
  display: flex;
  justify-content: space-between;
  padding: 1.5625rem 4.25rem 1.5625rem 5.5625rem;
  align-items: center;
  margin-top: 2.625rem;
}

@media screen and (max-width: 1200px) {
  .p-subscription__box {
    padding: 1.5625rem 2.5rem 1.5625rem;
  }
}

@media screen and (max-width: 768px) {
  .p-subscription__box {
    padding: 1.875rem 2.5rem;
    margin-top: 1.875rem;
  }
}

@media screen and (max-width: 576px) {
  .p-subscription__box {
    display: block;
    padding: 2.125rem 1.25rem;
  }
}

.p-subscription__box p {
  text-align: left;
  font-size: 1.875rem;
  line-height: 1.7;
}

@media screen and (max-width: 1200px) {
  .p-subscription__box p {
    font-size: 1.625rem;
  }
}

@media screen and (max-width: 992px) {
  .p-subscription__box p {
    font-size: 1.5rem;
    padding-left: 2.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-subscription__box p {
    font-size: 1.375rem;
    padding-left: 2.5rem;
    line-height: 1.7;
    width: 73%;
  }
}

@media screen and (max-width: 768px) {
  .p-subscription__box p {
    font-size: 1.25rem;
  }
}

@media screen and (max-width: 576px) {
  .p-subscription__box p {
    width: 100%;
    text-align: center;
    padding-left: 0;
    line-height: 1.4;
    padding-top: 1rem;
  }
}

.p-subscription__box figure img {
  width: 100%;
}

@media screen and (max-width: 1200px) {
  .p-subscription__logo {
    width: 23%;
  }
}

@media screen and (max-width: 768px) {
  .p-subscription__logo {
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-subscription__logo {
    width: 40%;
    margin: auto;
  }
}

@media screen and (max-width: 1200px) {
  .p-subscription__image {
    width: 23%;
  }
}

@media screen and (max-width: 768px) {
  .p-subscription__image {
    display: none;
  }
}

.p-subscription__btn {
  padding-top: 2.5rem;
}

.p-subscription__btn a::after {
  position: absolute;
  background-image: url(../image/front/icon-next-wt.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 10%;
}

/*
  cta
*/

.p-cta {
  background-image: url("../image/common/cv-bg@2x.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 5rem 0;
}

@media screen and (max-width: 768px) {
  .p-cta {
    padding: 3.125rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-cta__ttl {
    padding: 3.125rem 0 3.75rem;
  }
}

.p-cta__ttl {
  font-size: 2rem;
  letter-spacing: 0.1em;
  line-height: 1.8;
  text-align: center;
  text-shadow: 0px 3px 6px rgb(0, 0, 0, 0.16);
  color: #fff;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
  .p-cta__ttl {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-cta__ttl {
    padding: 0;
    font-size: 1.375rem;
    line-height: 1.7;
  }
}

.p-cta__text {
  padding-top: 2.0625rem;
  line-height: 1.75;
  text-align: center;
  text-shadow: 0px 3px 6px rgb(0, 0, 0, 0.16);
  color: #fff;
  font-weight: bold;
}

@media screen and (max-width: 576px) {
  .p-cta__text {
    padding-top: 0.875rem;
    font-size: 0.875rem;
  }
}

.p-cta__box {
  padding-top: 3.375rem;
}

@media screen and (max-width: 700px) {
  .p-cta__box {
    padding-top: 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-cta__box {
    padding-top: 1.25rem;
  }
}

.p-cta__box ul {
  display: flex;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-cta__box ul {
    display: block;
  }
}

.p-cta__box ul li {
  flex-grow: 1;
  position: relative;
}

.p-cta__box ul li:nth-child(1):after,
.p-cta__box ul li:nth-child(2)::after {
  position: absolute;
  content: "";
  background-color: rgb(255, 255, 255, 0.2);
  width: 1px;
  height: 100%;
  top: 0;
  left: 100%;
}

@media screen and (max-width: 700px) {
  .p-cta__box ul li:nth-child(1):after,
  .p-cta__box ul li:nth-child(2)::after {
    display: none;
  }
}

@media screen and (max-width: 700px) {
  .p-cta__box ul li:nth-child(2) {
    padding: 1.25rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-cta__box ul li:nth-child(2) {
    padding: 1.375rem 0;
  }
}

.p-cta__box ul li p {
  padding-top: 1.875rem;
}

@media screen and (max-width: 700px) {
  .p-cta__box ul li p {
    padding-top: 1.25rem;
  }
}

@media screen and (max-width: 768px) {
  .p-cta__box ul li figure img {
    width: 100px;
  }
}

@media screen and (max-width: 576px) {
  .p-cta__box ul li figure {
    width: 25%;
    margin: auto;
  }

  .p-cta__box ul li figure img {
    width: 100%;
  }
}

.p-cta__btn a::after {
  position: absolute;
  background-image: url(../image/common/icon-next-bl.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 7px;
  height: 11px;
  right: 10%;
}

/*
  topics
*/

.p-article__box {
  display: flex;
  padding: 1.875rem 0;
  padding-right: 6.25rem;
  background-image: url(../image/front/icon-contact.svg);
  background-size: 7px 11px;
  background-repeat: no-repeat;
  background-position: right center;
}

.p-toppics__contents article {
  border-bottom: 2px solid #ececec;
}

.p-toppics__contents article a {
  position: relative;
  left: 0;
}

.p-toppics__contents article a:hover {
  transition: 0.4s;
  left: 20px;
}

@media screen and (max-width: 768px) {
  .p-article__box {
    display: block;
    font-size: 0.875rem;
    padding: 1.375rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-article__box {
    background-image: none;
  }
}

.p-article__text {
  font-weight: bold;
  letter-spacing: 0.015em;
  padding-right: 3.125rem;
  color: #b8b8b8;
}

.p-article__title {
  color: #222;
}

@media screen and (max-width: 768px) {
  .p-article__title {
    padding-top: 0.3125rem;
  }
}

.p-toppics__contents article a:hover {
  transition: 0.4s;
  left: 20px;
}

/*
  footer
*/
.p-footer {
  background-color: #333333;
}

.p-footer__contents {
  max-width: 980px;
  margin: auto;
  padding: 3.75rem 0;
}

.p-footer__nav {
  display: flex;
  justify-content: space-between;
}

.p-footer__item a,
.p-footer__item__last a {
  position: relative;
  font-size: 0.875rem;
  color: #fff;
  display: block;
}

.p-footer__item a::after {
  content: "｜";
  position: absolute;
  display: inline-block;
  bottom: 0;
  padding-left: 4px;
}

.p-footer__item:nth-child(7) a::after {
  display: none;
}

.p-footer__copyright {
  font-size: 0.6875rem;
  color: #fff;
  text-align: center;
  padding-top: 2.1875rem;
}

.p-footerBtn {
  display: none;
}

@media screen and (max-width: 1200px) {
  .p-footerBtn {
    display: block;
    position: fixed;
    width: 100%;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.8);
    padding: 1rem 0;
    z-index: 100;
  }
}

@media screen and (max-width: 768px) {
  .p-footer__nav {
    display: flex;
    flex-wrap: wrap;
    font-size: 14px;
  }

  .p-footer__contents {
    padding: 3.125rem 0;
  }

  .p-footer__item a::after {
    display: none;
  }

  .p-footer__item {
    box-sizing: border-box;
    padding: 20px;
    text-align: left;
    width: 50%;
    border-bottom: 1px solid #fff;
    margin-right: 0;
  }

  .p-footer__item:nth-child(1) {
    border-top: 1px solid #fff;
  }

  .p-footer__item:nth-child(2) {
    border-top: 1px solid #fff;
  }

  .p-footer__item:nth-child(2n-1) {
    border-right: 1px solid #fff;
  }

  .p-footer__copyright {
    padding-top: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-footer__contents {
    padding: 2.5rem 0;
  }

  .p-footer__nav {
    display: block;
    margin: auto;
  }

  .p-footer__item {
    border-bottom: 0px;
    width: 100%;
    text-align: center;
    padding: 0.5rem 0;
  }

  .p-footer__item:nth-child(1) {
    border-top: 0px;
  }

  .p-footer__item:nth-child(2) {
    border-top: 0px;
  }

  .p-footer__item:nth-child(2n-1) {
    border-right: 0px;
  }

  .p-footer__copyright {
    padding-top: 1.25rem;
  }

  .p-footerBtn {
    padding: 0.625rem 0;
  }

  .p-footerBtn__container {
    margin: auto;
    width: 100%;
  }
}

/*リンクの形状*/
#page-top a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #e7235f;
  border-radius: 5px;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none;
  font-size: 0.8125rem;
  font-weight: bold;
  transition: all 0.3s;
}

#page-top a::before {
  content: "";
  position: absolute;
  left: 60%;
  right: 0;
  left: 0;
  margin: 0 auto;
  top: 20%;
  width: 8px;
  height: 8px;
  border-top: 2px solid#fff;
  border-right: 2px solid#fff;
  transform: rotate(-45deg);
}

@media screen and (max-width: 768px) {
  #page-top a {
    width: 60px;
    height: 60px;
    font-size: 0.75rem;
  }
}

#page-top a:hover {
  opacity: 100%;
}

/*リンクを右下に固定*/
#page-top {
  position: fixed;
  right: 50px;
  bottom: 40px;
  z-index: 2;
  /*はじめは非表示*/
  opacity: 0;
  transform: translateY(100px);
}

@media screen and (max-width: 768px) {
  #page-top {
    right: 20px;
    bottom: 20px;
  }
}

@media screen and (max-width: 576px) {
  #page-top {
    right: 10px;
    bottom: 10px;
  }
}

/*　上に上がる動き　*/

#page-top.UpMove {
  animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/*　下に下がる動き　*/

#page-top.DownMove {
  animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 1;
    transform: translateY(200%);
  }
}

/*
  Button
*/
.button {
  position: relative;
  display: block;
  width: 100%;
  background-color: #333;
  color: #fff;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
}
.button-primary {
  padding: 0.875rem;
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1.428;
}
.button-primary:before,
.button-primary:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
}
.button-primary:before {
  background-color: #fff;
  right: 1.5rem;
}

.button-primary:after {
  background-color: #333;
  right: 1.625rem;
}

@media screen and (min-width: 768px) {
  .button {
    width: 320px;
    margin: 0 auto;
  }
}

/*
  Case
----------------------------------------------- */

/*
  heading
*/

.p-heading {
  background-image: url("../image/common/header-bg@2x.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 50px 0 60px;
}

@media screen and (max-width: 768px) {
  .p-heading {
    padding: 25px 0 30px;
  }
}

.p-heading h1 {
  text-align: left;
  font-size: 2.125rem;
  font-weight: bold;
  letter-spacing: 0.015em;
  line-height: 1.58;
}

@media screen and (max-width: 768px) {
  .p-heading h1 {
    font-size: 1.75rem;
  }
}

@media screen and (max-width: 576px) {
  .p-heading h1 {
    font-size: 1.375rem;
  }
}

.p-heading h1 span {
  font-size: 1.0625rem;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .p-heading h1 span {
    font-size: 1rem;
  }
}

@media screen and (max-width: 576px) {
  .p-heading h1 span {
    font-size: 0.625rem;
  }
}

.p-heading.-useful {
  background-image: url("../image/common/header-bg@2x.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 50px 0 50px;
}
@media screen and (max-width: 768px) {
  .p-heading.-useful {
    font-size: 1rem;
    padding: 30px 0 30px;
  }
}

.p-heading.-useful h1 {
  text-align: center;
  font-size: 32px;
}
@media screen and (max-width: 768px) {
  .p-heading.-useful h1 {
    font-size: 22px;
  }
}

/*
  ぱんくずリスト
*/

.pan {
  padding: 2.5rem 0;
  max-width: 1292px;
  margin: auto;
}

@media screen and (max-width: 1300px) {
  .pan {
    width: 90%;
  }
}

@media screen and (max-width: 576px) {
  .pan {
    padding: 1rem 0;
  }
}

#breadcrumbs span.home {
  position: relative;
  padding-right: 1.255rem;
}

@media screen and (max-width: 576px) {
  #breadcrumbs span.home {
    padding-right: 0.625rem;
  }
}

#breadcrumbs span.home::after {
  content: "";
  display: inline-block;
  background-image: url(../image/common/icon-pan.svg);
  width: 6px;
  height: 10px;
  margin-left: 1.25rem;
}

@media screen and (max-width: 576px) {
  #breadcrumbs span.home::after {
    margin-left: 0.625rem;
  }
}

#breadcrumbs span a {
  font-size: 0.875rem;
  color: #222;
}

@media screen and (max-width: 576px) {
  #breadcrumbs span a {
    font-size: 0.8125rem;
  }
}

#breadcrumbs span.layer a {
  color: #b8b8b8;
}

/*
  interview
*/

.p-interview__body {
  padding-top: 6.25rem;
  max-width: 1280px;
  margin: 0 auto;
}

@media screen and (max-width: 992px) {
  .p-interview__body {
    padding-top: 5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-interview__body {
    padding-top: 1.875rem;
  }
}

.tab-area,
.contents-tab-area {
  /* display: flex; */
  cursor: pointer;
  align-items: center;
  justify-content: center;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  gap: 15px;
}

@media screen and (max-width: 1200px) {
  .tab-area,
  .contents-tab-area {
    font-size: 1.4vw;
  }
}

@media screen and (max-width: 992px) {
  .tab-area {
    flex-wrap: wrap;
    font-size: 0.9375rem;
    padding-top: 1.25rem;
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}

@media screen and (max-width: 992px) {
  .contents-tab-area {
    font-size: 0.9375rem;
    padding: 1.25rem 0 1.875rem;
  }
}

@media screen and (max-width: 576px) {
  .tab-area,
  .contents-tab-area {
    font-size: 0.875rem;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
}

@media screen and (max-width: 576px) {
  .contents-tab-area {
    padding: 1rem 0 1.5rem;
  }
}

/* .tab-area li + li,
.contents-tab-area li + li {
  margin-left: 1.625rem;
}

@media screen and (max-width: 1200px) {
  .tab-area li + li,
  .contents-tab-area li + li {
    margin-left: 1rem;
  }
}

@media screen and (max-width: 992px) {
  .tab-area li + li:nth-child(5) {
    margin-top: 0.625rem;
  }
}

@media screen and (max-width: 734px) {
  .tab-area li + li:nth-child(4) {
    margin-top: 0.625rem;
  }
}

@media screen and (max-width: 474px) {
  .tab-area li + li:nth-child(3) {
    margin-top: 0.625rem;
  }
}

@media screen and (max-width: 303px) {
  .tab-area li + li:nth-child(2) {
    margin-top: 0.625rem;
  }
} */

.p-tab__body {
  display: flex;
  margin: auto;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 992px) {
  .p-tab__body {
    display: block;
  }
}

.tab-ttl {
  font-size: 1.25rem;
  font-weight: bold;
  letter-spacing: 0.5em;
  margin-right: 30px;
  white-space: nowrap;
}

@media screen and (max-width: 1200px) {
  .tab-ttl {
    margin-right: 1.875rem;
  }
}

@media screen and (max-width: 992px) {
  .tab-ttl {
    text-align: center;
    margin-right: 0;
  }
}

@media screen and (max-width: 576px) {
  .tab-ttl {
    font-size: 1.125rem;
  }
}

.tab-item {
  letter-spacing: 0.015em;
  line-height: 2;
  white-space: nowrap;
}

.tab {
  text-align: center;
  color: #b8b8b8;
  background-color: #f7f8fa;
  display: block;
  float: left;
  text-align: center;
  font-weight: 500;
  transition: all 0.2s ease;
  border-radius: 50px;
  padding: 10px 15px;
  letter-spacing: 0.015em;
}

@media screen and (max-width: 576px) {
  .tab {
    padding: 5px 0;
  }
}

.tab:hover {
  opacity: 0.9;
}

.tab.active {
  background-color: #222;
  color: #fff;
}

.panel-area {
  padding-top: 3.5rem;
}

@media screen and (max-width: 992px) {
  .panel-area {
    padding-top: 2.1875rem;
  }
}

@media screen and (max-width: 768px) {
  .panel-area {
    padding-top: 0rem;
  }
}

@media screen and (max-width: 576px) {
  .panel-area {
    padding-top: 0.625rem;
  }
}

.panel {
  display: none;
  text-align: center;
}

.panel.active {
  display: block;
}

.p-front-interview {
  position: relative;
  background: #fff;
  padding: 24px 30px 32px;
  display: flex;
  flex-direction: column;
  height: 500px;
}

@media screen and (max-width: 768px) {
  .p-front-interview {
    padding: 20px;
    height: auto;
  }
}

.p-front-interview a ::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: transparent;
  transform: none;
  z-index: 0;
}

.p-front-interview a:hover {
  text-decoration: underline;
  color: #222;
  opacity: 10;
}

.p-front-interview .inner {
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
}

.p-front-interview figure {
  margin-bottom: 18px;
}

@media screen and (max-width: 768px) {
  .p-front-interview figure {
    margin-bottom: 14px;
  }
}

.p-front-interview h3 {
  font-weight: 700;
  color: #11488b;
  font-size: 18px;
  line-height: 1.8;
}

@media screen and (max-width: 768px) {
  .p-front-interview h3 {
    font-size: 15px;
    line-height: 1.7;
  }
}

.p-front-interview__ttl {
  font-size: 22px;
  color: #333;
  font-weight: 700;
  line-height: 1.7;
  padding-top: 10px;
}

@media screen and (max-width: 768px) {
  .p-front-interview__ttl {
    font-size: 18px;
    line-height: 1.7;
    padding-top: 5px;
  }
}

.p-front-interview .category {
  margin-top: auto;
  padding-top: 20px;
  text-align: right;
}

@media screen and (max-width: 768px) {
  .p-front-interview .category {
    padding-top: 14px;
  }
}

.p-front-interview .category p {
  border: 1px solid #222;
  padding: 2px 16px;
  display: inline-block;
}

@media screen and (max-width: 768px) {
  .p-front-interview .category p {
    font-size: 14px;
    line-height: 1.5;
  }
}

.p-interview__box {
  flex-direction: column;
  display: flex;
  position: relative;
}

@media screen and (max-width: 992px) {
  .p-interview__box {
    padding-top: 1.25rem;
  }
}

.p-interview__box a {
  color: #222;
}

.p-interview__box a ::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: transparent;
  transform: none;
  z-index: 0;
}

.p-interview__box a:hover {
  opacity: 1;
  color: #222;
  text-decoration: underline;
}

.p-interview__box h3 {
  color: #11488b;
  font-weight: bold;
  background-color: #f7f8fa;
  display: inline-block;
  padding: 0.4375rem 0;
  font-size: 18px;
  margin-top: 8px;
}

.p-interview__image img {
  width: 100%;
}

.p-interview__ttl {
  font-size: 1.625rem;
  letter-spacing: 0.015em;
  line-height: 1.6;
  font-weight: bold;
  text-align: left;
  padding: 1.25rem 0;
}

@media screen and (max-width: 992px) {
  .p-interview__ttl {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-interview__ttl {
    font-size: 1.125rem;
    line-height: 1.5;
    padding: 1rem 0 0.5rem;
  }
}

.p-interview__text {
  letter-spacing: 0.015em;
  line-height: 1.75rem;
  text-align: left;
  padding-bottom: 1.75rem;
}

@media screen and (max-width: 576px) {
  .p-interview__text {
    padding-bottom: 1rem;
    line-height: 1.6;
  }
}

.p-interview__under {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: auto;
}

.p-interview__category {
  background-color: #fff;
  border: solid 1px #222;
  padding: 0.4375rem 0.75rem;
  display: inline-block;
  line-height: 1.5;
}

@media screen and (max-width: 576px) {
  .p-interview__category {
    font-size: 0.8125rem;
    padding: 0.3125rem 0.75rem;
  }
}

.p-interview__logo img {
  width: 100%;
}

@media screen and (max-width: 1200px) {
  .p-interview__logo {
    width: 50%;
  }
}

@media screen and (max-width: 576px) {
  .p-interview__logo {
    width: 40%;
  }
}

.p-interview__logo-box figure {
  width: 90%;
  margin-left: auto;
}

/*
  F&Q
----------------------------------------------- */

.p-faq__primary {
  font-size: 1.75rem;
  line-height: 1.9;
  font-weight: bold;
  border-left: 4px solid #e7235f;
  padding-left: 1.875rem;
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 576px) {
  .p-faq__primary {
    font-size: 1.25rem;
    padding-left: 1rem;
    border-left: 3px solid #e7235f;
    margin-bottom: 1.875rem;
  }
}

.p-faq__inner {
  padding-top: 7.5rem;
}

@media screen and (max-width: 768px) {
  .p-faq__inner {
    padding-top: 6.25rem;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__inner {
    padding-top: 2.9375rem;
  }
}

.p-faq__contents {
  background-color: #fafafa;
  padding: 3.75rem 0;
}

@media screen and (max-width: 768px) {
  .p-faq__contents {
    padding: 1.5rem 0;
  }
}

.p-faq__contents dl {
  max-width: 1000px;
  margin: auto;
  padding-bottom: 1.25rem;
}

.p-faq__question {
  position: relative;
  background-color: #fff;
  padding: 1.5625rem 7.5rem 1.5625rem 3.125rem;
  display: flex;
  align-items: center;
  cursor: pointer;
  z-index: 1;
  align-items: flex-start;
}

@media screen and (max-width: 1200px) {
  .p-faq__question {
    width: 95%;
    margin: auto;
  }
}

.p-faq__question:after {
  content: "";
  position: absolute;
  right: 3.75rem;
  top: 38%;
  transition: all 0.2s ease-in-out;
  display: block;
  width: 15px;
  height: 15px;
  border-top: solid 4px #e7235f;
  border-right: solid 4px #e7235f;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}

@media screen and (max-width: 768px) {
  .p-faq__question:after {
    right: 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__question:after {
    right: 1rem;
    width: 8px;
    height: 8px;
  }
}

.p-faq__question.open:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 45%;
}

@media screen and (max-width: 1200px) {
  .p-faq__question {
    padding: 1.25rem 6rem 1.25rem 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__question {
    padding: 1rem 2.125rem 1rem 0.875rem;
  }
}

.js-question.is-active + .p-faq__answer {
  height: 100%;
}

.p-faq__text {
  line-height: 2;
  display: inline-block;
  width: 90%;
}

.p-faq__text a {
  text-decoration: none;
  color: #2d6fa3;
  border-bottom: 1.5px solid #2d6fa3;
}

@media screen and (max-width: 1200px) {
  .p-faq__text {
    font-size: 0.875rem;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__text {
    line-height: 1.6;
  }
}

.p-faq__label {
  font-size: 1.8125rem;
  letter-spacing: 0.06em;
  display: inline-block;
  width: 8%;
  padding-right: 2%;
  line-height: 1.2;
}

@media screen and (max-width: 992px) {
  .p-faq__label {
    width: 11%;
  }
}

@media screen and (max-width: 768px) {
  .p-faq__label {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__label {
    font-size: 1.25rem;
    width: 18%;
  }
}

.p-faq__title {
  font-size: 1.1875rem;
  font-weight: bold;
  width: 90%;
}

@media screen and (max-width: 1200px) {
  .p-faq__title {
    font-size: 1.125rem;
    font-weight: bold;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__title {
    font-size: 1rem;
    width: 89%;
    line-height: 1.6;
  }
}

.p-faq__answer {
  display: none;
  padding: 1rem 4.375rem 1.25rem 3.125rem;
  background-color: #fff;
  align-items: flex-start;
}

.p-faq__item {
  display: flex;
}

@media screen and (max-width: 1200px) {
  .p-faq__answer {
    width: 95%;
    margin: auto;
    padding: 1rem 6rem 1.25rem 2.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-faq__answer {
    padding: 0.3125rem 2rem 1rem 1rem;
  }
}

/*
  useful contents
----------------------------------------------- */
.p-useful__body {
  padding-top: 2.5rem;
  max-width: 1292px;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .p-useful__body {
    padding-top: 0px;
  }
}

.useful-tab {
  text-align: center;
  color: #b8b8b8;
  background-color: #f7f8fa;
  display: block;
  float: left;
  text-align: center;
  font-weight: 500;
  transition: all 0.2s ease;
  border-radius: 50px;
  padding: 0.8125rem 2.25rem;
  letter-spacing: 0.015em;
}

@media screen and (max-width: 576px) {
  .useful-tab {
    padding: 0.625rem 2.25rem;
  }
}

.useful-tab:hover {
  opacity: 0.9;
}

.useful-tab.active {
  background-color: #222;
  color: #fff;
}

.p-usefultab__body {
  display: flex;
  max-width: 1400px;
  margin: auto;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 1200px) {
  .p-usefultab__body {
    display: block;
  }
}

.p-contentstab__body {
  display: flex;
  max-width: 1400px;
  margin: auto;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 1300px) {
  .p-contentstab__body {
    display: block;
  }
}

.p-contentstab__body p {
  font-size: 1.25rem;
  font-weight: bold;
  letter-spacing: 0.5em;
  margin-right: 20px;
}

@media screen and (max-width: 1300px) {
  .p-contentstab__body p {
    text-align: center;
    padding-bottom: 1.875rem;
    margin-right: 0;
  }
}

@media screen and (max-width: 992px) {
  .p-contentstab__body p {
    padding-bottom: 0.625rem;
  }

  .contents-tab-area li + li:nth-child(5) {
    margin-left: 0;
    margin-top: 10px;
  }

  .contents-tab-area li + li:nth-child(6) {
    margin-top: 10px;
  }
}

@media screen and (max-width: 576px) {
  .p-contentstab__body p {
    padding-bottom: 0;
  }
}

@media screen and (max-width: 844px) {
  .contents-tab-area li + li:nth-child(4) {
    margin-top: 10px;
  }

  .contents-tab-area li + li:nth-child(5) {
    margin-left: 1rem;
  }
}

@media screen and (max-width: 683px) {
  .contents-tab-area li + li:nth-child(3) {
    margin-top: 10px;
    margin-left: 0;
  }
}

.tab-ttl__useful {
  font-size: 1.25rem;
  font-weight: bold;
  letter-spacing: 0.5em;
  margin-right: 20px;
}

@media screen and (max-width: 1200px) {
  .tab-ttl__useful {
    text-align: center;
    margin-right: 0;
  }
}

.p-useful__box {
  background-color: #fafafa;
  box-shadow: 0px 0px 6px rgb(0, 0, 0, 0.16);
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
}

.p-useful__image img {
  width: 100%;
}

.p-useful__ttl {
  font-size: 1.4375rem;
  letter-spacing: 0.015em;
  font-weight: bold;
  line-height: 1.5;
  padding-top: 1.125rem;
  padding-bottom: 0.895rem;
}

@media screen and (max-width: 576px) {
  .p-useful__ttl {
    font-size: 1.25rem;
    line-height: 1.4;
    padding: 1rem 0 0.625rem;
  }
}

.p-useful__category {
  font-size: 0.9375rem;
  border: 1px solid #e7235f;
  padding: 0 28px;
  width: 148px;
  margin: auto;
}

@media screen and (max-width: 576px) {
  .p-useful__category {
    font-size: 0.8125rem;
  }
}

.p-useful__category.-report {
  font-size: 0.9375rem;
  border: 1px solid #e7235f;
  padding: 0 28px;
  width: 255px;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .p-useful__category.-report {
    width: 85%;
  }
}

.p-useful__category.-introduce {
  font-size: 0.9375rem;
  border: 1px solid #e7235f;
  padding: 0 28px;
  width: 165px;
  margin: auto;
}

.p-useful__text {
  font-size: 0.9375rem;
  text-align: left;
  line-height: 1.8;
  padding: 1.0625rem 1.75rem;
  flex: 2;
  height: 100%;
  min-height: 0%;
}

@media screen and (max-width: 576px) {
  .p-useful__text {
    font-size: 0.875rem;
    line-height: 1.4;
    padding: 0.625rem 1rem 1rem;
  }
}

.p-useful__btn {
  padding: 0 1.75rem 2.12rem 1.75rem;
  margin-top: auto;
}

@media screen and (max-width: 1200px) {
  .p-useful__btn {
    padding: 0 0 2.12rem 0;
    margin-top: auto;
    width: 90%;
    margin: auto;
  }
}

@media screen and (max-width: 576px) {
  .p-useful__btn {
    padding: 0 0 1.25rem 0;
  }
}

.p-useful__btn a::after {
  position: absolute;
  background-image: url(../image/front/icon-next-wt.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 5%;
}

/*
  function
----------------------------------------------- */
.l-contents.-functiontop {
  padding: 3.75rem 0 6.25rem;
}

@media screen and (max-width: 768px) {
  .l-contents.-functiontop {
    padding: 1.25rem 0;
  }
}

.p-function__top {
  max-width: 1000px;
  margin: auto;
}

.p-function__top p {
  font-size: 1.125rem;
  line-height: 1.8;
  padding-bottom: 6.25rem;
}

@media screen and (max-width: 992px) {
  .p-function__top p {
    padding-bottom: 5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-function__top p {
    font-size: 1rem;
    padding-bottom: 3.75rem;
  }
}

@media screen and (max-width: 576px) {
  .p-function__top p {
    font-size: 0.9375rem;
    padding-bottom: 2.5rem;
  }
}

.p-function__top ul {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
}

.p-function__top ul li {
  position: relative;
  font-size: 1.125rem;
  letter-spacing: 0.015em;
  border-left: 1px solid #d8d8d8;
  flex: 1;
}

@media screen and (max-width: 576px) {
  .p-function__top ul li {
    width: 25%;
  }
}

.p-function__top ul li a {
  position: relative;
  font-size: 1.125rem;
  letter-spacing: 0.015em;
  border-left: 1px solid #d8d8d8;
  color: #222;
  display: inline-block;
  padding: 1.375rem 6.875rem 1.375rem 2.5rem;
  background-image: url(../image/function/icon-under.svg);
  background-repeat: no-repeat;
  transition: all 0.3s ease-in-out;
  background-position: 90% center;
}

@media screen and (max-width: 992px) {
  .p-function__top ul li a {
    color: #222;
    display: inline-block;
    padding: 1.375rem 4rem 1.375rem 1.875rem;
    white-space: nowrap;
  }
}

@media screen and (max-width: 768px) {
  .p-function__top ul li a {
    font-size: 0.9375rem;
    padding: 1rem 3.75rem 1rem 1rem;
  }
}

@media screen and (max-width: 700px) {
  .p-function__top ul li a {
    white-space: normal;
    font-size: 0.875rem;
    padding: 1rem 2rem 1rem 1rem;
  }
}

@media screen and (max-width: 576px) {
  .p-function__top ul li a {
    padding: 1rem 2.125rem 1rem 0.625rem;
    font-size: 2.5vw;
  }
}

.p-function__top ul li a:hover {
  background-position: 90% 65%;
}

.p-function__top ul li:nth-child(4) {
  border-right: 1px solid #d8d8d8;
}

/* .p-function__top ul li::after {
  content: "";
  position: absolute;
  background-image: url(../image/function/icon-under.svg);
  width: 12px;
  height: 8px;
  background-repeat: no-repeat;
  top: 0;
  bottom: 0;
  margin: auto 0;
  right: 18%;
} */

/* @media screen and (max-width: 768px) {
  .p-function__top ul li::after {
    right: 10%;
  }
} */

.p-function__contents {
  padding-bottom: 9.375rem;
}

@media screen and (max-width: 768px) {
  .p-function__contents {
    padding-bottom: 6.25rem;
  }
}

@media screen and (max-width: 576px) {
  .p-function__contents {
    padding-bottom: 3.125rem;
  }
}

.p-function__primary {
  background-color: #f7f8fa;
  padding: 4.75rem 0;
  margin-bottom: 4.6875rem;
}

@media screen and (max-width: 768px) {
  .p-function__primary {
    padding: 3.75rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-function__primary {
    padding: 1.25rem 0;
    margin-bottom: 1.875rem;
  }
}

.p-function__primary h2 {
  font-size: 1.5rem;
  font-weight: bold;
  letter-spacing: 0.015em;
  text-align: center;
  line-height: 2;
  padding-top: 1.0625rem;
}

@media screen and (max-width: 768px) {
  .p-function__primary h2 {
    font-size: 1.125rem;
  }
}

@media screen and (max-width: 576px) {
  .p-function__primary h2 img {
    width: 10%;
    padding-bottom: 5px;
  }
}

.p-function__item {
  width: 500px;
  margin: auto;
  text-align: center;
  /*padding-top: ;*/
}

@media screen and (max-width: 576px) {
  .p-function__item {
    width: 85%;
  }
}

.p-function__topimage {
  width: 100%;
  margin: auto;
}

.p-function__topimage img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .p-function__topimage {
    width: 75%;
  }
}

@media screen and (max-width: 576px) {
  .p-function__topimage {
    width: 80%;
  }
}

.p-function__image {
  width: 300px;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .p-function__image {
    width: 100%;
  }
}

@media screen and (max-width: 576px) {
  .p-function__image {
    width: 80%;
    margin: auto;
  }
}

.p-function__image img {
  width: 100%;
}

.p-function__item h3 {
  font-size: 1.375rem;
  letter-spacing: 0.015em;
  line-height: 1.8;
  font-weight: bold;
  padding: 1.625rem 0 1.25rem;
}

@media screen and (max-width: 576px) {
  .p-function__item h3 {
    font-size: 1.125rem;
    padding: 1rem 0 0.3125rem;
  }
}

.p-function__item h3 span {
  font-size: 1rem;
  line-height: 1.8;
  display: inline-block;
  padding-right: 8px;
  color: red;
}

@media screen and (max-width: 576px) {
  .p-function__item h3 {
    font-size: 1.125rem;
    padding: 1rem 0 0.3125rem;
  }
}

.p-function__item p {
  font-size: 1.125rem;
  text-align: left;
  padding-bottom: 1.25rem;
}

@media screen and (max-width: 576px) {
  .p-function__item p {
    font-size: 0.9375rem;
    padding-bottom: 0.625rem;
    line-height: 1.7;
  }
}

.p-function__item ul {
  text-align: left;
}

@media screen and (max-width: 576px) {
  .p-function__item ul {
    font-size: 0.875rem;
  }
}

@media screen and (max-width: 576px) {
  .p-function__item ul li {
    line-height: 1.7;
  }
}

.p-function__point {
  padding-top: 3.125rem;
  max-width: 1100px;
  margin: auto;
  width: 90%;
}

@media screen and (max-width: 576px) {
  .p-function__point {
    padding-top: 1.625rem;
  }
}

.p-point__inner {
  background-color: #fafafa;
  padding: 2.5rem;
}

@media screen and (max-width: 576px) {
  .p-point__inner {
    padding: 1.5rem 1.25rem;
  }
}

.p-point__ttl span {
  font-size: 1.0625rem;
  letter-spacing: 0.06em;
}

@media screen and (max-width: 576px) {
  .p-point__ttl span {
    font-size: 0.8125rem;
  }
}

.p-point__ttl {
  font-size: 1.4374rem;
  font-weight: bold;
  letter-spacing: 0.015em;
  border-left: 4px solid #e7235f;
  padding-left: 2.5rem;
  line-height: 1.4;
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 576px) {
  .p-point__ttl {
    font-size: 1.25rem;
    padding-left: 1rem;
    margin-bottom: 1.25rem;
    border-left: 3px solid #e7235f;
  }
}

.p-point__approval picture img {
  padding: 2rem 3rem;
  width: 100%;
}

@media screen and (max-width: 576px) {
  .p-point__approval picture img {
    padding: 2rem 1rem;
    width: 100%;
  }
}

.p-point__item {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 768px) {
  .p-point__item {
    display: block;
  }
}

.p-point__item li {
  background-color: #fff;
  padding: 1.5rem 2.375rem;
  line-height: 1.75;
  width: 50%;
}

@media screen and (max-width: 768px) {
  .p-point__item li {
    width: 100%;
    padding: 1.5rem 1rem;
  }
}

.p-point__item li + li {
  margin-left: 1.875rem;
}

@media screen and (max-width: 768px) {
  .p-point__item li + li {
    margin-left: 0;
    margin-top: 1.25rem;
  }
}

.p-point__alighment {
  font-size: 1.25rem;
  letter-spacing: 0.015em;
}

.p-point__box {
  margin-top: 1.875rem;
  background-color: #fff;
  padding: 3.125rem 3.375rem;
}

@media screen and (max-width: 576px) {
  .p-point__box {
    margin-top: 1.25rem;
    padding: 1.5rem 1rem;
  }
}

.p-point__box figure {
  width: 100%;
  margin: auto;
  padding-bottom: 2.125rem;
}

.p-point__box figure.p-point__image01 {
  width: 80%;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .p-point__box figure.p-point__image01 {
    width: 100%;
  }
}

@media screen and (max-width: 576px) {
  .p-point__box figure {
    width: 100%;
    padding-bottom: 1.25rem;
  }
}

.p-point__box figure img {
  width: 100%;
}

.p-point__device {
  border-top: 1px solid #e4e4e4;
  padding-top: 2.875rem;
}

.p-point__device picture img {
  width: 100%;
}

@media screen and (max-width: 576px) {
  .p-point__device {
    padding-top: 1.25rem;
  }
}

.p-point__devicettl {
  font-size: 1.25rem;
  font-weight: bold;
  text-align: center;
  padding-bottom: 1.4375rem;
}

@media screen and (max-width: 576px) {
  .p-point__devicettl {
    font-size: 1.125rem;
    line-height: 1.7;
    padding-bottom: 0;
  }
}

.p-point__device ul {
  display: flex;
  flex-wrap: wrap;
  box-sizing: border-box;
}

.p-point__device ul li {
  background-color: #e5eef9;
  color: #11488b;
  padding: 1.125rem 0;
  font-weight: bold;
  line-height: 1;
  width: 25%;
  text-align: center;
  margin-bottom: 0.875rem;
}

.p-point__list {
  margin-left: 1px;
}

.p-point__note {
  font-size: 1rem;
  text-align: center;
  padding-top: 1.375rem;
  line-height: 1.7;
}

@media screen and (max-width: 576px) {
  .p-point__note {
    font-size: 0.875rem;
    padding-top: 5px;
  }
}

.p-point__word {
  padding: 0 2.8125rem;
}

@media screen and (max-width: 576px) {
  .p-point__word {
    padding: 0;
  }
}

.p-point__word p {
  padding-bottom: 2.25rem;
}

@media screen and (max-width: 576px) {
  .p-point__word p {
    padding-bottom: 1.5rem;
  }
}

.p-point__word figure img {
  width: 100%;
}

.p-point__word picture img {
  width: 100%;
}

.p-function__container {
  max-width: 1100px;
  margin: auto;
}

@media screen and (max-width: 992px) {
  .p-function__container {
    width: 90%;
  }
}

@media screen and (max-width: 576px) {
  .p-function__container {
    width: 85%;
  }
}

.p-environment {
  border-top: 1px solid #e4e4e4;
}

.p-environment__container {
  padding-top: 5.375rem;
}

.p-environment__box {
  padding-top: 6.25rem;
}

@media screen and (max-width: 768px) {
  .p-environment__box {
    padding-top: 4.25rem;
  }
}

@media screen and (max-width: 576px) {
  .p-environment__box {
    padding-top: 2.5rem;
  }
}

.p-environment__box h3 {
  font-size: 1.625rem;
  font-weight: bold;
  letter-spacing: 0.015em;
  border-left: 4px solid #e7235f;
  padding-left: 1.5rem;
}

@media screen and (max-width: 768px) {
  .p-environment__box h3 {
    margin-bottom: 0rem;
  }
}

@media screen and (max-width: 576px) {
  .p-environment__box h3 {
    font-size: 1.25rem;
    padding-left: 1rem;
    margin-bottom: 0;
    border-left: 3px solid #e7235f;
  }
}

.p-environment__inner {
  padding-left: 1.5rem;
  padding-top: 2.5rem;
}

@media screen and (max-width: 768px) {
  .p-environment__inner {
    padding-left: 0;
    padding-top: 1.5rem;
  }
}

.p-environment__ttl {
  font-size: 1.4375rem;
  padding-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
  .p-environment__ttl {
    font-size: 1.25rem;
    padding-bottom: 1rem;
  }
}

@media screen and (max-width: 576px) {
  .p-environment__ttl {
    font-size: 1.125rem;
  }
}

.p-environment__inner dl {
  display: flex;
  border-bottom: 1px solid #d6d7d8;
}

@media screen and (max-width: 576px) {
  .p-environment__inner dl {
    display: block;
    border-bottom: none;
  }
}

.p-environment__inner dt {
  width: 28%;
  background-color: #fafafa;
  /* padding: 10px 45px; */
  padding: 1.375rem 4.0625rem;
  font-weight: 700;
}

@media screen and (max-width: 576px) {
  .p-environment__inner dt {
    width: 100%;
    padding: 10px 30px;
  }
}

.p-environment__inner dd {
  width: 72%;
  padding: 1.375rem 4.0625rem;
}

@media screen and (max-width: 576px) {
  .p-environment__inner dd {
    width: 100%;
    padding: 13px 30px;
  }
}

.p-environment__note {
  font-size: 1rem;
  padding-top: 1.875rem;
}

@media screen and (max-width: 576px) {
  .p-environment__note {
    font-size: 0.875rem;
    padding-top: 1.25rem;
  }
}

/*
  product QC-One
----------------------------------------------- */
.p-product__box {
  padding: 4.375rem 10.75rem 2.125rem 15.625rem;
  background-color: #fff;
  box-shadow: 0px 0px 10px rgb(17, 72, 139, 0.25);
}

@media screen and (max-width: 1200px) {
  .p-product__box {
    padding: 4.375rem 5rem 2.125rem;
  }
}

@media screen and (max-width: 768px) {
  .p-product__box {
    padding: 3.125rem;
  }
}

@media screen and (max-width: 576px) {
  .p-product__box {
    padding: 1.875rem 1.5rem;
  }
}

.p-product__box.-qconeLite {
  box-shadow: 0px 0px 10px rgb(231, 35, 95, 0.25);
}

.p-product__ttl {
  position: relative;
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.6;
  text-align: center;
  letter-spacing: 0.015em;
}

@media screen and (max-width: 1200px) {
  .p-product__ttl {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-product__ttl {
    font-size: 1.25rem;
  }
}

.p-product__ttl::before {
  position: absolute;
  content: "";
  background-image: url(../image/qcone/em-blue-left.svg);
  background-repeat: no-repeat;
  width: 40px;
  height: 46px;
  bottom: 0;
  left: 0;
}

@media screen and (max-width: 768px) {
  .p-product__ttl::before {
    display: none;
  }
}

.p-product__ttl::after {
  position: absolute;
  content: "";
  background-image: url(../image/qcone/em-blue-right.svg);
  background-repeat: no-repeat;
  width: 40px;
  height: 46px;
  bottom: 0;
  right: 0;
}

@media screen and (max-width: 768px) {
  .p-product__ttl::after {
    display: none;
  }
}

.p-product__ttl.-qconeLite::before {
  position: absolute;
  content: "";
  background-image: url(../image/qconeLite/em-pink-left.svg);
  background-repeat: no-repeat;
  width: 40px;
  height: 46px;
  bottom: 0;
  left: 0;
}

.p-product__ttl.-qconeLite::after {
  position: absolute;
  content: "";
  background-image: url(../image/qconeLite/em-pink-right.svg);
  background-repeat: no-repeat;
  width: 40px;
  height: 46px;
  bottom: 0;
  right: 0;
}

.p-product__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 2.6875rem;
}

@media screen and (max-width: 992px) {
  .p-product__inner {
    padding-top: 1.375rem;
  }
}

@media screen and (max-width: 768px) {
  .p-product__inner {
    display: block;
    padding-top: 0rem;
  }
}

@media screen and (max-width: 576px) {
  .p-product__inner {
    padding-top: 0.625rem;
  }
}

.p-product__image {
  position: relative;
}

@media screen and (max-width: 992px) {
  .p-product__image {
    width: 40%;
  }
}

@media screen and (max-width: 768px) {
  .p-product__image {
    width: 80%;
    margin: auto;
  }
}

.p-product__image img {
  width: 100%;
}

.p-product__image::before {
  position: absolute;
  content: "";
  background-image: url(../image/qcone/product01-cv-bg.svg);
  top: -3%;
  left: -35%;
  width: 121px;
  height: 209px;
}

@media screen and (max-width: 1200px) {
  .p-product__image::before {
    display: none;
  }
}

.p-product__image.-product02::before {
  position: absolute;
  content: "";
  background-image: url(../image/qconeLite/product02-cv-bg.svg);
  top: -3%;
  left: -35%;
  width: 121px;
  height: 209px;
}

.p-product__image image {
  width: 100%;
}

.p-product__text {
  font-size: 1.75rem;
  font-weight: bold;
}

@media screen and (max-width: 1200px) {
  .p-product__text {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-product__text {
    text-align: center;
  }
}

@media screen and (max-width: 576px) {
  .p-product__text {
    font-size: 1.25rem;
  }

  .p-product__text img {
    width: 25%;
    vertical-align: middle;
  }
}

.p-product01__btn a {
  position: relative;
  margin-top: 1.4375rem;
}

@media screen and (max-width: 576px) {
  .p-product01__btn a {
    margin-top: 1.25rem;
  }
}

.p-product01__btn a::after {
  position: absolute;
  background-image: url(../image/front/icon-next-wt.svg);
  content: "";
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 6px;
  height: 10px;
  right: 10%;
}

/*
  product QC-One Lite
----------------------------------------------- */
.p-comparison {
  background-color: #fafafa;
}

.p-product02__contents {
  padding-top: 4.375rem;
}

@media screen and (max-width: 768px) {
  .p-product02__contents {
    padding-top: 2.5rem;
  }
}

@media screen and (max-width: 1200px) {
  .p-product02__contents figure {
    width: 90%;
    margin: auto;
  }
}

@media screen and (max-width: 768px) {
  .p-product02__contents figure {
    width: 100%;
  }
}

.p-comparison__image img {
  width: 100%;
}

.p-price__box {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 576px) {
  .p-price__box {
    display: block;
  }
}

.p-price__inner01 {
  background-color: #fff;
  box-shadow: 0px 0px 10px rgb(0, 0, 0, 0.16);
  padding: 3.125rem 0;
  border-radius: 10px;
}

@media screen and (max-width: 768px) {
  .p-price__inner01 {
    padding: 1.875rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-price__inner01 {
    padding: 1.5rem 0 1.875rem;
  }
}

.p-price__inner01 figure {
  padding: 0 3.125rem;
}

@media screen and (max-width: 576px) {
  .p-price__inner01 figure {
    padding: 0 1.25rem;
    width: 95%;
    margin: auto;
  }
}

.p-price__inner02 {
  background-color: #fff;
  box-shadow: 0px 0px 10px rgb(0, 0, 0, 0.16);
  padding: 3.125rem 0;
  border-radius: 10px;
}

@media screen and (max-width: 1200px) {
  .p-price__inner02 {
    margin-left: 20px;
  }
}

@media screen and (max-width: 768px) {
  .p-price__inner02 {
    padding: 1.875rem 0;
  }
}

@media screen and (max-width: 576px) {
  .p-price__inner02 {
    padding: 1.5rem 0;
    margin-left: 0;
    margin-top: 30px;
  }
}

.p-price__inner02 figure {
  padding: 0 0.9375rem 0 3.125rem;
}

@media screen and (max-width: 576px) {
  .p-price__inner02 figure {
    padding: 0 0 0 1.25rem;
    width: 95%;
    margin: auto;
  }
}

.p-price__box li p {
  font-size: 1.625rem;
  letter-spacing: 0.015em;
  font-weight: bold;
  text-align: center;
  padding-bottom: 1.875rem;
}

@media screen and (max-width: 768px) {
  .p-price__box li p {
    padding-bottom: 0.625rem;
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-price__box li p {
    font-size: 1.25rem;
    padding-bottom: 0.625rem;
  }
}

.p-price__box li figure img {
  width: 100%;
}

.p-price__note {
  line-height: 1.75;
  padding: 3.75rem 0 6.25rem;
}

@media screen and (max-width: 768px) {
  .p-price__note {
    font-size: 0.875rem;
    padding: 1.875rem 0 1.875rem;
  }
}

.p-price__suport {
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0px 0px 10px rgb(0, 0, 0, 0.16);
  padding: 3.375rem 5.625rem;
}

@media screen and (max-width: 768px) {
  .p-price__suport {
    padding: 2.5rem 3.125rem;
  }
}

@media screen and (max-width: 576px) {
  .p-price__suport {
    padding: 1.875rem 2rem;
  }
}

.p-price__suport figure {
  text-align: center;
  padding: 2.875rem 0 1.5rem;
}

@media screen and (max-width: 768px) {
  .p-price__suport figure {
    width: 80%;
    margin: auto;
    padding: 1.875rem 0 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-price__suport figure {
    padding: 1rem 0;
    width: 100%;
  }

  .p-price__suport figure img {
    width: 100%;
  }
}

.p-price__text {
  font-size: 1.375rem;
  line-height: 1.9;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-price__text {
    font-size: 1.25rem;
    line-height: 1.6;
  }
}

@media screen and (max-width: 576px) {
  .p-price__text {
    font-size: 1.125rem;
    line-height: 1.6;
  }
}

.p-suport__last {
  text-align: center;
}

@media screen and (max-width: 576px) {
  .p-suport__last {
    font-size: 0.875rem;
    line-height: 1.5;
  }
}

.p-step {
  background-color: #f7f8fa;
}

.p-step__text {
  font-size: 1.375rem;
  text-align: center;
  position: relative;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .p-step__text {
    font-size: 1.125rem;
  }
}

.p-step__text::before {
  content: "";
  background-image: url(../image/qconeLite/step-en-left.svg);
  position: absolute;
  background-repeat: no-repeat;
  width: 26px;
  height: 30px;
  bottom: 0;
  left: 5%;
}

@media screen and (max-width: 576px) {
  .p-step__text::before {
    display: none;
  }
}

.p-step__text::after {
  content: "";
  background-image: url(../image/qconeLite/step-en-right.svg);
  position: absolute;
  background-repeat: no-repeat;
  width: 26px;
  height: 30px;
  bottom: 0;
  right: 5%;
}

@media screen and (max-width: 576px) {
  .p-step__text::after {
    display: none;
  }
}

.p-step__text span {
  font-size: 1.8125rem;
}

@media screen and (max-width: 768px) {
  .p-step__text span {
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 576px) {
  .p-step__text span {
    font-size: 1.25rem;
  }
}

.p-step__inner {
  padding-top: 2.75rem;
}

@media screen and (max-width: 768px) {
  .p-step__inner {
    padding-top: 1.875rem;
  }
}

@media screen and (max-width: 576px) {
  .p-step__inner {
    padding-top: 1.5rem;
  }
}

.p-step__contents li + li {
  position: relative;
}

.p-step__contents li + li::before {
  position: absolute;
  content: "";
  background-image: url(../image/qconeLite/qconelite-flow-icon.svg);
  width: 37px;
  height: 23px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  left: -36%;
}

@media screen and (max-width: 1200px) {
  .p-step__contents li + li::before {
    left: -20%;
  }
}

@media screen and (max-width: 576px) {
  .p-step__contents li + li::before {
    left: -33%;
  }
}

.p-step__item {
  text-align: center;
  padding: 46px 0;
  background-color: #fff;
  box-shadow: 0px 0px 6px rgb(0, 0, 0, 0.16);
  display: flex;
  flex: 1 0 auto;
  flex-direction: column;
}

@media screen and (max-width: 576px) {
  .p-step__item {
    padding: 24px 0;
  }
}

.p-step__item figure {
  padding: 1.4375rem 0 1.875rem;
}

@media screen and (max-width: 576px) {
  .p-step__item figure {
    padding: 1.25rem 0;
    width: 40%;
    margin: auto;
  }

  .p-step__item figure img {
    width: 100%;
  }
}

.p-step__ttl {
  font-size: 1.1875rem;
}

@media screen and (max-width: 576px) {
  .p-step__ttl {
    font-size: 1rem;
  }
}

.p-step__name {
  font-size: 1.25rem;
  letter-spacing: 0.015em;
}

@media screen and (max-width: 576px) {
  .p-step__name {
    font-size: 1rem;
  }
}

/*
  contact
*/
.p-contact__inner {
  display: flex;
}

@media screen and (max-width: 768px) {
  .p-contact__inner {
    display: block;
  }
}

.p-contact__left {
  width: 48%;
}

@media screen and (max-width: 768px) {
  .p-contact__left {
    width: 100%;
    padding-top: 0;
  }
}

.p-contact__right {
  width: 50%;
  margin-left: 2%;
  margin-top: -50px;
}

@media screen and (max-width: 768px) {
  .p-contact__right {
    width: 100%;
    margin-left: 0;
    padding-top: 20px;
    margin-top: 35px;
  }
}

.p-contact__text {
  padding-bottom: 30px;
}

@media screen and (max-width: 768px) {
  .p-contact__text {
    padding-bottom: 20px;
  }
}

.p-contact__list {
  font-size: 18px;
  padding: 30px 0;
}

@media screen and (max-width: 568px) {
  .p-contact__list {
    font-size: 16px;
    padding: 20px 0;
  }
}

.p-contact__list li img {
  width: 35px;
  vertical-align: middle;
  padding-right: 10px;
}

@media screen and (max-width: 568px) {
  .p-contact__list li img {
    width: 30px;
    padding-right: 5px;
  }
}

.p-contact__link {
  font-weight: bold;
  font-size: 18px;
  padding-bottom: 18px;
}

@media screen and (max-width: 768px) {
  .p-contact__link {
    text-align: center;
  }
}

@media screen and (max-width: 568px) {
  .p-contact__link {
    font-size: 16px;
  }
}

.p-contact__btn {
  margin-top: 10px;
}

@media screen and (max-width: 768px) {
  .p-contact__btn {
    text-align: center;
  }
}

.p-contact__btn a {
  font-weight: bold;
  font-size: 18px;
  color: #fff;
  background-color: #11488b;
  padding: 16px 50px;
  border-radius: 10px;
}

@media screen and (max-width: 568px) {
  .p-contact__btn a {
    font-size: 17px;
  }
}

.p-contact__btn a img {
  vertical-align: middle;
  width: 18px;
  margin-left: 15px;
}

@media screen and (max-width: 568px) {
  .p-contact__btn a img {
    width: 15px;
  }
}

.p-contact__img {
  width: 75%;
}

@media screen and (max-width: 768px) {
  .p-contact__img {
    margin: auto;
  }
}

@media screen and (max-width: 568px) {
  .p-contact__img {
    width: 70%;
  }
}

.p-contact__img img {
  width: 100%;
}

/*
  thanksページ
*/
.p-thanks__inner {
  text-align: center;
  font-size: 18px;
  line-height: 2;
}

.p-thanks__text {
  text-align: center;
}

@media screen and (max-width: 568px) {
  .p-thanks__text {
    font-size: 16px;
  }
}

.p-thanks__text a {
  text-decoration: underline;
  color: #333;
}

.p-thanks__btn {
  padding-top: 50px;
}

@media screen and (max-width: 768px) {
  .p-thanks__btn {
    padding-top: 24px;
  }
}

.p-thanks__btn a {
  color: #11488b;
  background: #fff;
  border: 2px solid #11488b;
  padding: 16px 0;
  width: 330px;
  display: inline-block;
  border-radius: 50px;
  font-weight: 700;
  background-image: url(../image/contact/icon-back-blue.svg);
  background-repeat: no-repeat;
  background-position: 10% center;
}

@media screen and (max-width: 568px) {
  .p-thanks__btn a {
    padding: 14px 0;
    width: 100%;
    font-size: 16px;
  }
}

/*
  1カラム
*/

.p-application__inner p a {
  color: #e7235f;
  text-decoration: underline;
}

/*
  モーダルウィンドウ
*/
.overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: 1000000;
}
.content {
  max-width: 55%;
  max-height: 55%;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}

@media screen and (max-width: 1400px) {
  .content {
    max-width: 70%;
  }
}

@media screen and (max-width: 768px) {
  .content {
    max-width: 90%;
  }
}

.is-active {
  overflow: hidden;
}

/*
  導入実績　単独ページ
*/
.p-case__interview {
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
  position: relative;
  background: #fff;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
}

.p-case__interview figure img {
  width: 100%;
}

.p-case__interview .box {
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
  padding: 1.5rem 1.5625rem 2.375rem;
}

@media screen and (max-width: 568px) {
  .p-case__interview .box {
    padding: 1.375rem 1.5625rem 1.875rem;
  }
}

.p-case__interview h3 {
  font-size: 0.9375rem;
  line-height: 1.25;
}

.p-case__interview p {
  font-size: 1.25rem;
  line-height: 1.6;
  font-weight: bold;
  padding: 1.25rem 0;
}

@media screen and (max-width: 568px) {
  .p-case__interview p {
    font-size: 1.125rem;
    padding: 1rem 0;
  }
}

.p-case__interview a:hover {
  color: #333;
  opacity: 1;
  text-decoration: underline;
}

.p-case__interview p::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: transparent;
  transform: none;
  z-index: 0;
}

.p-case__interview ul {
  display: flex;
  margin-top: auto;
}

.p-case__interview ul li {
  font-size: 0.875rem;
  color: #0e7cd1;
}

@media screen and (max-width: 568px) {
  .p-case__interview ul li {
    font-size: 0.8125rem;
  }
}

.p-case__interview ul li + li {
  padding-left: 1.25rem;
}

@media screen and (max-width: 568px) {
  .p-case__interview ul li + li {
    padding-left: 0.625rem;
  }
}

.p-case__interview ul li img {
  vertical-align: middle;
  padding-right: 0.3125rem;
}

@media screen and (max-width: 568px) {
  .p-case__interview ul li img {
    width: 20px;
  }
}

/*
  導入実績 単独ページ
*/

.p-interview__top h2 {
  font-size: 1.875rem;
  font-weight: bold;
  line-height: 1.7;
}

@media screen and (max-width: 1000px) {
  .p-interview__top h2 {
    font-size: 1.75rem;
  }
}

@media screen and (max-width: 568px) {
  .p-interview__top h2 {
    font-size: 1.25rem;
    line-height: 1.6;
  }
}

.p-interview__top figure {
  width: 70%;
  margin: auto;
  padding: 3.125rem 0;
}

@media screen and (max-width: 768px) {
  .p-interview__top figure {
    width: 100%;
  }
}

@media screen and (max-width: 568px) {
  .p-interview__top figure {
    padding: 1.875rem 0;
  }
}

.p-interview__top figure img {
  width: 100%;
}

.p-interview__top .company-name {
  font-size: 1.75rem;
  font-weight: bold;
  color: #e7235f;
  text-align: center;
  line-height: 1.5;
}

@media screen and (max-width: 568px) {
  .p-interview__top .company-name {
    font-size: 1.125rem;
    line-height: 1.8;
  }
}

.p-interview__top .company-name span {
  font-size: 1.125rem;
  color: #e7235f;
  text-align: center;
  font-weight: 500;
}

@media screen and (max-width: 568px) {
  .p-interview__top .company-name span {
    font-size: 0.9375rem;
  }
}

.p-interview__top .text {
  font-size: 1.0625rem;
  font-weight: 400;
  padding: 2.5rem 0 3.75rem;
}

@media screen and (max-width: 568px) {
  .p-interview__top .text {
    font-size: 0.9375rem;
    padding: 1.25rem 0 1.875rem;
  }
}

.p-interview__top .box {
  margin-bottom: 10rem;
  padding: 1.875rem 5rem;
}

@media screen and (max-width: 1000px) {
  .p-interview__top .box {
    padding: 1.875rem 3.125rem;
    margin-bottom: 7.5rem;
  }
}

@media screen and (max-width: 568px) {
  .p-interview__top .box {
    padding: 1.875rem 1.25rem;
    margin-bottom: 3.75rem;
  }
}

.p-interview__top .box p {
  font-size: 1.375rem;
  line-height: 1.6;
  color: #2d6fa3;
  font-weight: bold;
}

@media screen and (max-width: 568px) {
  .p-interview__top .box p {
    font-size: 1.125rem;
  }
}

.p-interview__top .box dl dd {
  font-size: 1.25rem;
  font-weight: bold;
  padding-top: 0.625rem;
}

@media screen and (max-width: 568px) {
  .p-interview__top .box dl dd {
    font-size: 1rem;
  }
}

.p-interview__top .box dl dd img {
  vertical-align: middle;
  width: 30px;
  padding-right: 0.625rem;
}

@media screen and (max-width: 568px) {
  .p-interview__top .box dl dd img {
    width: 25px;
    padding-right: 0.3125rem;
  }
}

.p-interview__top .box dl dt {
  font-size: 1.375rem;
  font-weight: bold;
  color: #2d6fa3;
  padding-left: 30px;
}

@media screen and (max-width: 568px) {
  .p-interview__top .box dl dt {
    font-size: 1.0625rem;
    padding-left: 0px;
  }
}

.p-interview__inner {
  letter-spacing: 0.015em;
}

.p-interview__inner h2 {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.3;
  margin-bottom: 2rem;
  background: #f7f8fa;
  padding: 0.625rem 1.5rem;
  color: #222e51;
}

@media screen and (max-width: 568px) {
  .p-interview__inner h2 {
    font-size: 1.125rem;
    line-height: 1.7;
    margin-bottom: 1.25rem;
  }
}

.p-interview__inner .ttl {
  font-size: 1.375rem;
  font-weight: 500;
  color: #e7235f;
  padding-bottom: 1.25rem;
}

@media screen and (max-width: 568px) {
  .p-interview__inner .ttl {
    font-size: 1.0625rem;
    line-height: 1.7;
  }
}

.p-interview__inner .end {
  font-size: 1.375rem;
  font-weight: 500;
  color: #222e51;
  padding-bottom: 1.25rem;
}

@media screen and (max-width: 568px) {
  .p-interview__inner .end {
    font-size: 1.0625rem;
    line-height: 1.7;
  }
}

.p-interview__inner .text {
  font-size: 1.0625rem;
}

@media screen and (max-width: 568px) {
  .p-interview__inner .text {
    font-size: 0.9375rem;
  }
}

.p-interview__inner .period {
  text-align: right;
  padding-top: 2rem;
}

.p-interview__inner .talk figure {
  width: 45%;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .p-interview__inner .talk figure {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .p-interview__inner .talk {
    width: 100%;
  }
}

.p-interview__inner .talk p {
  padding-top: 1.25rem;
  text-align: center;
  font-weight: bold;
}

@media screen and (max-width: 568px) {
  .p-interview__inner .talk p {
    padding-top: 1rem;
  }
}

.p-interview__inner figure img {
  width: 100%;
}

.p-interview__company {
  border: 1px solid #8d8d8d;
  padding: 2.5rem 4.1875rem 3.75rem;
}

@media screen and (max-width: 568px) {
  .p-interview__company {
    padding: 2.5rem 1.5rem 1.875rem;
  }
}

.p-interview__company .name {
  display: flex;
  align-items: center;
  color: #e7235f;
  font-weight: bold;
  font-size: 1.25rem;
}

@media screen and (max-width: 568px) {
  .p-interview__company .name {
    display: block;
  }
}

.p-interview__company figure {
  padding-right: 2.1875rem;
}

@media screen and (max-width: 568px) {
  .p-interview__company figure {
    padding-right: 0;
  }
}

.p-interview__company figure img {
  width: 100%;
}

.p-interview__company .text {
  padding: 0.625rem 0 1.875rem;
}

@media screen and (max-width: 568px) {
  .p-interview__company .text {
    padding: 1.375rem 0 1.875rem;
  }
}

.p-interview__company dl {
  display: flex;
  padding: 0.875rem;
  border-top: 1px solid #e6e6e6;
}

@media screen and (max-width: 568px) {
  .p-interview__company dl {
    padding: 0.625rem;
    font-size: 0.8125rem;
  }
}

.p-interview__company dl dd {
  width: 25%;
}

@media screen and (max-width: 568px) {
  .p-interview__company dl dd {
    width: 30%;
  }
}

.p-interview__company dl dt {
  width: 75%;
}

.pt_20 {
  padding-top: 20px;
}

@media screen and (max-width: 768px) {
  .pt_20 {
    padding-top: 10;
  }
}

.pb_90 {
  padding-bottom: 5.625rem;
}

@media screen and (max-width: 768px) {
  .pb_90 {
    padding-bottom: 4.375rem;
  }
}

@media screen and (max-width: 568px) {
  .pb_90 {
    padding-bottom: 2.5rem;
  }
}

.mt_50 {
  margin-top: 50px;
}

@media screen and (max-width: 768px) {
  .mt_50 {
    margin-top: 40px;
  }
}

@media screen and (max-width: 568px) {
  .mt_50 {
    margin-top: 30px;
  }
}

.pt_50 {
  padding-top: 3.125rem;
}

@media screen and (max-width: 768px) {
  .pt_50 {
    padding-top: 2.5rem;
  }
}

.pt_90 {
  padding-top: 5.625rem;
}

@media screen and (max-width: 768px) {
  .pt_90 {
    padding-top: 4.375rem;
  }
}

@media screen and (max-width: 568px) {
  .pt_90 {
    padding-top: 2.5rem;
  }
}

.p-interview__inner .end {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.3;
  margin-bottom: 2rem;
  background: #222e51;
  padding: 0.625rem 1.5rem;
  color: #fff;
}

@media screen and (max-width: 568px) {
  .p-interview__inner .end {
    font-size: 1.125rem;
    line-height: 1.7;
    margin-bottom: 1.25rem;
  }
}

.l-contents .-case {
  max-width: 950px;
  margin: auto;
  width: 90%;
}

@media screen and (max-width: 1000px) {
  .l-contents .-case {
    width: 85%;
  }
}

@media screen and (max-width: 768px) {
  .l-contents .-case {
    width: 90%;
  }
}

.p-interview__inner .text .liner {
  font-weight: bold;
  background-color: #ffdfe9;
}

.p-interview__inner .text .bold {
  font-weight: bold;
}

/*
  コラム一覧
*/

.l-container.-column {
  max-width: 1200px;
  margin: 0 auto;
  width: 90%;
}

.p-column__container {
  display: flex;
  padding: 2.0625rem 0 9.375rem;
  justify-content: space-between;
}

@media screen and (max-width: 768px) {
  .p-column__container {
    display: block;
    padding: 1rem 0 3.75rem;
  }
}

.p-column__left {
  width: 70%;
}

@media screen and (max-width: 768px) {
  .p-column__left {
    width: 100%;
    padding-right: 0;
  }
}

.p-column__left article {
  margin-bottom: 3.75rem;
}

@media screen and (max-width: 768px) {
  .p-column__left article {
    margin-bottom: 1.5rem;
  }
}

.p-column__inner {
  display: flex;
  align-items: flex-start;
}

@media screen and (max-width: 768px) {
  .p-column__inner {
    display: block;
  }
}

.p-column__inner figure {
  width: 30%;
  margin-top: 10px;
}

@media screen and (max-width: 768px) {
  .p-column__inner figure {
    width: 100%;
    padding-bottom: 0.875rem;
    margin-top: 0;
  }
}

.p-column__inner figure img {
  width: 100%;
}

.p-column__text {
  width: 74%;
  padding-left: 4%;
}

@media screen and (max-width: 768px) {
  .p-column__text {
    width: 100%;
    padding-left: 0;
  }
}

.p-column__text h2 {
  color: #e7235f;
  font-size: clamp(1rem, 0.797rem + 0.9vw, 1.375rem);
  line-height: 1.7;
  padding-bottom: 0.3125rem;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .p-column__text h2 {
    padding-bottom: 0.5rem;
  }
}

.p-column__text p {
  line-height: 1.7;
  color: #222;
}

.p-aside__right {
  width: 23%;
}

@media screen and (max-width: 768px) {
  .p-aside__right {
    width: 100%;
    padding-top: 0.875rem;
  }
}

.p-aside__right h2 {
  color: #222222;
  font-weight: 700;
  line-height: 1.5;
  font-size: clamp(1rem, 0.864rem + 0.6vw, 1.25rem);
}

.p-aside__right li {
  padding-top: 1.25rem;
}

@media screen and (max-width: 768px) {
  .p-aside__right li {
    padding-top: 1rem;
  }
}

.p-aside__right figure img {
  width: 100%;
}

/*
  コラム記事
*/

.p-column__contents {
  max-width: 950px;
  padding: 2.0625rem 0 9.375rem;
  margin: auto;
  width: 90%;
}

@media screen and (max-width: 768px) {
  .p-column__contents {
    padding: 0.625rem 0;
  }
}

.p-article__inner {
  font-size: clamp(0.938rem, 0.87rem + 0.3vw, 1.063rem);
}

.ttl h1 {
  color: #e7235f;
  font-size: clamp(1.375rem, 0.968rem + 1.81vw, 2.125rem);
  line-height: 1.7;
  padding-bottom: 1.875rem;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .ttl h1 {
    padding-bottom: 1.25rem;
  }
}

.ttl p {
  padding: 2.5rem 0 3.125rem;
  font-weight: 400;
}

@media screen and (max-width: 768px) {
  .ttl p {
    padding: 1.25rem 0 1.25rem;
  }
}

.ttl figure img {
  width: 100%;
}

/*
  コラム記事 目次
*/

.table {
  background-color: #f7f8f9;
  padding: 1.875rem 2.5rem;
}
@media screen and (max-width: 768px) {
  .table {
    padding: 1.25rem 1.125rem;
  }
}

.table p {
  color: #e7235f;
  font-weight: 700;
  font-size: clamp(0.938rem, 0.768rem + 0.75vw, 1.25rem);
}

.table li {
  padding: 0.625rem 0;
}

@media screen and (max-width: 768px) {
  .table li {
    padding: 0.3125rem 0;
  }
}

.table li + li {
  border-top: dashed 1px #ced4dc;
}

.table li a {
  font-size: clamp(0.875rem, 0.773rem + 0.45vw, 1.063rem);
  color: #222;
  font-weight: 500;
}

.table li a:hover {
  text-decoration: underline;
}

/*
  コラム記事 本文
*/

.contents {
  padding-bottom: 6.25rem;
  border-bottom: 3px solid #0d2c48;
}

@media screen and (max-width: 768px) {
  .contents {
    padding-bottom: 1.875rem;
  }
}

.contents .column {
  padding-top: 5rem;
}

@media screen and (max-width: 768px) {
  .contents .column {
    padding-top: 2.5rem;
  }
}

.contents h2 {
  color: #222;
  font-size: clamp(1.25rem, 0.911rem + 1.51vw, 1.875rem);
  padding-bottom: 1.75rem;
  margin-bottom: 2.8125rem;
  border-bottom: 4px solid #e7235f;
  line-height: 1.7;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .contents h2 {
    padding-bottom: 0.875rem;
    margin-bottom: 1.25rem;
    border-bottom: 3px solid #e7235f;
  }
}

.contents h3 {
  color: #222;
  border-left: solid 5px #e7235f;
  font-weight: 700;
  font-size: clamp(1.063rem, 0.825rem + 1.05vw, 1.5rem);
  padding-left: 24px;
  margin-bottom: 1.625rem;
  margin-top: 3.125rem;
  line-height: 1.7;
}

@media screen and (max-width: 768px) {
  .contents h3 {
    /* margin: 0.5rem; */
    margin-top: 1.875rem;
    margin-bottom: 1rem;
    padding-left: 12px;
    border-left: solid 4px #e7235f;
  }
}

.contents p {
  line-height: 2.2;
}

.contents ul {
  padding: 1.625rem 0;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .contents ul {
    padding: 1.25rem 0;
  }
}

.contents li {
  display: flex;
  align-items: baseline;
}

.contents ul li span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #d9d9d9;
  display: inline-block;
  margin-right: 1.25rem;
  margin-bottom: 1px;
  flex-shrink: 0;
}

@media screen and (max-width: 768px) {
  .contents ul li span {
    margin-right: 0.625rem;
  }
}

.contents ol {
  padding: 1.625rem 0;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .contents ol {
    padding: 1.25rem 0;
  }
}

.contents a {
  font-weight: 700;
  color: #e7235f;
  text-decoration: underline;
}

.contents p span {
  font-weight: 700;
}

.contents .images {
  padding-top: 3.125rem;
}

@media screen and (max-width: 768px) {
  .contents .images {
    padding-top: 1.375rem;
  }
}

.contents .images figure img {
  width: 100%;
}

.contents .iso-tbl-01 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-01 {
    margin: 1.375rem 0;
    line-height: 1.5;
  }
}

.contents .iso-tbl-01 th {
  width: 20%;
  background: #ffeaf0;
  border: 1px solid #bab9b9;
  padding: 14px 0;
}

.contents .iso-tbl-01 td {
  width: 20%;
  border: 1px solid #bab9b9;
  text-align: center;
  padding: 14px 0;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-01 td {
    padding: 10px 0;
  }
}

.contents .iso-tbl-02 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-02 {
    margin: 1.375rem 0;
  }
}

.contents .iso-tbl-02 .ttl {
  background: #ffeaf0;
}

.contents .iso-tbl-02 .ttl .detail {
  text-align: center;
}

.contents .iso-tbl-02 .purpose {
  width: 30%;
  border: 1px solid #bab9b9;
  padding: 14px 0;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-02 .purpose {
    padding: 10px 0;
  }
}

.contents .iso-tbl-02 .detail {
  width: 70%;
  border: 1px solid #bab9b9;
  text-align: center;
  padding: 14px 60px;
  text-align: left;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-02 .detail {
    padding: 10px 10px;
    line-height: 1.8;
  }
}

.contents .iso-tbl-03 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-03 {
    margin: 1.375rem 0;
  }
}

.contents .iso-tbl-03 th {
  width: 50%;
  background: #ffeaf0;
  border: 1px solid #bab9b9;
  padding: 14px 0;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-03 th {
    padding: 10px 0;
  }
}

.contents .iso-tbl-03 td {
  width: 50%;
  border: 1px solid #bab9b9;
  text-align: center;
  padding: 14px 0;
}

@media screen and (max-width: 768px) {
  .contents .iso-tbl-03 td {
    padding: 10px 5px;
    line-height: 1.8;
  }
}

.p-column__btn {
  padding-top: 5rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-column__btn {
    padding-top: 1.875rem;
    margin-bottom: 2.5rem;
  }
}

.c-button__back {
  position: relative;
  display: inline-block;
  background: #e7235f;
  line-height: 1;
  color: #ffffff;
  font-size: clamp(0.875rem, 0.773rem + 0.45vw, 1.063rem);
  padding: 1.625rem 6.25rem 1.625rem 6.25rem;
  background-image: url(../image/common/icon_next_white.svg);
  background-repeat: no-repeat;
  background-position: 93% center;
  letter-spacing: 0.02em;
  font-weight: 700;
  border-radius: 50px;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
}

@media screen and (max-width: 768px) {
  .c-button__back {
    width: 100%;
    padding: 1.25rem 0rem;
    text-align: center;
    background-position: 95% center;
  }
}

.c-button__back:after {
  position: absolute;
  content: "";
  background-image: url(../image/common/icon_back_white.svg);
  width: 12px;
  height: 14px;
  left: 10%;
}

.p-header {
  width: 100%;
  z-index: 100;
  box-shadow: 0px 10px 10px -5px rgba(112, 104, 104, 0.1);
  position: relative;
}

.p-header__body {
  display: flex;
  width: 95%;
  justify-content: space-between;
  max-width: 1400px;
  margin: auto;
  padding: 0.875rem 0;
}
@media screen and (max-width: 1200px) {
  .p-header__body {
    margin: 0 1rem;
    width: 90%;
    margin: auto;
    padding: 0.625rem 0;
  }
}
@media screen and (max-width: 768px) {
  .p-header__body {
    padding: 0.875rem 0;
  }
}

.p-header__left {
  display: flex;
  align-items: center;
}

.p-header__right {
  display: flex;
}
@media screen and (max-width: 1200px) {
  .p-header__right {
    display: none;
  }
}

.p-header__title {
  padding-right: 3.5625rem;
}
.p-header__title a {
  display: inline-block;
}
.p-header__title img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .p-header__title img {
    width: 120px;
  }
}

.p-global__box {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1200px) {
  .p-global__box {
    padding-left: 0;
  }
}

.p-global-nav {
  display: flex;
  transform: translateX(0);
  align-items: center;
  position: relative;
}
@media screen and (max-width: 1200px) {
  .p-global-nav {
    overflow-y: scroll;
    position: fixed;
    -webkit-overflow-scrolling: touch;
    top: 0;
    /* left: 0; */
    right: 0;
    bottom: 0;
    /* width: 100%; */
    width: 80%;
    height: 120%;
    background: #fff;
    z-index: 1000;
    display: block;
    transition: transform 0.3s ease-in-out;
    transform: translateX(100%);
    -webkit-transform: translateX(100%); /* Android, Brackberry  */
    -ms-transform: translateX(100%); /* IE9 */
    padding: 5rem 0;
  }
}
@media screen and (max-width: 768px) {
  .p-global-nav {
    padding: 1.75rem 0;
  }
}

.p-global-nav__item {
  position: relative;
  margin-right: 1.875rem;
}
/* @media screen and (max-width: 1320px) {
  .p-global-nav__item {
    margin-right: 1.125rem;
  }
} */
@media screen and (max-width: 1200px) {
  .p-global-nav__item {
    margin-right: 0;
    border-bottom: 1px solid #e6e6e6;
  }
}

.p-global-nav__item a {
  display: inline-block;
  font-size: 0.875rem;
  color: #222;
  position: relative;
  letter-spacing: 0.1em;
  display: inline-block;
  width: 100%;
  padding: 0.75rem 0;
  font-weight: 500;
}
@media screen and (max-width: 1200px) {
  .p-global-nav__item a {
    padding: 1.25rem 0 1.625rem 2.5rem;
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 768px) {
  .p-global-nav__item a {
    padding: 0.625rem 0 0.625rem 1.25rem;
    font-size: 0.875rem;
  }
}

.p-global-nav__item.active a {
  color: #3cb5b1;
}

.p-global-nav__item.-function {
  padding-right: 0.5rem;
  margin-right: 2.1875rem;
}
@media screen and (max-width: 1200px) {
  .p-global-nav__item.-function {
    padding-right: 0px;
    margin-right: 0px;
  }
}

.p-global-nav__item.-function::before {
  content: "";
  position: absolute;
  left: 100%;
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 10px;
  height: 10px;
  border-top: 3px solid #e7235f;
  border-right: 3px solid #e7235f;
  transform: rotate(135deg);
}
@media screen and (max-width: 1200px) {
  .p-global-nav__item.-function::before {
    display: none;
  }
}

.child-menu {
  position: absolute;
  visibility: hidden; /*非表示*/
  transform: scale(1, 0); /*高さを0に*/
  transform-origin: top; /*上からアニメーション*/
  opacity: 0;
  transition: 0.3s;
  width: 180%;
  top: 130%;
}
@media screen and (max-width: 1200px) {
  .child-menu {
    position: static;
    visibility: visible;
    opacity: 1;
    transform: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem 0.5rem;
    width: 100%;
    padding: 0 2.5rem;
    margin-bottom: 1.875rem;
  }
}
@media screen and (max-width: 768px) {
  .child-menu {
    padding: 0 1.25rem;
    gap: 0.3125rem 0.3125rem;
    margin-bottom: 1.25rem;
  }
}

.p-global-nav > .p-global-nav__item:hover .child-menu {
  visibility: visible; /*表示*/
  opacity: 1;
  transform: scale(1, 1); /*高さを100%に*/
}

.child-menu li {
  border-bottom: 1.5px solid #e7235f;
  line-height: 1.7;
}
@media screen and (max-width: 1200px) {
  .child-menu li {
    border-bottom: none;
  }
}
.child-menu li:last-child {
  border-bottom: none;
}

.child-menu li a {
  background: #ffeaf0;
  display: inline-block;
  font-size: 0.875rem;
  font-weight: 700;
  color: #e7235f;
  padding: 0.75rem 1.25rem;
}
@media screen and (max-width: 1200px) {
  .child-menu li a {
    padding: 0.875rem 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  .child-menu li a {
    text-align: center;
    padding: 0.5rem 0.625rem;
    line-height: 1.7;
  }
}

.p-header__download {
  background: #00428d;
  border: 2px solid #00428d;
  border-radius: 50px;
  margin-right: 0.625rem;
}
@media screen and (max-width: 1200px) {
  .p-header__download {
    margin-right: 0rem;
    width: 90%;
    margin: auto;
    margin-top: 1.625rem;
  }
}
@media screen and (max-width: 768px) {
  .p-header__download {
    margin-top: 1.25rem;
  }
}
.p-header__download a {
  color: #fff;
  display: flex;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  text-align: center;
  display: inline-block;
  width: 100%;
  font-weight: 700;
}
@media screen and (max-width: 1200px) {
  .p-header__download a {
    padding: 1rem 0;
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 768px) {
  .p-header__download a {
    padding: 0.75rem 0;
    font-size: 0.875rem;
  }
}
.p-header__download img {
  width: 17px;
  vertical-align: middle;
  margin-right: 8px;
}
@media screen and (max-width: 1200px) {
  .p-header__download img {
    width: 18px;
    margin-right: 12px;
  }
}

.p-header__contact {
  border: 2px solid #00428d;
  border-radius: 50px;
}
@media screen and (max-width: 1200px) {
  .p-header__contact {
    margin-right: 0rem;
    width: 90%;
    margin: auto;
    margin-top: 0.75rem;
  }
}
.p-header__contact a {
  color: #00428d;
  display: flex;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  text-align: center;
  display: inline-block;
  width: 100%;
  font-weight: 700;
}
@media screen and (max-width: 1200px) {
  .p-header__contact a {
    padding: 1rem 0;
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 768px) {
  .p-header__contact a {
    padding: 0.75rem 0;
    font-size: 0.875rem;
  }
}
.p-header__contact img {
  width: 17px;
  vertical-align: middle;
  margin-right: 8px;
}
@media screen and (max-width: 1200px) {
  .p-header__contact img {
    width: 20px;
    margin-right: 12px;
  }
}

.p-global__cta {
  display: none;
}
@media screen and (max-width: 1200px) {
  .p-global__cta {
    display: block;
  }
}

.js-header.change-color {
  position: fixed;
  background-color: #fff;
  top: 0;
  box-shadow: 0px 6px 6px -4px rgba(0, 0, 0, 0.1);
  animation-name: headerAnimation;
  animation-duration: 0.5s;
  animation-timing-function: ease-out;
  z-index: 1000000;
}

@keyframes headerAnimation {
  0% {
    top: -10%;
  }
  100% {
    top: 0;
  }
}
.js-header.change-color .p-header__body {
  padding: 0.875rem 0;
}

@media screen and (max-width: 1200px) {
  .is-active-drawer .p-global-nav {
    /* Android, Brackberry  */ /* IE9 */
    transform: translateX(0);
  }
  .is-active-drawer .drawer_bg {
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    background-color: rgba(51, 51, 51, 0.6);
  }
  .fixed {
    width: 100%;
    height: 100%;
    position: fixed;
  }
}

.contents .qi-tbl-01 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .qi-tbl-01 {
    margin: 1.375rem 0;
  }
}

.contents .qi-tbl-01 th {
  width: 50%;
  background: #ffeaf0;
  border: 1px solid #bab9b9;
  padding: 14px 0;
}

@media screen and (max-width: 768px) {
  .contents .qi-tbl-01 th {
    padding: 10px 0;
  }
}

.contents .qi-tbl-01 td {
  width: 50%;
  border: 1px solid #bab9b9;
  text-align: center;
  padding: 14px 0;
}

@media screen and (max-width: 768px) {
  .contents .qi-tbl-01 td {
    padding: 10px 0;
  }
}

/*
  動画
*/

.p-movie {
  padding-top: 2.1875rem;
  padding-bottom: 0.625rem;
}

@media screen and (max-width: 768px) {
  .p-movie {
    padding-top: 1.25rem;
    padding-bottom: 0rem;
  }
}

.p-movie p {
  font-size: clamp(1.063rem, 0.893rem + 0.75vw, 1.375rem);
  color: #222;
  padding-top: 1.625rem;
  text-align: center;
  font-weight: 700;
}

.p-movie p span {
  font-size: 18px;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .p-movie p {
    line-height: 1.6;
    padding-top: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .p-movie p span {
    font-size: 14px;
    font-weight: 500;
  }
}

#movie {
  width: 70%;
  height: auto;
  position: relative;
  margin: auto;
}

@media screen and (max-width: 768px) {
  #movie {
    width: 100%;
  }
}

#movie::before {
  display: block;
  content: "";
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}

#movie video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border: 2px solid #d9d9d9;
}

.play-btn {
  display: block;
  width: 10%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
}

@media screen and (max-width: 768px) {
  .play-btn {
    width: 17%;
  }
}

.play-btn.playActive {
  display: none;
}

.hide_pc {
  display: none;
}

@media screen and (max-width: 768px) {
  .hide_pc {
    display: block;
  }
}

.contents .cc-tbl-01 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-01 {
    margin: 1.375rem 0;
    line-height: 1.7;
  }
}

.contents .cc-tbl-01 .ttl th {
  background: #ffeaf0;
  padding: 10px 0;
  border: 1px solid #bab9b9;
}

.contents .cc-tbl-01 td {
  padding: 14px 0;
  border: 1px solid #bab9b9;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-01 td {
    padding: 10px;
  }
}

.contents .cc-tbl-01 .detail {
  padding: 14px 0 14px 50px;
  border: 1px solid #bab9b9;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-01 .detail {
    padding: 10px;
  }
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.contents .cc-tbl-02 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-02 {
    margin: 1.375rem 0;
    line-height: 1.7;
  }
}

.contents .cc-tbl-02 td {
  padding: 14px 0;
  border: 1px solid #bab9b9;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-02 td {
    padding: 10px;
  }
}

.contents .cc-tbl-02 .step {
  width: 15%;
  text-align: center;
  background: #ededed;
}

.contents .cc-tbl-02 .kind {
  width: 30%;
  padding: 14px 20px;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-02 .kind {
    padding: 10px;
  }
}

.contents .cc-tbl-02 .detail {
  padding: 14px 30px;
  border: 1px solid #bab9b9;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-02 .detail {
    padding: 10px;
  }
}

.wt-70 {
  width: 70%;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .wt-70 {
    width: 100%;
  }
}

.contents .cc-tbl-03 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-03 {
    margin: 1.375rem 0;
    line-height: 1.7;
  }
}

.contents .cc-tbl-03 th {
  padding: 14px 0;
  background: #ffeaf0;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-03 th {
    padding: 10px;
  }
}

.contents .cc-tbl-03 td {
  padding: 20px 200px;
  border: 1px solid #bab9b9;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-03 td {
    padding: 10px;
  }
}

.contents .cc-tbl-04 {
  border: 2px solid #bab9b9;
  width: 100%;
  margin: 2.5rem 0;
  /* min-width: 500px; */
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-04 {
    margin: 1.375rem 0;
    line-height: 1.7;
  }
}

.contents .cc-tbl-04 th {
  padding: 14px 0;
  background: #e0eaf6;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-04 th {
    padding: 10px;
  }
}

.contents .cc-tbl-04 td {
  padding: 20px 200px;
  border: 1px solid #bab9b9;
}

@media screen and (max-width: 768px) {
  .contents .cc-tbl-04 td {
    padding: 10px;
  }
}

.p-contact {
  border-bottom: 2px solid #f8f8f8;
}

.p-contact__contents {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .p-contact__contents {
    display: block;
  }
}

.p-contact__txt {
  padding-top: 10px;
  width: 48%;
}
@media screen and (max-width: 768px) {
  .p-contact__txt {
    padding-top: 0px;
    width: 100%;
  }
}
.p-contact__txt .ttl {
  font-size: clamp(1.125rem, 0.922rem + 0.9vw, 1.5rem);
  font-weight: 700;
  line-height: 1.8;
  color: #e7235f;
}
@media screen and (max-width: 768px) {
  .p-contact__txt .ttl {
    text-align: center;
  }
}
.p-contact__txt .ttl span {
  font-size: clamp(0.875rem, 0.807rem + 0.3vw, 1rem);
  color: #e7235f;
}
.p-contact__txt figure {
  padding: 1.25rem 0;
}
@media screen and (max-width: 768px) {
  .p-contact__txt figure {
    padding: 0.625rem 0 0.625rem;
    width: 80%;
    margin: auto;
  }
}
.p-contact__txt figure img {
  width: 100%;
}
.p-contact__txt .point li {
  padding-bottom: 0.3125rem;
  font-weight: 700;
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 768px) {
  .p-contact__txt .point li {
    padding-bottom: 0.125rem;
  }
}
.p-contact__txt .point li > img {
  width: 26px;
  display: inline-block;
  margin-right: 0.625rem;
  padding-top: 0.3125rem;
}
@media screen and (max-width: 768px) {
  .p-contact__txt .point li > img {
    width: 20px;
    margin-right: 0.5rem;
  }
}
.p-contact__txt .box {
  background: #fafafa;
  border-radius: 10px;
  padding: 1.25rem 2.6875rem;
  margin: 1.75rem 0;
}
@media screen and (max-width: 768px) {
  .p-contact__txt .box {
    padding: 0.875rem 1.75rem;
    margin: 0 0 20px 0;
  }
}
.p-contact__txt .box li {
  display: flex;
  align-items: flex-start;
}
.p-contact__txt .box p {
  font-weight: 700;
}
.p-contact__txt .box .circle {
  display: inline-block;
  margin-right: 8px;
  background: #e7235f;
  width: 8px;
  height: 8px;
  border-radius: 50px;
  flex-shrink: 0;
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .p-contact__txt .box .circle {
    margin-right: 7px;
    margin-top: 10px;
  }
}

.p-contact__form {
  margin-top: -40px;
  width: 48%;
}
@media screen and (max-width: 768px) {
  .p-contact__form {
    margin-top: 0px;
    width: 100%;
  }
}

.l-container.-Small {
  max-width: 950px;
  margin: 0 auto;
  width: 90%;
}

.p-download {
  border-bottom: 2px solid #f8f8f8;
}

.p-download__thanks {
  text-align: center;
  padding: 40px 0 70px;
}
@media screen and (max-width: 768px) {
  .p-download__thanks {
    padding-top: 1.25rem;
  }
}
.p-download__thanks .tel {
  display: inline-block;
  text-decoration: underline;
}
.p-download__thanks .txt {
  color: #e7235f;
  font-weight: 700;
  text-align: center;
  font-size: clamp(1.125rem, 0.978rem + 0.65vw, 1.5rem);
  padding: 3.125rem 0 1.875rem;
}
@media screen and (max-width: 768px) {
  .p-download__thanks .txt {
    line-height: 1.7;
    padding: 1.875rem 0 1.25rem;
  }
}
.p-download__thanks .box {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  -moz-column-gap: 1.875rem;
  column-gap: 1.875rem;
}
@media screen and (max-width: 768px) {
  .p-download__thanks .box {
    grid-template-columns: 1fr;
    row-gap: 1.25rem;
  }
}
.p-download__thanks figure img {
  width: 100%;
}
.p-download__thanks .item {
  border-radius: 10px;
  padding: 1.875rem 1.25rem 2.5rem;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.16);
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
}
@media screen and (max-width: 768px) {
  .p-download__thanks .item {
    padding: 1.25rem;
    grid-template-rows: auto;
  }
}
.p-download__thanks .ttl {
  font-weight: 700;
  font-size: clamp(1.125rem, 1.027rem + 0.43vw, 1.375rem);
  line-height: 1.5;
}
.p-download__thanks figure {
  width: 90%;
  margin: auto;
  padding-top: 0.625rem;
}
@media screen and (max-width: 768px) {
  .p-download__thanks figure {
    width: 70%;
    padding-top: 0.3125rem;
  }
}
.p-download__thanks .text-back {
  display: inline-block;
  text-decoration: underline;
  padding-top: 2.5rem;
}
@media screen and (max-width: 768px) {
  .p-download__thanks .text-back {
    padding-top: 1.25rem;
  }
}
.p-download__thanks .text-back a {
  color: #00100e;
}
.p-download__thanks .btn {
  padding-top: 1.625rem;
}
@media screen and (max-width: 768px) {
  .p-download__thanks .btn {
    padding-top: 0.625rem;
  }
}
.p-download__thanks .btn a {
  color: #fff;
  font-weight: 700;
  text-align: center;
  border-radius: 50px;
  background: #e7235f;
  display: inline-block;
  padding: 0.3125rem;
  font-size: clamp(1rem, 0.902rem + 0.43vw, 1.25rem);
  width: 100%;
  background-image: url(../image/download/icon-next.svg);
  background-repeat: no-repeat;
  background-position: 93% center;
  position: relative;
}
.p-download__thanks .btn a::after {
  position: absolute;
  content: "";
  background-image: url(../image/common/icon_next_white.svg);
  width: 12px;
  height: 14px;
  right: 8%;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .p-download__thanks .btn a {
    padding: 0.3125rem;
  }
}
.p-download__thanks .btn a:hover {
  opacity: 0.9;
}
.p-download__thanks .youtube {
  padding-top: 1.5rem;
}
@media screen and (max-width: 768px) {
  .p-download__thanks .youtube {
    padding-top: 1rem;
  }
}
.p-download__thanks .youtube a {
  text-decoration: underline;
  color: #222222;
} /*# sourceMappingURL=common.css.map */

.p-download__thanks .list {
  text-align: left;
  padding-top: 20px;
  margin-left: 70px;
}

@media screen and (max-width: 768px) {
  .p-download__thanks .list {
    text-align: left;
    padding-top: 18px;
    margin-left: 0px;
  }
}

.hide_sp {
  display: block;
}

@media screen and (max-width: 768px) {
  .hide_sp {
    display: none;
  }
}

.hide_pc {
  display: none;
}

@media screen and (max-width: 768px) {
  .hide_pc {
    display: block;
  }
}

.p-contact__contents video {
  width: 100%;
  margin-top: 30px;
}

@media screen and (max-width: 768px) {
  .p-contact__contents video {
    width: 100%;
    margin-top: 20px;
  }
}

.ul-movie-navi {
  width: 85%;
  margin: 40px auto 50px;
}

@media screen and (max-width: 768px) {
  .ul-movie-navi {
    width: 100%;
    margin: 30px auto 40px;
  }
}

.ul-movie-navi li {
  display: inline-block;
  width: 32%;
  text-align: center;
  border-right: #e7225e 2px solid;
}

.ul-movie-navi li a {
  color: #222;
  text-decoration: underline;
}

.ul-movie-navi li:last-child {
  border-right: none;
}

.h2_std {
  width: 180px;
  margin: auto;
  margin-bottom: 20px;
}

@media screen and (max-width: 768px) {
  .h2_std {
    margin-bottom: 10px;
  }
}

.h2_std span {
  padding: 3px 0px;
  border-radius: 50px;
  display: inline-block;
  background: #e7225e;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .h2_std span {
    padding: 3px 0px;
    font-size: 16px;
  }
}

.screen-movie {
  width: 85%;
  margin: 25px auto;
}

@media screen and (max-width: 768px) {
  .screen-movie {
    width: 95%;
    margin: 15px auto;
  }
}

.screen-movie h3 {
  font-weight: 700;
  margin-bottom: 10px;
}

@media screen and (max-width: 768px) {
  .screen-movie h3 {
    margin-bottom: 3px;
  }
}

.screen-movie p {
  margin-bottom: 30px;
}

@media screen and (max-width: 768px) {
  .screen-movie p {
    margin-bottom: 18px;
  }
}

.screen-movie video {
  width: 100%;
  border: #ccc 1px solid;
}

.pc-none {
  display: none;
}

@media screen and (max-width: 768px) {
  .pc-none {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .sp-none {
    display: none;
  }
}

.mgn-bottom50 {
  margin-bottom: 50px;
}

.slick-dots li button:before {
  font-size: 10px;
}
@media screen and (max-width: 768px) {
  .slick-dots li button:before {
    font-size: 10px;
  }
}

.slick-dots li.slick-active button:before {
  color: #e7235f;
}

.slick-next:before,
.slick-prev:before {
  color: #333;
  opacity: 1;
}
.slick-dotted.slick-slider {
  margin-bottom: 3.125rem;
}

.slick-slide img {
  width: 100%;
}

.slider {
  padding-top: 1.5625rem;
  width: 90%;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .slider {
    padding-top: 1.25rem;
  }
}

.slider .pages {
  border: 1.5px solid #cfcfcf;
}

.p-interview__top .point {
  margin-bottom: 70px;
}

@media screen and (max-width: 768px) {
  .p-interview__top .point {
    margin-bottom: 30px;
  }
}

.p-interview__top .point p {
  color: #222e51;
  font-weight: 700;
  background: #efefef;
  font-size: clamp(1.063rem, 0.893rem + 0.75vw, 1.375rem);
  border-radius: 5px;
  padding: 0.4375rem 2.0625rem;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point p {
    padding: 0.3125rem 1.25rem;
  }
}

.p-interview__top .point dl {
  display: flex;
  padding: 1.625rem 1.25rem;
  justify-content: space-between;
  border-bottom: 2px solid #ececec;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point dl {
    display: block;
    padding: 0.875rem 0;
  }
}

.p-interview__top .point dl:last-child {
  border-bottom: none;
}

.p-interview__top .point dt {
  font-size: clamp(1rem, 0.864rem + 0.6vw, 1.25rem);
  /* color: #e7235f; */
  font-weight: 500;
  width: 15%;
  line-height: 1;
  padding-top: 6px;
  width: 30%;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point dt {
    width: 100%;
  }
}

.p-interview__top .point dt img {
  width: 19px;
  margin-right: 0.8125rem;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point dt img {
    width: 17px;
    vertical-align: middle;
    margin-right: 0.625rem;
  }
}

.p-interview__top .point .list {
  width: 80%;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point .list {
    width: 100%;
    padding-top: 0.5rem;
  }
}

.p-interview__top .point dd {
  display: flex;
}

.p-interview__top .point dd img {
  display: inline-block;
  width: 10px;
  margin-right: 0.625rem;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point dd img {
    width: 9px;
  }
}
.p-interview__top .point ul {
  padding: 1.625rem 1.25rem;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point ul {
    padding: 0.875rem 0;
  }
}
.p-interview__top .point li img {
  display: inline-block;
  width: 10px;
  margin-right: 0.625rem;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .p-interview__top .point li img {
    width: 9px;
  }
}
