@charset "UTF-8";
#navi {
  display: block;
  position: fixed;
  top: 0;
  right: -420px;
  bottom: 0;
  max-width: 420px;
  width: 100%;
  color: #fff;
  padding: 10px 25px 20px;
  background-color: #222324;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transition: all .5s;
  z-index: 999;
  opacity: 0; }
  @media (min-width: 768px) {
    #navi {
      padding: 10px 20px 20px;
      max-width: 300px; } }
  #navi nav {
    /*アコーディオン全体*/ }
    #navi nav .header-logo {
      margin: 10px 0 0 0;
      transition: .5s; }
      @media (min-width: 768px) {
        #navi nav .header-logo {
          margin: 20px 0 0 0; } }
      #navi nav .header-logo a img {
        width: 240px;
        transition: .5s; }
        @media (min-width: 768px) {
          #navi nav .header-logo a img {
            width: 200px; } }
      #navi nav .header-logo h3 {
        font-size: 0.8em;
        margin-top: 4px; }
        @media (min-width: 768px) {
          #navi nav .header-logo h3 {
            font-size: 0.7em; } }
    #navi nav .pcsp-menu {
      margin: 40px 0 0 0; }
      @media (min-width: 768px) {
        #navi nav .pcsp-menu {
          margin: 60px 0 0 0; } }
    #navi nav ul.accordion-area {
      list-style: none; }
      #navi nav ul.accordion-area li {
        opacity: 0;
        margin-bottom: 20px; }
        #navi nav ul.accordion-area li:last-child {
          margin-bottom: 40px; }
        #navi nav ul.accordion-area li a {
          font-size: 1.125em;
          font-weight: 700;
          color: #fff;
          transition: .5s; }
          @media (min-width: 1024px) {
            #navi nav ul.accordion-area li a {
              font-size: 1.5em; } }
    #navi nav ul.menu-shita {
      padding-bottom: 40px;
      opacity: 0; }
      #navi nav ul.menu-shita li {
        margin-top: 20px; }
        #navi nav ul.menu-shita li:last-child {
          margin-top: 10px; }
          #navi nav ul.menu-shita li:last-child a p {
            font-size: 0.7em;
            font-weight: normal; }
        #navi nav ul.menu-shita li a {
          display: flex; }
          #navi nav ul.menu-shita li a p {
            font-size: 0.8em;
            font-weight: 700;
            line-height: 1.2em;
            position: relative;
            color: #fff; }
            #navi nav ul.menu-shita li a p::after {
              position: absolute;
              bottom: 0;
              left: 0;
              content: '';
              width: 100%;
              height: 1px;
              background: #fff;
              transform: scale(0, 1);
              transform-origin: right top;
              transition: transform .3s; }
            #navi nav ul.menu-shita li a p:hover::after {
              transform-origin: left top;
              transform: scale(1, 1); }
          #navi nav ul.menu-shita li a img {
            width: 14px;
            margin-left: 10px; }
    #navi nav .sns-logo {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 40px;
      opacity: 0; }
      #navi nav .sns-logo ul {
        display: flex; }
        #navi nav .sns-logo ul li {
          position: relative;
          margin-right: 10px; }
          #navi nav .sns-logo ul li:last-child {
            margin-right: 0; }
          #navi nav .sns-logo ul li a:hover img:first-child {
            opacity: 0.0; }
          #navi nav .sns-logo ul li a img {
            width: 30px;
            transition: .5s; }
            @media (min-width: 1250px) {
              #navi nav .sns-logo ul li a img {
                width: 36px; } }
            #navi nav .sns-logo ul li a img:nth-child(2) {
              position: absolute;
              top: 0;
              left: 0;
              z-index: -1; }
    #navi nav .mynavi {
      margin-top: 12px;
      opacity: 0; }
      #navi nav .mynavi a {
        position: relative;
        background-color: #fff;
        border-radius: 50px;
        width: 100%;
        height: 60px;
        display: flex;
        align-items: center;
        margin: auto;
        justify-content: center;
        text-align: center;
        color: #000; }
        #navi nav .mynavi a:hover img {
          right: 10px; }
        #navi nav .mynavi a h3 {
          font-size: 1.0em;
          line-height: 1.4em; }
        #navi nav .mynavi a img {
          width: 18px;
          position: absolute;
          top: 0;
          bottom: 0;
          right: 10px;
          display: flex;
          height: 100%;
          transition: .5s; }
    #navi nav ul.privacy-btn {
      margin-top: 16px;
      opacity: 0; }
      #navi nav ul.privacy-btn li {
        text-align: center; }
        #navi nav ul.privacy-btn li a {
          font-size: 0.8em;
          color: #fff; }

.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); } }
#navi.panelactive .mynavi {
  animation: fadeInRight3 0.5s ease forwards;
  animation-delay: 1.0s; }

#navi.panelactive .privacy-btn {
  animation: fadeInRight3 0.5s ease forwards;
  animation-delay: 1.0s; }

#navi.panelactive .sns-logo {
  animation: fadeInRight3 0.5s ease forwards;
  animation-delay: 1.0s; }

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