@charset "UTF-8";
/* ===================================================================

 file name  :reset.css
 style info :リセットCSS v3

=================================================================== */
/* reset ---*/
* {
  outline: none;
  box-sizing: border-box; }

*::before,
*::after {
  box-sizing: inherit; }

html {
  /* overflow-y: scroll; */
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: unset;
  /* rem用基準を10px */
  font-size: 62.5%; }

@media only screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; } }
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td,
figure {
  margin: 0;
  padding: 0; }

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption,
th {
  text-align: left; }

q:before,
q:after {
  content: ''; }

object,
embed {
  vertical-align: top; }

hr,
legend {
  display: none; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal; }

img,
abbr,
acronym,
fieldset {
  border: 0; }

img {
  vertical-align: bottom; }

li {
  list-style-type: none; }

sup {
  font-size: 62.5%;
  vertical-align: text-top; }

/* ---------------------------------------------------------------------------
default
--------------------------------------------------------------------------- */
/* body */
body {
  position: relative;
  background: #f2f2f2;
  color: #000;
  font-family: YakuHanJP, 'Noto Sans JP', sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  line-height: 1.6; }

html {
  font-size: 3.67vw; }
  @media screen and (min-width: 768px) {
    html {
      font-size: min(100%,1.11111vw); } }

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

@media screen and (max-width: 767px) {
  .sp-hide {
    display: none; } }
@media screen and (min-width: 768px) {
  .pc-hide {
    display: none; } }
/* link */
a {
  color: inherit;
  text-decoration: none; }
  @media screen and (min-width: 768px) {
    a[href^='tel:'] {
      pointer-events: none; } }

.u-img-w100 {
  width: 100%; }

.u-mb1 {
  margin-bottom: 1em; }
@media screen and (min-width: 768px){
  .u-mb2--pc {
    margin-bottom: 2em; } }

@media screen and (min-width: 768px) {
  .u-mb-15--pc {
    margin-bottom: 1.5em; } }
.u-cl-e50012 {
  color: #e50012; }

.u-bold {
  font-weight: 700; }

.u-fz136 {
  font-size: 136%;
  line-height: 1.1; }

.u-uline {
  border-bottom: 1px solid currentColor; }

.u-kenten {
  background: top left/1em 0.4em repeat-x radial-gradient(circle, currentColor 0.08em, #fff 0.08em);
  padding-top: 0.1em; }
  .u-kenten--half {
    background: top left/0.5em 0.4em repeat-x radial-gradient(circle, currentColor 0.08em, #fff 0.08em); }

.u-align-center {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .u-align-center--pc {
    text-align: center; } }

@media screen and (min-width: 768px) {
  .u-fz160--pc {
    font-size: 160%;
    line-height: 1; } }

@media screen and (min-width: 768px) {
  .pc-hide {
    display: none; } }

.u-disp-inline-block {
  display: inline-block; }

.u-hover-uline--hide {
  background: linear-gradient(currentColor, currentColor) no-repeat right 100%/0 1px;
  transition: background-size ease 0.4s; }

@media (any-hover: hover) {
  .u-hover-uline--hide:hover {
    background-size: 100% 1px;
    background-position: left 100%; }

  .u-hover-opacity {
    transition: opacity ease 0.4s; }

  .u-hover-opacity:hover {
    opacity: 0.7; } }
/* ---------------------------------------------------------------------------
	囲み要素
--------------------------------------------------------------------------- */
/*.l-inner {
  width: 92%;
  margin: 0 auto; }
  @media screen and (min-width: 768px) {
    .l-inner {
      width: 83.33%; } }*/

/* ---------------------------------------------------------------------------
		#wrapper
			全体
--------------------------------------------------------------------------- */
.l-wrap img {
  width: 100%;
  height: auto; }

.c-bgttl {
  margin-bottom: 1.5em;
  background: #fff100;
  font-weight: 700;
  padding: 0.2em;
  border-radius: 100px;
  text-align: center;
  color: #000; }
  @media screen and (min-width: 768px) {
    .c-bgttl {
      font-size: 110%; } }
  .c-bgttl--gray {
    background: #e6e6e6; }
  .c-bgttl--large {
    font-size: 1.3rem; }

.c-bluetxt {
  color: #007cc2;
  font-weight: 700; }
  @media screen and (min-width: 768px) {
    .c-bluetxt {
      text-align: center;
      font-size: 102%; } }

.c-btn-arrow a {
  position: relative;
  display: block;
  padding: 0.6em 1.5em;
  text-align: center;
  background: #fff000;
  font-size: 1.2rem;
  font-weight: 700; }
  @media screen and (min-width: 768px) {
    .c-btn-arrow a {
      font-size: 1.5rem; } }
  .c-btn-arrow a::after {
    content: '';
    background: url(../img/ico_blank.svg) no-repeat center/contain;
    width: 1em;
    aspect-ratio: 1 / 1;
    position: absolute;
    right: 1em;
    top: 50%;
    transform: translateY(-50%); }
  @media (any-hover: hover) {
    .c-btn-arrow a {
      transition: background ease 0.3s; }
      .c-btn-arrow a:hover {
        background: #ff9700; } }

.c-caption {
  font-size: 0.75rem;
  line-height: 1.3; }

.c-block {
  border: 1px solid #0075bd; }
  .c-block__ttl {
    padding: 0.4em;
    background: #0075bd;
    font-weight: 700;
    font-size: 1.2rem;
    color: #fff;
    margin-bottom: 1em;
    text-align: center; }
    @media screen and (min-width: 768px) {
      .c-block__ttl {
        letter-spacing: 0.1rem; } }
  .c-block__inner {
    padding: 0 1rem 1rem; }

/*
.toggleBtn
---------------------------*/
.toggleBtn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #003893;
  border: 1px solid #fff;
  height: 3.71429rem;
  aspect-ratio: 1 / 1;
  z-index: 10000;
  cursor: pointer; }

.toggleBtn__mark {
  position: relative;
  cursor: pointer;
  height: 1.57143rem;
  width: 1.78571rem; }

.toggleBtn__bar {
  position: absolute;
  left: 0;
  background-color: #fff;
  height: 0.14286rem;
  width: 100%; }
  .toggleBtn__bar:first-of-type {
    top: 0; }
    .is-gmenu-open .toggleBtn__bar:first-of-type {
      transform: translateY(0.71429rem) rotate(45deg); }
  .toggleBtn__bar:nth-child(2) {
    top: 0.71429rem; }
    .is-gmenu-open .toggleBtn__bar:nth-child(2) {
      transform: translateY(-50%);
      opacity: 0; }
  .toggleBtn__bar:last-of-type {
    bottom: 0; }
    .is-gmenu-open .toggleBtn__bar:last-of-type {
      transform: translateY(-0.71429rem) rotate(-45deg); }

.toggleBtn__mark,
.toggleBtn__bar {
  transition: all 0.6s ease;
  box-sizing: border-box; }

/*-----------------------------------------------------------
header
-----------------------------------------------------------*/
.l-header__inner {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 0 0 0.71429rem; }
  @media screen and (min-width: 768px) {
    .l-header__inner {
      justify-content: flex-end;
      padding: 0 1.25rem;
      height: 3.125rem; } }

.l-header__content {
  display: flex;
  align-items: flex-start;
  position: absolute;
  top: 0;
  left: 0.71429rem;
  z-index: 10000;
  transition: all ease 0.6s; }
  @media screen and (min-width: 768px) {
    .l-header__content {
      top: 0;
      left: 1.25rem; } }

.l-header__logo,
.l-header__home {
  display: flex;
  align-items: center;
  background-color: #fff;
  border: 1px solid #2367a4;
  border-top: none;
  padding: 0.625rem 1.0625rem;
  border-radius: 0 0 20px 20px;
  margin-right: 8px; }

@media only screen and (max-width: 767px) {
  .l-header__logo,
  .l-header__home {
    background-color: #fff;
    border-radius: 0 0 10px 10px;
    padding: 0.5rem 0.85714rem; } }
.l-header__home > p {
  font-size: 0.875rem;
  line-height: 1; }

@media only screen and (max-width: 767px) {
  .l-header__home > p {
    font-size: 0.78571rem; } }
.l-header__img.renewal {
  margin-right: 0.9375rem;
  width: 3.95625rem; }

@media only screen and (max-width: 767px) {
  .l-header__img.renewal {
    margin-right: 0.5rem;
    width: 2.26071rem; } }
.l-header__img.nexco {
  width: 4.68125rem; }

@media only screen and (max-width: 767px) {
  .l-header__img.nexco {
    width: 2.675rem; } }
.l-header__img.navi {
  margin-right: 10px;
  width: 1.2rem; }

@media only screen and (max-width: 767px) {
  .l-header__img.navi {
    margin-right: 5px;
    width: 0.68571rem; } }
.l-header__txt {
  position: relative;
  margin-right: 4.375rem; }

@media only screen and (max-width: 767px) {
  .l-header__txt {
    margin-right: 1.42857rem; } }
.l-header__txt::after {
  content: '';
  position: absolute;
  top: 0;
  right: -2.1875rem;
  bottom: 0;
  margin: auto;
  background-color: #2367a4;
  height: 1.875rem;
  width: 2px; }

@media only screen and (max-width: 767px) {
  .l-header__txt::after {
    right: -0.71429rem;
    height: 1.07143rem; } }
.l-header__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 0.9375rem;
  width: 70%; }

@media only screen and (max-width: 767px) {
  .l-header__info {
    font-size: 0.85714rem;
    width: 100%; } }
.l-header__txt {
  white-space: nowrap; }

.l-header__detail {
  overflow: hidden; }

@media only screen and (max-width: 767px) {
  .l-header__detail {
    width: 100%; } }
.l-header__detail span {
  display: inline-block;
  white-space: nowrap;
  line-height: 1em;
  animation: flowTxt 20s linear infinite; }

@media only screen and (max-width: 767px) {
  .l-header__detail span {
    animation: flowTxt-sp 20s linear infinite;
    padding-left: 20%; } }
.l-header__btn {
  position: fixed;
  top: 0;
  right: 0;
  top: 0;
  right: 0;
  transition: all ease 0.6s; }
  @media print, screen and (min-width: 768px) {
    .l-header__btn {
      display: none; } }

.l-header__time{
  background: #f9be00;
  color: #fff;
  text-align: center;
  font-size: 0.9rem;
  padding-block: 0.5em;
  margin-block: 4em 0.5em;
  position: relative;
}
.l-header__time a{
  display: block;
}
.l-header__time::after{
  content: '';
  display: block;
  width: 1.6em;
  height: 1.6em;
  background: url("../img/ico_link.svg") no-repeat;
  position: absolute;
  right: 0.5em;
  top: calc(50% - 0.8em);
}
@media screen and (min-width: 768px){
  .l-header__time{
    font-size: 1.32rem;
    padding-block: 0.5em;
    margin-block: 0 1em;
  }
}

/*
.gnav
---------------------------*/
.gnav {
  background-color: #fff; }

@media only screen and (max-width: 767px) {
  .gnav {
    position: fixed;
    top: 0;
    left: 0;
    background-image: url("../img/bg_mv_sp.webp");
    background-size: cover;
    padding: 0.71429rem;
    height: 100%;
    width: 100%;
    z-index: 9999;
    transform: translateX(-100%);
    transition: all ease 0.6s;
    overflow-y: scroll; } }
@media only screen and (max-width: 767px) {
  .is-gmenu-open .gnav {
    transform: translateX(0%); } }
@media only screen and (max-width: 767px) {
  .gnav__innner {
    background-color: #003893; } }
.gnav__list1 {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.5rem 0 1.25rem; }

@media only screen and (max-width: 767px) {
  .gnav__list1 {
    display: block;
    padding: 5.71429rem 1.25rem 3rem; } }
@media only screen and (max-width: 767px) {
  .gnav__item1.book {
    border-top: 2px solid #fff;
    padding: 1.42857rem 0 0; } }
.gnav__item1.book a {
  display: flex;
  align-items: center;
  background-color: #2367a4;
  border-radius: 10px;
  height: 3.75rem;
  width: 12.5rem; }
  @media screen and (min-width: 768px) {
    .gnav__item1.book a {
      transition: background ease 0.3s; }
      .gnav__item1.book a:hover {
        background-color: #003893; } }

@media only screen and (max-width: 767px) {
  .gnav__item1.book a {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-color: #fff;
    height: 3.57143rem;
    width: 100%; } }
.gnav__item1.book .gnav__icon {
  width: 1.5625rem;
  margin: 0 0.625rem 0 1.25rem; }

@media only screen and (max-width: 767px) {
  .gnav__item1.book .gnav__icon {
    width: 2rem;
    margin: 0 0.71429rem 0 0; } }
.gnav__item1.book .gnav__icon .cls-1 {
  fill: #fff; }

@media only screen and (max-width: 767px) {
  .gnav__item1.book .gnav__icon .cls-1 {
    fill: #003893; } }
.gnav__item1.book .gnav__txt {
  color: #fff; }

@media only screen and (max-width: 767px) {
  .gnav__item1.book .gnav__txt {
    color: #003893;
    font-size: 1.28571rem; } }
.gnav__list2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end; }

@media only screen and (max-width: 767px) {
  .gnav__list2 {
    display: block; } }
.gnav__item2 {
  margin-right: 3.125rem;
  text-align: center; }
  .gnav__item2 a {
    display: block; }
  @media only screen and (max-width: 767px) {
    .gnav__item2 .gnav__item2 {
      margin-right: 0; } }
  .gnav__item2:not(:last-of-type) {
    position: relative; }

@media print, screen and (min-width: 768px) {
  .gnav__item2:not(:last-of-type)::after {
    content: '／';
    position: absolute;
    color: #2367a4;
    font-size: 1.125rem;
    font-weight: bold;
    right: -2.125rem;
    bottom: -4px; } }
.gnav__item2.construction .gnav__icon {
  width: 2.3125rem; }

.gnav__item2.car .gnav__icon {
  width: 2.5rem; }

.gnav__item2 .gnav__txt {
  display: block;
}

@media only screen and (max-width: 767px) {
  .gnav__item2 .gnav__txt {
    font-size: 1.42857rem;
    margin: 0; } }
@media only screen and (max-width: 767px) {
  .gnav__item2 > a {
    display: flex;
    align-items: center;
    border-top: 2px solid #fff;
    padding: 1.42857rem 0 1.42857rem 2.85714rem; } }
.gnav__icon {
  margin: 0 auto;
  width: 1.875rem; }

@media all and (-ms-high-contrast: none) {
  .gnav__icon {
    height: 1.875rem; } }
@media only screen and (max-width: 767px) {
  .gnav__icon {
    margin: 0 0.71429rem 0 0;
    width: 2.14286rem; } }
.gnav__icon .cls-1 {
  fill: #2367a4; }
  @media screen and (min-width: 768px) {
    .gnav__icon .cls-1 {
      transition: fill ease 0.4s; }
      a:hover .gnav__icon .cls-1 {
        fill: #003893; } }

@media only screen and (max-width: 767px) {
  .gnav__icon .cls-1 {
    fill: #fff; } }
.gnav__txt {
  color: #2367a4;
  font-weight: bold; }
  @media screen and (min-width: 768px) {
    .gnav__txt {
      transition: color ease 0.4s; }
      a:hover .gnav__txt {
        color: #003893; } }

@media only screen and (max-width: 767px) {
  .gnav__txt {
    color: #fff; } }
/*
.main-contents
---------------------------*/
.main-contents {
  background: #fff;
  padding: 1.2rem;
  width: 92%;
  margin: 1.2rem auto;
  border-radius: 1.8rem; }
  @media screen and (min-width: 768px) {
    .main-contents {
      width: 83.33%;
      max-width: 1200px;
      padding: 2rem; } }

/*
.l-footer
---------------------------*/
.l-footer {
  padding-block: 1.5em; }

.l-footer__btn-pagetop {
  position: fixed;
  right: 10px;
  bottom: 10px;
  width: 40px;
  opacity: 0;
  pointer-events: none;
  transition: all ease 0.2s;
  z-index: 666; }
  @media screen and (min-width: 768px) {
    .l-footer__btn-pagetop {
      width: 70px;
      bottom: 140px; } }
  .l-footer__btn-pagetop.is-show {
    opacity: 1;
    pointer-events: auto; }
  .l-footer__btn-pagetop a {
    transition: opacity ease 0.3s; }
    @media (any-hover: hover) {
      .l-footer__btn-pagetop a:hover {
        opacity: 0.8; } }

.fnav__parent {
  display: flex;
  justify-content: center;
  flex-wrap: wrap; }

.fnav__item {
  font-size: 84%;
  padding: 0.3em 0; }
  @media screen and (min-width: 768px) {
    .fnav__item .fnav__item {
      font-size: 1.2rem; } }

.fnav__item:not(:last-child)::after {
  content: '｜'; }

.copyright {
  padding: 1.5em 1em 1em;
  font-size: 84%;
  text-align: center; }
  @media screen and (min-width: 768px) {
    .copyright {
      padding: 1.5em 1em;
      font-size: 1rem; } }

/*
.section
---------------------------*/
.section + .section {
  margin-top: 3rem; }
  @media screen and (min-width: 768px) {
    .section + .section {
      margin-top: 4rem; } }

.section__ttl {
  margin-bottom: 0.8em;
  background: #007cc3;
  font-size: 1.4rem;
  font-weight: 700;
  padding: 0.1em;
  border-radius: 100px;
  text-align: center;
  color: #fff; }
  @media screen and (min-width: 768px) {
    .section__ttl {
      margin-bottom: 1em;
      font-size: 2.2rem;
      letter-spacing: 0.1em; } }
  .section__ttl--yellow {
    background: #fff000;
    color: #000; }
