@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
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,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video,
span {
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  border: 0;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
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-spacing: 0;
  border-collapse: collapse;
}

img {
  display: block;
  width: 100%;
}

html {
  font-size: 10px;
}
@media (max-width: 768px) {
  html {
    font-size: 7.5px;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  overflow-x: hidden;
  background-color: #ffffff;
}
body * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
body h1,
body h2,
body h3,
body h4,
body h5 {
  font-weight: bold;
  line-height: 1.45;
}
body p {
  line-height: 1.75;
}
body a {
  display: block;
  text-decoration: none;
  color: #000000;
}

.l-container {
  width: 100%;
  max-width: 1232px;
  margin: 0 auto;
  padding: 0 16px;
}
@media (max-width: 768px) {
  .l-container {
    padding: 0 4%;
  }
}
.l-container--750 {
  max-width: calc(750px + 32px);
  margin: 0 auto;
}
.l-container--900 {
  max-width: calc(900px + 32px);
  margin: 0 auto;
}

.l-main {
  overflow-x: hidden;
  min-width: 1200px;
}
@media (max-width: 768px) {
  .l-main {
    min-width: auto;
  }
}

.c-text {
  font-size: 16px;
}
@media (max-width: 768px) {
  .c-text {
    font-size: 16px;
  }
}
.c-text + .c-text {
  margin-top: calc(16px * 1.75);
}

.c-bold {
  font-weight: bold;
}

img,
picture {
  display: block;
  height: auto;
}

.pc-none {
  display: none;
}
@media (max-width: 768px) {
  .pc-none {
    display: block;
  }
}

.sp-none {
  display: block;
}
@media (max-width: 768px) {
  .sp-none {
    display: none;
  }
}

.c-en {
  font-family: "Montserrat", sans-serif;
}

.c-link-wrapper {
  display: inline-block;
}

.c-inner-link {
  text-decoration: underline;
  color: #000000;
}

.c-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-decoration: none;
  color: #000000;
}
.c-link::after {
  width: 24px;
  height: 24px;
  margin-left: 8px;
  content: "";
  background-image: url(../../assets/img/ico_arrow01.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.c-link--external {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-link--external::after {
  width: 24px;
  height: 24px;
  margin-left: 8px;
  content: "";
  background-image: url(../../assets/img/ico_arrow_external01.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.c-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-flex--2 {
  gap: 40px;
}
@media (max-width: 768px) {
  .c-flex--2 {
    gap: 24px;
  }
}
.c-flex--2 .c-flex__item {
  width: calc(100% / 2 - (40px / 2));
}
@media (max-width: 768px) {
  .c-flex--2 .c-flex__item {
    width: 100%;
  }
}

.c-flex--3 {
  gap: 24px;
}
@media (max-width: 768px) {
  .c-flex--3 {
    gap: 24px;
  }
}
.c-flex--3 .c-flex__item {
  width: calc(100% / 3 - (24px / 3 * 2));
}
@media (max-width: 768px) {
  .c-flex--3 .c-flex__item {
    width: 100%;
  }
}

.c-text-inner-link {
  display: inline-block;
  text-decoration: underline;
}
.c-text-inner-link::before {
  display: inline-block;
  width: 24px;
  height: 24px;
  -webkit-transition: right 0.3s;
  transition: right 0.3s;
  background-image: url(../../assets/img/ico_new_tab02.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}

.material .c-link--pdf {
  margin-top: 40px;
}
.material .c-link + .c-link {
  margin-top: 24px;
}

.c-link {
  font-size: 16px;
  line-height: 2;
  text-decoration: underline;
}
.c-link:hover {
  text-decoration: none;
}

.c-link--pdf {
  font-size: 16px;
  line-height: 2;
  position: relative;
  padding-left: 32px;
}
.c-link--pdf:before {
  position: absolute;
  top: calc(16px * 2 / 2);
  left: 0;
  width: 32px;
  height: 32px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-image: url(../../assets/img/ico_pdf01.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.c-text--link {
  display: inline-block;
  text-decoration: underline;
}

body {
  position: relative;
}

.l-header {
  position: fixed;
  z-index: 99;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  min-width: calc(1200px - 32px);
  max-width: 1920px;
  padding: 8px 16px;
}
@media (max-width: 768px) {
  .l-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow-y: visible;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: calc(100%);
    min-width: auto;
    padding: 0 4%;
  }
}

.l-header__logo {
  font-family: "Montserrat", sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #005bac;
}
@media (max-width: 768px) {
  .l-header__logo {
    font-size: 16px;
    position: relative;
    top: 0;
  }
}
.l-header__logo img {
  display: block;
}

.l-header__nav {
  position: relative;
  z-index: 98;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media (max-width: 768px) {
  .l-header__nav {
    position: absolute;
    top: 50px;
    display: none;
    width: 100%;
    height: calc(100svh - 100px);
    padding: 40px 24px;
    background-color: #ffffff;
  }
}

@media (max-width: 768px) {
  .l-header__nav-btn.active + .l-header__nav {
    left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.l-header__nav-list {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  .l-header__nav-list {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 2.4rem;
  }
}

.l-header__nav-logo {
  display: none;
}

.l-header__nav-list-item:last-child {
  margin-left: 24px;
}
@media (max-width: 768px) {
  .l-header__nav-list-item:last-child {
    margin: 0 auto;
  }
}
.l-header__nav-list-item:last-child a {
  font-weight: bold;
  padding: 12px 40px;
  -webkit-transition: background-color 0.3s, color 0.3s;
  transition: background-color 0.3s, color 0.3s;
  color: #ffffff;
  border: 2px solid #005bac;
  border-radius: 24px;
  background-color: #005bac;
}
.l-header__nav-list-item:last-child a::before {
  display: none;
}
.l-header__nav-list-item:last-child a:hover {
  color: #000000;
  background-color: #ffffff;
}

.l-header__nav-list-item a {
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1.45;
  position: relative;
  display: block;
  padding: 4px 12px;
  text-decoration: none;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #000000;
}
@media (max-width: 768px) {
  .l-header__nav-list-item a {
    font-size: 2.4rem;
    padding: 8px 0;
    text-align: left;
  }
}
.l-header__nav-list-item a::before {
  position: absolute;
  bottom: 0;
  left: 20%;
  width: 0;
  height: 2px;
  content: "";
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
  background-color: #000000;
}
.l-header__nav-list-item a:hover {
  color: #000000;
}
.l-header__nav-list-item a:hover::before {
  width: 60%;
}

.l-header__nav-copy {
  font-size: 24px;
  font-weight: 300;
  line-height: 1.45;
  display: none;
  margin-top: 18px;
  color: #ffff;
}
@media (max-width: 768px) {
  .l-header__nav-copy {
    display: block;
  }
}

.l-header__link {
  position: absolute;
  top: 0;
  right: -16px;
}
@media (max-width: 768px) {
  .l-header__link {
    position: initial;
    right: 0;
    margin-left: auto;
  }
}
@media (max-width: 1600px) {
  .l-header__link {
    right: 0;
  }
}

.l-header__link-list-item {
  font-size: 1.2rem;
  font-weight: bold;
  position: relative;
  display: block;
  width: 9rem;
  height: 9rem;
  padding: 60px 4px 18px;
  text-align: center;
  text-decoration: none;
}
@media (max-width: 768px) {
  .l-header__link-list-item {
    font-size: 0;
    width: 60px;
    height: 60px;
    padding: 0;
  }
}
.l-header__link-list-item::before {
  position: absolute;
  top: 19px;
  left: 50%;
  width: 36px;
  height: 26px;
  content: "";
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background-image: url(../../assets/img/common/ico_mail.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
@media (max-width: 768px) {
  .l-header__link-list-item::before {
    top: 50%;
    width: 24px;
    height: 18px;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}

.l-header__nav-btn {
  position: relative;
  z-index: 99;
  display: none;
}
@media (max-width: 768px) {
  .l-header__nav-btn {
    display: block;
  }
}

.c-openbtn1 {
  position: relative;
  /*ボタン内側の基点となるためrelativeを指定*/
  width: 50px;
  height: 50px;
  margin-left: 8px;
  cursor: pointer;
}

/*ボタン内側*/
.c-openbtn1 span.c-openbtn1__line {
  position: absolute;
  left: 50%;
  display: inline-block;
  width: 70%;
  height: 2px;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  /*アニメーションの設定*/
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: #000000;
}

.c-openbtn1 span:nth-of-type(1) {
  top: calc(25px - 8px);
}

.c-openbtn1 span:nth-of-type(2) {
  top: 25px;
}

.c-openbtn1 span:nth-of-type(3) {
  top: calc(25px + 8px);
}

.c-openbtn1.active .open {
  opacity: 0;
}
.c-openbtn1.active .close {
  opacity: 1;
}

.c-openbtn1.active span:nth-of-type(1) {
  top: calc(25px + 6px);
  left: 43%;
  width: 45%;
  -webkit-transform: rotate(30deg) translateX(-50%);
          transform: rotate(30deg) translateX(-50%);
}

.c-openbtn1.active span:nth-of-type(2) {
  opacity: 0;
  /*真ん中の線は透過*/
}

.c-openbtn1.active span:nth-of-type(3) {
  top: calc(25px - 6px);
  left: 43%;
  width: 45%;
  -webkit-transform: rotate(-30deg) translateX(-50%);
          transform: rotate(-30deg) translateX(-50%);
}

span.c-openbtn1__ttl {
  font-size: 1.4rem;
  font-weight: bold;
  position: absolute;
  bottom: 8px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  text-transform: uppercase;
}

@media (max-width: 768px) {
  .l-header__nav-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 32px;
  }
}
.l-header__nav-link .c-btn {
  margin-top: 0;
}
.l-header__nav-link .c-btn-inner {
  text-transform: uppercase;
}

.c-header__link {
  font-size: 24px;
  font-weight: bold;
  padding: 16px 40px;
  text-decoration: none;
  text-transform: capitalize;
  color: #000000;
  background-color: #ffffff;
}

.c-nav-store-name {
  font-size: 16px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #ffffff;
}

.c-nav-link-list {
  margin-top: 16px;
}

.c-nav-link-item * {
  text-transform: uppercase;
  color: #ffffff;
}
.c-nav-link-item .c-link--external::after {
  background-image: url(../../assets/img/ico_arrow_external_white01.svg);
}

.c-nav-sns-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 16px;
  gap: 24px;
}

.c-sns-link {
  width: 40px;
  height: 40px;
  padding: 10px;
  border-radius: 50%;
  background-color: #ffffff;
}
.c-sns-link img {
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center center;
     object-position: center center;
}

.l-header__nav-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: 24px;
  gap: 16px;
}
@media (max-width: 768px) {
  .l-header__nav-link {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-left: 0;
  }
}
.l-header__nav-link a {
  font-size: 16px;
  line-height: 1.45;
  padding: 8px 24px;
  -webkit-transition: -webkit-box-shadow 0.3s;
  transition: -webkit-box-shadow 0.3s;
  transition: box-shadow 0.3s;
  transition: box-shadow 0.3s, -webkit-box-shadow 0.3s;
  text-align: center;
  text-decoration: none;
  border-radius: 24px;
}
.l-header__nav-link a:hover {
  -webkit-box-shadow: none;
          box-shadow: none;
}
.l-header__nav-link .download {
  color: #ffff;
  background-color: #000000;
}
.l-header__nav-link .contact {
  color: #000000;
  background-color: #eabe0c;
}

.l-footer {
  overflow-x: hidden;
  min-width: 1200px;
}
@media (max-width: 768px) {
  .l-footer {
    min-width: auto;
  }
}

.l-footer__inner {
  padding-bottom: 2.4rem;
  color: #ffffff;
  background-color: #005bac;
}

.l-footer-contact__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.l-footer-contact {
  position: relative;
  margin-top: 240px;
  padding: 80px 0;
  background-color: rgba(0, 91, 172, 0.1);
}
@media (max-width: 768px) {
  .l-footer-contact {
    margin-top: 180px;
  }
}
.l-footer-contact .c-sec-header__en {
  font-size: 56px;
}
.l-footer-contact .c-sec-header__jp {
  text-align: center;
}
.l-footer-contact .c-phone {
  font-size: 32px;
  font-weight: bold;
}
@media (max-width: 768px) {
  .l-footer-contact .c-phone {
    font-size: 24px;
  }
}
.l-footer-contact .c-btn {
  margin: 40px auto 0;
}
.l-footer-contact .c-text {
  margin-top: 0;
  text-align: center;
}

.p-footer-contact__link,
.p-footer-contact__content {
  width: calc(50% - (56px / 2));
}
@media (max-width: 768px) {
  .p-footer-contact__link,
.p-footer-contact__content {
    width: 100%;
  }
}

.p-footer__logo {
  width: auto;
  color: #ffffff;
}
@media (max-width: 768px) {
  .p-footer__logo {
    margin: 0 auto;
  }
}

.l-footer-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-top: 80px;
}
.l-footer-content a,
.l-footer-content p {
  display: inline-block;
}
.l-footer-content p {
  display: block;
}

.l-footer-content__nav {
  margin-top: 0;
}
@media (max-width: 768px) {
  .l-footer-content__nav {
    margin-top: 40px;
  }
}

.p-footer-nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
}
@media (max-width: 768px) {
  .p-footer-nav__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-footer-nav__list a {
  display: inline-block;
  text-decoration: none;
  color: #ffffff;
}

.p-footer-nav__item-inner {
  text-transform: uppercase;
}
.p-footer-nav__item-inner:hover {
  text-decoration: underline;
}

.c-footer-link-item-header {
  font-size: 16px;
  width: 80px;
}

.l-footer-content__link-item-list a {
  text-decoration: underline;
}
.l-footer-content__link-item-list a::after {
  background: url(../../assets/img/ico_arrow_external_white01.svg);
}

.l-footer-copyright {
  margin-top: 80px;
}

.c-copyright {
  font-size: 14px;
  text-align: center;
}
@media (max-width: 768px) {
  .c-copyright {
    margin-top: 32px;
    margin-left: auto;
    padding: 0 4%;
    text-align: right;
  }
}

.c-footer-copy {
  font-size: 64px;
  font-weight: 200;
  line-height: 1.2;
  text-align: left;
}
@media (max-width: 768px) {
  .c-footer-copy {
    font-size: 24px;
    text-align: left;
  }
}

.c-btn-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-btn {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.45;
  display: inline-block;
  width: 100%;
  max-width: 320px;
  margin-top: 6rem;
  padding: 12px 40px;
  -webkit-transition: color 0.3s, background-color 0.3s;
  transition: color 0.3s, background-color 0.3s;
  text-align: center;
  text-decoration: none;
  color: #005bac;
  border: 2px solid #005bac;
  border-radius: 40px;
}
@media (max-width: 768px) {
  .c-btn {
    font-size: 14px;
    max-width: 240px;
  }
}
.c-btn:hover {
  color: #ffffff;
  background-color: #005bac;
}
.c-btn--external {
  padding: 0;
  color: #000000;
  border: 0;
  background-color: initial;
}
.c-btn--external:hover {
  text-decoration: underline;
  border: 0;
}
.c-btn--external:hover .c-btn-inner::after {
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.c-btn--external .c-btn-inner {
  padding-right: 16px;
  padding-left: 32px;
}
.c-btn--external .c-btn-inner::after {
  left: 0;
  background-image: url(../../assets/img/ico_external02.svg);
}
.c-btn--external .c-btn-inner::before {
  display: none;
}
.c-btn--white {
  color: #000000;
  border: 1px solid #ffffff;
  background-color: #ffffff;
}
.c-btn--white:hover {
  border: 1px solid #ffffff;
}
.c-btn--white .c-btn-inner::after {
  background-image: url(../../assets/img/ico_arrow04.svg);
}
.c-btn--text {
  font-size: 1.4rem;
  line-height: 1.45;
  width: 100%;
  padding: 0;
  color: #000000;
  border: 0;
  border-radius: 0;
  background-color: initial;
}
@media (max-width: 768px) {
  .c-btn--text {
    font-size: 14px;
  }
}
.c-btn--text:hover {
  text-decoration: underline;
  border: 0;
}
.c-btn--text:hover .c-btn-inner::after {
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.c-btn--text .c-btn-inner {
  padding-right: 0;
  padding-left: 2.4rem;
}
.c-btn--text .c-btn-inner::before {
  display: none;
}
.c-btn--text .c-btn-inner::after {
  left: 0;
  width: 2.4rem;
  height: 2.4rem;
  background-image: url(../../assets/img/ico_arrow_navy01.svg);
}
.c-btn--orange {
  color: #ffffff;
  background-color: #005bac;
}

.c-btn-inner {
  line-height: 1.45;
  position: relative;
  display: block;
  width: 100%;
  padding-right: 77px;
  text-transform: capitalize;
}
@media (max-width: 768px) {
  .c-btn-inner {
    padding-right: 50px;
  }
}
.c-btn-inner::before {
  position: absolute;
  z-index: 0;
  top: 50%;
  right: 0;
  width: 36px;
  height: 36px;
  content: "";
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border-radius: 50%;
  background-color: #ffffff;
}
.c-btn-inner::after {
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 6px;
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-image: url(../../assets/img/ico_arrow01.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
@media (max-width: 768px) {
  .c-btn-inner::after {
    width: 20px;
    height: 20px;
  }
}

.c-btn--white {
  background-color: #ffffff;
}

.c-btn--center {
  display: block;
  max-width: 320px;
  margin: 0 auto;
  padding: 24px 40px;
  border-radius: 40px;
}
@media (max-width: 768px) {
  .c-btn--center {
    max-width: 280px;
    padding: 12px 24px;
  }
}

.c-pagetitle-wrapper {
  position: relative;
  padding: 120px 0;
  background: #e0e0e0;
  background-position: center center;
  background-size: cover;
}
@media (max-width: 768px) {
  .c-pagetitle-wrapper {
    padding: 120px 0 80px;
  }
}
.c-pagetitle-wrapper::after {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
}
.c-pagetitle-wrapper * {
  position: relative;
  z-index: 1;
}

.c-pagetitle-sub {
  font-size: 48px;
  font-weight: 200;
  font-weight: bold;
  text-align: center;
  text-transform: uppercase;
  color: #000000;
}
@media (max-width: 768px) {
  .c-pagetitle-sub {
    font-size: 32px;
  }
}

.c-pagetitle {
  font-size: 24px;
  font-weight: normal;
  margin-top: 8px;
  text-align: center;
  color: #005bac;
}
@media (max-width: 768px) {
  .c-pagetitle {
    font-size: 16px;
  }
}

.c-breadcrumbs-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow-x: scroll;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 16px 0;
  gap: 32px;
}

.c-breadcrumbs-item a {
  text-decoration: underline;
  color: #000000;
}
.c-breadcrumbs-item a:hover {
  text-decoration: none;
}
.c-breadcrumbs-item a,
.c-breadcrumbs-item p {
  line-height: 24px;
  display: block;
  white-space: nowrap;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .c-breadcrumbs-item a,
.c-breadcrumbs-item p {
    line-height: 20px;
  }
}

.c-breadcrumbs-item + .c-breadcrumbs-item {
  position: relative;
}
.c-breadcrumbs-item + .c-breadcrumbs-item::before {
  position: absolute;
  top: 50%;
  left: calc(32px / 2 * -1);
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-image: url(../../assets/img/ico_arrow02.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
@media (max-width: 768px) {
  .c-breadcrumbs-item + .c-breadcrumbs-item::before {
    width: 20px;
    height: 20px;
  }
}

/****************************************

COMMON

****************************************/
.c-top-section + .c-top-section {
  margin-top: 240px;
}
@media (max-width: 768px) {
  .c-top-section + .c-top-section {
    margin-top: 160px;
  }
}

.c-sec-header {
  position: relative;
}
.c-sec-header::after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 2px;
  background-color: #000000;
}
.c-sec-header + * {
  margin-top: 40px;
}
@media (max-width: 768px) {
  .c-sec-header + * {
    margin-top: 32px;
  }
}

p.c-sec-header__en {
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.45;
  display: inline-block;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #005bac;
}
@media (max-width: 768px) {
  p.c-sec-header__en {
    font-size: 28px;
  }
}

h2.c-sec-header__jp {
  font-size: 32px;
  font-weight: bold;
  line-height: 1.45;
  margin-top: 4px;
}
@media (max-width: 768px) {
  h2.c-sec-header__jp {
    font-size: 16px;
  }
}

.c-copy {
  font-size: 40px;
  font-weight: bold;
  line-height: 1.45;
  margin-top: 40px;
}
@media (max-width: 768px) {
  .c-copy {
    font-size: 28px;
    margin-top: 24px;
  }
}

.c-text {
  line-height: 1.75;
  margin-top: 26px;
}

.c-arrow {
  position: relative;
  padding-right: 24px;
}
.c-arrow::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transition: right 0.3s;
  transition: right 0.3s;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-image: url(../../assets/img/ico_arrow01.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
.c-arrow:hover::after {
  right: -8px;
}

/****************************************

KV

****************************************/
.p-kv {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 90px;
  aspect-ratio: calc(1440 / 700);
}
@media (max-width: 768px) {
  .p-kv {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: 50px;
    padding-top: calc(300 / 375 * 100%);
    aspect-ratio: calc(375 / 550);
  }
}
.p-kv::before {
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  display: block;
  overflow: hidden;
  width: calc(1200 / 1440 * 100%);
  height: auto;
  content: "";
  border-radius: 80px 0 0 0;
  background: url(../../assets/img/nippon-ev/kv01.jpg) top right/100% 100% no-repeat;
  aspect-ratio: calc(1200 / 600);
}
@media (max-width: 768px) {
  .p-kv::before {
    width: 96%;
    border-radius: 48px 0 0 0;
    background: url(../../assets/img/nippon-ev/kv01_sp.jpg) top right/100% 100% no-repeat;
    aspect-ratio: calc(400 / 300);
  }
}
.p-kv .c-btn {
  font-size: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 80px;
}
@media (max-width: 768px) {
  .p-kv .c-btn {
    font-size: 16px;
    max-width: 280px;
    height: 64px;
    margin: 24px auto 0;
  }
}
.p-kv .c-btn:hover {
  color: #005bac;
  background-color: #ffffff;
}

.p-kv__inner {
  width: 92%;
  padding: 0 4%;
}

.p-kv__copy {
  font-size: 40px;
  font-weight: bold;
}
@media (max-width: 768px) {
  .p-kv__copy {
    font-size: 30px;
  }
}
.p-kv__copy span {
  color: #005bac;
}

.p-kv__desc {
  font-size: 16px;
  max-width: 400px;
  margin-top: 40px;
}
@media (max-width: 768px) {
  .p-kv__desc {
    margin-top: 18px;
  }
}

/****************************************

NEWS

****************************************/
.p-top-news {
  padding: 40px 0;
}
@media (max-width: 768px) {
  .p-top-news {
    padding: 24px 0;
  }
}
.p-top-news .c-journal__all {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-top: 24px;
}

.l-container.p-top-news-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media (max-width: 768px) {
  .l-container.p-top-news-inner {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.l-container.p-top-news-inner .c-text {
  margin-top: 0;
}

.p-top-news-list {
  width: 750px;
  margin-top: 0;
  margin-left: auto;
}
@media (max-width: 768px) {
  .p-top-news-list {
    width: 100%;
    margin-top: 24px;
  }
}

.p-top-news-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 24px;
}
@media (max-width: 768px) {
  .p-top-news-item {
    gap: 8px;
  }
}
.p-top-news-item + .p-top-news-item {
  margin-top: 24px;
}
@media (max-width: 768px) {
  .p-top-news-item + .p-top-news-item {
    margin-top: 16px;
  }
}

.p-top-news-item__date {
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  line-height: 1.2;
}
.p-top-news-item__cateory {
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  line-height: 1.2;
  width: 110px;
  padding: 2px 4px;
  text-align: center;
  text-transform: capitalize;
  border: 1px solid #000000;
}
.p-top-news-item__title {
  font-size: 16px;
  line-height: 1.75;
  display: block;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.p-top-news-item__title:hover {
  text-decoration: underline;
}

/****************************************

ABOUT

****************************************/
.p-about {
  position: relative;
  margin-top: 180px;
}
.p-about img {
  border-radius: 8px;
}

/****************************************

SERVICE

****************************************/
.p-top-service-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-top-service-item-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  max-width: 900px;
  margin: 60px auto 0;
  gap: 60px;
}
.p-top-service-item-wrapper .c-btn {
  margin-top: auto;
}

.p-top-service-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 40px;
}
@media (max-width: 768px) {
  .p-top-service-item {
    width: 100%;
  }
}
@media (max-width: 768px) {
  .p-top-service-item .c-btn {
    display: block;
    margin: 0;
  }
}
.p-top-service-item .p-top-service-item__desc {
  margin-top: 3.2rem;
  margin-bottom: 4rem;
}
.p-top-service-item:nth-child(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.p-top-service-img {
  width: calc(100% / 2 - 40px / 2);
  border-radius: 8px;
}
@media (max-width: 768px) {
  .p-top-service-img {
    width: 100%;
    margin: 0 auto;
  }
}
.p-top-service-img img {
  aspect-ratio: calc(4 / 3);
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}

.p-top-service-item-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: calc(100% / 2 - 40px / 2);
}
@media (max-width: 768px) {
  .p-top-service-item-inner {
    width: 100%;
  }
}

.p-top-service-item__header {
  font-size: 24px;
  display: block;
  width: 100%;
  text-align: left;
}

/****************************************

COMPANY

****************************************/
.p-top-company img {
  border-radius: 8px;
}

.p-top-company__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 900px;
  margin: 60px auto 0;
  gap: 24px;
}

.p-top-company__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: calc(100% / 3 - 24px * 2 / 3);
  gap: 24px;
}
@media (max-width: 768px) {
  .p-top-company__item {
    width: 100%;
  }
}
.p-top-company__item a {
  font-size: 20px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  width: 100%;
  min-height: 160px;
  padding: 24px;
  -webkit-transition: color 0.3s, background-color 0.3s;
  transition: color 0.3s, background-color 0.3s;
  color: #ffffff;
  border: 1px solid #005bac;
  border-radius: 8px;
  background-color: rgba(0, 91, 172, 0.5);
}
.p-top-company__item a:before {
  position: absolute;
  z-index: 0;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  border-radius: 8px;
  background: url(../../assets/img/nippon-ev/img_company01.jpg) top center/cover;
}
.p-top-company__item a:hover {
  background-color: rgba(0, 91, 172, 0.9);
}
.p-top-company__item a.access:before {
  background: url(../../assets/img/nippon-ev/img_company02.jpg) top center/cover;
}
.p-top-company__item a.greeting:before {
  background: url(../../assets/img/nippon-ev/img_company03.jpg) top center/cover;
}

/****************************************

NEWS

****************************************/
.p-news__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 750px;
  margin: 60px auto 0;
  gap: 32px;
}

.p-news__item {
  padding-bottom: 8px;
  border-bottom: 1px solid #e0e0e0;
}

.p-news__item-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 40px;
}
@media (max-width: 768px) {
  .p-news__item-inner {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 12px;
  }
}

.p-news__item-date {
  font-size: 14px;
  color: #005bac;
}

.p-news__item-tag {
  font-size: 14px;
  display: inline-block;
  padding: 4px 12px;
  white-space: nowrap;
  color: #ffffff;
  border-radius: 16px;
  background-color: #005bac;
}

.p-news__item-title {
  font-size: 16px;
}
@media (max-width: 768px) {
  .p-news__item-title {
    width: 100%;
  }
}

/****************************************

Works

****************************************/
.p-top-works-inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 60px;
  gap: 40px;
}

.p-top-works__desc {
  width: calc((100% - 250px) - 40px / 2);
  margin-top: 0;
}
@media (max-width: 768px) {
  .p-top-works__desc {
    width: 100%;
  }
}

.p-top-works__img {
  width: calc(250px - 40px / 2);
}
@media (max-width: 768px) {
  .p-top-works__img {
    position: absolute;
    right: -5%;
    bottom: -100px;
    width: 120px;
  }
}

.p-top-works__item-wrapper {
  margin-top: 80px;
}

.p-top-works__item {
  padding: 24px;
  border-radius: 16px;
  background-color: #f0f0f0;
}

.p-top-works__item-cat {
  font-size: 16px;
  display: inline-block;
  padding: 4px 16px;
  color: #ffffff;
  border-radius: 24px;
  background-color: #52baff;
}

.p-top-works__item-title {
  font-size: 20px;
  font-weight: bold;
  margin-top: 8px;
  color: #000000;
}

.c-un-sec-header {
  font-size: 32px;
  font-weight: bold;
  text-align: center;
}
.c-un-sec-header span {
  position: relative;
  display: inline-block;
  padding-bottom: 16px;
}
.c-un-sec-header span::before {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 75%;
  height: 4px;
  content: "";
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #005bac;
}
.c-un-sec-header + * {
  margin-top: 80px;
}

.c-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 80px 0 0;
  padding: 0;
  list-style: none;
}

.c-pagination a {
  font-size: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 40px;
  height: 40px;
  margin: 0 5px;
  -webkit-transition: background-color 0.3s ease, color 0.3s ease;
  transition: background-color 0.3s ease, color 0.3s ease;
  text-decoration: none;
  color: black;
  /* 文字の色 */
  border: 1px solid #dddddd;
  border-radius: 50%;
  /* 円形の背景 */
  background-color: white;
  /* 背景色 */
}

.c-pagination a:hover {
  color: black;
  background-color: #f0f0f0;
}

.c-pagination .prev,
.c-pagination .next {
  position: relative;
}
.c-pagination .prev::before,
.c-pagination .next::before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-image: url(../../assets/img/ico_arrow02.svg);
}

.c-pagination .prev::before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transform: translate(-50%, -50%) rotate(-180deg);
          transform: translate(-50%, -50%) rotate(-180deg);
  background-image: url(../../assets/img/ico_arrow02.svg);
}

.c-pagination .active {
  color: white;
  background-color: black;
}

.c-pagination .dots {
  font-size: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 40px;
  height: 40px;
  margin: 0 5px;
  color: black;
}

.c-journal-cat-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 40px;
  gap: 24px;
}
@media (max-width: 768px) {
  .c-journal-cat-menu {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 16px;
  }
}

.c-journal-cat-menu-item a {
  font-size: 14px;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 12px 32px;
  text-decoration: none;
  text-transform: uppercase;
  color: #000000;
  border: 1px solid #000000;
  background-color: #ffffff;
}
@media (max-width: 768px) {
  .c-journal-cat-menu-item a {
    width: auto;
    height: auto;
    padding: 8px 32px;
  }
}
.c-journal-cat-menu-item.current a {
  color: #ffffff;
  background-color: #000000;
}

.c-breadcrumbs-wrapper + .l-main {
  margin-top: 120px;
}
@media (max-width: 768px) {
  .c-breadcrumbs-wrapper + .l-main {
    margin-top: 80px;
  }
}

.c-un-section .c-sec-header + * {
  margin-top: 80px;
}
@media (max-width: 768px) {
  .c-un-section .c-sec-header + * {
    margin-top: 64px;
  }
}
.c-un-section + .c-un-section {
  margin-top: 180px;
}
@media (max-width: 768px) {
  .c-un-section + .c-un-section {
    margin-top: 120px;
  }
}

.c-dl {
  display: block;
  max-width: 750px;
  margin: 0 auto;
}

.c-dl-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding-bottom: 24px;
  border-bottom: 1px solid #cfcfcf;
  gap: 40px;
}
@media (max-width: 768px) {
  .c-dl-inner {
    gap: 16px;
  }
}
.c-dl-inner + .c-dl-inner {
  margin-top: 24px;
}

.c-dl__dd,
.c-dl__dt {
  font-size: 16px;
  line-height: 1.75;
}

.c-dl__dt {
  font-weight: bold;
  width: 180px;
}
@media (max-width: 768px) {
  .c-dl__dt {
    width: 100%;
  }
}

.c-dl__dd {
  width: calc(100% - 40px - 180px);
}
@media (max-width: 768px) {
  .c-dl__dd {
    width: 100%;
  }
}

.c-sign {
  text-align: right;
}

.p-service .c-un-section + .c-un-section {
  margin-top: 100px;
}
@media (max-width: 768px) {
  .p-service .c-un-section + .c-un-section {
    margin-top: 75px;
  }
}

.p-service-item .p-top-service-item__header {
  margin: 0;
  padding-bottom: 24px;
  border-bottom: 1px solid #010203;
}
.p-service-item + .p-service-item {
  margin-top: 120px;
}
@media (max-width: 768px) {
  .p-service-item + .p-service-item {
    margin-top: 80px;
  }
}

.p-service-item__header {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.2;
  margin-top: 40px;
  text-transform: capitalize;
}
.p-service-content-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 24px;
  gap: 56px;
}
@media (max-width: 768px) {
  .p-service-content-wrapper {
    gap: 16px;
  }
}

.p-service-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 16px;
}
.p-service-detail__item {
  font-size: 16px;
  line-height: 1.75;
  position: relative;
  padding-left: 16px;
}
.p-service-detail__item::before {
  position: absolute;
  top: calc(16px * 1.75 / 2);
  left: calc(16px / 2);
  width: 4px;
  height: 4px;
  content: "";
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  border-radius: 50%;
  background-color: #000000;
}

.p-access iframe {
  width: 100%;
}

.p-contact {
  max-width: 800px;
  margin: 0 auto 120px;
}
@media (max-width: 768px) {
  .p-contact {
    margin-bottom: 80px;
  }
}
.p-contact h2 + p {
  margin-top: 32px;
}
.p-contact .section ul {
  margin-top: 32px;
}
.p-contact .section ul li {
  line-height: 1.45;
}
.p-contact__pagetitle {
  display: none;
}
.p-contact h2 {
  font-size: 32px;
  text-align: center;
}
@media (max-width: 768px) {
  .p-contact h2 {
    font-size: 28px;
  }
}
.p-contact__web {
  margin-top: 8rem;
}
.p-contact__web-note {
  font-size: 1.25rem;
  font-weight: normal;
  margin-top: 2rem;
  text-align: center;
}
.p-contact__phone {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-top: 4.2rem;
  padding: 20px;
  border: 1px dashed #000000;
}
@media (max-width: 768px) {
  .p-contact__phone {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: calc(100% - 2px);
    margin-right: auto;
    margin-left: auto;
    padding: 16px;
    padding-left: 0;
  }
}
.p-contact__phone-inner {
  font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 2.7rem;
  font-weight: bold;
  position: relative;
  padding-left: 60px;
  text-decoration: none;
  letter-spacing: 1.5px;
  color: #0080ca;
}
@media (max-width: 768px) {
  .p-contact__phone-inner {
    font-size: 2rem;
    position: relative;
    width: 220px;
    padding-left: 40px;
    padding-left: 22px;
    text-align: center;
  }
}
.p-contact__phone-inner::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 42px;
  height: 45px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-image: url(../../assets/img/ico_phone_02.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
@media (max-width: 768px) {
  .p-contact__phone-inner::before {
    width: 30px;
    height: 30px;
  }
}
.p-contact__phone-time {
  font-size: 1.25rem;
  font-weight: bold;
  margin-left: 70px;
  color: #000000;
}
@media (max-width: 768px) {
  .p-contact__phone-time {
    width: 100%;
    margin-top: 2rem;
    margin-left: 0;
    text-align: center;
  }
}
.p-contact__table {
  display: block;
  width: 100% !important;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .p-contact__table {
    margin-top: 60px;
  }
}
.p-contact__table tr {
  display: block;
  width: 100%;
}
.p-contact__table tr + tr {
  margin-top: 40px;
}
@media (max-width: 768px) {
  .p-contact__table tr + tr {
    margin-top: 30px;
  }
}
.p-contact__table td {
  display: block;
  width: 100%;
}
.p-contact__title {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.45;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  text-align: left;
}
.p-contact__title.required::after {
  font-size: 14px;
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  content: "必須";
  color: #ffffff;
  border-radius: 24px;
  background-color: #f43232;
}
.p-contact__input {
  font-size: 16px;
  display: block;
  width: 100% !important;
}
.p-contact__input--text {
  display: block;
  width: 100% !important;
  margin-top: 8px;
}
.p-contact__input--text input {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  padding: 16px 16px;
}
.p-contact__input--check {
  margin-top: 8px;
  padding: 0;
}
.p-contact__input--textarea {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  max-height: 240px;
  margin-top: 8px;
  padding: 8px 8px;
}
.p-contact__form {
  max-width: 800px;
  margin: 80px auto;
}
.p-contact__submit {
  position: relative;
  display: block;
  width: 300px;
  height: auto;
  margin-top: 8rem;
  margin-right: auto;
  margin-left: auto;
  border-bottom: none;
}
@media (max-width: 768px) {
  .p-contact__submit {
    width: 90%;
    max-width: 580px;
  }
}
.p-contact__submit::before {
  position: absolute;
  z-index: 10;
  top: 50%;
  right: 40px;
  width: 65px;
  height: 50px;
  -webkit-transition: right 0.3s;
  transition: right 0.3s;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-image: url(../../assets/img/ico_arrow_white_01.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-contact__submit:hover::before {
  right: 0;
}
.p-contact__privacy .c-link {
  line-height: 1;
  display: inline-block;
  text-decoration: underline;
  color: #3070be;
}
.p-contact__privacy .c-link:hover {
  text-decoration: none;
}
.p-contact__privacy-inner {
  font-size: 18px;
  font-weight: bold;
  position: relative;
  left: 50%;
  -webkit-box-sizing: content-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding: 16px 32px;
  cursor: pointer;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  color: #ffffff;
  border: none;
  border-radius: 24px;
  outline: none;
  background-color: #000000;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
@media (max-width: 768px) {
  .p-contact__privacy-inner {
    padding: 8px 40px;
  }
}
.p-contact .c-under-header-2 {
  margin-top: 8.5rem;
}
@media (max-width: 768px) {
  .p-contact .c-under-header-2 {
    font-size: 2rem;
  }
}

.p-contact__input--check label {
  font-size: 16px;
  line-height: 1.2;
  position: relative;
  display: inline-block;
  margin-top: 10px;
  padding-left: 30px;
  cursor: pointer;
}
.p-contact__input--check label span::before,
.p-contact__input--check label span::after {
  position: absolute;
  display: block;
  content: "";
}
.p-contact__input--check label span::before {
  top: 50%;
  left: 0;
  width: 20px;
  height: 20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: 1px solid #000000;
  border-radius: 0;
  background-color: #ffffff;
}
.p-contact__input--check label span::after {
  top: 4px;
  left: 3px;
  width: 14px;
  height: 7px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  opacity: 0;
  border-bottom: 2px solid #000000;
  border-left: 2px solid #000000;
}
.p-contact__input--check input:checked + span::after {
  opacity: 1;
}
.p-contact__input--check .visually-hidden {
  /* コンテンツの流れから切り離す */
  position: absolute;
  /* オーバーフローしているコンテンツを隠す */
  overflow: hidden;
  /* 要素のどの部分が表示されるかを定義するもの */
  /* 古いブラウザでは使用できない */
  clip: rect(0 0 0 0);
  /* 可能な限り文字サイズを小さくするための処理
   * (スクリーンリーダー中には height と width が 0 のものを無視するため)
   */
  width: 1px;
  height: 1px;
  /* 今現在なぜ-1pxがここで設定されるかは分かっていないそうです。
   * それに加えていくつか問題もあるそうです 
   * (参考: https://github.com/h5bp/html5-boilerplate/issues/1985)
   */
  margin: -1px;
  padding: 0;
  /* 誤ったコードに対処するための回避策 */
  white-space: nowrap;
  /* 要素サイズを変更しうるプロパティのリセット */
  border: 0;
  /* 最近のブラウザ用
   * コンテンツを非表示にする設定  */
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
}

.p-contact-error,
.error {
  color: red;
}
.p-contact-error li,
.error li {
  color: red;
}

.p-contact-finish {
  max-width: 750px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .p-contact-finish {
    margin-top: 80px;
  }
}
.p-contact-finish .section {
  margin: 80px 0;
}
@media (max-width: 768px) {
  .p-contact-finish .section {
    margin: 60px 0;
  }
}
.p-contact-finish .section ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.p-contact-finish .section ul li a {
  font-size: 16px;
  line-height: 1.75;
}
.p-contact-finish__title {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  color: #3070be;
}
@media (max-width: 768px) {
  .p-contact-finish__title {
    font-size: 20px;
  }
}
.p-contact-finish__title--3 {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  color: #3070be;
}
.p-contact-finish__desc {
  font-size: 16px;
  margin-top: 32px;
  text-align: center;
}
.p-contact-finish .c-link {
  color: #3070be;
}

.p-contact-finish + footer,
.p-contact-error + footer {
  margin-top: 80px;
}

.p-contact-finish + .l-footer {
  margin-top: 150px;
}

.p-contact-wrapper + .l-footer {
  margin-top: 150px;
}

.p-contact-finish__link .c-btn--normal {
  padding: 16px 32px;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.p-privacy ol {
  padding-left: 16px;
  list-style-type: decimal;
}
.p-privacy ol ol {
  padding-left: 16px;
}
.p-privacy ol li {
  font-size: 16px;
  line-height: 1.75;
}
.p-privacy .c-un-section + .c-un-section {
  margin-top: 80px;
}
@media (max-width: 768px) {
  .p-privacy .c-un-section + .c-un-section {
    margin-top: 60px;
  }
}
.p-privacy h2 {
  font-size: 24px;
}
.p-privacy h2 + * {
  margin-top: 16px;
}
.p-privacy .c-link--blank {
  display: inline-block;
  text-decoration: underline;
}
.p-privacy .c-link--blank:hover {
  text-decoration: none;
}

/***********
service
***********/
.p-service-about__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 40px;
}
@media (max-width: 768px) {
  .p-service-about__inner .c-text {
    margin: 0;
  }
}

.p-service-about__text {
  width: calc(100% - 400px - 40px);
}
@media (max-width: 768px) {
  .p-service-about__text {
    width: 100%;
  }
}

.p-service-about__img {
  width: 400px;
}
@media (max-width: 768px) {
  .p-service-about__img {
    width: 100%;
  }
}

.p-service-about__copy {
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}
@media (max-width: 768px) {
  .p-service-about__copy {
    font-size: 28px;
  }
}

@media (max-width: 768px) {
  .p-service-about__img {
    width: 75%;
    max-width: 300px;
    margin-right: auto;
    margin-left: auto;
  }
}

.p-service-onayami {
  padding: 120px 0;
  background-color: #e0e0e0;
}
.p-service-onayami .c-copy {
  text-align: center;
}
@media (max-width: 768px) {
  .p-service-onayami .c-copy {
    font-size: 24px;
    text-align: left;
  }
}

.p-service-onayami__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 900px;
  margin: 60px auto 0;
  gap: 40px;
}
@media (max-width: 768px) {
  .p-service-onayami__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}

.p-service-onayami__img {
  width: 320px;
}
@media (max-width: 768px) {
  .p-service-onayami__img {
    width: 75%;
    margin: 0 auto;
  }
}

.p-service-onayami__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 24px;
}
.p-service-onayami__list li {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.45;
  position: relative;
  padding-left: 32px;
}
@media (max-width: 768px) {
  .p-service-onayami__list li {
    font-size: 18px;
  }
}
.p-service-onayami__list li::before {
  position: absolute;
  top: calc(24px * 1.45 / 2);
  left: 0;
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../../assets/img/nippon-ev/ico_check01.svg) center center/contain no-repeat;
}
@media (max-width: 768px) {
  .p-service-onayami__list li::before {
    top: calc(18px * 1.45 / 2);
  }
}

.p-service-onayami__copy02 {
  margin-top: 80px;
}

.p-service-solution__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: center;
}
.p-service-solution__inner .c-text {
  font-size: 20px;
  margin-top: 60px;
}
.p-service-solution__inner .c-text + .c-text {
  margin-top: 20px;
}

.p-service-content__imte-header {
  font-size: 30px;
  font-weight: bold;
}
@media (max-width: 768px) {
  .p-service-content__imte-header {
    font-size: 24px;
  }
}

.p-service-content .c-flex + .c-flex {
  margin-top: 40px;
}
.p-service-content .c-flex {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-service-content .c-flex--reverse {
  -ms-flex-wrap: wrap-reverse;
      flex-wrap: wrap-reverse;
}

.p-service-system img {
  width: 240px;
  margin: 0 auto;
}
.p-service-system .p-service-system__item-header {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}

.p-service-flow__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}

.p-service-flow__list {
  max-width: 750px;
  margin-right: auto;
  margin-left: auto;
}

.p-service-flow__item {
  font-size: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 8px;
  gap: 24px;
}
.p-service-flow__item .p-service-flow__item-number {
  font-size: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 56px;
  height: 56px;
  color: #005bac;
  color: #ffffff;
  border-radius: 50%;
  background-color: #005bac;
}
.p-service-flow__item .p-service-flow__item-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: calc(100% - 24px - 56px);
  gap: 24px;
}

.p-service-flow__item-header {
  font-size: 24px;
  font-weight: bold;
  color: #005bac;
}

.c-article {
  margin-top: 120px;
}
@media (max-width: 768px) {
  .c-article {
    margin-top: 80px;
  }
}
.c-article .c-article__title {
  font-size: 24px;
  font-weight: bold;
}
.c-article .date {
  font-size: 14px;
  display: block;
  margin-top: 16px;
}

.p-contact__mail {
  position: relative;
  max-width: 600px;
  margin: 80px auto 0;
}
.p-contact__mail a {
  font-size: 24px;
  font-weight: bold;
  padding: 40px 24px 40px 72px;
  color: #ffffff;
  border-radius: 16px;
  background-color: #005bac;
}
@media (max-width: 768px) {
  .p-contact__mail a {
    font-size: 16px;
    padding: 24px 24px 24px 56px;
  }
}
.p-contact__mail a::before {
  position: absolute;
  top: 50%;
  left: 16px;
  width: 40px;
  height: 40px;
  content: "";
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../../assets/img/nippon-ev/ico_mail01.svg) center center/contain no-repeat;
}
@media (max-width: 768px) {
  .p-contact__mail a::before {
    left: 16px;
    width: 24px;
    height: 24px;
  }
}

body.contact .l-footer-contact {
  display: none;
}
body.contact .l-footer {
  margin-top: 120px;
}

.p-top-recruit .c-btn-wrapper {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
@media (max-width: 768px) {
  .p-top-recruit .c-btn-wrapper {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.p-service-faq__item-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  max-width: 750px;
  margin: 80px auto 0;
  gap: 40px;
}

.p-service-faq__item dd,
.p-service-faq__item dt {
  font-size: 16px;
  line-height: 1.75;
  padding: 24px;
  padding-right: 48px;
}
.p-service-faq__item dd span,
.p-service-faq__item dt span {
  position: relative;
  display: block;
  padding-left: 32px;
}
.p-service-faq__item dd span::before,
.p-service-faq__item dt span::before {
  font-family: "Roboto";
  font-size: 24px;
  font-weight: bold;
  position: absolute;
  top: calc(16px * 1.75 / 2);
  left: 0;
  content: "Q";
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  text-transform: capitalize;
}
.p-service-faq__item dt {
  position: relative;
  color: #ffffff;
  background-color: #005bac;
}
.p-service-faq__item dt:hover {
  cursor: pointer;
}
.p-service-faq__item dt::before {
  position: absolute;
  top: 50%;
  right: 24px;
  width: 32px;
  height: 2px;
  content: "";
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #ffffff;
}
@media (max-width: 768px) {
  .p-service-faq__item dt::before {
    width: 18px;
  }
}
.p-service-faq__item dt::after {
  position: absolute;
  top: 50%;
  right: 24px;
  width: 32px;
  height: 2px;
  content: "";
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
  background-color: #ffffff;
}
@media (max-width: 768px) {
  .p-service-faq__item dt::after {
    width: 18px;
  }
}
.p-service-faq__item dd {
  display: none;
  background-color: #e0e0e0;
}
.p-service-faq__item dd span::before {
  content: "A";
}
.p-service-faq__item.is-open dt::after {
  -webkit-transform: translateY(-50%) rotate(0deg);
          transform: translateY(-50%) rotate(0deg);
}

.p-article .p-article-inner {
  max-width: 900px;
  margin: 0 auto;
}
.p-article * + .c-article-header--2 {
  margin-top: 8rem;
}
.p-article .c-article-header--2 {
  font-size: 3.2rem;
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 8px;
}
@media (max-width: 768px) {
  .p-article .c-article-header--2 {
    margin-bottom: 25px;
  }
}
.p-article .c-article-header--3 {
  font-size: 2.4rem;
  margin-bottom: 25px;
}
@media (max-width: 768px) {
  .p-article .c-article-header--3 {
    margin-bottom: 20px;
  }
}
.p-article .c-article-desc {
  font-size: 1.8rem;
  line-height: 1.8;
  margin-bottom: 25px;
}
@media (max-width: 768px) {
  .p-article .c-article-desc {
    margin-bottom: 20px;
  }
}
.p-article .c-article-img {
  margin: 30px 0;
  text-align: center;
}
.p-article .c-article-img img {
  display: block;
  max-width: 60%;
  height: auto;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .p-article .c-article-img img {
    max-width: 90%;
  }
}
.p-article .c-article-img figcaption {
  font-size: 1.6rem;
  line-height: 1.45;
  margin-top: 4px;
  text-align: center;
}
.p-article .c-list {
  margin: 25px 0;
}
.p-article .c-list .c-list__item {
  font-size: 1.8rem;
  line-height: 1.75;
  position: relative;
  margin-bottom: 15px;
  padding-left: 20px;
}
@media (max-width: 768px) {
  .p-article .c-list .c-list__item {
    margin-bottom: 10px;
  }
}
.p-article .c-list .c-list__item::before {
  font-size: 1.6rem;
  position: absolute;
  top: calc(1.8rem * 1.75 / 2);
  left: 0;
  content: "・";
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media (max-width: 768px) {
  .p-article .c-list .c-list__item::before {
    margin-bottom: 10px;
  }
}
.p-article .c-btn-article {
  margin-top: 90px;
}
@media (max-width: 768px) {
  .p-article .c-btn-article {
    margin-top: 60px;
  }
}

.c-article-date {
  margin-bottom: 8px;
  display: block;
}
@media (max-width: 768px) {
  .c-article-date {
    margin-bottom: 6px;
  }
}