@charset "utf-8";
/* CSS Document */

@media screen and (max-width: 768px) {


    header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:1000;
    font-family: zen-maru-gothic, sans-serif;
    font-style: normal;
    font-weight:500;
  }

  header .inner{
    display:flex;
    justify-content:space-between;
    align-items:center;
    height:70px;
    padding:0 16px;
  }

  header .logo img{
    width:auto;
    height:50px;
  }

  header .inner-title{
    display:none;
  }

  .toggle_btn{
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    width:40px;
    height:40px;
    background:#1F3C88;
    border:none;
    border-radius:999px;
    cursor:pointer;
    z-index:3000;
    box-shadow:0 4px 10px rgba(0,0,0,0.2);
    gap:5px; 
  }

  .toggle_btn span{
  width:20px;
  height:2px;
  background:#fff;
  border-radius:999px;
  transition:
    transform 0.3s ease,
    opacity 0.2s ease;
  transform-origin:center;
}

#navArea.open .toggle_btn span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
  margin: 0;
}

#navArea.open .toggle_btn span:nth-child(2){
  opacity:0;
}

#navArea.open .toggle_btn span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
  margin:0;
}

  #navArea{
    position:relative;
    z-index:1100;
  }

  /* ここを強めに固定 */
  #navArea nav{
    display:block !important;
    position:fixed;
    top:0;
    right:0;
    width:240;
    height:auto;
    opacity:0;
    visibility:hidden;
    transform:translateX(20px);
    transition:
      transform 0.25s ease,
      opacity 0.25s ease,
      visibility 0.25s ease;
    z-index:2500;
    pointer-events:none;
  }

#navArea.open nav{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}

#navArea .menu{
  background:#1F3C88;
  border-radius:0 0 0 16px;
  padding:60px 0 16px;
  min-height:200px;
  box-shadow:0 12px 30px rgba(0,0,0,0.2);
}

  /* ここもPC用を完全に潰す */
  #navArea .menu ul{
    display:flex !important;
    flex-direction:column !important;
    gap:0 !important;
    list-style:none;
    padding:0;
    margin:0;
  }

  #navArea .menu li{
    display:block;
    width:100%;
  }

  #navArea .menu a{
    display:block !important;
    width:100%;
    box-sizing:border-box;
    padding:7px 15px;
    color:#fff;
    text-decoration:none;
    font-size:12px;
    margin:5px 0 ;
  }

  #navArea .menu a:hover{
    background:rgba(255,255,255,0.08);
  }

  #navArea .menu li.join{
    padding:5px 20px;
  }

  #navArea .menu li.join a{
    background:#F20C0C;
    border-radius:999px;
    text-align:center;
  }

  header .menu li.join a:hover{
  background:#FF2E2E;
  transform:translateY(-2px)scale(1.005);
  box-shadow:0 6px 16px rgba(0,0,0,0.25);
}

/* 押したとき */
header .menu li.join a:active{
 background:#ff3b3b;
  transform:translateY(1px) scale(0.99);
  box-shadow:0 1px 3px rgba(0,0,0,0.2);
}

  .nav-indicator{
    display:none !important;
  }

  .menu-overlay{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.35);
    opacity:0;
    visibility:hidden;
    transition:0.25s;
    z-index:900;
  }

  .menu-overlay.show{
    opacity:1;
    visibility:visible;
  }














footer{
    background-color: #1F3C88;
    color:#FFFFFF;
    text-align: center;
    padding:2rem 5% 1rem;
    font-family: zen-maru-gothic, sans-serif;
    font-style: normal;
    font-weight:500;
}

footer .grid{
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 1fr;
}

footer .pages{
    grid-row-start: 1;
    grid-row-end: 2;
    align-items: center;
}

footer .socialmedia{
    grid-row-start: 2;
    grid-row-end: 3;
}

footer a:hover{
    color:#DCE6FF;
    opacity: 0.7;
    text-decoration: none;
}

footer ul li{
    list-style-type: none;
    margin: 0.75rem 0;
    font-size: 12px;
    font-weight: 600;
}

footer ul{
    padding:0;
}

footer ul a{
    color:#FFFFFF;
}


footer .official{
    font-size: 16px;
    font-weight:700;
    border-bottom: 1px #FFFFFF solid;
    margin-bottom: 1rem;
    padding-bottom: 3px;
    width:90%;
    margin-left:auto;
    margin-right:auto;
}

footer .socialmedia li{
    font-size: 12px;
    font-weight: 600;
}

footer ul{
    margin-bottom:2.5rem;
}


footer .line{
    vertical-align: middle;
}


footer li.line{
  display: flex;
  align-items: center;
  justify-content:center;
  gap:8px;
}

footer .hakumon{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:60px;
}

footer img{
    height:25px;
    width:auto;
}



footer .website a{
    color:#FFFFFF;
    font-size: 14px;
    font-weight:600;
}

footer .website{
    margin: 5rem 0 0;
}



footer .copyright{
    margin-top: 3.5rem;
    font-size: 10px;
    color:#FFFFFF;
}



    
}