@charset "UTF-8";

:root{
  --font-gothic:"Noto Sans JP", "メイリオ", "Hiragino Kaku Gothic ProN", sans-serif;
  --font-en:montserrat, arial, sans-serif;
  --color:#231815;
  --noscript:2000;
  --dialog:1001;
  --modalbackdrop:1000;
}

:lang(en){
  font-family:var(--font-en);
}

.is-focus,
:focus:not(:focus-visible){
  outline:0;
}

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

html{
  height:100%;
  font-family:var(--font-gothic);
  font-size:0.625em;
  scroll-behavior:smooth;
  scroll-padding-top:64px;
  -webkit-text-size-adjust:100%;
          text-size-adjust:100%;
}

html::after{
    display:block;
    content:"";
    position:fixed;
    z-index:-1;
    inset:0;
    margin:auto;
    background-color:rgba(0, 0, 0, 0.5);
    visibility:hidden;
    opacity:0;
    transition:visibility 0.3s, opacity 0.3s;
  }

html.is-modal{
    overflow:hidden;
  }

html.is-modal::after{
      z-index:var(--modalbackdrop);
      visibility:visible;
      opacity:1;
    }

body{
  margin:auto;
  min-width:320px;
  max-width:2000px;
  font-size:1.1rem;
  line-height:2.09091;
  color:var(--color);
  background-color:#fff;
}

html.is-modal body{
    overflow:hidden;
  }

main{
  display:block;
}

h1,
h2,
h3,
h4,
h5,
h6{
  font-size:2rem;
  font-weight:400;
  line-height:inherit;
}

figure,
p{
  margin:0;
}

ul,
ol{
  padding:0;
  list-style:none;
}

dl dt,dl dd{
    padding:0;
    margin:0;
  }

ul ul,
ul ol,
ol ol,
ol dl,
dl ol,
dl ul,
dl dl{
  margin:0;
}

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

table th,table td{
    word-break:break-all;
  }

em{
  font-style:normal;
  font-weight:700;
}

strong{
  font-style:normal;
  font-weight:700;
}

small,
kbd,
samp{
  font-family:inherit;
}

code{
  color:var(--color);
  -webkit-user-select:all;
          user-select:all;
}

abbr[title]{
  text-decoration:none;
}

address{
  font-style:normal;
}

img{
  max-width:100%;
  height:auto;
  border-style:none;
}

:link,
:visited{
  color:#0042a0;
  text-decoration:underline;
}

a{
  word-break:break-all;
}

a:not([href],
[role="button"]){
  cursor:default;
  text-decoration:none;
}

[href^="tel:"]{
  pointer-events:none;
  text-decoration:none;
  word-break:break-word;
}

button,
input[type="button"],
input[type="submit"],
input[type="reset"],
[role="button"]:not([aria-disabled="true"]),
[role="tab"]:not([aria-selected="true"]){
  cursor:pointer;
}

button{
  overflow:visible;
  padding:0;
  border:0;
  margin:auto;
  background:transparent;
  color:inherit;
  font-family:inherit;
  font-size:inherit;
  line-height:inherit;
  word-break:break-all;
}

button:disabled,button[aria-disabled="true"]{
    cursor:default;
  }

::placeholder{
  opacity:1;
}

iframe{
  border:0;
}

.l-header{
  position:fixed;
  top:10px;
  left:10px;
  right:10px;
  z-index:1001;
  border-radius:10px;
  margin:0 auto;
  max-width:1516px;
  background-color:#fff;
  container:header / inline-size;
}

.l-header__inner{
  display:grid;
  align-items:center;
}

.l-headerLogo{
  display:inline-block;
  line-height:1;
  vertical-align:middle;
}

.l-headerLogo  > img{
    vertical-align:bottom;
  }

.l-headerSlogan{
  line-height:1;
}

.l-headerSlogan  > img{
    vertical-align:bottom;
  }

.l-headerToc__list{
  margin:0;
}

.l-headerToc__link{
  align-items:center;
  position:relative;
  font-weight:700;
  color:#000;
}

.l-headerToc__link::after{
    display:block;
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    margin:auto;
  }

@media (min-width: 768px){
  html{
    height:100%;
    scroll-padding-top:74px;
  }
  body{
    font-size:1.6rem;
    line-height:2.0625;
  }
  .l-header{
    padding:12px 33px 12px 25px;
  }
  .l-header__inner{
    grid-template-columns:max-content 1fr max-content;
    gap:30px;
  }
  .l-header__areaLogo{
    grid-column:1 / 2;
    grid-row:1 / 2;
  }
  .l-header__areaSlogan{
    grid-column:3 / 4;
    grid-row:1 / 2;
  }
  .l-header__areaToc{
    grid-column:2 / 3;
    grid-row:1 / 2;
    justify-self:end;
  }
    @container header (max-width: 920px){
  .l-headerLogo{
      max-width:84px;
  }
    }
  .l-headerToc__list{
    display:flex;
    gap:10px;
  }
  .l-headerToc__link{
    display:inline-flex;
    justify-content:center;
    border:1px solid #E3E3E3;
    border-radius:9em;
    padding:0 40px;
    min-width:175px;
    min-height:40px;
    font-size:1.4rem;
    text-align:center;
    background-color:#FFFFFF;
  }
    .l-headerToc__link::after{
      right:17px;
      width:14px;
      height:8px;
      background:url(../img/bg_l-headerToc__link_pc.svg) no-repeat;
    }
    @container header (max-width: 920px){
  .l-headerToc__link{
      padding:0 30px 0 15px;
      min-width:auto;
  }
      .l-headerToc__link::after{
        right:10px;
      }
    }
}

@media (min-width: 768px) and (scripting: enabled){
  .l-header__areaHamburgerButton{
    display:none;
  }
}

@media (max-width: 767px){
  .l-header__inner{
    grid-template-columns:max-content 1fr;
  }
  .l-header__areaLogo{
    grid-column:1 / 2;
    grid-row:1 / 2;
    padding:12px 0 12px 12px;
  }
  .l-header__areaSlogan{
    grid-column:2 / 3;
    grid-row:1 / 2;
    justify-self:end;
    padding:0 15px;
  }
  .l-header__areaToc{
    grid-column:1 / 3;
    grid-row:2 / 3;
  }
  .l-headerLogo{
    max-width:84px;
  }
  .l-headerToc__list{
    border-top:1px solid #E6E6E6;
    padding:5px 24px;
    font-size:1.6rem;
  }
    .l-headerToc__item:not(:last-child){
      border-bottom:1px solid #E6E6E6;
    }
  .l-headerToc__link{
    display:flex;
    padding:25px 24px 25px 6px;
  }
    .l-headerToc__link::after{
      right:7px;
      width:16px;
      height:10px;
      background:url(../img/bg_l-headerToc__link_sp.svg) no-repeat;
    }
}

@media (max-width: 767px) and (scripting: enabled){
  .l-header__inner{
    grid-template-columns:max-content 1fr max-content;
  }
  .l-header__areaHamburgerButton{
    grid-column:3 / 4;
    grid-row:1 / 2;
  }
  .l-header__areaToc{
    grid-column:1 / 4;
  }
  .l-headerHamburgerButton{
    position:relative;
    border-radius:0 10px 10px 0;
    min-width:54px;
    min-height:54px;
    vertical-align:bottom;
    background-color:#F5F5F5;
    overflow:hidden;
    transition:all 0.5s;
  }
    .l-headerHamburgerButton::before,.l-headerHamburgerButton::after{
      display:block;
      content:"";
      position:absolute;
      inset:0;
      border-radius:9em;
      margin:auto;
      width:26px;
      height:3px;
      background-color:#0075C1;
      transition:all 0.5s;
    }
    .l-headerHamburgerButton::before{
      transform:translateY(-10px);
    }
    .l-headerHamburgerButton::after{
      transform:translateY(10px);
    }
    .l-headerHamburgerButton[aria-expanded="true"]{
      border-radius:0 10px 0 0;
    }
      .l-headerHamburgerButton[aria-expanded="true"]::before{
        transform:rotate(-45deg);
      }
      .l-headerHamburgerButton[aria-expanded="true"]::after{
        transform:rotate(45deg);
      }
    .l-headerHamburgerButton__inner::after{
      display:block;
      content:"";
      position:absolute;
      inset:0;
      border-radius:9em;
      margin:auto;
      width:26px;
      height:3px;
      background-color:#0075C1;
      transition:all 0.5s;
    }
      :is(.l-headerHamburgerButton[aria-expanded="true"] .l-headerHamburgerButton__inner)::after{
        opacity:0;
      }
  .l-headerHamburgerButton__label,
.js-hamburgerMenu__state{
    position:absolute;
    z-index:-1;
  }
  .js-hamburgerMenu{
    overflow:hidden;
    height:0;
    opacity:0;
    visibility:hidden;
    transition:height 0.5s, opacity 0.5s, visibility 0.5s;
  }
    .js-hamburgerMenu.is-open{
      overflow:auto;
      height:auto;
      opacity:1;
      visibility:visible;
    }
}

@media (hover: hover){
    :is(:link,:visited):hover{
      text-decoration:none;
    }
    .l-headerToc__link:any-link{
      color:currentColor;
      text-decoration:none;
      transition:opacity 0.5s;
    }
      .l-headerToc__link:any-link:hover{
        opacity:0.7;
      }
}
