@charset "UTF-8";
#header {
  position: relative;
  /*メニュー押した後のアニメーション*/ }
  #header .openbtn {
    position: fixed;
    top: 10px;
    right: 10px;
    background-color: #fff;
    cursor: pointer;
    width: 60px;
    height: 60px;
    z-index: 1000;
    border-radius: 10px;
    /*activeクラスが付与されると線が回転して×に*/ }
    @media (min-width: 768px) {
      #header .openbtn {
        top: 20px;
        right: 20px;
        width: 70px;
        height: 70px; } }
    #header .openbtn.active {
      background-color: rgba(255, 255, 255, 0); }
    #header .openbtn img {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      width: 70px; }
    #header .openbtn span {
      display: inline-block;
      transition: all .4s;
      /*アニメーションの設定*/
      position: absolute;
      left: 15px;
      width: 30px;
      height: 2px;
      border-radius: 2px;
      background: #000; }
      @media (min-width: 768px) {
        #header .openbtn span {
          left: 17px;
          width: 36px; } }
      #header .openbtn span:nth-child(1) {
        top: 18px; }
        @media (min-width: 768px) {
          #header .openbtn span:nth-child(1) {
            top: 20px; } }
      #header .openbtn span:nth-child(2) {
        top: 26px; }
        @media (min-width: 768px) {
          #header .openbtn span:nth-child(2) {
            top: 28px; } }
      #header .openbtn span:nth-child(3) {
        top: 33px; }
        @media (min-width: 768px) {
          #header .openbtn span:nth-child(3) {
            top: 36px; } }
      #header .openbtn span:nth-of-type(3)::after {
        content: "MENU";
        position: absolute;
        top: 3px;
        left: 0;
        font-size: 0.65em;
        text-transform: uppercase; }
        @media (min-width: 768px) {
          #header .openbtn span:nth-of-type(3)::after {
            font-size: 0.8em; } }
    #header .openbtn.active span:nth-of-type(1) {
      top: 20px;
      left: 16px;
      transform: translateY(6px) rotate(-45deg);
      width: 30px; }
      @media (min-width: 768px) {
        #header .openbtn.active span:nth-of-type(1) {
          top: 22px;
          left: 20px; } }
    #header .openbtn.active span:nth-of-type(2) {
      opacity: 0;
      /*真ん中の線は透過*/ }
    #header .openbtn.active span:nth-of-type(3) {
      top: 32px;
      left: 16px;
      transform: translateY(-6px) rotate(45deg);
      width: 30px; }
      @media (min-width: 768px) {
        #header .openbtn.active span:nth-of-type(3) {
          top: 34px;
          left: 20px; } }
    #header .openbtn.active span:nth-of-type(3)::after {
      content: "CLOSE";
      transform: translateY(0) rotate(-45deg);
      top: 7px;
      left: 11.5px; }
      @media (min-width: 768px) {
        #header .openbtn.active span:nth-of-type(3)::after {
          top: 8px;
          left: 10px; } }
  #header .overlay {
    position: fixed;
    background-color: #F0F1EC;
    top: 0;
    transition: all .3s ease-in-out;
    overflow: hidden;
    z-index: 200;
    width: 100%;
    display: none; }
    #header .overlay .headerlogo {
      margin: 15px auto 0;
      width: 250px;
      position: fixed;
      z-index: 10;
      top: 0;
      left: 5%; }
      @media (min-width: 1024px) {
        #header .overlay .headerlogo {
          margin: 15px auto 0 0; } }
    #header .overlay.open {
      display: block;
      visibility: visible;
      height: 100vh;
      overflow: scroll; }
    #header .overlay .sp-menu {
      position: absolute;
      bottom: 5%;
      right: 0;
      max-width: 650px;
      width: 90%; }
      #header .overlay .sp-menu nav {
        margin-top: 40px; }
        #header .overlay .sp-menu nav ul {
          list-style: none; }
          #header .overlay .sp-menu nav ul li {
            position: relative;
            opacity: 0;
            padding: 20px 0;
            border-top: 1px solid rgba(0, 0, 0, 0.6); }
            #header .overlay .sp-menu nav ul li:first-child {
              border-top: none; }
            #header .overlay .sp-menu nav ul li:last-child {
              border-bottom: 1px solid rgba(255, 255, 255, 0); }
            #header .overlay .sp-menu nav ul li h3 {
              font-size: 1.6em;
              font-weight: 700; }
              @media (min-width: 768px) {
                #header .overlay .sp-menu nav ul li h3 {
                  font-size: 2em; } }
            #header .overlay .sp-menu nav ul li a {
              display: block;
              text-decoration: none;
              color: #000;
              transition: all .3s;
              display: flex; }
              #header .overlay .sp-menu nav ul li a:hover {
                color: #58A52C; }
              #header .overlay .sp-menu nav ul li a h4 {
                font-size: 0.8em;
                font-weight: 700;
                margin: 13px 0 0 10px; }
                @media (min-width: 768px) {
                  #header .overlay .sp-menu nav ul li a h4 {
                    font-size: 1.125em;
                    margin: 15px 0 0 10px; } }
      #header .overlay .sp-menu p {
        font-size: 0.7em;
        color: #000;
        margin-top: 20px;
        opacity: 0; }
  #header .overlay.open h2 {
    animation: fadeInNav 0.5s ease forwards;
    animation-delay: .40s; }
@keyframes fadeInNav {
  0% {
    opacity: 0;
    transform: translateY(0); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
  #header .overlay.open .sp-menu nav ul li {
    animation: fadeInRight1 0.5s ease forwards;
    animation-delay: .45s; }
    #header .overlay.open .sp-menu nav ul li:nth-of-type(2) {
      animation-delay: .55s; }
    #header .overlay.open .sp-menu nav ul li:nth-of-type(3) {
      animation-delay: .65s; }
    #header .overlay.open .sp-menu nav ul li:nth-of-type(4) {
      animation-delay: .75s; }
    #header .overlay.open .sp-menu nav ul li:nth-of-type(5) {
      animation-delay: .85s; }
    #header .overlay.open .sp-menu nav ul li:nth-of-type(6) {
      animation-delay: .90s; }
    #header .overlay.open .sp-menu nav ul li:nth-of-type(7) {
      animation-delay: .95s; }
@keyframes fadeInRight1 {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
  #header .overlay.open .radio-menu {
    animation: fadeInRight1 0.5s ease forwards;
    animation-delay: .85s; }
@keyframes fadeInRight1 {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
  #header .overlay.open .menu-type2 {
    animation: fadeInp 0.5s ease forwards;
    animation-delay: .80s; }
  #header .overlay.open p {
    animation: fadeInp 0.5s ease forwards;
    animation-delay: .90s; }
@keyframes fadeInp {
  0% {
    opacity: 0;
    transform: translateY(0); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
