@charset "UTF-8";
.openbtn {
  position: fixed;
  top: 0;
  right: 0;
  cursor: pointer;
  width: 60px;
  height: 60px;
  background-color: #0BB3B1;
  border-bottom-left-radius: 10px;
  z-index: 1000;
  transition: .5s; }
  @media (min-width: 768px) {
    .openbtn {
      right: 10px;
      top: 10px;
      border-radius: 5px; } }
  @media (min-width: 1250px) {
    .openbtn {
      right: 20px;
      top: 20px; } }
  .openbtn span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 17px;
    height: 3px;
    background: #fff;
    width: 26px; }
    .openbtn span:nth-of-type(1) {
      top: 20px; }
    .openbtn span:nth-of-type(2) {
      top: 29px; }
    .openbtn span:nth-of-type(3) {
      top: 38px; }
  .openbtn.active span:nth-of-type(1) {
    top: 22px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 40%; }
  .openbtn.active span:nth-of-type(2) {
    opacity: 0; }
  .openbtn.active span:nth-of-type(3) {
    top: 34px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 40%; }

#sp-nav {
  display: block;
  position: fixed;
  top: 0;
  right: -420px;
  bottom: 0;
  max-width: 420px;
  width: 100%;
  padding: 10px 15px 20px 10px;
  background-color: #F4F4F4;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transition: all .5s;
  z-index: 999;
  /*アコーディオン全体*/ }
  @media (min-width: 768px) {
    #sp-nav {
      padding: 10px 15px 20px 40px; } }
  @media (min-width: 1110px) {
    #sp-nav {
      display: none; } }
  #sp-nav .header-logo a {
    display: flex;
    align-items: center; }
    #sp-nav .header-logo a img {
      width: 110px; }
    #sp-nav .header-logo a .txt {
      margin: 5px 0 0 10px;
      color: #7D7775; }
      #sp-nav .header-logo a .txt h4 {
        font-size: 0.6em; }
      #sp-nav .header-logo a .txt h3 {
        font-size: 1.0em; }
  #sp-nav .pcsp-menu {
    margin: 40px 0 0 20px; }
    @media (min-width: 768px) {
      #sp-nav .pcsp-menu {
        margin: 40px 0 0 0; } }
  #sp-nav ul.accordion-area {
    list-style: none;
    color: #000; }
    #sp-nav ul.accordion-area li {
      opacity: 0;
      /*アコーディオンタイトル*/ }
      #sp-nav ul.accordion-area li:last-child {
        margin-bottom: 18px; }
      #sp-nav ul.accordion-area li .title {
        font-size: 1.125em;
        font-weight: 700;
        color: #000;
        position: relative;
        cursor: pointer;
        padding: 12px 0 12px 0;
        transition: all .5s ease;
        transition: .5s; }
        @media (min-width: 1024px) {
          #sp-nav ul.accordion-area li .title {
            font-size: 1.5em; } }
        #sp-nav ul.accordion-area li .title::before, #sp-nav ul.accordion-area li .title::after {
          position: absolute;
          content: '';
          width: 15px;
          height: 2px;
          background-color: #000; }
        #sp-nav ul.accordion-area li .title::before {
          top: 50%;
          right: 15px;
          transform: rotate(0deg); }
        #sp-nav ul.accordion-area li .title::after {
          top: 50%;
          right: 15px;
          transform: rotate(90deg); }
        #sp-nav ul.accordion-area li .title.close::before {
          transform: rotate(45deg); }
        #sp-nav ul.accordion-area li .title.close::after {
          transform: rotate(-45deg); }
      #sp-nav ul.accordion-area li .box-1 {
        display: none;
        /*はじめは非表示*/ }
        #sp-nav ul.accordion-area li .box-1 ul.menu {
          margin: 0 10px 0 0; }
          #sp-nav ul.accordion-area li .box-1 ul.menu li {
            padding: 0 0 22px 16px; }
            @media (min-width: 1024px) {
              #sp-nav ul.accordion-area li .box-1 ul.menu li {
                padding: 10px 0 10px 16px; } }
            #sp-nav ul.accordion-area li .box-1 ul.menu li a {
              font-size: 0.95em;
              font-feature-settings: "palt";
              letter-spacing: 0.04em;
              padding-left: 5px;
              color: #000;
              position: relative;
              transition: .5s; }
              @media (min-width: 1024px) {
                #sp-nav ul.accordion-area li .box-1 ul.menu li a {
                  font-size: 1.0em; } }
              #sp-nav ul.accordion-area li .box-1 ul.menu li a:hover {
                color: #E50012; }
                #sp-nav ul.accordion-area li .box-1 ul.menu li a:hover::before {
                  background-color: #E50012;
                  transform: scale(2); }
              #sp-nav ul.accordion-area li .box-1 ul.menu li a::before {
                content: "";
                position: absolute;
                left: -10px;
                top: 2px;
                bottom: 0;
                display: flex;
                margin: auto;
                width: 5px;
                height: 5px;
                background-color: #000;
                border-radius: 50%;
                transition: .5s; }
    #sp-nav ul.accordion-area li.txt {
      padding: 15px 0 15px 0; }
    #sp-nav ul.accordion-area li h3 {
      font-size: 1.125em;
      font-weight: 700; }
      @media (min-width: 1024px) {
        #sp-nav ul.accordion-area li h3 {
          font-size: 1.5em; } }
      #sp-nav ul.accordion-area li h3 a {
        position: relative;
        color: #000;
        transition: .5s; }
        #sp-nav ul.accordion-area li h3 a:hover {
          color: #E50012; }
  #sp-nav ul.btn-area {
    margin-top: 40px;
    opacity: 0; }
    #sp-nav ul.btn-area li {
      margin-bottom: 20px;
      display: flex;
      justify-content: center;
      opacity: 0; }
      #sp-nav ul.btn-area li:last-child {
        margin-bottom: 0; }

.open #sp-nav {
  right: 0;
  opacity: 1; }

.open #mask {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: .7;
  z-index: 10;
  cursor: pointer; }

#sp-nav.panelactive ul li {
  animation: fadeInRight1 0.5s ease forwards;
  animation-delay: .5s; }
  #sp-nav.panelactive ul li:nth-of-type(2) {
    animation-delay: .55s; }
  #sp-nav.panelactive ul li:nth-of-type(3) {
    animation-delay: .60s; }
  #sp-nav.panelactive ul li:nth-of-type(4) {
    animation-delay: .65s; }
  #sp-nav.panelactive ul li:nth-of-type(5) {
    animation-delay: .70s; }
  #sp-nav.panelactive ul li:nth-of-type(6) {
    animation-delay: .75s; }
  #sp-nav.panelactive ul li:nth-of-type(7) {
    animation-delay: .80s; }
  #sp-nav.panelactive ul li:nth-of-type(8) {
    animation-delay: .85s; }
  #sp-nav.panelactive ul li:nth-of-type(9) {
    animation-delay: .90s; }
  #sp-nav.panelactive ul li:nth-of-type(10) {
    animation-delay: .95s; }
  #sp-nav.panelactive ul li:nth-of-type(11) {
    animation-delay: 1s; }
  #sp-nav.panelactive ul li:nth-of-type(12) {
    animation-delay: 1.05s; }
  #sp-nav.panelactive ul li:nth-of-type(13) {
    animation-delay: 1.10s; }
  #sp-nav.panelactive ul li:nth-of-type(14) {
    animation-delay: 1.15s; }
  #sp-nav.panelactive ul li:nth-of-type(15) {
    animation-delay: 1.20s; }

@keyframes fadeInRight1 {
  0% {
    opacity: 0;
    transform: translateX(20px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
#sp-nav.panelactive .btn-area {
  animation: fadeInRight2 0.5s ease forwards;
  animation-delay: .85s; }

@keyframes fadeInRight2 {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
#sp-nav.panelactive .fuppi-oeoe {
  animation: fadeInRight3 0.5s ease forwards;
  animation-delay: 1.0s; }

@keyframes fadeInRight3 {
  0% {
    opacity: 0;
    transform: translateY(0); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
