/*=============================================
 * body
 *=============================================*/
body {
   background: #fff;
   color: #4b4b4b;
   font-family: "Zen Old Mincho", serif;
   font-weight: 400;
   font-size: 16px;
   line-height: 32px;
   letter-spacing: 0;
   min-width: inherit;
   min-height: inherit;
   max-height: 100%;
   word-break: break-word;
}

@media screen and (max-width: 767px) {
   body {
      font-size: 14px;
      line-height: 22px;
   }
}

/*=============================================
 * <main>
 *=============================================*/
main {
   clear: both;
   width: 100%;
   box-sizing: border-box;
   position: relative;
   margin: 0;
   padding: 0;
}

/* =============================================
 * Custom
*=============================================*/
.h2 {
   font-weight: 700;
   font-size: 31px;
   line-height: 36px;
   letter-spacing: 0.1em;
   text-align: center;
}

.h2 .sub {
   display: block;
   font-family: "albertan-pro", sans-serif;
   font-weight: 500;
   font-size: 70px;
   line-height: 78px;
   letter-spacing: 0.075em;
   position: relative;
}

.h2 .sub:after {
   content: '';
   display: block;
   width: 122px;
   height: 0;
   border-bottom: 1px solid;
   margin: 30px auto 40px;
}

.h-18 {
   font-weight: 500;
   font-size: 18px;
}

.h-20 {
   font-weight: 700;
   font-size: 20px;
   line-height: 30px;
}

.h-22 {
   font-weight: 700;
   font-size: 22px;
   line-height: 32px;
}

.h-25 {
   font-weight: 700;
   font-size: 25px;
   line-height: 40px;
}

.h-28 {
   font-weight: 700;
   font-size: 28px;
   line-height: 42px;
}

.h-30 {
   font-weight: 700;
   font-size: 30px;
   line-height: 45px;
}

.h-32 {
   font-weight: 700;
   font-size: 32px;
   line-height: 40px;
}

.h-35 {
   font-weight: 700;
   font-size: 35px;
   line-height: 48px;
}

@media screen and (max-width: 767px) {
   .h2 {
      font-size: 20px;
      line-height: 30px;
   }

   .h2 .sub {
      font-size: 36px;
      line-height: 50px;
      padding-bottom: 5px;
   }

   .h2 .sub:after {
      width: 80px;
      margin: 15px auto;
   }

   .h-18 {
      font-size: 14px;
   }

   .h-20 {
      font-size: 16px;
      line-height: 24px;
   }

   .h-22,
   .h-25 {
      font-size: 18px;
      line-height: 26px;
   }

   .h-28,
   .h-30,
   .h-32 {
      font-size: 20px;
      line-height: 30px;
   }

   .h-35 {
      font-size: 22px;
      line-height: 32px;
   }
}

.h2-udl {
   font-weight: 700;
   font-size: 56px;
   line-height: 65px;
   letter-spacing: 0.025em;
   text-align: center;
}

.h2-udl:after {
   content: '';
   display: block;
   width: 122px;
   height: 0;
   border-top: 1px solid;
   margin: 35px auto 0;
}

@media screen and (max-width: 767px) {
   .h2-udl {
      font-size: 30px;
      line-height: 45px;
   }

   .h2-udl:after {
      width: 80px;
      margin-top: 20px;
   }
}

/* button */
.button {
   position: relative;
}

.button a {
   display: flex;
   justify-content: center;
   align-items: center;
   gap: 40px;
   width: 100%;
   height: 98px;
   font-weight: 500;
   font-size: 30px;
   line-height: 36px;
   letter-spacing: 0.025em;
   color: #fff;
   box-sizing: border-box;
   margin: 0 auto;
   padding: 0;
   position: relative;
   z-index: 1;
}

.button a:before {
   content: '';
   background-color: #00c5dc;
   position: absolute;
   top: 0;
   right: 5px;
   bottom: 0;
   left: 5px;
   transform: skewX(-10deg);
   z-index: -1;
   transition: all 0.3s;
   box-shadow: 8px 8px 0 #00515b;
}

.button a:after {
   content: '';
   width: 84px;
   height: 13px;
   background: url("../img/common/btn-arrow-wh.png") no-repeat center/100% auto;
   display: block;
}

.button a:hover {
   opacity: 1;
   transform: translate(8px, 8px);
}

.button a:hover:before {
   box-shadow: none;
}

@media screen and (max-width: 767px) {
   .button {
      a {
         gap: 10px;
         height: 70px;
         font-size: 16px;
         line-height: 24px;
      }
   }
}

.btn-1 {
   position: relative;

   a {
      display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 35px;
    width: 370px;
    height: 84px;
    font-size: 25px;
    letter-spacing: -0.01em;
    line-height: 36px;
    background-color: #006496;
    color: #fff;
    clip-path: polygon(10% 0%, 100% 0%, 90% 100%, 0% 100%);
    box-sizing: border-box;

      &:after {
         content: '';
         width: 70px;
         height: 12px;
         background: url("../img/common/btn-arrow-wh.png") no-repeat center/100% auto;
         display: block;
      }

      &:hover {
         background-color: #4b4b4b;
         opacity: 1;
      }
   }
}

@media screen and (max-width: 767px) {
   .btn-1 {
      a {
         gap: 20px;
         width: 250px;
         height: 60px;
         font-size: 18px;
         line-height: 26px;

         &:after {
            width: 50px;
         }
      }
   }
}

/* -- -- */
.txt-udl {
   text-decoration: underline;
}

a.txt-udl:hover {
   text-decoration: none;
}

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

.txt-j {
   text-align: justify;
}

.txt-r {
   text-align: right;
}

.cl-blue {
   color: #006496;
}

.cl-green {
   color: #96BE31;
}

.cl-red {
   color: #BD1B21;
}

.cl-yellow {
   color: #FFB357;
}

.cl-brown {
   color: #634C2E;
}

.cl-white {
   color: #fff;
}

.cl-orange {
   color: #E64900;
}

.bg-cl01 {
   background-color: #dce7ea;
}

.bg-cl02 {
   background-color: #f4f6f6;
}

.udl01 {
   background-image: linear-gradient(#FEFA7F, #FEFA7F);
   background-size: 100% 10px;
   background-repeat: no-repeat;
   background-position: left bottom;
}

.fw-r {
   font-weight: 400;
}

.fw-m {
   font-weight: 500;
}

.fw-b {
   font-weight: 700;
}

.fw-black {
   font-weight: 900;
}

.bdra-10 {
   border-radius: 10px;
}

.bdra-20 {
   border-radius: 20px;
}

.bdra-30 {
   border-radius: 30px;
}

.img_shadow {
   box-shadow: 0 10px 10px rgba(0, 0, 0, 0.05);
}

.img-obj {
   width: 100%;
   max-width: inherit;
   height: 100%;
   object-fit: cover;
}

@media screen and (max-width: 767px) {
   .bdra-20 {
      border-radius: 10px;
   }

   .bdra-30 {
      border-radius: 15px;
   }
}

/* -- -- */
.img-zoom,
.img-zoom figure {
   display: block;
   overflow: hidden;
}

.img-zoom .img,
.img-zoom .img-obj {
   transition: 0.6s ease-in-out;
}

.img-zoom:hover .img,
.img-zoom:hover .img-obj {
   transform: scale(1.07);
}

/* -- --*/
.filter-gray {
   filter: grayscale(100%);
   cursor: pointer;
   transition: all 0.3s;
}

.filter-gray:hover {
   filter: grayscale(0);
}

/* -- --*/
.photo-full img {
   width: 100%;
   max-width: inherit;
}

@media screen and (max-width: 767px) {
   .photo-full {
      width: 100%;
      height: 60vw;
   }

   .photo-full img {
      height: 100%;
      object-fit: cover;
   }
}

/* -- --*/
hr {
   border: 0;
   border-bottom: 1px solid #fff;
}

/* -- --*/
.slick-arrow {
   display: block;
   width: 45px;
   height: 9px;
   border: 0;
   cursor: pointer;
   font-size: 0;
   transition: all 0.3s;
}

.slick-arrow:hover {
   opacity: 0.7;
}

.slick-prev {
   background: url("../img/common/slider-prev.png") no-repeat center/cover;
}

.slick-next {
   background: url("../img/common/slider-next.png") no-repeat center/cover;
}

.slick-dots {
   display: flex;
   align-items: center;
   gap: 8px;
}

.slick-dots li {
   width: 8px;
   height: 8px;
}

.slick-dots button {
   display: block;
   width: 100%;
   height: 100%;
   background-color: #D5D5D5;
   border: 0;
   font-size: 0;
   border-radius: 50%;
   cursor: pointer;
   transition: all 0.3s;
}

.slick-dots .slick-active button,
.slick-dots button:hover {
   background-color: #202945;
}

/* -- -- */

.section-space {
   padding: 150px 0;
}

.pt50 {
   padding-top: 50px;
}

.pt120 {
   padding-top: 120px;
}

.pt150 {
   padding-top: 150px;
}

.pt200 {
   padding-top: 200px;
}

.pb50 {
   padding-bottom: 50px;
}

.pb120 {
   padding-bottom: 120px;
}

.pb150 {
   padding-bottom: 150px;
}

.pb200 {
   padding-bottom: 200px;
}
/*アイセル追記260305 ここから*/
.mb10 {
	margin-bottom: 10px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt30 {
	margin-top: 30px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}


.mb40 {
	margin-bottom: 40px !important;
}

.mb70 {
	margin-bottom: 70px !important;
}

/*アイセル追記260305 ここまで*/
@media screen and (max-width: 767px) {
   .section-space {
      padding: 80px 0;
   }

   .pt50 {
      padding-top: 20px;
   }

   .pt120 {
      padding-top: 50px;
   }

   .pt150, .pt200 {
      padding-top: 80px;
   }

   .pb50 {
      padding-bottom: 20px;
   }

   .pb120 {
      padding-bottom: 50px;
   }

   .pb150, .pb200 {
      padding-bottom: 80px;
   }
}

/* -- -- */

.w990 {
   max-width: 990px;
   margin: 0 auto;
}

/*=============================================
 * <header>
 *=============================================*/
header {
   background-color: #fff;
   width: 100%;
   z-index: 100;
   box-sizing: border-box;
   padding: 30px 50px 20px;
}

header .logo a {
   display: block;
   max-width: 480px;
}

@media screen and (max-width: 1023px) {
   header {
      display: flex;
      align-items: center;
      gap: 10px;
      height: 80px;
      padding: 0 10px 0 20px;
      position: sticky;
      top: 0;
   }

   header .logo {
      flex: 1 0 0;
   }

   header .logo a {
      max-width: 300px;
   }

   header .logo-1 {
      display: none;
   }

   .hamburger {
      display: block;
   }

   #navbar {
      background: #fff;
      width: 100%;
      height: 100vh;
      position: fixed;
      top: 0;
      left: 0;
      box-sizing: border-box;
      padding: 100px 10vw;
      overflow-y: auto;
      z-index: -1;
      opacity: 0;
      visibility: hidden;
      transition: all 0.3s linear;
   }

   #navbar .nav-list {
      color: #006496;
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0;
   }

   #navbar .nav-list li {
      position: relative;
   }

   #navbar .nav-list a {
      display: block;
      border-bottom: 1px solid;
      padding: 20px 0;
   }

   #navbar .nav-list .has-children>a {
      position: relative;
   }

   #navbar .nav-list .has-children .icon {
      display: block;
      width: 50%;
      height: 70px;
      position: absolute;
      top: 0;
      right: 0;
   }

   #navbar .nav-list .has-children .icon:after {
      content: '';
      width: 20px;
      height: 20px;
      background: url("../img/common/arrow-down.png") no-repeat center/100% auto;
      position: absolute;
      top: 50%;
      right: 0;
      transform: translateY(-50%);
      transition: all 0.3s;
   }

   #navbar .nav-list .has-children .sub-menu {
      display: none;
      background-color: #006496;
      color: #fff;
      font-size: 18px;
      padding: 0 20px 20px;
   }

   #navbar .nav-list .has-children.is-active>.icon:after {
      transform: translateY(-50%) rotate(-180deg);
   }

   #navbar .nav-list .sub-menu-1 .icon:after {
      background-image: url("../img/common/arrow-down-wh.png");
   }

   #navbar .nav-list .sub-menu-1 ol {
      display: none;
      background-color: #fff;
      color: #006496;
   }

   #navbar .nav-list .sub-menu-1 ol a {
      display: block;
      border-bottom: 1px solid;
      padding: 10px;
      font-size: 15px;
   }

   #navbar .nav-list .sub-menu-1.is-active .icon:after {
      transform: translateY(-50%) rotate(-180deg);
   }

   #navbar .nav-bnr-recruit {
      margin: 0 -10vw;
      padding-top: 70px;
   }

   #navbar .nav-sub {
      font-weight: 500;
      font-size: 18px;
      line-height: 1.5;
      padding-top: 65px;
   }

   #navbar .nav-sub a {
      display: inline-flex;
      background: url("../img/common/arrow-circle-down.png") no-repeat center left/21px auto;
      padding-left: 30px;
   }

   #navbar .nav-sub li.pc {
      display: none;
   }

   #navbar .nav-sns {
      display: flex;
      justify-content: center;
      gap: 20px;
      border-bottom: 1px dashed #006496;
      padding: 65px 0;
   }

   #navbar .nav-sns li {
      width: 65px;
   }

   #navbar .nav-tel {
      text-align: center;
      padding-top: 65px;
   }

   #navbar .nav-tel span {
      display: block;
      font-size: 4vw;
      line-height: 1.5;
      letter-spacing: 0.1em;
      padding-bottom: 6.6vw;
   }

   #navbar .nav-tel a {
      display: block;
      background: url("../img/common/icon-tel.png") no-repeat center left/12.8vw auto;
      font-size: 11.3vw;
      line-height: 12.8vw;
      text-align: right;
   }

   #navbar .nav-inq {
      display: block;
      padding-top: 24px;
   }

   #navbar .nav-inq a {
      display: flex;
      align-items: center;
      justify-content: center;
      height: 12vw;
      border: 2px solid #006496;
      border-radius: 5px;
      color: #006496;
      font-size: 16px;
      letter-spacing: 0.025em;
      line-height: 2;
   }

   .navOpen header:before {
      content: '';
      width: 100%;
      height: 100%;
      background-color: #fff;
      position: absolute;
      top: 0;
      left: 0;
   }

   .navOpen #navbar {
      opacity: 1;
      visibility: visible;
   }
}

@media screen and (min-width: 1024px) {
   header {
      display: flex;
      flex-wrap: wrap;
      gap: 0 30px;
      position: relative;
   }

   header .logo-1 {
      width: 75px;
   }

   #navbar {
      width: 100%;
      height: auto !important;
      position: relative;
      padding-top: 90px;
   }

   #navbar .nav-list {
      display: flex;
      justify-content: center;
      font-size: 16px;
      line-height: 35px;
      color: #006496;
      max-width: max-content;
      margin: 0 auto;
      position: relative;
   }

   #navbar .nav-list li {
      position: static;
   }

   #navbar .nav-list>li+li {
      margin-left: -1px;
   }

   #navbar .nav-list>li>a {
      display: block;
      position: relative;
      padding: 15px 35px 14px 10px;
      box-sizing: border-box;
   }

   #navbar .nav-list>li>a:before {
      content: '';
      width: 100%;
      height: 100%;
      border: 1px solid #006496;
      position: absolute;
      top: 0;
      left: 0;
      box-sizing: border-box;
      transform: skewX(-10deg);
      transition: all 0.3s;
      z-index: -1;
   }

   #navbar .nav-list>li>a:after {
      content: '';
      width: 15px;
      height: 14px;
      background: url("../img/common/arrow-down.png") no-repeat center top/cover;
      position: absolute;
      top: 50%;
      right: 10px;
      transform: translateY(-50%);
   }

   #navbar .nav-list>li>a:hover,
   #navbar .nav-list>li>a.current {
      color: #fff;
      opacity: 1;
   }

   #navbar .nav-list>li>a:hover:before,
   #navbar .nav-list>li>a.current:before {
      background-color: #006496;
   }

   #navbar .nav-list>li>a:hover:after,
   #navbar .nav-list>li>a.current:after {
      background-image: url("../img/common/arrow-down-wh.png");
   }

   #navbar .nav-list>li:not(.has-children)>a:after {
      transform: translateY(-50%) rotate(-90deg);
   }

   #navbar .nav-list .has-children .sub-menu {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      width: 100%;
      background-color: #006496;
      color: #fff;
      position: absolute;
      top: 100%;
      left: 50%;
      padding: 10px 0 20px;
      box-sizing: border-box;
      transition: all 0.3s;
      transform: translateX(-50%);
      margin-left: -6px;
      opacity: 0;
      visibility: hidden;
      line-height: 24px;
   }

   #navbar .nav-list .has-children .sub-menu>li {
      padding: 0 20px;
      box-sizing: border-box;
      position: static;
   }

   #navbar .nav-list .has-children .sub-menu a {
      display: block;
      border-bottom: 1px solid;
      padding: 10px 0;
   }

   #navbar .nav-list .has-children:hover>a {
      color: #fff;
      opacity: 1;
   }

   #navbar .nav-list .has-children:hover>a:before {
      background-color: #006496;
   }

   #navbar .nav-list .has-children:hover>a:after {
      background-image: url("../img/common/arrow-down-wh.png");
   }

   #navbar .nav-list .has-children:hover .sub-menu {
      opacity: 1;
      visibility: visible;
      transition-delay: 0.1s;
   }

   #navbar .nav-sns {
      display: flex;
      gap: 10px;
      position: absolute;
      top: 10px;
      right: 280px;
   }

   #navbar .nav-sns li {
      width: 65px;
   }

   #navbar .nav-sub {
      display: flex;
      align-items: center;
      gap: 10px;
      font-weight: 500;
      font-size: 14px;
      line-height: 26px;
      position: absolute;
      top: 30px;
      right: 430px;
   }

   #navbar .nav-sub a {
      display: inline-block;
      background: url("../img/common/arrow-circle-down.png") no-repeat center left/21px auto;
      padding-left: 28px;
   }

   #navbar .nav-tel {
      position: absolute;
      top: 10px;
      right: 0;
   }

   #navbar .nav-tel span {
      display: block;
      font-size: 18px;
      line-height: 20px;
   }

   #navbar .nav-tel a {
      display: block;
      background: url("../img/common/icon-tel.png") no-repeat center left/32px auto;
      font-size: 37px;
      line-height: 40px;
      margin-top: 5px;
      padding-left: 45px;
   }
}

@media screen and (min-width: 1200px) {
   #navbar .nav-list {
      font-size: 18px;
      margin-right: 0;
   }

   #navbar .nav-list>li>a {
      padding: 15px 50px 14px 20px;
   }

   #navbar .nav-list .has-children .sub-menu {
      grid-template-columns: repeat(4, 1fr);
   }
}

@media screen and (min-width: 1400px) {
   #navbar {
      padding-top: 20px;
   }

   #navbar .nav-sns,
   #navbar .nav-tel {
      top: -70px;
   }

   #navbar .nav-sub {
      top: -47px;
   }
}

@media screen and (min-width: 1600px) {
   #navbar .nav-list>li {
      width: 250px;
   }
}

/*=============================================
 * <footer>
 *=============================================*/
footer {
   background-color: #fff;
   font-size: 20px;
   line-height: 35px;
   padding: 120px 0;
   position: relative;
}

footer nav {
   padding-top: 40px;
}

footer nav a {
   display: inline-block;
   background: url("../img/common/arrow-circle-right.png") no-repeat center left/20px auto;
   padding-left: 40px;
}

footer address {
   text-align: left;
   padding-top: 40px;
}

footer .logo {
   width: 45%;
   max-width: 555px;
   position: absolute;
   top: 50%;
   right: 0;
   transform: translateY(-50%);
}

@media screen and (max-width: 767px) {
   footer {
      font-size: 12px;
      line-height: 20px;
      padding: 40px 0 80px;
   }

   footer nav {
      padding-top: 20px;
   }

   footer nav a {
      background-size: 10px auto;
      padding-left: 20px;
   }

   footer .logo {
      width: 100%;
      position: static;
      padding-top: 30px;
      transform: translateY(0);
   }

   footer address {
      font-size: 10px;
      text-align: center;
      margin: 0 -5vw;
      padding-top: 20px;
   }
}

.ft-fixed {
   position: fixed;
   opacity: 0;
   visibility: hidden;
   transition: all 0.3s;
   z-index: 9;
}

.ft-fixed.fixed {
   opacity: 1;
   visibility: visible;
}

@media screen and (max-width: 1199px) {
   .ft-fixed {
      width: 100%;
      bottom: 0;
      left: 0;
   }

   .ft-fixed a {
      display: flex;
      justify-content: center;
      align-items: center;
      width: 100%;
      height: 40px;
      font-size: 16px;
      line-height: 24px;
      letter-spacing: 0.1em;
      background: #006496;
      color: #fff;
   }

   .ft-fixed ul {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
   }

   .ft-fixed ul li:nth-child(even) a {
      background-color: #00c5dc;
   }
}

@media screen and (min-width: 1200px) {
   .ft-fixed {
      display: grid;
      top: 290px;
      right: 0;
      bottom: 20px;
   }

   .ft-fixed a {
      display: flex;
      justify-content: center;
      align-items: center;
      width: 90px;
      height: 100%;
      font-size: 23px;
      line-height: 24px;
      letter-spacing: 0.1em;
      background: #006496;
      color: #fff;
   }

   .ft-fixed a span {
      display: block;
      width: 23px;
   }

   .ft-fixed ul {
      height: 100%;
      max-height: 835px;
      margin: auto;
   }

   .ft-fixed ul li {
      height: 33.33%;
   }

   .ft-fixed ul li:nth-child(even) a {
      background-color: #00c5dc;
   }
}

@media screen and (min-width: 1500px) {
   .ft-fixed {
      top: 225px;
   }
}

@media screen and (min-width: 1200px) and (max-height: 790px) {
   .ft-fixed a {
      font-size: 16px;
      line-height: 16px;
   }
}

/*=============================================
 * <section>
 *=============================================*/
.fadeIn {
   opacity: 0;
   -webkit-transition: all cubic-bezier(0.61, 1, 0.88, 1);
   transition: all 1s cubic-bezier(0.61, 1, 0.88, 1);
}

.fadeIn[style*="visible"] {
   opacity: 1;
   -webkit-transform: translate3d(0, 0, 0);
   transform: translate3d(0, 0, 0);
}

.fadeInUp {
   opacity: 0;
   -webkit-transform: translate3d(0, 30px, 0);
   transform: translate3d(0, 30px, 0);
   -webkit-transition: all cubic-bezier(0.61, 1, 0.88, 1);
   transition: all 1s cubic-bezier(0.61, 1, 0.88, 1);
}

.fadeInUp[style*="visible"] {
   opacity: 1;
   -webkit-transform: translate3d(0, 0, 0);
   transform: translate3d(0, 0, 0);
}

.delay-1 {
   transition-delay: 0.1s;
}

.delay-2 {
   transition-delay: 0.2s;
}

.delay-3 {
   transition-delay: 0.3s;
}

.delay-4 {
   transition-delay: 0.4s;
}

.delay-5 {
   transition-delay: 0.5s;
}

.delay-6 {
   transition-delay: 0.6s;
}

.delay-7 {
   transition-delay: 0.7s;
}

/*=============================================
 * <KEY>
 *=============================================*/
#key {
   width: 100%;
   height: 632px;
   position: relative;
   z-index: 1;
}

#key img {
   position: absolute;
   top: 0;
   left: 0;
}

#key h1 {
   display: flex;
   flex-direction: column;
   justify-content: center;
   min-width: 540px;
   min-height: 125px;
   color: #fff;
   font-weight: 700;
   font-size: 45px;
   line-height: 52px;
   letter-spacing: 0.01em;
   position: absolute;
   bottom: 70px;
   left: 0;
   padding: 15px 125px;
   z-index: 1;
}

#key h1:before {
   content: '';
   height: 100%;
   background-image: linear-gradient(25deg, #006496, #82aebc);
   position: absolute;
   top: 0;
   right: 0;
   left: -25px;
   transform: skewX(-15deg);
   z-index: -1;
}

#key h1 small {
   display: block;
   font-size: 25px;
}

@media screen and (max-width: 1200px) {
   #key h1 {
      min-width: inherit;
      padding: 15px 50px 35px;
   }
}

@media screen and (max-width: 1023px) {
   #key h1 {
      font-size: 35px;
      padding: 20px 30px 30px;
   }

   #key h1 small {
      font-size: 20px;
   }
}

@media screen and (max-width: 767px) {
   #key {
      height: 100vw;
   }

   #key h1 {
      min-height: 60px;
      font-size: 25px;
      line-height: 35px;
      padding: 10px 20px;
      bottom: 20px;
   }

   #key h1 small {
      font-size: 15px;
   }
}

/*=============================================
 * <breadcrumb>
 *=============================================*/
.breadcrumb {
   font-weight: 900;
   font-size: 20px;
   line-height: 30px;
   letter-spacing: 0.01em;
   color: #006496;
   padding: 35px 0;
   position: relative;
   z-index: 1;
}

.breadcrumb ul {
   display: flex;
   flex-wrap: wrap;
   gap: 10px 20px;
   width: 87%;
   margin: 0 auto;
}

.breadcrumb li {
   display: flex;
   align-items: center;
   gap: 20px;
   position: relative;
}

.breadcrumb li:not(:last-child):after {
   content: '';
   width: 16px;
   height: 19px;
   background: url('../img/common/arrow-right.png') no-repeat center top / cover;
}

.breadcrumb a {
   font-weight: 400;
   border-bottom: 1px solid transparent;
}

.breadcrumb a:hover {
   border-bottom-color: #006496;
}

@media screen and (max-width: 767px) {
   .breadcrumb {
      font-size: 16px;
      line-height: 24px;
      /*overflow-x: auto;*/
      padding: 20px 0;
   }

   .breadcrumb ul {
      gap: 10px;
      /*width: max-content;*/
      margin: 0;
      padding: 0 20px;
   }

   .breadcrumb ul li {
      gap: 10px;
   }

   .breadcrumb li:not(:last-child):after {
      width: 8px;
      height: 10px;
   }
}

/*=============================================
 * 
 *=============================================*/
.box-icon {
   text-align: center;
   position: relative;
}

.box-icon .icon {
   width: attr(data-width-pc px);
   position: absolute;
   top: 0;
   left: calc(50% + 435px);
}

.box-icon .txt {
   font-weight: 400;
   padding-top: 30px;
}

.box-icon .txt small {
   font-size: 18px;
}

@media screen and (max-width: 1200px) {
   .box-icon .icon {
      position: static;
      margin: 0 auto;
      padding-bottom: 20px;
   }
}
@media screen and (max-width: 767px) {
   .box-icon .icon {
      width: attr(data-width-sp px);
      padding-bottom: 10px;
   }

   .box-icon .txt {
      padding-top: 20px;
   }

   .box-icon .txt small {
      font-size: 14px;
   }
}