@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Zen+Maru+Gothic:wght@500;900&display=swap');

/* A Modern CSS Reset */
*,*::before,*::after{box-sizing:border-box}body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}ul[role="list"],ol[role="list"]{list-style:none}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5}a:not([class]){text-decoration-skip-ink:auto}img,picture{max-width:100%;height: auto;display:block}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}

ul,ol {
    list-style-type: none;
    margin: 0;
    padding: 0;
  }
  
  :root {
    --min-viewport-width: 375;
    --max-viewport-width: 1366;
    --min-fluid-ratio: calc(1 / var(--min-viewport-width) * 100dvi);
    --max-fluid-ratio: calc(1 / var(--max-viewport-width) * 100dvi);
    --pc-shared-layout: 1024px;
    --sp-shared-layout: calc(310 * var(--min-fluid-ratio));
    --base-font-size: 16;
    --rem: calc(1rem / var(--base-font-size));
    --text-color: #111111;
    --theme-color: #0568D3;
    --em-color:#F7DE0A;
    --body-bg-color: #ffffff;
    --sub-bg-color: #F3F3F3;
    --line-color: #CCE5FF;
    --line-color2: #E7E7E7;
    --line-color3: #E0E0E0;
    --text-spacing: 0;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semiBold: 600;
    --font-weight-bold: 700;
    --font-weight-exbold: 800;
    --font-weight-black: 900;
    --font-noto-sans:"Noto Sans JP", "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
    --font-zenmaru-g: "Zen Maru Gothic", serif;
    --border-rounded: calc(1px / 0);
    --easeInOut: cubic-bezier(.7,0,.3,1);
    --border-gradient:linear-gradient(90deg, rgba(94,199,240,1) 0%, rgba(41,136,225,1) 100%);
  }

  html {
    scroll-behavior: smooth;
  }
  html, body, .wrapper {
    height: 100%;
  }
  
  body {
    font-family:var(--font-noto-sans);
    font-weight: var(--font-weight-regular);
    font-optical-sizing: auto;
    font-style: normal;
    font-size: calc(16 * var(--rem));
    color: var(--text-color);
  }
  
  a {
    text-decoration: none;
    transition: all .25s ease-in-out;
  }
  @media (hover) {
    a:hover {
      opacity: .75;
    }
  }

  .pc {
    display: inline;
  }

  .sp {
    display: none;
  }
  
  @media screen and (max-width: 767px) {

    .pc {
      display: none;
    }
  
    .sp {
      display: inline;
    }

  }
  /*------------------------------------------
  
    header / ヘッダー
  
  ------------------------------------------*/
  .header {
    container-type: inline-size;
    position: relative;
    z-index: calc(infinity);
  }
  
  .header_inner {
    height: 113px;
    max-width: 1264px;
    margin-inline: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  
  .header .header_logo {
    width: 300px;
  }

  .header .header_logo a {
    color: var(--theme-color);
  }
  
  .nav_list {
    display: flex;
    white-space: nowrap;
  }

  .nav_list > li > a {
    font-size: calc(18 * var(--rem));
    color: var(--text-color);
    text-decoration: none;
    font-weight: var(--font-weight-bold);
    padding: 40px 25px 0;
    height: 113px;
  }



  .nav_list > li:last-child > a {
    padding-right: 0;
  }

  .nav_list li:has(button) {
    padding-right: 25px;
  }
  
  .nav_list li:has(button) a {
    padding-right: 5px;
  } 
  
  .nav_list > li {
    align-items: baseline;
  }
  
  .nav_list button {
    width: 13px;
    height: 12px;
    background: none;
    margin: 0;
    padding: 0;
    border: none;
  }

  .nav_list button:focus {
    outline: 2px solid blue;
  }

  .nav_list button::after:focus {
    border: none;
  }
  .is-touch .nav_list button {
    position: relative;
  }
  .nav_sub {
    line-height: 1;
    background: var(--body-bg-color);
    padding: 36px 0 56px;
  }
  
  .nav_sub_wrap {
    max-width: 1264px;
    margin-inline: auto;
    position: relative;
  }
  
  .nav_sub_title {
    position: relative;
    background-color: var(--body-bg-color);
    z-index: 5;
    width: 200px;
    font-size: calc(36 * var(--rem));
    font-weight: var(--font-weight-black);
    color: var(--theme-color);
    padding: 0 20px;
    margin-left: 60px;
    top: -18px;
  }
  
  .nav_sub_list::before {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 8px;
    background: var(--body-bg-color);
    z-index: 2;
  }
  
  .nav_sub_list::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 15px;
    background: var(--border-gradient);
  }
  
  .nav_sub_list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, 1fr);
    row-gap: 21px;
    padding:45px 59px 62px;
  }
  
  .nav_sub_list li {
    position: relative;
    z-index: 3;
  }
  
  .nav_sub a {
    color: var(--text-color);
    font-weight: var(--font-weight-regular);
    background: url(../images/shared/icon-arrow-black-right.svg) no-repeat left / 10px auto;
    padding-left: 28px;
    letter-spacing: 0.2em;
    font-size: calc(17 * var(--rem));
  }
  .nav_sub a span {
    color: var(--theme-color);
    font-weight: var(--font-weight-bold);
    font-size: calc(20 * var(--rem));
  }

  .nav_sub a small {
    font-size: calc(17 * var(--rem));
  }
  
  
  @media (hover) {
    .nav_list a:hover {
      transition-duration: .1s;
    }
  }

  @media screen and (max-width: 1366px) {
    
    .header_inner {
      height: calc(113 * var(--max-fluid-ratio));
      max-width: calc(1264 * var(--max-fluid-ratio));
    }

    .header .header_logo {
      width: calc(300 * var(--max-fluid-ratio));
    }
    
    .nav_list > li > a {
      font-size: calc(18 * var(--max-fluid-ratio));
      padding: calc(40 * var(--max-fluid-ratio)) calc(25 * var(--max-fluid-ratio)) 0;
      height: calc(113 * var(--max-fluid-ratio));
    }
    
    .nav_list li:has(button) > a {
      padding-right: calc(5 * var(--max-fluid-ratio));
    } 
    
    .nav_list button {
      width: calc(13 * var(--max-fluid-ratio));
      height: calc(12 * var(--max-fluid-ratio));
    }
    .nav_sub {
      padding: calc(36 * var(--max-fluid-ratio)) 0 calc(56 * var(--max-fluid-ratio));
    }
    
    .nav_sub_wrap {
      max-width: calc(1264 * var(--max-fluid-ratio));
    }
    
    .nav_sub_title {
      width: calc(200 * var(--max-fluid-ratio));
      font-size: calc(36 * var(--max-fluid-ratio));
      padding: 0 calc(20 * var(--max-fluid-ratio));
      margin-left: calc(60 * var(--max-fluid-ratio));
      top: calc(-18 * var(--max-fluid-ratio));
    }
    
    .nav_sub_list::before {
      inset: calc(6 * var(--max-fluid-ratio));
      border-radius: calc(8 * var(--max-fluid-ratio));
    }
    
    .nav_sub_list::after {
      border-radius: calc(15 * var(--max-fluid-ratio));
    }
    
    .nav_sub_list {
      row-gap: calc(21 * var(--max-fluid-ratio));
      padding: calc(45 * var(--max-fluid-ratio)) calc(59 * var(--max-fluid-ratio)) calc(62 * var(--max-fluid-ratio));
    
    }
    
    .nav_sub a {
      background: url(../images/shared/icon-arrow-black-right.svg) no-repeat left / calc(10 * var(--max-fluid-ratio)) auto;
      padding-left: calc(28 * var(--max-fluid-ratio));
      font-size: calc(17 * var(--max-fluid-ratio));
    }
    .nav_sub a span {
      font-size: calc(20 * var(--max-fluid-ratio));
    }

    .nav_sub a small {
      font-size: calc(17 * var(--max-fluid-ratio));
    }
    
  }
  
  
  @media screen and (min-width: 768px) {
    .nav_toggle {
        display: none;
    }
    .nav_list li {
        display: flex;      
    }
    .nav_list > li > a {
        position: relative;
    }

    .nav_list > li > a > span {
      position: relative;
      display: inline-block;
    }

    .nav_list > li > a > span::after {
      position: absolute;
      left: 0;
      content: '';
      width: 100%;
      height: 3px;
      background: #111;
      bottom: -9px;
      transform: scale(0, 1);
      transform-origin: right top;
      transition: transform 0.3s;
    }

    .nav_list > li > a:hover {
      opacity: 1;
    }

    .nav_list > li > a:hover span::after {
      transform: scale(1, 1); 
      transform-origin: left top;
    }
    
    .nav_sub {
        z-index: -1;
        position: absolute;
        top: 100%;
        right: 0;
        left: 0;
        clip-path: inset(0 -50vw 100%);
        opacity: 0;
    }
    @media (hover) {
        .nav_sub {
            transition: opacity .2s var(--easeInOut);
        }
        .nav_list li:hover .nav_sub {
            pointer-events: auto;
            opacity: 1;
            clip-path: inset(0 -50vw);
        }
    }
    .nav_sub.is-anim {
        transition: clip-path .4s var(--easeInOut);
    }
    .nav_sub.is-open {
      z-index: 1;
        pointer-events: auto;
        clip-path: inset(0 -50vw);
        opacity: 1;
    }
  }
  
  @media screen and (max-width: 767px) {
  
    .header_inner {
      width: 100%;
      padding-left: calc(6 * var(--min-fluid-ratio));
      height: calc(86 * var(--min-fluid-ratio));
    }
    .header .header_logo {
      width: calc(200 * var(--min-fluid-ratio));
    }

    .nav_list > li {
      border-bottom: 2px solid;
      border-image: var(--border-gradient);
      border-image-slice: 1;
      line-height: 1;
    }

    .nav_list > li > a {
      padding: calc(20 * var(--min-fluid-ratio)) 0;
      font-size: calc(15 * var(--min-fluid-ratio));
      height: auto;
      display: block;
      font-weight: var(--font-weight-medium);
    }

    .nav_list > li:nth-child(2) > a {
      padding-bottom: calc(10 * var(--min-fluid-ratio));
    }
    .nav_list li:has(button) {
      padding-right: 0;
    }
    
    .nav_list li:has(button) a {
      padding-right: 0;
    } 
    .nav_list button {
      display: none;
    }
    .is-touch .nav_list button {
      position: relative;
    }
    .nav_sub {
      line-height: 1;
      margin-top: 0;
      padding: 0;
      background: var(--body-bg-color);
      margin-top: 0;
    }
    
    .nav_sub_wrap {
      max-width: none;
    }
    
    .nav_sub_title {
      display: none;
    }
    
    .nav_sub_list::before {
      content: none;
    }
    
    .nav_sub_list::after {
      content: none;
    }

    .nav_sub a {
      column-gap: 0;
      display: block;
      padding-left: calc(20 * var(--min-fluid-ratio));
    }    
    .nav_sub_list {
      display: grid;
      grid-template-columns: 1fr;
      grid-template-rows: 1fr;
      row-gap: 0;
      padding: 0 0 calc(14 * var(--min-fluid-ratio));
      margin-left: calc(17 * var(--min-fluid-ratio));
    }
    
    .nav_sub_list li {
      position: relative;
      z-index: 3;
      line-height: calc(36/20);
    }
    
    .nav_sub a {
      color: var(--text-color);
      font-weight: var(--font-weight-regular);
      background: url(../images/shared/icon-arrow-black-right.svg) no-repeat left / calc(8 * var(--min-fluid-ratio)) auto;
      padding-left: calc(20 * var(--min-fluid-ratio));
      font-size: calc(17 * var(--min-fluid-ratio));
    }
    .nav_sub a span {
      color: var(--theme-color);
      font-weight: var(--font-weight-bold);
      font-size: calc(20 * var(--min-fluid-ratio));
    }

    .nav_sub a small {
      font-size: calc(14 * var(--min-fluid-ratio));
      margin-top: calc(-3 * var(--min-fluid-ratio));
    }
    
    @media (hover) {
      .nav_list a:hover {
          text-decoration: underline;
          transition-duration: .1s;
      }
    }
    .nav {
      height: 100%;
    }
    .nav.is-open {
      overflow: auto;
    }
    .nav_list {
      flex-direction: column;
      overflow: auto;
      position: absolute;
      inset: calc(78 * var(--min-fluid-ratio)) 0 auto auto;
      padding: 0 calc(20 * var(--min-fluid-ratio)) calc(30 * var(--min-fluid-ratio));
      background: var(--body-bg-color);
      height: auto;
      clip-path: inset(0);
      width: 100%;
    }
    /* スクロールバーを消す */
    .nav_list {
      scrollbar-width: none;
      scrollbar-color: transparent;
      -webkit-overflow-scrolling: touch;
      
    }
    .nav_list::-webkit-scrollbar {
      width: 0;
      height: 0;
    }
    .nav_list::-webkit-scrollbar-thumb,
    .nav_list::-webkit-scrollbar-track {
      background: transparent;
    }
    .nav_list.is-anim {
      transition: clip-path .4s var(--easeInOut);
    }
    .nav:not(.is-open) {
      pointer-events: none;
    }
    .nav:not(.is-open)::before {
      opacity: 0;
    }
    .nav_list:not(.is-open) {
      clip-path: inset(0 0 100% 0);
    }
  
    /* ハンバーガーボタン */
    .nav_toggle {
      pointer-events: auto;
      display: grid;
      place-items: center;
      z-index: 1;
      position: absolute;
      top: 0;
      right: 0;
      width: calc(70 * var(--min-fluid-ratio));
      height: calc(82 * var(--min-fluid-ratio));
      background: transparent;
      border: none;
    }
    .nav_toggle svg {
      grid-area: 1 / 1;
      position: absolute;
      overflow: visible;
      fill: none;
      stroke: currentcolor;
      width: calc(24 * var(--min-fluid-ratio));
      stroke-width: 2;
      stroke-linecap: round;
      transition: opacity .4s var(--easeInOut), transform .4s var(--easeInOut);
      color: var(--text-color);
    }
    .nav_toggle .b1 {
      transform: translateY(calc(-10 * var(--min-fluid-ratio)));
    }
    .nav_toggle .b3 {
      transform: translateY(calc(10 * var(--min-fluid-ratio)));
    }
    /* カーソルを乗せると色が変わる */
    @media (hover) {
      .nav_toggle {
          transition: color .4s;
      }
      .nav_toggle:hover {
          color: #272727;
          transition-duration: .1s;
      }
      .nav_toggle {
          cursor: pointer;
      }
    }
    /* ドロワーが開くとバツになる */
    .nav_toggle.is-open .b1 {
      transform: rotate(-45deg);
    }
    .nav_toggle.is-open .b2 {
      opacity: 0;
      transform: rotate(-90deg);
    }
    .nav_toggle.is-open .b3 {
      transform: translateY(calc(1 * var(--min-fluid-ratio))) rotate(-135deg);
    }
  }
  
  /*------------------------------------------
  
    footer / フッター
  
  ------------------------------------------*/
  .footer {
    --bg-color: #333;
    --text-color: #fff;
    container-type: inline-size;
    background-color: var(--bg-color);
    color: var(--text-color);
    position: sticky;
    top: 100vh;
    top: 100dvh;
  }
  
  .footer a {
    color: var(--text-color);
  }
  
  .footer_inner {
    max-width: 1364px;
    margin-inline: auto;
    display: grid;
    grid-template-columns: minmax(385px, 535px) minmax(min-content ,828px) 1fr;
    grid-template-rows: 1fr min-content;
    position: relative;
  }
  
  .footer_contact {
    text-align: center;
    padding-top: 105px;
    grid-row: 1;
  }
  
  .footer_contact_inner {
    margin-inline: auto;
  }
  
  .footer_contact .footer_contact_text {
    font-size: calc(18 * var(--rem));
    line-height: calc(33 / 18);
    font-weight: var(--font-weight-medium);
  }
  
  .footer_contact .footer_contact_btn {
    display: block;
    color: #111;
    background-color: #fff;
    border-radius: var(--border-rounded);
    font-weight: var(--font-weight-bold);
    /*font-size: calc(24 * var(--rem));*/
    font-size: calc(22 * var(--rem));
    text-decoration: none;
    max-width: 385px;
    margin: 27px auto 0;
    padding: 19px 0;
  }
  
  .footer_contact .footer_contact_notice {
    display: block;
    font-size: calc(12 * var(--rem));
    margin-top: 16px;
    padding-left: 5px;
  }
  
  .footer_navWrap {
    padding: 55px 20px 36px 60px;
    border-left: 1px solid var(--sub-bg-color);
    grid-row: 1;
  }
   
  .footer_navWrap .footer_nav1 {
    display: grid;
    grid-template-columns: max-content;
    margin-left: 5px;
  }
  
  .footer_navWrap .footer_nav1 a {
    --text-spacing: 0.2em;
    --text-color:#ccc;
    font-size: calc(21 * var(--rem));
    letter-spacing: var(--text-spacing);
    color: var(--text-color);
    background: url(../images/shared/icon-arrow-white-right.svg) no-repeat left / 10px auto;
    padding-left: 30px;
    line-height: calc(42/24);
  }
  
  .footer_navWrap .footer_nav1 span {
    font-weight: var(--font-weight-bold);
    font-size: calc(24 * var(--rem));
    color: #fff;
  }
  
  .footer_navWrap .footer_nav1 a small {
    font-size: calc(16 * var(--rem));
    margin-left: -5px;
  }
  
  .footer_navWrap .footer_nav2 {
    margin-top: 37px;
  }
  
  .footer_navWrap .footer_nav2_list {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: repeat(5, max-content);
  }
  
  .footer_navWrap .footer_nav2 li {
    font-size: calc(18 * var(--rem));
    font-weight: var(--font-weight-bold);
  }
  
  .footer_navWrap .footer_nav2 li span {
    font-weight: var(--font-weight-regular);
  }
  
  .footer_copyright {
    text-align: center;
    grid-row: 2;
    order: 3;
    font-size: calc(12 * var(--rem));
    vertical-align: bottom;
    margin-top: 5px;
  }
  
  .footer_nav3 {
    grid-row: 2;
    display: flex;
    border-left: 1px solid var(--sub-bg-color);
    padding-left: 60px;
    padding-bottom:40px;
    order: 4;
    column-gap: calc(32 * var(--rem));
  }
  
  .footer_nav3 a {
    font-size: calc(16 * var(--rem));
  }
  
  .footer .pagetop {
    --boder-color: #707070;
    width: 100px;
    height: 100px;
    display: grid;
    place-content: center;
    position: absolute;
    inset: 58px 58px auto auto;
    border: 1px solid var(--boder-color);
    font-family: var(--font-zenmaru-g);
    font-weight: var(--font-weight-black);
    font-size: calc(18 * var(--rem));
    text-align: center;
    letter-spacing: 0.15em;
  }
  
  .footer .pagetop img {
    margin-inline: auto;
  }

  @media screen and (max-width: 1366px) {
  
    .footer_inner {
      max-width: calc(1364 * var(--max-fluid-ratio));
      grid-template-columns: minmax(calc(385 * var(--max-fluid-ratio)), calc(535 * var(--max-fluid-ratio))) minmax(min-content ,calc(828 * var(--max-fluid-ratio))) 1fr;
    }
  
    .footer_contact {
      padding-top: calc(105 * var(--max-fluid-ratio));
    }
  
    .footer_contact .footer_contact_text {
      font-size: calc(18 * var(--max-fluid-ratio));
    }
  
    .footer_contact .footer_contact_btn {
      /*font-size: calc(24 * var(--max-fluid-ratio));*/
      font-size: calc(22 * var(--max-fluid-ratio));
      max-width: calc(385 * var(--max-fluid-ratio));
      padding: calc(19 * var(--max-fluid-ratio)) 0;
      margin-top: calc(27 * var(--max-fluid-ratio));
    }
  
    .footer_contact .footer_contact_notice {
      font-size: calc(12 * var(--max-fluid-ratio));
      margin-top: calc(16 * var(--max-fluid-ratio));
      padding-left: calc(5 * var(--max-fluid-ratio));
    }
  
    .footer_navWrap {
      padding: calc(55 * var(--max-fluid-ratio))  calc(60 * var(--max-fluid-ratio)) calc(36 * var(--max-fluid-ratio)) calc(20 * var(--max-fluid-ratio));
    }
    
    .footer_navWrap .footer_nav1 {
      margin-left: calc(5 * var(--max-fluid-ratio))
    }
  
    .footer_navWrap .footer_nav1 a {
      font-size: calc(21 * var(--max-fluid-ratio));
      background: url(../images/shared/icon-arrow-white-right.svg) no-repeat left / calc(10 * var(--max-fluid-ratio)) auto;
      padding-left: calc(30 * var(--max-fluid-ratio));
    }
  
    .footer_navWrap .footer_nav1 span {
      font-size: calc(24 * var(--max-fluid-ratio));
    }
  
    .footer_navWrap .footer_nav1 a small {
      font-size: calc(16 * var(--max-fluid-ratio));
      margin-left: calc(-5 * var(--max-fluid-ratio));
    }
  
    .footer_navWrap .footer_nav2 {
      margin-top: calc(37 * var(--max-fluid-ratio));
    }
  
  
    .footer_navWrap .footer_nav2 li {
      font-size: calc(18 * var(--max-fluid-ratio));
    }
  
  
    .footer_copyright {
      font-size: calc(12 * var(--max-fluid-ratio));
      margin-top: calc(5 * var(--max-fluid-ratio));
    }
  
    .footer_nav3 {
      padding-left: calc(60 * var(--max-fluid-ratio));
      padding-bottom: calc(40 * var(--max-fluid-ratio));
      column-gap:  calc(32 * var(var(--max-fluid-ratio)));
    }
  
    .footer_nav3 a {
      font-size: calc(16 * var(--max-fluid-ratio));
    }
    .footer .pagetop {
      width: calc(100 * var(--max-fluid-ratio));
      height: calc(100 * var(--max-fluid-ratio));
      inset: calc(58 * var(--max-fluid-ratio)) calc(58 * var(--max-fluid-ratio)) auto auto;
      font-size: calc(18 * var(--max-fluid-ratio));
    } 
  }
  
  @media screen and (max-width: 767px) {
  
    .footer_inner {
      max-width: none;
      width: calc(335 * var(--min-fluid-ratio));
      grid-template-columns: 1fr;
      grid-template-rows: 1fr;
    }
  
    .footer_contact {
      text-align: center;
      padding-top: calc(33 * var(--min-fluid-ratio));
      grid-row: 2;
      order: 2;
    }
  
    .footer_contact_inner {
      margin-inline: auto;
    }
  
    .footer_contact .footer_contact_text {
      font-size: calc(14 * var(--min-fluid-ratio));
      line-height: calc(28 / 14);
    }
  
    .footer_contact .footer_contact_btn {
      /*font-size: calc(20 * var(--min-fluid-ratio));*/
      font-size: calc(18 * var(--min-fluid-ratio));
      max-width: calc(303 * var(--min-fluid-ratio));
      padding: calc(10 * var(--min-fluid-ratio)) 0;
      margin-top: calc(20 * var(--min-fluid-ratio));
    }
  
    .footer_contact .footer_contact_notice {
      font-size: calc(12 * var(--min-fluid-ratio));
      margin-top: calc(25 * var(--min-fluid-ratio));
      padding-left: 0;
    }
  
    .footer_navWrap {
      padding: calc(38 * var(--min-fluid-ratio)) 0 0;
      border-left: none;
      grid-row: 1;
      order: 1;
    }
    
    .footer_navWrap .footer_nav1 {
      margin-left: 0;
    }
  
    .footer_navWrap .footer_nav1 a {
      font-size: calc(17 * var(--min-fluid-ratio));
      background: url(../images/shared/icon-arrow-white-right.svg) no-repeat left / calc(8 * var(--min-fluid-ratio)) auto;
      padding-left: calc(21 * var(--min-fluid-ratio));
      line-height: calc(36/20);
    }
  
    .footer_navWrap .footer_nav1 span {
      font-size: calc(20 * var(--min-fluid-ratio));
    }
  
    .footer_navWrap .footer_nav1 a small {
      font-size: calc(14 * var(--min-fluid-ratio));
      margin-left: calc(-5 * var(--min-fluid-ratio));
    }
  
    .footer_navWrap .footer_nav2 {
      margin-top: calc(35 * var(--min-fluid-ratio));
    }

    .footer_navWrap .footer_nav2_list {
      display: grid;
      grid-auto-flow: row;
      grid-template-columns: 1fr;
      border-top: 1px solid #fff;
    }
  
    .footer_navWrap .footer_nav2 li {
      font-size: calc(15 * var(--min-fluid-ratio));
      font-weight: var(--font-weight-medium);
      border-bottom: 1px solid #fff;
    }
  
    .footer_navWrap .footer_nav2 a {
      display: block;
      padding: calc(18 * var(--min-fluid-ratio)) 0 calc(16 * var(--min-fluid-ratio));
  
    }
  
    .footer_navWrap .footer_nav2 li::after {
      content: none;
    }
  
    .footer_copyright {
      grid-row: 4;
      order: 4;
      font-size: calc(12 * var(--min-fluid-ratio));
      margin-top: calc(10 * var(--min-fluid-ratio));
      padding-bottom:calc(23 * var(--min-fluid-ratio));
    }
  
    .footer_nav3 {
      grid-row: 3;
      border-left: none;
      padding-left: 0;
      padding-bottom:0;
      order: 4;
      justify-content: center;
      margin-top: calc(42 * var(--min-fluid-ratio));
      column-gap: calc(22 * var(--min-fluid-ratio));
    }
  
    .footer_nav3 a {
      font-size: calc(10 * var(--min-fluid-ratio));
    }

    .footer .pagetop {
      display: none;
  
    }    
  }

/*------------------------------------------
  
  page_title / ページタイトル
  
------------------------------------------*/ 

.page_title .title_group {
  background-color: var(--theme-color);
  color: #fff;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  height: 200px;
  line-height: 1;
}

.page_title .title_group_text {
  font-size: calc(42 * var(--rem));
  font-weight: var(--font-weight-bold);
  line-height: 1;
}

.page_title .title_group_deco {
  position: absolute;
  inset: -30px -9px auto auto;
  font-size: calc(128 * var(--rem));
  font-weight: var(--font-weight-black);
  opacity: .05;
  pointer-events: none;
}

.page_title .breadcrumb {
  max-width: 960px;
  margin-inline: auto;
  margin-top: 20px;
}

.page_title .breadcrumb_list {
  display: flex;
}

.page_title .breadcrumb_list li {
  font-size: calc(12 * var(--rem));
  display: grid;
  grid-template-columns: max-content auto;
}

.page_title .breadcrumb_list li:last-child {
  -webkit-box-orient: vertical;
  line-clamp: 1;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  overflow: hidden;
}


.page_title .breadcrumb_list span {
  margin-inline: 10px;
}

.page_title .breadcrumb_list li a {
  color: var(--text-color);
}
.page_title .breadcrumb_list li a:hover {
  opacity: 1;
  text-decoration: underline;
}

@media screen and (max-width: 1366px) {
  .page_title .title_group {
    height: calc(200 * var(--max-fluid-ratio));
  }
  
  .page_title .title_group_text {
    font-size: calc(42 * var(--max-fluid-ratio));
  }
  
  .page_title .title_group_deco {
    inset: calc(-30 * var(--max-fluid-ratio)) calc(-9 * var(--max-fluid-ratio)) auto auto;
    font-size: calc(128 * var(--max-fluid-ratio));
  }
  
  .page_title .breadcrumb {
    max-width: calc(960 * var(--max-fluid-ratio));
    margin-inline: auto;
    margin-top: calc(20 * var(--max-fluid-ratio));
  }
  
  .page_title .breadcrumb_list li {
    font-size: calc(12 * var(--max-fluid-ratio));
  }

  .page_title .breadcrumb_list span {
    margin: 0 calc(10 * var(--max-fluid-ratio));
  }  
}

@media screen and (max-width: 767px) {
  .page_title .title_group {
    height: calc(140 * var(--min-fluid-ratio));
  }
  
  .page_title .title_group_text {
    font-size: calc(26 * var(--min-fluid-ratio));
    text-align: center;
  }

  .page_title .title_group_text:has(br) {
    font-size: calc(22 * var(--min-fluid-ratio));
    line-height: calc(32 / 22);
  }
  
  .page_title .title_group_deco {
    inset: auto auto 0 auto;
    font-size: calc(48 * var(--min-fluid-ratio));
    word-break: keep-all;
    text-align: center;
    display: grid;
    grid-template-columns: repeat(3, max-content);
    column-gap: 1.5rem;
  }
  .page_title .title_group_deco:before {
    content: attr(data-text);
  }
  .page_title .title_group_deco:after {
      content: attr(data-text);
  }      
  
  .page_title .breadcrumb {
    max-width: none;
    width: calc(335 * var(--min-fluid-ratio));
    margin-top: calc(15 * var(--min-fluid-ratio));
  }
  
  .page_title .breadcrumb_list li {
    font-size: calc(10 * var(--min-fluid-ratio));
  }
  
  .page_title .breadcrumb_list span {
    margin: 0 calc(10 * var(--min-fluid-ratio));
  }  
}


/* css adjust breadcrumb ------------*/
.page_title .breadcrumb_list > span,
.page_title .breadcrumb_list > span span {
    font-size: calc(12* var(--rem));
  margin: 0;
}
.page_title .breadcrumb_list > span a {
  color: var(--text-color);
}
.page_title .breadcrumb_list > span a:hover {
  opacity: 1;
  text-decoration: underline;
}
.page_title .breadcrumb_list span.split {
  margin-inline: 10px;
}


.page_title .breadcrumb_list > span{
  font-size: calc(12 * var(--rem));
  display: grid;
  grid-template-columns: max-content auto;
}
.page_title .breadcrumb_list > span:last-child{
  -webkit-box-orient: vertical;
  line-clamp: 1;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  overflow: hidden;
}


@media screen and (max-width: 1366px) {
  .page_title .breadcrumb_list > span,
  .page_title .breadcrumb_list > span span {
    font-size: calc(12 * var(--max-fluid-ratio));
  }
  .page_title .breadcrumb_list span.split {
    margin: 0 calc(10 * var(--max-fluid-ratio));
  }  
}
@media screen and (max-width: 767px) {
  .page_title .breadcrumb_list > span,
  .page_title .breadcrumb_list > span span {
    font-size: calc(10 * var(--min-fluid-ratio));
  }
  .page_title .breadcrumb_list span.split {
    margin: 0 calc(10 * var(--min-fluid-ratio));
  }  
}
/* //css adjust breadcrumb --------*/



/*------------------------------------------
  
  pagination / ページネーション 
  
------------------------------------------*/ 

.pagination {
  padding-top: 80px;
  margin-top: 60px;
  border-top: 1px solid var(--line-color3);
}

.pagination .pagination_list {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 8px;
  flex-shrink: 0;
  list-style-type: none;
}


.pagination .pagination_list a,
.pagination .pagination_list span {
  width: 34px;
  height: 34px;
  font-family: var(--font-zenmaru-g);
  font-size: calc(16 * var(--rem));
  display: grid;
  place-items: center;
  color: var(--text-color);
  border-radius: var(--border-rounded);
  transition: all .25s ease-in-out;
}
.pagination .pagination_list a.thisPage {
  background-color: var(--line-color2);
  opacity: 1;
}

.pagination .previous {
  margin-right: 43px;
}

.pagination .next {
  margin-left: 43px;
}

.pagination .previous a,
.pagination .next a {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line-color2);
  border-radius: 4px;
}

@media (hover) {

  .pagination .pagination_list a:hover {
    border: 1px solid #0768D3;
    background-color: #fff;
  }

  .pagination .previous a:hover,
  .pagination .next a:hover {
    opacity: 1;
    background-color: #fff;
  }
}

.pagination .previous img,
.pagination .next img {
  width: 8.5px;
}
.btn-back {
  width: 500px;
  min-height: 80px;
  padding: 10px 60px;
  margin-inline: auto;
  font-size: calc(22 * var(--rem));
  color: var(--theme-color);
  font-weight: var(--font-weight-bold);
  text-align: center;
  display: grid;
  border: 1px solid var(--line-color2);
  background-color: #fff;
  border-radius: var(--border-rounded);
  box-shadow: 0px 1px 15px rgba(0, 0, 0, 0.1);
  place-items: center;
  position: relative;
}
.btn-back::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0 0 0 33px;
  margin-block: auto;
  background: url(../images/shared/icon-arrow-blue-left.svg) no-repeat center / 12px auto;
  width: 12px;
  height: 18px;
}

.pagination .btn-back {
  margin-top: 100px;
}


@media screen and (max-width: 1366px) {
 
  .pagination {
    padding-top: calc(80 * var(--max-fluid-ratio));
    margin-top: calc(60 * var(--max-fluid-ratio));
  }

  .pagination .pagination_list {
    column-gap: calc(8 * var(--max-fluid-ratio));
  }


  .pagination .pagination_list a,
  .pagination .pagination_list span {
    width: calc(34 * var(--max-fluid-ratio));
    height: calc(34 * var(--max-fluid-ratio));
    font-size: calc(16 * var(--max-fluid-ratio));
  }

  .pagination .previous {
    margin-right: calc(43 * var(--max-fluid-ratio));
  }

  .pagination .next {
    margin-left: calc(43 * var(--max-fluid-ratio));
  }

  .pagination .previous a,
  .pagination .next a {
    width: calc(50 * var(--max-fluid-ratio));
    height: calc(50 * var(--max-fluid-ratio));
    border-radius: calc(4 * var(--max-fluid-ratio));
  }

  .pagination .previous img,
  .pagination .next img {
    width: calc(8.5 * var(--max-fluid-ratio));
  }
  .btn-back {
    width: calc(500 * var(--max-fluid-ratio));
    min-height: calc(80 * var(--max-fluid-ratio));
    padding: calc(10 * var(--max-fluid-ratio)) calc(60 * var(--max-fluid-ratio));
    font-size: calc(22 * var(--max-fluid-ratio));
    box-shadow: 0px calc(1 * var(--max-fluid-ratio)) calc(15 * var(--max-fluid-ratio)) rgba(0, 0, 0, 0.1);
  }
  .btn-back::after {
    inset: 0 0 0 calc(33 * var(--max-fluid-ratio));
    margin-block: auto;
    background: url(../images/shared/icon-arrow-blue-left.svg) no-repeat center / calc(12 * var(--max-fluid-ratio)) auto;
    width: calc(12 * var(--max-fluid-ratio));
    height: calc(18 * var(--max-fluid-ratio));
  }

  .pagination .btn-back {
    margin-top: calc(100 * var(--max-fluid-ratio));
  }

}

@media screen and (max-width: 767px) {
  .pagination {
    padding-top: calc(45 * var(--min-fluid-ratio));
    margin-top: 0;
  }
  
  .pagination .pagination_list {
    column-gap: calc(10 * var(--min-fluid-ratio));
  }
  
  
  .pagination .pagination_list a,
  .pagination .pagination_list span {
    width: calc(28 * var(--min-fluid-ratio));
    height: calc(28 * var(--min-fluid-ratio));
    font-size: calc(13 * var(--min-fluid-ratio));
    transition: none;
  }

  
  .pagination .previous {
    margin-right: calc(25 * var(--min-fluid-ratio));
  }
  
  .pagination .next {
    margin-left: calc(25 * var(--min-fluid-ratio));
  }
  
  .pagination .previous a,
  .pagination .next a {
    width: calc(42 * var(--min-fluid-ratio));
    height: calc(42 * var(--min-fluid-ratio));
    border-radius: calc(4 * var(--min-fluid-ratio));
  }
  
  .pagination .previous img,
  .pagination .next img {
    width: calc(9 * var(--min-fluid-ratio));
  }
  .btn-back {
    width: 100%;
    min-height: calc(70 * var(--min-fluid-ratio));
    padding: calc(10 * var(--min-fluid-ratio)) calc(60 * var(--min-fluid-ratio));
    font-size: calc(16 * var(--min-fluid-ratio));
    box-shadow: 0px calc(1 * var(--min-fluid-ratio)) calc(15 * var(--min-fluid-ratio)) rgba(0, 0, 0, 0.1);
  }
  .btn-back::after {
    inset: 0 0 0 calc(29 * var(--min-fluid-ratio));
    background: url(../images/shared/icon-arrow-blue-left.svg) no-repeat center / calc(10 * var(--min-fluid-ratio)) auto;
    width: calc(10 * var(--min-fluid-ratio));
    height: calc(18 * var(--min-fluid-ratio));
  }
  .pagination .btn-back {
    margin-top: calc(60 * var(--min-fluid-ratio));
  }
}



/*------------------------------------------
  
  pagination / ページネーション

  WPページネーションに調整
  
------------------------------------------*/ 

.pagination {
  padding-top: 80px;
  margin-top: 60px;
  border-top: 1px solid var(--line-color3);
}
.pagination .wp-pagenavi {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 8px;
  flex-shrink: 0;
  list-style-type: none;
}
.pagination .wp-pagenavi .pages{
  display: none;
}
.pagination .wp-pagenavi a,
.pagination .wp-pagenavi span {
  width: 34px;
  height: 34px;
  font-family: var(--font-zenmaru-g);
  font-size: calc(16 * var(--rem));
  display: grid;
  place-items: center;
  color: var(--text-color);
  border-radius: var(--border-rounded);
  transition: all .25s ease-in-out;
}
.pagination .wp-pagenavi .current {
  background-color: var(--line-color2);
  opacity: 1;
}
.pagination .previouspostslink {
  margin-right: 43px;
}

.pagination .nextpostslink {
  margin-left: 43px;
}

.pagination a.previouspostslink ,
.pagination a.nextpostslink {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line-color2);
  border-radius: 4px;
}
@media (hover) {
  .pagination .wp-pagenavi a:hover {
    border: 1px solid #0768D3;
    background-color: #fff;
  }

  .pagination a.previouspostslink:hover,
  .pagination a.nextpostslink:hover {
    opacity: 1;
    background-color: #fff;
  }
}



.pagination .previouspostslink img,
.pagination .nextpostslink img {
  width: 8.5px;
}


.pagination .previouspostslink ,
.pagination .nextpostslink  {
  background-repeat: no-repeat;
  background-position: center;
  background-size: 8.5px;
}
.pagination .previouspostslink {
  background-image: url(../images/shared/icon-arrow-blue-left.svg);
}
.pagination .nextpostslink {
  background-image: url(../images/shared/icon-arrow-blue-right.svg);
}

@media screen and (max-width: 1366px) {
   .pagination {
    padding-top: calc(80 * var(--max-fluid-ratio));
    margin-top: calc(60 * var(--max-fluid-ratio));
  }

  .pagination .wp-pagenavi {
    column-gap: calc(8 * var(--max-fluid-ratio));
  }
  .pagination .wp-pagenavi a,
  .pagination .wp-pagenavi span {
    width: calc(34 * var(--max-fluid-ratio));
    height: calc(34 * var(--max-fluid-ratio));
    font-size: calc(16 * var(--max-fluid-ratio));
  }
  .pagination .previouspostslink {
    margin-right: calc(43 * var(--max-fluid-ratio));
  }
  .pagination .nextpostslink {
    margin-left: calc(43 * var(--max-fluid-ratio));
  }
  .pagination a.previouspostslink,
  .pagination a.nextpostslink {
    width: calc(50 * var(--max-fluid-ratio));
    height: calc(50 * var(--max-fluid-ratio));
    border-radius: calc(4 * var(--max-fluid-ratio));
  }
  .pagination .previouspostslink img,
  .pagination .nextpostslink img {
    width: calc(8.5 * var(--max-fluid-ratio));
  }
  .pagination .previouspostslink ,
  .pagination .nextpostslink  {
      background-size: calc(8.5 * var(--max-fluid-ratio));
  }
}

@media screen and (max-width: 767px) {
  .pagination {
    padding-top: calc(45 * var(--min-fluid-ratio));
    margin-top: 0;
  }
  .pagination .wp-pagenavi {
    column-gap: calc(10 * var(--min-fluid-ratio));
  }
  .pagination .wp-pagenavi a,
  .pagination .wp-pagenavi span {
    width: calc(28 * var(--min-fluid-ratio));
    height: calc(28 * var(--min-fluid-ratio));
    font-size: calc(13 * var(--min-fluid-ratio));
    transition: none;
  }
  .pagination .previouspostslink {
    margin-right: calc(25 * var(--min-fluid-ratio));
  }
  .pagination .nextpostslink {
    margin-left: calc(25 * var(--min-fluid-ratio));
  }
  .pagination a.previouspostslink,
  .pagination a.nextpostslink {
    width: calc(42 * var(--min-fluid-ratio));
    height: calc(42 * var(--min-fluid-ratio));
    border-radius: calc(4 * var(--min-fluid-ratio));
  }
  
  .pagination .previouspostslink img,
  .pagination .nextpostslink img {
    width: calc(9 * var(--min-fluid-ratio));
  }
  .pagination .previouspostslink ,
  .pagination .nextpostslink  {
      background-size: calc(9 * var(--min-fluid-ratio));
  }
}
