@charset "UTF-8";
#navi {
  display: block;
  position: fixed;
  top: 0;
  right: -420px;
  bottom: 0;
  max-width: 420px;
  width: 100%;
  color: #fff;
  background-color: #F7F7F7;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transition: all .5s;
  z-index: 999;
  opacity: 0; }
  @media (min-width: 1024px) {
    #navi {
      padding: 20px 25px 60px 30px; } }
  #navi .sp-logo-title {
    margin: 20px 0 0 10px; }
    @media (min-width: 768px) {
      #navi .sp-logo-title {
        display: none; } }
    #navi .sp-logo-title a img {
      width: 130px; }
    #navi .sp-logo-title h3 {
      font-size: 0.6em;
      font-weight: 900;
      color: #BC1B21;
      margin: 10px 0 0 0; }
      @media (min-width: 1024px) {
        #navi .sp-logo-title h3 {
          font-size: 1.0em; } }
  #navi nav {
    padding-left: 30px;
    /*アコーディオン全体*/ }
    #navi nav ul.accordion-area {
      list-style: none;
      color: #000;
      margin-top: 20px; }
      @media (min-width: 768px) {
        #navi nav ul.accordion-area {
          margin-top: 60px; } }
      #navi nav ul.accordion-area li {
        opacity: 0;
        padding: 10px 0 10px 0;
        font-size: 1.125em;
        font-weight: 700;
        /*アコーディオンタイトル*/ }
        @media (min-width: 1024px) {
          #navi nav ul.accordion-area li {
            font-size: 1.35em;
            padding: 15px 0 15px 0; } }
        #navi nav ul.accordion-area li a {
          position: relative; }
          #navi nav ul.accordion-area li a:hover {
            color: #BC1B21; }
        #navi nav ul.accordion-area li .title {
          font-size: 1.0em;
          font-weight: 700;
          position: relative;
          cursor: pointer;
          transition: all .5s ease; }
          #navi nav ul.accordion-area li .title::before, #navi nav ul.accordion-area li .title::after {
            position: absolute;
            content: '';
            width: 20px;
            height: 2px;
            background-color: #000; }
          #navi nav ul.accordion-area li .title::before {
            top: 50%;
            right: 30px;
            transform: rotate(0deg); }
          #navi nav ul.accordion-area li .title::after {
            top: 50%;
            right: 30px;
            transform: rotate(90deg); }
          #navi nav ul.accordion-area li .title.close::before {
            transform: rotate(45deg); }
          #navi nav ul.accordion-area li .title.close::after {
            transform: rotate(-45deg); }
        #navi nav ul.accordion-area li .box-1 {
          display: none;
          /*はじめは非表示*/ }
          #navi nav ul.accordion-area li .box-1 ul.menu {
            margin: 5px 10px 0 0; }
            @media (min-width: 768px) {
              #navi nav ul.accordion-area li .box-1 ul.menu {
                margin: 0 10px 0 0; } }
            #navi nav ul.accordion-area li .box-1 ul.menu li {
              padding: 0px 0; }
              #navi nav ul.accordion-area li .box-1 ul.menu li a {
                font-size: 0.75em;
                font-weight: 500;
                letter-spacing: 0.05em;
                position: relative; }
                @media (min-width: 768px) {
                  #navi nav ul.accordion-area li .box-1 ul.menu li a {
                    font-size: 0.6em; } }
                #navi nav ul.accordion-area li .box-1 ul.menu li a:hover {
                  color: #BC1B21; }
          #navi nav ul.accordion-area li .box-1 ul.entry li {
            display: flex;
            margin-bottom: 10px; }
            #navi nav ul.accordion-area li .box-1 ul.entry li a img {
              width: 90%; }
          #navi nav ul.accordion-area li .box-1 ul.entry li.line-entry {
            padding-right: 5%;
            margin-top: 20px; }
            #navi nav ul.accordion-area li .box-1 ul.entry li.line-entry a {
              display: flex;
              align-items: center;
              justify-content: center;
              background-color: #06C755;
              border-radius: 10px;
              width: 100%;
              padding: 8px; }
              #navi nav ul.accordion-area li .box-1 ul.entry li.line-entry a:first-child {
                margin-right: 5%; }
              #navi nav ul.accordion-area li .box-1 ul.entry li.line-entry a img {
                width: 25px;
                margin-right: 5px; }
              #navi nav ul.accordion-area li .box-1 ul.entry li.line-entry a p {
                font-size: 0.75em;
                font-weight: bold;
                color: #fff; }
    #navi nav .menu-shita {
      margin-top: 30px;
      padding-bottom: 40px;
      opacity: 0; }
      @media (min-width: 768px) {
        #navi nav .menu-shita {
          padding-bottom: 0; } }
      #navi nav .menu-shita .common-btn-type2:first-child {
        margin-bottom: 20px; }

.open #navi {
  right: 0;
  opacity: 1; }

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

#navi.panelactive ul li {
  animation: fadeInRight1 0.5s ease forwards;
  animation-delay: .5s; }
  #navi.panelactive ul li:nth-of-type(2) {
    animation-delay: .55s; }
  #navi.panelactive ul li:nth-of-type(3) {
    animation-delay: .60s; }
  #navi.panelactive ul li:nth-of-type(4) {
    animation-delay: .65s; }
  #navi.panelactive ul li:nth-of-type(5) {
    animation-delay: .70s; }
  #navi.panelactive ul li:nth-of-type(6) {
    animation-delay: .75s; }
  #navi.panelactive ul li:nth-of-type(7) {
    animation-delay: .80s; }
  #navi.panelactive ul li:nth-of-type(8) {
    animation-delay: .85s; }

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

@keyframes fadeInRight2 {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
