@charset "UTF-8";
body {
  background-color: #41E2A3; }

.top .marquee .marquee__inner {
  background-color: #41E2A3; }

.header_menu a {
  background-color: #41E2A3; }

@media (hover: hover) {
  .header_menu a:hover {
    background-color: #ABFCDC; } }
/************************************/
footer {
  padding-top: 180px; }

@media (max-width: 480px) {
  footer {
    padding-top: 120px; } }
/*max-width:480px*/
/************************************/
.mv {
  background: url("../images/index/mv.svg") top center repeat-x #41E2A3;
  background-size: 29px 792px;
  position: relative;
  border-bottom: 1px solid #949494;
  padding: 80px 0 30px;
  overflow: hidden; }

@media (max-width: 1024px) {
  .mv {
    padding: 50px 0 30px; } }
/*max-width:1280px*/
/************************************************************/
.mv_box {
  background: url("../images/index/mv/mv_cloud.webp");
  background-size: contain;
  width: calc(100% - 60px);
  aspect-ratio: 1872/914;
  max-width: 1872px;
  height: auto;
  margin: 0 auto -20px;
  position: relative;
  z-index: 90;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .9s ease, transform .9s ease; }
  .mv_box.is-in {
    opacity: 1;
    transform: translateY(0); }
  .mv_box:before, .mv_box:after {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
    animation-duration: 1.6s;
    animation-timing-function: steps(1, end);
    animation-iteration-count: infinite; }
  .mv_box:before {
    background: url("../images/index/mv/mv_kira2.webp") center center no-repeat;
    background-size: contain;
    animation-name: mv_kira_before; }
  .mv_box:after {
    background: url("../images/index/mv/mv_kira1.webp") center center no-repeat;
    background-size: contain;
    animation-name: mv_kira_after; }
  .mv_box div {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0; }
    .mv_box div:before {
      position: absolute;
      content: "";
      display: block;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0; }
    .mv_box div.mv_left, .mv_box div.mv_right {
      will-change: transform; }
      .mv_box div.mv_left span, .mv_box div.mv_right span {
        position: absolute;
        display: block;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0; }
    .mv_box div.mv_left {
      z-index: 3; }
      .mv_box div.mv_left span.mv_left01 {
        background: url("../images/index/mv/mv_left_01.webp") center center no-repeat;
        background-size: contain;
        z-index: 4;
        animation: floatleft01 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left02 {
        background: url("../images/index/mv/mv_left_02.webp") center center no-repeat;
        background-size: contain;
        z-index: 3;
        animation: floatleft02 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left03 {
        background: url("../images/index/mv/mv_left_03.webp") center center no-repeat;
        background-size: contain;
        z-index: 2;
        animation: floatleft03 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left04 {
        background: url("../images/index/mv/mv_left_04.webp") center center no-repeat;
        background-size: contain;
        z-index: 1;
        animation: floatleft04 4.5s ease-in-out infinite; }
    .mv_box div.mv_right {
      animation-delay: -2.2s;
      z-index: 3; }
      .mv_box div.mv_right span.mv_right01 {
        background: url("../images/index/mv/mv_right_01.webp") center center no-repeat;
        background-size: contain;
        z-index: 4;
        animation: floatright01 4.5s ease-in-out infinite; }
      .mv_box div.mv_right span.mv_right02 {
        background: url("../images/index/mv/mv_right_02.webp") center center no-repeat;
        background-size: contain;
        z-index: 3;
        animation: floatright02 4.5s ease-in-out infinite; }
      .mv_box div.mv_right span.mv_right03 {
        background: url("../images/index/mv/mv_right_03.webp") center center no-repeat;
        background-size: contain;
        z-index: 2;
        animation: floatright03 4.5s ease-in-out infinite; }
      .mv_box div.mv_right span.mv_right04 {
        background: url("../images/index/mv/mv_right_04.webp") center center no-repeat;
        background-size: contain;
        z-index: 2;
        animation: floatright04 4.5s ease-in-out infinite; }
    .mv_box div.mv_mird, .mv_box div.mv_human {
      z-index: 2; }
      .mv_box div.mv_mird:before, .mv_box div.mv_mird:after, .mv_box div.mv_human:before, .mv_box div.mv_human:after {
        position: absolute;
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0; }
      .mv_box div.mv_mird:before, .mv_box div.mv_human:before {
        animation: swapOver 2.4s steps(1, end) infinite; }
      .mv_box div.mv_mird:after, .mv_box div.mv_human:after {
        animation: swapBase 2.4s steps(1, end) infinite; }
    .mv_box div.mv_mird:before {
      background: url("../images/index/mv/mv_mird02.webp") center center no-repeat;
      background-size: contain; }
    .mv_box div.mv_mird:after {
      background: url("../images/index/mv/mv_mird01.webp") center center no-repeat;
      background-size: contain; }
    .mv_box div.mv_human:after {
      background: url("../images/index/mv/mv_human01-2.webp") center center no-repeat;
      background-size: contain; }
    .mv_box div.mv_human:before {
      background: url("../images/index/mv/mv_human01-1.webp") center center no-repeat;
      background-size: contain; }
    .mv_box div.mv_ttl {
      background: url("../images/index/mv/mv_ttl.webp") center center no-repeat;
      background-size: contain;
      z-index: 1; }

@keyframes swapBase {
  0%, 49.999% {
    opacity: 1; }
  50%, 100% {
    opacity: 0; } }
@keyframes swapOver {
  0%, 49.999% {
    opacity: 0; }
  50%, 100% {
    opacity: 1; } }
@keyframes mv_kira_before {
  0%, 10% {
    opacity: 1; }
  40%, 60% {
    opacity: 0; }
  90%, 100% {
    opacity: 1; } }
@keyframes mv_kira_after {
  0%, 10% {
    opacity: 0; }
  40%, 60% {
    opacity: 1; }
  90%, 100% {
    opacity: 0; } }
@keyframes floatleft01 {
  0%, 100% {
    transform: translateY(0); }
  50% {
    transform: translateY(20px); } }
@keyframes floatleft02 {
  0%, 100% {
    transform: translateY(0); }
  50% {
    transform: translateY(12px); } }
@keyframes floatleft03 {
  0%, 100% {
    transform: translateY(0); }
  50% {
    transform: translateY(-12px); } }
@keyframes floatleft04 {
  0%, 100% {
    transform: translateX(0); }
  50% {
    transform: translateX(-42px); } }
@keyframes floatright01 {
  0%, 100% {
    transform: translateY(0); }
  50% {
    transform: translateY(-20px); } }
@keyframes floatright02 {
  0%, 100% {
    transform: translateY(0); }
  50% {
    transform: translateY(-12px); } }
@keyframes floatright03 {
  0%, 100% {
    transform: translateY(0); }
  50% {
    transform: translateY(12px); } }
@keyframes floatright04 {
  0%, 100% {
    transform: translateX(0); }
  50% {
    transform: translateX(12px); } }
@media (max-width: 1280px) {
  .mv_box {
    background: url("../images/index/mv/mv_cloud.webp");
    background-size: contain;
    width: calc(100% + 80px);
    margin: 0 auto -10px -40px; } }
/*max-width:1280px*/
@media (max-width: 768px) {
  .mv_box {
    background: url("../images/index/mv/sp_mv_cloud.webp");
    background-size: contain;
    width: calc(100% - 40px);
    aspect-ratio: 750/1224;
    max-width: 768px;
    height: auto;
    margin: 0 auto; }
    .mv_box:before, .mv_box:after {
      display: none; }
    .mv_box div.mv_left {
      z-index: 3; }
      .mv_box div.mv_left span.mv_left01 {
        background: url("../images/index/mv/sp_mv_left_01.webp") center center no-repeat;
        background-size: contain;
        z-index: 4;
        animation: floatleft01 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left02 {
        background: url("../images/index/mv/sp_mv_left_02.webp") center center no-repeat;
        background-size: contain;
        z-index: 3;
        animation: floatleft02 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left03 {
        background: url("../images/index/mv/sp_mv_left_03.webp") center center no-repeat;
        background-size: contain;
        z-index: 2;
        animation: floatleft03 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left04 {
        display: none; }
    .mv_box div.mv_right span.mv_right01 {
      background: url("../images/index/mv/sp_mv_right_01.webp") center center no-repeat;
      background-size: contain;
      z-index: 4;
      animation: floatright01 4.5s ease-in-out infinite; }
    .mv_box div.mv_right span.mv_right02 {
      background: url("../images/index/mv/sp_mv_right_02.webp") center center no-repeat;
      background-size: contain;
      z-index: 3;
      animation: floatright02 4.5s ease-in-out infinite; }
    .mv_box div.mv_right span.mv_right03 {
      background: url("../images/index/mv/sp_mv_right_03.webp") center center no-repeat;
      background-size: contain;
      z-index: 2;
      animation: floatright03 4.5s ease-in-out infinite; }
    .mv_box div.mv_right span.mv_right04 {
      display: none; }
    .mv_box div.mv_mird:before {
      background: url("../images/index/mv/sp_mv_mird02.webp") center center no-repeat;
      background-size: contain; }
    .mv_box div.mv_mird:after {
      background: url("../images/index/mv/sp_mv_mird01.webp") center center no-repeat;
      background-size: contain; }
    .mv_box div.mv_human {
      display: none; }
    .mv_box div.mv_ttl {
      background: url("../images/index/mv/sp_mv_ttl.webp") center center no-repeat;
      background-size: contain;
      z-index: 1; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .mv_box {
    background: url("../images/index/mv/sp_mv_cloud.webp");
    background-size: contain;
    width: calc(100% - 40px);
    aspect-ratio: 750/1224;
    max-width: 768px;
    height: auto;
    margin: 0 auto; }
    .mv_box:before, .mv_box:after {
      display: none; }
    .mv_box div.mv_left {
      z-index: 3; }
      .mv_box div.mv_left span.mv_left01 {
        background: url("../images/index/mv/sp_mv_left_01.webp") center center no-repeat;
        background-size: contain;
        z-index: 4;
        animation: floatleft01 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left02 {
        background: url("../images/index/mv/sp_mv_left_02.webp") center center no-repeat;
        background-size: contain;
        z-index: 3;
        animation: floatleft02 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left03 {
        background: url("../images/index/mv/sp_mv_left_03.webp") center center no-repeat;
        background-size: contain;
        z-index: 2;
        animation: floatleft03 4.5s ease-in-out infinite; }
      .mv_box div.mv_left span.mv_left04 {
        display: none; }
    .mv_box div.mv_right span.mv_right01 {
      background: url("../images/index/mv/sp_mv_right_01.webp") center center no-repeat;
      background-size: contain;
      z-index: 4;
      animation: floatright01 4.5s ease-in-out infinite; }
    .mv_box div.mv_right span.mv_right02 {
      background: url("../images/index/mv/sp_mv_right_02.webp") center center no-repeat;
      background-size: contain;
      z-index: 3;
      animation: floatright02 4.5s ease-in-out infinite; }
    .mv_box div.mv_right span.mv_right03 {
      background: url("../images/index/mv/sp_mv_right_03.webp") center center no-repeat;
      background-size: contain;
      z-index: 2;
      animation: floatright03 4.5s ease-in-out infinite; }
    .mv_box div.mv_right span.mv_right04 {
      display: none; }
    .mv_box div.mv_mird {
      transform: scale(1.1) translateY(20px);
      transform-origin: center center; }
      .mv_box div.mv_mird:before {
        background: url("../images/index/mv/sp_mv_mird02.webp") center center no-repeat;
        background-size: contain; }
      .mv_box div.mv_mird:after {
        background: url("../images/index/mv/sp_mv_mird01.webp") center center no-repeat;
        background-size: contain; }
    .mv_box div.mv_human {
      display: none; }
    .mv_box div.mv_ttl {
      background: url("../images/index/mv/sp_mv_ttl.webp") center center no-repeat;
      background-size: contain;
      z-index: 1;
      transform: scale(1.1) translateY(20px);
      transform-origin: center center; } }
/*max-width:480px*/
/**********************************/
.frame {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 10;
  pointer-events: none;
  top: 0;
  left: 0; }
  .frame:before {
    width: calc(100% - 60px);
    height: calc(100% - 60px);
    position: absolute;
    content: "";
    display: block;
    border: 1px solid #949494;
    border-top: none;
    left: 30px;
    top: 30px; }
  .frame .marquee {
    position: absolute;
    overflow: hidden; }
    .frame .marquee .marquee__inner {
      background-color: #41E2A3;
      display: flex;
      width: 200%;
      height: 100%;
      animation: marqueeX 60s linear infinite reverse;
      will-change: transform;
      pointer-events: none; }
      .frame .marquee .marquee__inner span {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center; }
      .frame .marquee .marquee__inner img {
        display: block;
        object-fit: contain; }
    .frame .marquee:nth-of-type(1) {
      top: 0;
      left: 0;
      width: 1811px;
      height: 30px; }
      .frame .marquee:nth-of-type(1) .marquee__inner {
        height: 30px; }
      .frame .marquee:nth-of-type(1) span {
        height: 100%;
        width: 1811px;
        padding: 0 12px 0 0; }
    .frame .marquee:nth-of-type(2) {
      top: 0;
      right: 0;
      width: 30px;
      height: 100%; }
      .frame .marquee:nth-of-type(2) .marquee__inner {
        flex-direction: column;
        width: 100%;
        height: 200%;
        animation: marqueeY 60s linear infinite; }
      .frame .marquee:nth-of-type(2) span {
        height: 1811px;
        width: 100%;
        padding: 12px 0 0 0; }
    .frame .marquee:nth-of-type(3) {
      bottom: 0;
      left: 0;
      width: 100%;
      height: 30px; }
      .frame .marquee:nth-of-type(3) .marquee__inner {
        width: max-content;
        height: 30px;
        animation: marqueeX 60s linear infinite reverse; }
      .frame .marquee:nth-of-type(3) span {
        height: 100%;
        width: 1811px;
        padding: 0 12px 0 0; }
    .frame .marquee:nth-of-type(4) {
      top: 0;
      left: 0;
      width: 30px;
      height: 100%; }
      .frame .marquee:nth-of-type(4) .marquee__inner {
        flex-direction: column;
        width: 100%;
        height: 200%;
        animation: marqueeY 60s linear infinite reverse; }
      .frame .marquee:nth-of-type(4) span {
        height: 1811px;
        width: 100%;
        padding: 12px 0 0 0; }

@keyframes marqueeX {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(-50%); } }
@keyframes marqueeY {
  from {
    transform: translateY(0); }
  to {
    transform: translateY(-50%); } }
@media (max-width: 768px) {
  .frame {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 10;
    pointer-events: none;
    top: 0;
    left: 0; }
    .frame:before {
      width: calc(100% - 40px);
      height: calc(100% - 40px);
      position: absolute;
      content: "";
      display: block;
      border: 1px solid #949494;
      border-top: none;
      left: 20px;
      top: 20px; }
    .frame .marquee {
      position: absolute;
      overflow: hidden; }
      .frame .marquee .marquee__inner {
        background-color: #41E2A3;
        display: flex;
        width: 200%;
        height: 100%;
        animation: marqueeX 60s linear infinite reverse;
        will-change: transform;
        pointer-events: none; }
        .frame .marquee .marquee__inner span {
          display: flex;
          flex-direction: row;
          flex-wrap: wrap;
          justify-content: center;
          align-items: center; }
        .frame .marquee .marquee__inner img {
          display: block;
          object-fit: contain; }
      .frame .marquee:nth-of-type(1) {
        top: 0;
        left: 0;
        width: 1207px;
        height: 20px; }
        .frame .marquee:nth-of-type(1) .marquee__inner {
          height: 20px; }
        .frame .marquee:nth-of-type(1) span {
          height: 100%;
          width: 1207px;
          padding: 0 12px 0 0; }
        .frame .marquee:nth-of-type(1) img {
          width: 1207px;
          height: 20px; }
      .frame .marquee:nth-of-type(2) {
        top: 0;
        right: 0;
        width: 20px;
        height: 100%; }
        .frame .marquee:nth-of-type(2) .marquee__inner {
          flex-direction: column;
          width: 100%;
          height: 200%;
          animation: marqueeY 60s linear infinite; }
        .frame .marquee:nth-of-type(2) span {
          flex: 0 0 50%;
          width: 100%;
          display: flex;
          justify-content: center;
          align-items: center; }
        .frame .marquee:nth-of-type(2) img {
          width: 20px;
          height: 1207px;
          display: block; }
      .frame .marquee:nth-of-type(3) {
        bottom: 0;
        left: 0;
        width: 1207px;
        height: 20px; }
        .frame .marquee:nth-of-type(3) .marquee__inner {
          height: 20px;
          animation: marqueeX 60s linear infinite reverse; }
        .frame .marquee:nth-of-type(3) span {
          height: 100%;
          width: 1207px;
          padding: 0 0 0;
          margin: 0 15px 0 0; }
        .frame .marquee:nth-of-type(3) img {
          width: 1207px;
          height: 20px; }
      .frame .marquee:nth-of-type(4) {
        top: 0;
        left: 0;
        width: 20px;
        height: 100%; }
        .frame .marquee:nth-of-type(4) .marquee__inner {
          flex-direction: column;
          width: 100%;
          height: 200%;
          animation: marqueeY 60s linear infinite reverse; }
        .frame .marquee:nth-of-type(4) span {
          flex: 0 0 50%;
          width: 100%;
          display: flex;
          justify-content: center;
          align-items: center; }
        .frame .marquee:nth-of-type(4) img {
          width: 20px;
          height: 1207px;
          display: block; } }
/*max-width:480px*/
/**********************************/
.line {
  background: url("../images/index/line01.svg") top center repeat-x;
  background-size: 75px 158px;
  border-bottom: 1px solid #858585; }
  .line p {
    display: block;
    text-align: center;
    margin: 0 auto;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    width: 100%;
    height: auto;
    max-width: 271px;
    aspect-ratio: 271/134; }
    .line p:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 100%;
      background: url("../images/index/kaizoudo_bar.png") center center no-repeat;
      background-size: contain;
      top: 0;
      left: 0;
      opacity: 0;
      animation: blinkOpacity 5s steps(1, end) infinite; }
  .line.line01 {
    height: 85px; }
  .line.line02 {
    height: 200px;
    padding: 22px 0 0 0; }
    .line.line02 p {
      background: url("../images/index/kaizoudo-1-1.png") center center no-repeat;
      background-size: contain;
      position: relative; }
  .line.line03 {
    height: 200px;
    padding: 22px 0 0 0; }
    .line.line03 p {
      background: url("../images/index/kaizoudo2-2.png") center center no-repeat;
      background-size: contain;
      position: relative; }
  .line.line04 {
    height: 200px;
    padding: 22px 0 0 0; }
    .line.line04 p {
      background: url("../images/index/kaizoudo3-3.png") center center no-repeat;
      background-size: contain;
      position: relative; }
  .line.line05 {
    height: 200px;
    padding: 22px 0 0 0; }
    .line.line05 p {
      background: url("../images/index/kaizoudo4-4.png") center center no-repeat;
      background-size: contain;
      position: relative; }

@keyframes blinkOpacity {
  0%, 39.999% {
    opacity: 0; }
  /* 0〜2.0秒 OFF */
  40%, 59.999% {
    opacity: 1; }
  /* 2.0〜3.0秒 ON（1秒） */
  60%, 100% {
    opacity: 0; }
  /* 3.0〜5.0秒 OFF */ }
@media (max-width: 768px) {
  .line {
    background: url("../images/index/line01.svg") top center repeat-x;
    background-size: 60px auto; }
    .line p {
      max-width: 240px; }
    .line.line02, .line.line03, .line.line04, .line.line05 {
      height: 180px;
      padding: 20px0 0 0; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .line {
    background: url("../images/index/line01_sp.svg") top center repeat-x;
    background-size: 12px 63px; }
    .line p {
      max-width: 180px; }
    .line.line01 {
      height: 45px; }
    .line.line02, .line.line03, .line.line04, .line.line05 {
      height: 140px;
      padding: 15px 0 0 0; } }
/*max-width:480px*/
/**********************************/
.nav01 {
  background: url("../images/page_bg/mieu_snap_bg.svg") top center repeat-x #D2FDEC;
  background-size: 29px 792px;
  position: relative;
  padding: 90px 30px 100px;
  position: relative;
  border-bottom: 1px solid #858585; }
  .nav01 h1 {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    position: absolute;
    aspect-ratio: 200/34;
    width: 100%;
    max-width: 200px;
    height: auto;
    top: -17px;
    left: 50%;
    transform: translate(-50%, 0%);
    background: url("../images/index/navigation01.svg") center center no-repeat;
    background-size: contain; }
  .nav01:after, .nav01:before {
    position: absolute;
    content: "";
    pointer-events: none;
    display: block;
    background-color: #D2FDEC;
    width: 30px;
    height: 100%;
    top: 0; }
  .nav01:before {
    left: 0;
    border-right: 1px solid #858585; }
  .nav01:after {
    right: 0;
    border-left: 1px solid #858585; }
  .nav01 h2 {
    aspect-ratio: 925/206;
    width: 100%;
    max-width: 925px;
    height: auto;
    margin: 0 auto 40px;
    position: relative;
    z-index: auto;
    text-indent: -9999px;
    background: url("../images/page_ttl/snap_ttl.png") center center no-repeat;
    background-size: contain; }
  .nav01 > p.top_txt {
    font: 2rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: .05em;
    text-align: center;
    margin: 0 0 15px; }
    .nav01 > p.top_txt br {
      display: none; }
  .nav01 > p {
    font: 1.8rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 400;
    letter-spacing: .05em;
    text-align: center;
    margin: 0 0 90px; }
    .nav01 > p br.num2 {
      display: none; }
  .nav01 .btn {
    font: 1.6rem/1em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: 0;
    text-decoration: none;
    padding: 18px 0 0 6px;
    position: relative;
    top: 0;
    display: block;
    margin: 0 auto;
    width: 250px;
    height: 70px;
    background: url("../images/index/nav04_check.svg") center center no-repeat;
    background-size: contain;
    text-align: center; }

.snap_box {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  align-items: flex-start;
  max-width: 1040px;
  margin: 0 auto;
  width: calc(100% - 80px); }

.snap_item {
  position: relative;
  width: calc((100% - 140px)/3);
  margin: 0 70px 65px 0;
  text-decoration: none; }
  .snap_item:nth-of-type(3n) {
    margin-right: 0; }
  .snap_item .ttl_card {
    max-width: 300px;
    width: 100%;
    position: relative;
    margin: 0 auto;
    box-sizing: border-box;
    text-align: center; }
    .snap_item .ttl_card:before {
      border-radius: 50%;
      position: absolute;
      content: "";
      display: block;
      width: 58px;
      height: 58px;
      top: -35px;
      left: 50%;
      transform: translate(-50%, 0);
      border: 1px solid #858585; }
  .snap_item .card__badge {
    position: absolute;
    top: -33px;
    left: 50%;
    transform: translateX(-50%);
    width: 56px;
    height: 56px;
    border-radius: 50%;
    font-weight: 700;
    background-color: #f5f5f5;
    z-index: 10; }
    .snap_item .card__badge:before {
      z-index: -1;
      border-radius: 50%;
      position: absolute;
      content: "";
      display: block;
      width: 45px;
      height: 45px;
      background: url("../images/snap/card__badge.svg") center center #ffffff no-repeat;
      background-size: 13px 18px;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
  .snap_item .card__text {
    font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    position: relative;
    z-index: 1;
    min-height: 120px;
    padding: 3px 20px 0;
    border-radius: 20px;
    border: 1px solid #858585;
    background: #f5f5f5;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center; }
  .snap_item .snap_img {
    position: relative;
    z-index: 10;
    margin: -10px auto 30px;
    aspect-ratio: 1/1;
    width: 100%;
    max-width: 300px;
    height: auto;
    padding: 10px;
    border-radius: 100%;
    background-color: #333;
    border: 1px solid #858585; }
    .snap_item .snap_img:before {
      aspect-ratio: 254 / 280;
      position: absolute;
      content: "";
      width: calc(100% - 46px);
      max-width: 254px;
      height: auto;
      left: 0;
      top: 30px;
      background: url(../images/snap/kirakira.svg) left top 0px no-repeat;
      background-size: contain; }
    .snap_item .snap_img span {
      display: block;
      aspect-ratio: 1/1;
      width: 100%;
      max-width: 100%;
      height: auto;
      border-radius: 100%;
      background-color: #fff;
      overflow: hidden;
      position: relative; }
    .snap_item .snap_img img {
      object-fit: cover;
      width: 100%;
      height: 100%; }
  .snap_item .class_txt {
    font: 1.3rem/1.5em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.05em;
    border: 1px solid #858585;
    top: auto;
    width: calc(100% + 10px);
    margin: 0 auto 0;
    padding: 8px 0;
    border-radius: 25px;
    background-color: #fff;
    position: absolute;
    z-index: 15;
    top: auto;
    bottom: 210px;
    left: 50%;
    transform: translate(-50%, 0%); }
  .snap_item .snap_txt {
    background-color: #fff;
    border: 1px solid #858585;
    border-bottom: 6px solid #000;
    border-radius: 25px;
    width: 100%;
    max-width: 300px;
    padding: 20px 30px;
    position: relative; }
    .snap_item .snap_txt:before {
      display: block;
      width: 13px;
      height: 16px;
      position: absolute;
      content: "";
      top: -16px;
      left: 50%;
      transform: translate(-50%, 0%);
      background-color: #fff;
      border: 1px solid #858585;
      border-bottom: 1px solid  #fff; }
    .snap_item .snap_txt p {
      font: 1.6rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em;
      margin: 0 0 15px;
      overflow: hidden;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2; }
    .snap_item .snap_txt span {
      padding: 0 25px 0 0;
      font: 1.5rem/40px "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      text-align: center;
      height: 40px;
      border-radius: 25px;
      display: block;
      background-color: #ccc;
      background-image: url("../images/snap/hand.svg");
      background-repeat: no-repeat;
      background-position: top 10px right 35px; }
  .snap_item.class01 .card__badge,
  .snap_item.class01 .card__text {
    background-color: #FFDADA; }
  .snap_item.class01 .snap_img {
    background-color: #FFB6B6; }
  .snap_item.class01 .snap_txt span {
    background-color: #FFDADA; }
  .snap_item.class02 .card__badge,
  .snap_item.class02 .card__text {
    background-color: #BBF3FC; }
  .snap_item.class02 .snap_img {
    background-color: #78E7FA; }
  .snap_item.class02 .snap_txt span {
    background-color: #BBF3FC; }
  .snap_item.class03 .card__badge,
  .snap_item.class03 .card__text {
    background-color: #DCDCFF; }
  .snap_item.class03 .snap_img {
    background-color: #BABAFF; }
  .snap_item.class03 .snap_txt span {
    background-color: #DCDCFF; }
  .snap_item.class04 .card__badge,
  .snap_item.class04 .card__text {
    background-color: #B2EAE5; }
  .snap_item.class04 .snap_img {
    background-color: #65D6CC; }
  .snap_item.class04 .snap_txt span {
    background-color: #B2EAE5; }
  .snap_item.class05 .card__badge,
  .snap_item.class05 .card__text {
    background-color: #B5F2CE; }
  .snap_item.class05 .snap_img {
    background-color: #6CE59E; }
  .snap_item.class05 .snap_txt span {
    background-color: #B5F2CE; }
  .snap_item.class06 .card__badge,
  .snap_item.class06 .card__text {
    background-color: #D0E0FC; }
  .snap_item.class06 .snap_img {
    background-color: #A2C1F9; }
  .snap_item.class06 .snap_txt span {
    background-color: #D0E0FC; }

@media (hover: hover) {
  .nav01 .btn:hover {
    top: -10px; }

  .snap_item:hover {
    cursor: pointer; }
    .snap_item:hover .snap_img:before {
      transform: scaleX(-1);
      right: 0;
      left: auto; }
    .snap_item:hover .snap_img img {
      transform: scale(1.1); }
    .snap_item:hover.class01 .snap_txt span {
      background-color: #FFB6B6; }
    .snap_item:hover.class02 .snap_txt span {
      background-color: #78E7FA; }
    .snap_item:hover.class03 .snap_txt span {
      background-color: #BABAFF; }
    .snap_item:hover.class04 .snap_txt span {
      background-color: #65D6CC; }
    .snap_item:hover.class05 .snap_txt span {
      background-color: #6CE59E; }
    .snap_item:hover.class06 .snap_txt span {
      background-color: #A2C1F9; } }
/*min-width:1920px*/
@media (max-width: 1280px) {
  .nav01 h2 {
    max-width: 750px; }
  .nav01 > p.top_txt {
    font: 1.8rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500; }
  .nav01 > p {
    font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 400; }
  .nav01 .btn {
    font: 1.5rem / 1em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    padding: 16px 0 0 6px;
    width: 236px;
    height: 67px; }

  .snap_item {
    position: relative;
    max-width: 300px;
    width: calc((100% - 100px)/3);
    margin: 0 50px 65px 0;
    text-decoration: none; }
    .snap_item .snap_txt span {
      max-width: 200px;
      margin: 0 auto;
      background-position: top 10px right 20px; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav01 > p br.num2 {
    display: block; }

  .snap_box {
    justify-content: space-between;
    align-items: flex-start;
    max-width: 640px;
    margin: 0 auto;
    width: calc(100% - 80px); }

  .snap_item {
    max-width: 300px;
    width: calc((100% - 40px)/2);
    margin: 0 0 65px 0; }
    .snap_item .ttl_card:before {
      width: 49px;
      height: 49px;
      top: -30px;
      left: 50%; }
    .snap_item .card__badge {
      top: -28px;
      width: 47px;
      height: 47px; }
      .snap_item .card__badge:before {
        width: 37px;
        height: 37px;
        background: url("../images/snap/card__badge.svg") center center #ffffff no-repeat;
        background-size: 10px 15px; }
    .snap_item .snap_txt {
      padding: 20px 20px;
      position: relative; }
      .snap_item .snap_txt p {
        font: 1.5rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em; }
      .snap_item .snap_txt span {
        font: 1.3rem/40px "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        height: 40px;
        background-position: top 10px right 25px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav01 {
    background: url("../images/page_bg/mieu_snap_bg.svg") top 0 center repeat-x #D2FDEC;
    background-size: 20px auto;
    position: relative;
    padding: 70px 20px 70px; }
    .nav01:after, .nav01:before {
      width: 20px; }
    .nav01 h2 {
      aspect-ratio: 357/257;
      width: 100%;
      max-width: 357px;
      background: url("../images/page_ttl/snap_ttl_sp.png") center center no-repeat;
      background-size: contain; }
    .nav01 > p.top_txt br {
      display: block; }
    .nav01 > p br.num2 {
      display: block; }
    .nav01 > p span {
      display: none; }

  .snap_box {
    display: block;
    max-width: 300px;
    margin: 0 auto;
    width: calc(100% - 40px); }

  .snap_item {
    position: relative;
    max-width: 300px;
    text-decoration: none;
    width: 100%;
    margin: 0 auto 60px;
    display: block; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav01 {
    background: url("../images/page_bg/mieu_snap_bg_sp.svg") top 0 center repeat-x #D2FDEC;
    background-size: 12px auto;
    position: relative;
    padding: 60px 10px 50px; }
    .nav01:after, .nav01:before {
      width: 10px; }
    .nav01 h1 {
      max-width: 135px;
      top: -11px;
      left: 50%; }
    .nav01 h2 {
      max-width: 225px;
      margin-bottom: 20px; }
    .nav01 > p.top_txt {
      font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      margin: 0 0 15px; }
    .nav01 > p {
      font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      margin: 0 0 50px; }
    .nav01 .btn {
      margin: -15px auto 0;
      font: 1.4rem / 1em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      padding: 19px 0 0 0px; }

  .snap_box {
    display: block;
    max-width: 300px;
    margin: 0 auto;
    width: calc(100% - 40px); }

  .snap_item .snap_img {
    width: 250px; }
  .snap_item .ttl_card {
    max-width: 250px; }
  .snap_item .class_txt {
    font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    padding: 4px 0;
    width: 100%; }
  .snap_item .card__text {
    font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    min-height: 100px; }
  .snap_item .snap_txt {
    max-width: 250px;
    margin: 0 auto; }
    .snap_item .snap_txt p {
      font: 1.4rem/1.8em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em;
      margin: 0 0 15px; }
    .snap_item .snap_txt span {
      font: 1.2rem/40px "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      height: 40px;
      border-radius: 25px; } }
/*max-width:480px*/
/**********************************/
.nav02 {
  background: url("../images/page_bg/a_day_mieu_bg.svg") top center repeat-x #C9F5FD;
  background-size: 29px 792px;
  position: relative;
  padding: 90px 30px 100px;
  min-height: 727px;
  position: relative;
  border-bottom: 1px solid #858585; }
  .nav02:after, .nav02:before {
    position: absolute;
    content: "";
    pointer-events: none;
    display: block;
    background-color: #C9F5FD;
    width: 30px;
    height: 100%;
    top: 0; }
  .nav02:before {
    left: 0;
    border-right: 1px solid #858585; }
  .nav02:after {
    right: 0;
    border-left: 1px solid #858585; }
  .nav02 h1 {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    position: absolute;
    aspect-ratio: 200/34;
    width: 100%;
    max-width: 200px;
    height: auto;
    top: -17px;
    left: 50%;
    transform: translate(-50%, 0%);
    background: url("../images/index/navigation02.svg") center center no-repeat;
    background-size: contain; }
  .nav02 h2 {
    aspect-ratio: 1066/221;
    width: 100%;
    max-width: 1066px;
    height: auto;
    margin: 0 auto 40px;
    position: relative;
    z-index: auto;
    text-indent: -9999px; }
    .nav02 h2:before {
      position: absolute;
      content: "";
      display: block;
      background: url("../images/page_ttl/index_a_day_mieu_ttl.png") center center no-repeat;
      background-size: contain;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      z-index: 1; }
    .nav02 h2:after {
      position: absolute;
      content: "";
      display: block;
      background: url("../images/index/aday-1.png") center center no-repeat;
      background-size: contain;
      width: 90px;
      height: 151px;
      left: 35%;
      top: 45px;
      z-index: 0;
      opacity: 0; }
    .nav02 h2.active:after {
      top: 45px; }
  .nav02 > p {
    font: 2rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: .05em;
    text-align: center;
    margin: 0 0 60px; }

.nav02 h2.is-anim-start:after {
  animation: nav02rise 0.6s ease forwards; }

@keyframes nav02rise {
  from {
    opacity: 0;
    top: 45px; }
  to {
    opacity: 1;
    top: -45px; } }
@media (max-width: 1280px) {
  .nav02 h2 {
    max-width: 850px; }
  .nav02 > p {
    font: 1.8rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav02 h2 {
    max-width: 640px; }
  .nav02 > p {
    font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav02 {
    background: url("../images/page_bg/a_day_mieu_bg.svg") top center repeat-x #C9F5FD;
    background-size: 20px auto;
    position: relative;
    padding: 70px 20px 70px; }
    .nav02:after, .nav02:before {
      width: 20px; }
    .nav02 h2 {
      aspect-ratio: 451/316;
      width: 100%;
      max-width: 357px;
      margin: 0 auto 40px; }
      .nav02 h2:before {
        background: url("../images/page_ttl/a_day_mieu_ttl_sp.png") center center no-repeat;
        background-size: contain; }
      .nav02 h2:after {
        width: 68px;
        height: 113px;
        left: auto;
        right: 15%;
        top: 45px;
        z-index: 0;
        opacity: 0; }
      .nav02 h2.active:after {
        top: 45px; }
    .nav02 > p {
      margin: 0 0 40px; }
      .nav02 > p span {
        display: block; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav02 {
    background: url("../images/page_bg/a_day_mieu_bg_sp.svg") top center repeat-x #C9F5FD;
    background-size: 12px auto;
    background-size: 15px auto;
    position: relative;
    padding: 60px 10px 50px; }
    .nav02:after, .nav02:before {
      width: 10px; }
    .nav02 h1 {
      max-width: 135px;
      top: -11px;
      left: 50%; }
    .nav02 h2 {
      aspect-ratio: 714/502;
      width: 100%;
      max-width: 225px;
      margin: 0 auto 20px; }
      .nav02 h2:after {
        width: 43px;
        height: 71px;
        left: auto;
        right: 15%;
        top: 45px;
        z-index: 0;
        opacity: 0; }
      .nav02 h2.active:after {
        top: 45px; }
    .nav02 > p {
      font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      margin: 0 0 30px; }
      .nav02 > p span {
        display: block; }

  @keyframes nav02rise {
    from {
      opacity: 0;
      top: 45px; }
    to {
      opacity: 1;
      top: -30px; } } }
/*max-width:480px*/
/**********************************/
.slider_box {
  max-width: 1550px;
  width: calc(100% - 80px);
  margin: 0 auto 50px; }

.day_item {
  max-width: 500px;
  position: relative;
  padding: 50px 0 0; }
  .day_item a {
    text-decoration: none; }
  .day_item .pic {
    image-rendering: auto;
    aspect-ratio: 1120/1400;
    width: 100%;
    max-width: 500px;
    height: auto;
    height: auto;
    overflow: hidden;
    border: 1px solid #858585;
    position: relative;
    margin: 0 auto 40px;
    padding: 10px;
    background-color: #fff; }
    .day_item .pic img {
      width: 100%;
      height: 100%;
      position: relative;
      z-index: 3; }
    .day_item .pic:before {
      position: absolute;
      content: "";
      display: block;
      width: 100%;
      height: 100%;
      border: 10px solid #fff;
      top: 0;
      left: 0;
      z-index: 5; }
    .day_item .pic:after {
      position: absolute;
      content: "";
      display: block;
      width: calc(100% - 20px);
      height: calc(100% - 20px);
      border: 1px solid #858585;
      top: 10px;
      left: 10px;
      z-index: 5; }
  .day_item .number {
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0%);
    z-index: 10; }
  .day_item .txt {
    text-align: center;
    max-width: 382px;
    min-height: 100px;
    margin: 0 auto 25px;
    background-image: url("../images/index/slider_left.png"), url("../images/index/slider_right.png");
    background-repeat: no-repeat;
    background-position: center left,center right;
    background-size: 22px 100%;
    text-align: center;
    padding: 0 35px; }
    .day_item .txt span {
      font: 1.7rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      letter-spacing: 0.1em; }
    .day_item .txt p {
      font: 2.5rem/1.5em "Outfit", sans-serif;
      font-weight: 400;
      letter-spacing: 0.1em;
      position: relative;
      padding: 0 0 7px;
      margin: 0 0 10px; }
      .day_item .txt p:before {
        position: absolute;
        content: "";
        top: auto;
        bottom: 0;
        left: 50%;
        transform: translate(-50%, 0%);
        height: 1px;
        width: 250px;
        border-bottom: dashed 1px #858585; }
    .day_item .txt small {
      font: 1.5rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      letter-spacing: 0.1em; }
  .day_item .slider_btn {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    background: url("../images/index/day_btn.svg") center center no-repeat;
    background-size: contain;
    display: block;
    aspect-ratio: 17/6;
    width: 100%;
    max-width: 170px;
    height: auto;
    margin: 0 auto; }

.slider_nav {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center; }
  .slider_nav .swiper-button-next,
  .slider_nav .swiper-button-prev {
    left: auto;
    right: auto;
    position: relative;
    top: auto;
    width: 70px;
    height: 70px;
    margin: 0;
    z-index: 10;
    cursor: pointer;
    display: flex;
    color: #000;
    border: 1px solid #858585;
    background-color: #C9F5FD;
    border-radius: 50%; }
    .slider_nav .swiper-button-next:after,
    .slider_nav .swiper-button-prev:after {
      display: none; }
    .slider_nav .swiper-button-next:before,
    .slider_nav .swiper-button-prev:before {
      position: absolute;
      content: "";
      display: block;
      width: 30px;
      height: 23px;
      top: 48%;
      transform: translate(-50%, -50%); }
  .slider_nav .swiper-button-next:before {
    background: url("../images/common/hand.svg") center center no-repeat;
    background-size: contain;
    left: 52%; }
  .slider_nav .swiper-button-prev:before {
    background: url("../images/common/hand_left.svg") center center no-repeat;
    background-size: contain;
    left: 48%; }
  .slider_nav .swiper-pagination {
    position: relative;
    margin: 0;
    width: 70px;
    font-weight: 600;
    color: #333;
    bottom: auto;
    right: auto;
    left: auto;
    top: auto;
    font-family: "Outfit", sans-serif;
    font-size: 20px; }
  .slider_nav .swiper-pagination-current,
  .slider_nav .swiper-pagination-total {
    font-size: 20px; }

@media (hover: hover) {
  .day_item:hover .pic img {
    transform: scale(1.1); }

  .slider_nav .swiper-button-next:hover,
  .slider_nav .swiper-button-prev:hover {
    background-color: #fff; } }
/*min-width:1920px*/
@media (max-width: 1280px) {
  .day_item {
    max-width: 500px;
    position: relative;
    padding: 50px 0 0; }
    .day_item a {
      text-decoration: none; }
    .day_item .pic {
      aspect-ratio: 50/62;
      width: 100%;
      max-width: 500px;
      height: auto;
      height: auto;
      overflow: hidden;
      border: 1px solid #858585;
      position: relative;
      margin: 0 auto 40px;
      padding: 10px;
      background-color: #fff; }
      .day_item .pic img {
        width: 100%;
        height: 100%;
        position: relative;
        object-fit: cover;
        z-index: 3; }
      .day_item .pic:before {
        position: absolute;
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        border: 10px solid #fff;
        top: 0;
        left: 0;
        z-index: 5; }
      .day_item .pic:after {
        position: absolute;
        content: "";
        display: block;
        width: calc(100% - 20px);
        height: calc(100% - 20px);
        border: 1px solid #858585;
        top: 10px;
        left: 10px;
        z-index: 5; }
    .day_item .number {
      display: block;
      position: absolute;
      top: 0;
      left: 50%;
      transform: translate(-50%, 0%);
      z-index: 10; }
    .day_item .txt span {
      font: 1.3rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      letter-spacing: 0.1em; }
    .day_item .txt p {
      font: 1.8rem/1.5em "Outfit", sans-serif;
      font-weight: 400;
      letter-spacing: 0.1em;
      padding: 0 0 7px;
      margin: 0 0 10px; }
      .day_item .txt p:before {
        width: 200px; }
    .day_item .txt small {
      font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      letter-spacing: 0.1em; }
    .day_item .slider_btn {
      max-width: 125px; } }
/*max-width:1280px*/
/*max-width:1024px*/
@media (max-width: 768px) {
  .slider_box {
    width: 100%;
    margin: 0 auto 50px; }

  .day_item {
    padding: 40px 0 0; }
    .day_item .pic {
      margin: 0 auto 28px;
      padding: 5px; }
      .day_item .pic:before {
        border: 5px solid #fff; }
      .day_item .pic:after {
        width: calc(100% - 10px);
        height: calc(100% - 10px);
        top: 5px;
        left: 5px;
        z-index: 5; }
    .day_item .number {
      width: 80px; }
    .day_item .txt {
      width: calc(100% - 40px);
      margin: 0 auto 25px; }

  .slider_nav .swiper-button-next,
  .slider_nav .swiper-button-prev {
    width: 60px;
    height: 60px; }
    .slider_nav .swiper-button-next:after,
    .slider_nav .swiper-button-prev:after {
      display: none; }
    .slider_nav .swiper-button-next:before,
    .slider_nav .swiper-button-prev:before {
      width: 30px;
      height: 20px;
      top: 48%; }
  .slider_nav .swiper-button-next:before {
    left: 52%; }
  .slider_nav .swiper-button-prev:before {
    left: 48%; }
  .slider_nav .swiper-pagination {
    width: 100px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .slider_box {
    width: 100%;
    margin: 0 auto 15px; }

  .day_item {
    padding: 30px 0 0; }
    .day_item .pic {
      margin: 0 auto 15px; }
    .day_item .number {
      width: 70px; }
    .day_item .txt {
      width: calc(100% - 30px);
      padding: 0 25px;
      margin: 0 auto 15px;
      min-height: 90px; }
      .day_item .txt p:before {
        width: 180px; }

  .slider_nav .swiper-button-next,
  .slider_nav .swiper-button-prev {
    width: 50px;
    height: 50px; }
    .slider_nav .swiper-button-next:after,
    .slider_nav .swiper-button-prev:after {
      display: none; }
    .slider_nav .swiper-button-next:before,
    .slider_nav .swiper-button-prev:before {
      width: 30px;
      height: 20px;
      top: 48%; }
  .slider_nav .swiper-button-next:before {
    left: 52%;
    background-size: 20px; }
  .slider_nav .swiper-button-prev:before {
    left: 48%;
    background-size: 20px; }
  .slider_nav .swiper-pagination {
    width: 80px; } }
/*max-width:480px*/
/**********************************/
.nav03 {
  background: url("../images/page_bg/mieu_trip_guide_bg.svg") top center repeat-x #EAEAFF;
  background-size: 29px 727px;
  position: relative;
  padding: 90px 30px 100px;
  min-height: 727px;
  position: relative;
  border-bottom: 1px solid #858585; }
  .nav03:after, .nav03:before {
    position: absolute;
    content: "";
    pointer-events: none;
    display: block;
    background-color: #EAEAFF;
    width: 30px;
    height: 100%;
    top: 0; }
  .nav03:before {
    left: 0;
    border-right: 1px solid #858585; }
  .nav03:after {
    right: 0;
    border-left: 1px solid #858585; }
  .nav03 h1 {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    position: absolute;
    aspect-ratio: 200/34;
    width: 100%;
    max-width: 200px;
    height: auto;
    top: -17px;
    left: 50%;
    transform: translate(-50%, 0%);
    background: url("../images/index/navigation03.svg") center center no-repeat;
    background-size: contain; }
  .nav03 h2 {
    aspect-ratio: 886/369;
    width: 100%;
    max-width: 886px;
    height: auto;
    margin: 0 0 40px;
    position: relative;
    z-index: auto;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap; }
    .nav03 h2:before {
      position: absolute;
      content: "";
      display: block;
      background: url("../images/page_ttl/index_mieu_trip_guid.png") center center no-repeat;
      background-size: contain;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      z-index: 1; }

.nav03_box {
  width: calc(100% - 80px);
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start; }
  .nav03_box .map {
    background: url("../images/index/tripguide_map.webp") center center no-repeat;
    background-size: contain;
    width: 520px;
    height: 717px;
    position: relative; }
    .nav03_box .map:before, .nav03_box .map:after {
      position: absolute;
      content: "";
      display: block;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0; }
    .nav03_box .map:before {
      background: url("../images/index/nav03_map03.webp") center center no-repeat;
      background-size: contain;
      animation: floatYnav03 3.2s ease-in-out infinite;
      will-change: transform; }
    .nav03_box .map:after {
      background-position: center center;
      background-repeat: no-repeat;
      background-size: contain;
      animation: swapBgnav03 4s steps(1, end) infinite; }
  .nav03_box .txt {
    width: calc(100% - 540px);
    position: relative; }
    .nav03_box .txt > p {
      font: 2rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: .05em;
      text-align: center;
      margin: 0 auto 60px; }
    .nav03_box .txt a {
      display: block; }
  .nav03_box a {
    font: 1.7rem/1em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: 0;
    text-decoration: none;
    padding: 18px 0 0 6px;
    position: relative;
    top: 0;
    display: none;
    margin: 0 auto;
    width: 170px;
    height: 70px;
    background: url("../images/index/check.svg") center center no-repeat;
    text-align: center; }

@keyframes floatYnav03 {
  0% {
    transform: translateY(0); }
  50% {
    transform: translateY(-12px); }
  100% {
    transform: translateY(0); } }
@keyframes swapBgnav03 {
  0%, 50% {
    background-image: url("../images/index/nav03_map01.webp"); }
  50.001%, 100% {
    background-image: url("../images/index/nav03_map02.webp"); } }
@media (hover: hover) {
  .nav03_box .txt a:hover {
    top: -10px; } }
@media (max-width: 1280px) {
  .nav03_box {
    align-items: center; }
    .nav03_box .map {
      aspect-ratio: 520/717;
      width: 45%;
      max-width: 520px;
      height: auto; }
    .nav03_box .txt {
      width: 55%; }
      .nav03_box .txt > p {
        margin: 0 auto 30px;
        font: 1.8rem/2em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav03 h2 {
    aspect-ratio: 886/369;
    width: 100%;
    max-width: 600px;
    margin: 0 auto 25px; }

  .nav03_box {
    align-items: center;
    max-width: 768px; }
    .nav03_box .map {
      width: 100%;
      order: 2;
      margin: 0 auto 50px; }
    .nav03_box .txt {
      order: 1;
      width: 100%;
      margin: 0 auto 40px; }
      .nav03_box .txt > p {
        margin: 0 auto;
        font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500; }
      .nav03_box .txt a {
        display: none; }
    .nav03_box a {
      order: 3;
      display: block;
      margin: 0 auto; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav03 {
    background-size: 20px auto;
    position: relative;
    padding: 70px 20px 70px; }
    .nav03:after, .nav03:before {
      width: 20px; }
    .nav03 h2 {
      aspect-ratio: 1095/534;
      width: 100%;
      max-width: 548px;
      margin: 0 auto 25px; }
      .nav03 h2:before {
        background: url("../images/page_ttl/mieu_trip_guid_sp.png") center center no-repeat;
        background-size: contain; }

  .nav03_box {
    align-items: center;
    max-width: 480px;
    width: 100%; }
    .nav03_box .map {
      width: calc(100% - 20px);
      order: 2;
      margin: 0 auto 50px; }
    .nav03_box .txt {
      order: 1;
      width: calc(100% - 60px);
      margin: 0 auto 40px; }
      .nav03_box .txt > p {
        margin: 0 auto;
        font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500; }
        .nav03_box .txt > p span {
          display: block; }
        .nav03_box .txt > p br {
          display: none; }
      .nav03_box .txt a {
        display: none; }
    .nav03_box a {
      order: 3;
      display: block;
      margin: 0 auto; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav03 {
    background: url("../images/page_bg/mieu_trip_guide_bg_sp.svg") top center repeat-x #EAEAFF;
    background-size: 12px auto;
    position: relative;
    padding: 50px 10px 50px; }
    .nav03:after, .nav03:before {
      width: 10px; }
    .nav03 h1 {
      max-width: 135px;
      top: -11px;
      left: 50%; }
    .nav03 h2 {
      width: 100%;
      max-width: 330px;
      margin: 0 auto 20px; }

  .nav03_box .map {
    width: calc(100% - 30px);
    order: 2;
    margin: 0 auto 30px; }
  .nav03_box .txt {
    order: 1;
    width: calc(100% - 30px);
    margin: 0 auto 30px;
    max-width: 330px; }
    .nav03_box .txt > p {
      margin: 0 auto;
      font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500; }
      .nav03_box .txt > p span {
        display: block; }
      .nav03_box .txt > p br {
        display: none; }
  .nav03_box a {
    font: 1.4rem/1em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: 0;
    text-decoration: none;
    padding: 18px 0 0 6px;
    margin: 0 auto;
    width: 160px;
    height: 66px;
    background: url("../images/index/check.svg") center center no-repeat;
    background-size: contain;
    text-align: center; } }
/*max-width:480px*/
/**********************************/
.nav04 {
  background: url("../images/page_bg/graduate_interview_bg.svg") top center repeat-x #F5E3FE;
  background-size: 29px 727px;
  position: relative;
  padding: 90px 30px 100px;
  min-height: 727px;
  position: relative;
  border-bottom: 1px solid #858585; }
  .nav04:after, .nav04:before {
    position: absolute;
    content: "";
    pointer-events: none;
    display: block;
    background-color: #F5E3FE;
    width: 30px;
    height: 100%;
    top: 0; }
  .nav04:before {
    left: 0;
    border-right: 1px solid #858585; }
  .nav04:after {
    right: 0;
    border-left: 1px solid #858585; }
  .nav04 h1 {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    position: absolute;
    aspect-ratio: 200/34;
    width: 100%;
    max-width: 200px;
    height: auto;
    top: -17px;
    left: 50%;
    transform: translate(-50%, 0%);
    background: url("../images/index/navigation04.svg") center center no-repeat;
    background-size: contain; }
  .nav04 h2 {
    aspect-ratio: 823/350;
    width: 100%;
    max-width: 823px;
    height: auto;
    margin: 0 auto 40px;
    position: relative;
    z-index: auto; }
    .nav04 h2 span {
      z-index: 5;
      display: block;
      width: 100%;
      height: 100%;
      position: relative;
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap; }
      .nav04 h2 span:before, .nav04 h2 span:after {
        position: absolute;
        content: "";
        display: block; }
      .nav04 h2 span:before {
        background: url("../images/page_ttl/index_interview_ttl_btm.png") center center no-repeat;
        background-size: contain;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0;
        z-index: 5; }
      .nav04 h2 span:after {
        opacity: 0;
        background: url("../images/page_ttl/interview_ttl_btm_item.png") center center no-repeat;
        background-size: contain;
        width: 100px;
        height: 128px;
        left: 15%;
        top: 43%;
        z-index: 4; }
    .nav04 h2:before, .nav04 h2:after {
      position: absolute;
      content: "";
      display: block; }
    .nav04 h2:after {
      opacity: 0;
      background: url("../images/page_ttl/interview_ttl_top_item.png") center center no-repeat;
      background-size: contain;
      width: 100px;
      height: 157px;
      right: 15%;
      top: 5%;
      z-index: 1; }
    .nav04 h2:before {
      background: url("../images/page_ttl/index_interview_ttl_top.png") center center no-repeat;
      background-size: contain;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      z-index: 3; }
  .nav04 > p {
    font: 2rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: .05em;
    text-align: center;
    margin: 0 auto 60px; }
  .nav04 > a {
    font: 1.6rem/1em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: 0;
    text-decoration: none;
    padding: 18px 0 0 6px;
    position: relative;
    top: 0;
    display: block;
    margin: 0 auto;
    width: 250px;
    height: 70px;
    background: url("../images/index/nav04_check.svg") center center no-repeat;
    background-size: contain;
    text-align: center; }

.nav04 h2.is-anim-start:after {
  animation: riseIn01 0.6s ease forwards; }
.nav04 h2.is-anim-start span::after {
  animation: riseIn02 0.6s ease forwards 0.3s; }

@keyframes riseIn01 {
  from {
    opacity: 0;
    top: 0; }
  to {
    opacity: 1;
    top: -10%; } }
@keyframes riseIn02 {
  from {
    opacity: 0;
    top: 43%; }
  to {
    opacity: 1;
    top: 27%; } }
.nav04_box {
  width: calc(100% - 80px);
  margin: 0 auto 40px;
  max-width: 1200px;
  --cols: 4;
  --gap: 1px;
  --bar-h: 10px;
  --mb: 25px;
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap); }
  .nav04_box > a {
    text-decoration: none;
    box-sizing: border-box;
    outline: 1px solid #858585;
    background-color: #fff;
    position: relative;
    flex: 0 0 calc((100% - (var(--cols) - 1) * var(--gap)) / var(--cols) );
    margin-bottom: calc(var(--mb) + var(--bar-h)); }
    .nav04_box > a::before {
      content: "";
      position: absolute;
      left: -1px;
      width: calc(100% + 2px);
      top: 100%;
      transform: translateY(-1px);
      height: 8px;
      background: #000;
      z-index: 1;
      clip-path: polygon(0% 0%, 100% 0%, 95% 100%, 5% 100%); }
    .nav04_box > a p {
      display: block;
      padding: 12px;
      font: 1.7rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em; }
    .nav04_box > a .pic {
      padding: 10px;
      aspect-ratio: 4/3;
      width: 100%;
      max-width: 100%;
      height: auto;
      overflow: hidden;
      position: relative;
      border-bottom: 1px solid #858585; }
      .nav04_box > a .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
      .nav04_box > a .pic:before {
        width: 100%;
        height: 100%;
        position: absolute;
        content: "";
        display: block;
        left: 0;
        top: 0;
        border: 10px solid #fff;
        z-index: 5; }
      .nav04_box > a .pic:after {
        width: calc(100% - 20px);
        height: calc(100% - 20px);
        position: absolute;
        content: "";
        display: block;
        left: 10px;
        top: 10px;
        border: 1px solid #858585;
        z-index: 5; }
    .nav04_box > a dl {
      padding: 15px 20px 20px; }
    .nav04_box > a dt {
      padding: 0 0 8px;
      margin: 0 0 10px;
      font: 1.4rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em;
      border-bottom: 1px solid #C5C3C3; }
    .nav04_box > a dd {
      font: 1.6rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em; }
      .nav04_box > a dd span {
        font: 1.5rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 400;
        letter-spacing: 0.05em;
        display: block;
        padding: 0 0 3px; }
    .nav04_box > a.class01 .pic {
      background-color: #FFB6B6; }
      .nav04_box > a.class01 .pic:before {
        border-color: #FFDADA; }
    .nav04_box > a.class01 p {
      background-color: #FFB6B6; }
    .nav04_box > a.class02 .pic {
      background-color: #78E7FA; }
      .nav04_box > a.class02 .pic:before {
        border-color: #BBF3FC; }
    .nav04_box > a.class02 p {
      background-color: #78E7FA; }
    .nav04_box > a.class03 .pic {
      background-color: #BABAFF; }
      .nav04_box > a.class03 .pic:before {
        border-color: #DCDCFF; }
    .nav04_box > a.class03 p {
      background-color: #BABAFF; }
    .nav04_box > a.class04 .pic, .nav04_box > a.class04-1 .pic {
      background-color: #65D6CC; }
      .nav04_box > a.class04 .pic:before, .nav04_box > a.class04-1 .pic:before {
        border-color: #B2EAE5; }
    .nav04_box > a.class04 p, .nav04_box > a.class04-1 p {
      background-color: #65D6CC; }
    .nav04_box > a.class05 .pic, .nav04_box > a.class05-1 .pic {
      background-color: #6CE59E; }
      .nav04_box > a.class05 .pic:before, .nav04_box > a.class05-1 .pic:before {
        border-color: #B5F2CE; }
    .nav04_box > a.class05 p, .nav04_box > a.class05-1 p {
      background-color: #6CE59E; }
    .nav04_box > a.class06 .pic {
      background-color: #A2C1F9; }
      .nav04_box > a.class06 .pic:before {
        border-color: #D0E0FC; }
    .nav04_box > a.class06 p {
      background-color: #A2C1F9; }

@media (hover: hover) {
  .nav04_box > a:hover .pic img {
    transform: scale(1.1); } }
/*min-width:1920px*/
@media (max-width: 1280px) {
  .nav04 h2 {
    max-width: 610px; }
    .nav04 h2 span:after {
      width: 80px;
      height: 102px; }
    .nav04 h2:after {
      width: 80px;
      height: 125px; }
  .nav04 > p {
    font: 1.8rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: .05em; }
  .nav04 > a {
    font: 1.5rem/1em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    padding: 16px 0 0 6px;
    width: 236px;
    height: 67px; }

  .nav04_box {
    margin: 0 auto 20px; }
    .nav04_box > a p {
      display: block;
      padding: 10px 12px;
      font: 1.6rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em; }
    .nav04_box > a .pic {
      padding: 5px; }
      .nav04_box > a .pic:before {
        border: 5px solid #fff;
        z-index: 5; }
      .nav04_box > a .pic:after {
        width: calc(100% - 10px);
        height: calc(100% - 10px);
        left: 5px;
        top: 5px; }
    .nav04_box > a dl {
      padding: 15px 15px 15px; }
    .nav04_box > a dt {
      font: 1.3rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400; }
    .nav04_box > a dd {
      font: 1.5rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500; }
      .nav04_box > a dd span {
        font: 1.4rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 400; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav04 > p {
    font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500; }

  .nav04_box {
    max-width: 768px;
    --cols: 3;
    --gap: 1px;
    --bar-h: 10px;
    --mb: 25px;
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav04 {
    background-size: 20px auto;
    position: relative;
    padding: 70px 20px 70px; }
    .nav04:after, .nav04:before {
      width: 20px; }
    .nav04 h2 {
      aspect-ratio: 543/269;
      width: calc(100% - 40px);
      max-width: 543px;
      height: auto;
      margin: 0 auto 40px; }
      .nav04 h2 span:before {
        background: url("../images/page_ttl/interview_ttl_btm_sp.png") center center no-repeat;
        background-size: contain;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0;
        z-index: 5; }
      .nav04 h2 span:after {
        width: 70px;
        height: 90px;
        left: 15%;
        top: 43%;
        z-index: 4; }
      .nav04 h2:after {
        width: 70px;
        height: 110px;
        right: 15%;
        top: 5%;
        z-index: 1; }
      .nav04 h2:before {
        background: url("../images/page_ttl/interview_ttl_top_sp.png") center center no-repeat;
        background-size: contain;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0;
        z-index: 3; }
    .nav04 p br {
      display: none; }
    .nav04 p span {
      display: block; }

  .nav04_box {
    max-width: 480px;
    width: calc(100% - 60px);
    --cols: 2;
    --gap: 1px;
    --bar-h: 10px;
    --mb: 25px;
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap); }

  @keyframes riseIn01 {
    from {
      opacity: 0;
      top: 0; }
    to {
      opacity: 1;
      top: -20%; } }
  @keyframes riseIn02 {
    from {
      opacity: 0;
      top: 43%; }
    to {
      opacity: 1;
      top: 13%; } } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav04 {
    background: url("../images/page_bg/graduate_interview_bg_sp.svg") top center repeat-x #F5E3FE;
    background-size: 29px 727px;
    position: relative;
    padding: 50px 10px 50px; }
    .nav04:after, .nav04:before {
      width: 10px; }
    .nav04 h1 {
      max-width: 135px;
      top: -11px;
      left: 50%; }
    .nav04 h2 {
      aspect-ratio: 543/269;
      width: calc(100% - 30px);
      margin: 0 auto 20px; }
      .nav04 h2 span:after {
        width: 42px;
        height: 54px;
        left: 15%;
        top: 43%;
        z-index: 4; }
      .nav04 h2:after {
        width: 42px;
        height: 67px;
        right: 15%;
        top: 5%;
        z-index: 1; }
    .nav04 > p {
      font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: .05em;
      text-align: center;
      margin: 0 auto 30px; }
    .nav04 > a {
      font: 1.4rem/1em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      padding: 18px 0 0 6px;
      width: 236px;
      height: 66px; }

  .nav04_box {
    width: calc(100% - 30px);
    margin: 0 auto 40px; }
    .nav04_box > a {
      margin-bottom: 15px; }
      .nav04_box > a::before {
        height: 4px;
        clip-path: polygon(0% 0%, 100% 0%, 95% 100%, 5% 100%); }
      .nav04_box > a p {
        border-top: 1px solid #858585;
        display: block;
        padding: 5px 12px 8px;
        font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em; }
      .nav04_box > a dl {
        padding: 8px 10px 12px; }
      .nav04_box > a dt {
        padding: 0 0 5px;
        margin: 0 0 8px;
        font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 400;
        letter-spacing: 0.05em;
        border-bottom: 1px solid #C5C3C3; }
      .nav04_box > a dd {
        font: 1.3rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em; }
        .nav04_box > a dd span {
          font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
          font-weight: 400;
          letter-spacing: 0.05em;
          display: block;
          padding: 0 0 1px; }

  @keyframes riseIn01 {
    from {
      opacity: 0;
      top: 0; }
    to {
      opacity: 1;
      top: -12%; } }
  @keyframes riseIn02 {
    from {
      opacity: 0;
      top: 43%; }
    to {
      opacity: 1;
      top: 20%; } } }
/*max-width:480px*/
/**********************************/
.nav05 {
  background: url("../images/page_bg/nav05.svg") top center repeat-x #EAFCD4;
  background-size: 29px 727px;
  position: relative;
  padding: 90px 30px 0;
  min-height: 727px;
  position: relative;
  border-bottom: 1px solid #858585; }
  .nav05:after, .nav05:before {
    position: absolute;
    content: "";
    pointer-events: none;
    display: block;
    background-color: #EAFCD4;
    width: 30px;
    height: 100%;
    top: 0; }
  .nav05:before {
    left: 0;
    border-right: 1px solid #858585; }
  .nav05:after {
    right: 0;
    border-left: 1px solid #858585; }
  .nav05 h1 {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    position: absolute;
    aspect-ratio: 200/34;
    width: 100%;
    max-width: 200px;
    height: auto;
    top: -17px;
    left: 50%;
    transform: translate(-50%, 0%);
    background: url("../images/index/navigation05.svg") center center no-repeat;
    background-size: contain; }
  .nav05 .ttl_flex {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    width: 100%; }
    .nav05 .ttl_flex h2 {
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap;
      display: block; }
    .nav05 .ttl_flex p {
      font: 2rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: .05em; }
    .nav05 .ttl_flex.info {
      margin: 0 auto 40px; }
      .nav05 .ttl_flex.info h2 {
        background: url("../images/page_ttl/info_ttl.png") center center no-repeat;
        background-size: contain;
        aspect-ratio: 73/13;
        width: 100%;
        max-width: 730px;
        height: auto; }
      .nav05 .ttl_flex.info p {
        width: calc(100% - 730px);
        max-width: fit-content;
        padding: 30px 0 0 25px; }
    .nav05 .ttl_flex.sns {
      margin: 0 auto 40px; }
      .nav05 .ttl_flex.sns h2 {
        background: url("../images/page_ttl/sns_ttl.png") center center no-repeat;
        background-size: contain;
        aspect-ratio: 323/116;
        width: 100%;
        max-width: 323px;
        height: auto; }
      .nav05 .ttl_flex.sns p {
        width: calc(100% - 323px);
        max-width: fit-content;
        padding: 0 0 0 25px; }
    .nav05 .ttl_flex.site {
      margin: 0 auto 70px; }
      .nav05 .ttl_flex.site h2 {
        background: url("../images/page_ttl/site_ttl.png") center center no-repeat;
        background-size: contain;
        aspect-ratio: 864/116;
        width: 100%;
        max-width: 864px;
        height: auto; }
      .nav05 .ttl_flex.site p {
        width: calc(100% - 864px);
        max-width: fit-content;
        padding: 0 0 0 25px; }

/*min-width:1920px*/
@media (max-width: 1280px) {
  .nav05 .ttl_flex p {
    font: 1.8rem/2em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: .05em; }
  .nav05 .ttl_flex.info {
    margin: 0 auto 40px; }
    .nav05 .ttl_flex.info h2 {
      width: 100%;
      max-width: 560px;
      height: auto; }
    .nav05 .ttl_flex.info p {
      width: calc(100% - 540px);
      max-width: fit-content;
      padding: 20px 0 0 25px; }
  .nav05 .ttl_flex.sns {
    margin: 0 auto 40px; }
    .nav05 .ttl_flex.sns h2 {
      max-width: 245px;
      height: auto; }
    .nav05 .ttl_flex.sns p {
      width: calc(100% - 245px); }
  .nav05 .ttl_flex.site {
    margin: 0 auto 70px; }
    .nav05 .ttl_flex.site h2 {
      max-width: 655px;
      height: auto; }
    .nav05 .ttl_flex.site p {
      width: calc(100% - 655px); } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav05 .ttl_flex {
    display: block; }
    .nav05 .ttl_flex h2 {
      margin: 0 auto 20px !important; }
    .nav05 .ttl_flex p {
      font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: .05em;
      text-align: center;
      margin: 0 auto !important;
      width: 100% !important;
      max-width: fit-content !important;
      padding: 0 !important; }
    .nav05 .ttl_flex.info h2 {
      width: 100%;
      max-width: 530px;
      height: auto; }
    .nav05 .ttl_flex.sns {
      margin: 0 auto 40px; }
      .nav05 .ttl_flex.sns h2 {
        max-width: 215px;
        height: auto; }
    .nav05 .ttl_flex.site {
      margin: 0 auto 70px; }
      .nav05 .ttl_flex.site h2 {
        max-width: 630px;
        height: auto; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav05 {
    background-size: 20px auto;
    position: relative;
    padding: 70px 20px 70px; }
    .nav05:after, .nav05:before {
      width: 20px; }
    .nav05 .ttl_flex {
      display: block; }
      .nav05 .ttl_flex h2 {
        width: calc(100% - 40px);
        margin: 0 auto 20px !important; }
      .nav05 .ttl_flex p {
        font: 1.6rem/2em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: .05em;
        text-align: center;
        margin: 0 auto !important;
        width: 100% !important;
        max-width: fit-content !important;
        padding: 0 !important; }
      .nav05 .ttl_flex.info h2 {
        background: url("../images/page_ttl/info_ttl_sp.png") center center no-repeat;
        background-size: contain;
        aspect-ratio: 514/84;
        width: calc(100% - 40px);
        max-width: 514px; }
      .nav05 .ttl_flex.sns {
        margin: 0 auto 40px; }
        .nav05 .ttl_flex.sns h2 {
          background: url("../images/page_ttl/sns_ttl_sp.png") center center no-repeat;
          background-size: contain;
          aspect-ratio: 226/83;
          max-width: 226px;
          height: auto; }
      .nav05 .ttl_flex.site {
        margin: 0 auto 70px; }
        .nav05 .ttl_flex.site h2 {
          background: url("../images/page_ttl/site_ttl_sp.png") center center no-repeat;
          background-size: contain;
          aspect-ratio: 379/172;
          width: 100%;
          max-width: 379px;
          height: auto; }
        .nav05 .ttl_flex.site p br {
          display: none; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav05 {
    background: url("../images/page_bg/nav05_sp.svg") top center repeat-x #EAFCD4;
    background-size: 12px auto;
    position: relative;
    padding: 50px 20px 70px; }
    .nav05:after, .nav05:before {
      width: 10px; }
    .nav05 .ttl_flex {
      display: block; }
      .nav05 .ttl_flex h2 {
        width: calc(100% - 40px);
        margin: 0 auto 15px !important; }
      .nav05 .ttl_flex p {
        font: 1.4rem/2em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: .05em;
        text-align: center;
        margin: 0 auto !important;
        width: 100% !important;
        max-width: fit-content !important;
        padding: 0 !important; }
      .nav05 .ttl_flex.info {
        margin: 0 auto 25px; }
        .nav05 .ttl_flex.info h2 {
          width: calc(100% - 40px);
          max-width: 308px;
          height: auto; }
      .nav05 .ttl_flex.sns {
        margin: 0 auto 25px; }
        .nav05 .ttl_flex.sns h2 {
          max-width: 136px;
          height: auto; }
      .nav05 .ttl_flex.site {
        margin: 0 auto 20px; }
        .nav05 .ttl_flex.site h2 {
          max-width: 227px;
          height: auto; } }
/*max-width:480px*/
/****************************************/
.nav05_info {
  width: calc(100% - 80px);
  max-width: 1200px;
  margin: 0 auto 80px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  /* 3列 */
  gap: 20px;
  /* 余白はお好みで */ }
  .nav05_info a {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    text-decoration: none;
    background: url("../images/index/nav05info_link-bg.png") center center no-repeat;
    background-size: contain;
    aspect-ratio: 387/222;
    width: 100%;
    max-width: 100%;
    height: auto;
    position: relative;
    padding: 15px 0 0 185px; }
    .nav05_info a p {
      font: 1.9rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.1em;
      height: 60px;
      margin: 0 0 10px;
      display: flex;
      flex-direction: column;
      flex-wrap: wrap;
      justify-content: center;
      align-items: flex-start; }
    .nav05_info a span {
      background: url("../images/index/nav05_info_link.png") center center no-repeat;
      background-size: contain;
      aspect-ratio: 130/53;
      width: 100%;
      max-width: 130px;
      height: auto;
      text-align: center;
      font: 1.5rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      padding: 8px 0 0; }
    .nav05_info a:before {
      position: absolute;
      content: "";
      display: block;
      top: 50%;
      left: 0;
      transform: translate(0%, -50%);
      max-width: 185px;
      width: calc(100% - 185px);
      height: 56px; }
    .nav05_info a.info01:before {
      background: url("../images/index/nav05_info_icon01.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info02:before {
      background: url("../images/index/nav05_info_icon02.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info03:before {
      background: url("../images/index/nav05_info_icon03.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info04:before {
      background: url("../images/index/nav05_info_icon04.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info05:before {
      background: url("../images/index/nav05_info_icon05.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info06:before {
      background: url("../images/index/nav05_info_icon06.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info07:before {
      background: url("../images/index/nav05_info_icon07.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info08:before {
      background: url("../images/index/nav05_info_icon08.png") center center no-repeat;
      background-size: contain; }
    .nav05_info a.info09:before {
      background: url("../images/index/nav05_info_icon09.png") center center no-repeat;
      background-size: contain; }

/*min-width:1920px*/
@media (max-width: 1280px) {
  .nav05_info {
    width: calc(100% - 80px);
    gap: 15px;
    /* 余白はお好みで */ }
    .nav05_info a {
      padding: 15px 0 0 120px; }
      .nav05_info a p {
        font: 1.8rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.01em;
        height: 46px;
        margin: 0 0 10px; }
      .nav05_info a span {
        max-width: 120px;
        font: 1.4rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        padding: 5px 0 0; }
      .nav05_info a:before {
        max-width: 120px;
        width: 100%; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav05_info {
    max-width: 768px;
    grid-template-columns: repeat(2, 1fr);
    /* 3列 */ } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav05_info {
    width: calc(100% - 60px);
    max-width: 480px;
    grid-template-columns: repeat(2, 1fr);
    /* 3列 */
    gap: 20px;
    /* 余白はお好みで */ }
    .nav05_info p {
      margin: 0 0 15px; }
    .nav05_info a {
      background: url("../images/index/nav05info_link-bg_sp.svg") center center no-repeat;
      aspect-ratio: 259/327;
      background-size: contain;
      padding: 17% 0 5%;
      max-width: 350px;
      margin: 0 auto;
      align-items: center; }
      .nav05_info a:before {
        position: relative;
        top: 0;
        left: 0;
        transform: translate(0%, 0%);
        height: 40px;
        margin: 0 auto; }
      .nav05_info a p {
        margin: 13px auto 15px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav05_info {
    margin: 0 auto 50px;
    width: calc(100% - 40px);
    gap: 8px;
    /* 余白はお好みで */ }
    .nav05_info p {
      margin: 0 0 15px; }
    .nav05_info a {
      background: url("../images/index/nav05info_link-bg_sp.png") center center no-repeat;
      background-size: 100% 100%;
      aspect-ratio: auto;
      padding: 20px 0 0;
      max-width: 155px;
      height: 195px;
      margin: 0 auto 15px; }
      .nav05_info a:before {
        height: 30px;
        margin: 0 auto; }
      .nav05_info a p {
        font: 1.5rem/1.4em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        margin: 13px auto; }
      .nav05_info a span {
        max-width: 110px;
        font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        padding: 7px 0 0; } }
/*max-width:480px*/
/****************************************/
.nav05_sns {
  width: calc(100% - 80px);
  max-width: 1200px;
  margin: 0 auto 80px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between; }
  .nav05_sns a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 12px 0;
    text-decoration: none;
    font-weight: bold;
    background: url("../images/index/nav05_sns.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 224/124;
    width: 100%;
    max-width: 225px;
    width: calc((100% - 60px)/5);
    height: auto;
    padding: 0 0 0 104px;
    font: 1.8rem/1.5em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500;
    letter-spacing: 0.05em;
    position: relative; }
    .nav05_sns a:before {
      position: absolute;
      content: "";
      display: block;
      width: 60px;
      height: 60px;
      top: 50%;
      left: 25px;
      transform: translate(0%, -50%); }
    .nav05_sns a.sns_instagram:before {
      background: url("../images/index/nav05_sns_icon-instagram.png") center center no-repeat;
      background-size: contain; }
    .nav05_sns a.sns_x:before {
      background: url("../images/index/nav05_sns_icon-x.png") center center no-repeat;
      background-size: contain; }
    .nav05_sns a.sns_youtube:before {
      background: url("../images/index/nav05_sns_icon-youtube.png") center center no-repeat;
      background-size: contain; }
    .nav05_sns a.sns_facebook:before {
      background: url("../images/index/nav05_sns_icon-facebook.png") center center no-repeat;
      background-size: contain; }

@media (max-width: 1280px) {
  .nav05_sns a {
    aspect-ratio: 224/124;
    width: 100%;
    max-width: 225px;
    width: calc((100% - 40px)/5);
    height: auto;
    padding: 0 0 0 70px;
    font: 1.6rem/1.5em "M PLUS Rounded 1c", sans-serif;
    font-weight: 500; }
    .nav05_sns a:before {
      width: 50px;
      height: 50px;
      top: 50%;
      left: 12px;
      transform: translate(0%, -50%); } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav05_sns {
    max-width: 640px;
    margin: 0 auto 80px; }
    .nav05_sns a {
      margin: 0 0 20px;
      width: calc((100% - 20px)/2);
      max-width: 350px;
      padding: 0 0 0 104px;
      font: 1.8rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em;
      position: relative; }
      .nav05_sns a:before {
        position: absolute;
        content: "";
        display: block;
        width: 60px;
        height: 60px;
        top: 50%;
        left: 25px;
        transform: translate(0%, -50%); }
      .nav05_sns a br {
        display: none; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav05_sns {
    width: calc(100% - 60px);
    max-width: 480px;
    margin: 0 auto 80px;
    display: grid;
    grid-template-columns: repeat(2, 2fr);
    /* 4グリッド */
    gap: 16px; }
    .nav05_sns a {
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      margin: 0 auto;
      height: auto;
      aspect-ratio: 259/200;
      width: 100%;
      max-width: 259px;
      padding: 30% 0 0;
      background: url("../images/index/nav05_sns_sp.svg") center center no-repeat;
      background-size: 100% 100%; }
      .nav05_sns a:before {
        width: 50px;
        height: 50px;
        top: 13%;
        left: 50%;
        transform: translate(-50%, 0%); } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav05_sns {
    width: calc(100% - 40px);
    max-width: 480px;
    margin: 0 auto 50px;
    display: grid;
    grid-template-columns: repeat(2, 2fr);
    /* 4グリッド */
    gap: 8px; }
    .nav05_sns a {
      padding: 33% 0 0;
      font: 1.5rem/1em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500; }
      .nav05_sns a:before {
        width: 43px;
        height: 43px;
        top: 15%;
        left: 50%;
        transform: translate(-50%, 0%); } }
/*max-width:480px*/
/****************************************/
.nav05_site {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: stretch;
  width: calc(100% - 80px);
  max-width: 1200px;
  margin: 0 auto -120px; }
  .nav05_site .univ_site {
    display: flex;
    flex-direction: column;
    flex-wrap: center;
    justify-content: center;
    align-items: stretch;
    text-decoration: none;
    margin: 0 0 0 40px;
    background: url("../images/index/nav05_site.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 570/245;
    width: calc((100% - 80px)/2);
    max-width: 570px;
    height: auto;
    position: relative;
    text-align: center; }
    .nav05_site .univ_site div {
      margin: 0 0 0 auto;
      width: calc(40% + 20px);
      text-align: center; }
    .nav05_site .univ_site img {
      position: absolute;
      bottom: 25px;
      left: -20px;
      width: 60%;
      max-width: 335px; }
    .nav05_site .univ_site.official small:before {
      background: url("../images/index/nav05_site_official-icon.png") center top no-repeat;
      background-size: contain;
      width: 42px; }
    .nav05_site .univ_site.exam-support small:before {
      background: url("../images/index/nav05_site_exam-icon.png") center top no-repeat;
      background-size: contain;
      width: 26px; }
    .nav05_site .univ_site small {
      display: block;
      padding: 50px 0 0;
      position: relative;
      text-align: center;
      margin: 0 auto 10px;
      font: 1.8rem/1em "M PLUS Rounded 1c", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }
      .nav05_site .univ_site small:before {
        display: block;
        position: absolute;
        content: "";
        display: block;
        height: 30px;
        top: 0%;
        left: 50%;
        transform: translate(-50%, 0%); }
    .nav05_site .univ_site p {
      font: 2.1rem/1em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em;
      margin: 0 auto 15px; }
      .nav05_site .univ_site p br {
        display: none; }
    .nav05_site .univ_site span {
      background: url("../images/index/nav05_info_link.png") center center no-repeat;
      background-size: contain;
      aspect-ratio: 130/53;
      width: 100%;
      max-width: 130px;
      display: block;
      height: auto;
      text-align: center;
      font: 1.5rem/1.5em "M PLUS Rounded 1c", sans-serif;
      font-weight: 500;
      margin: 0 auto;
      padding: 8px 0 0;
      width: 100%; }

/*min-width:1920px*/
@media (max-width: 1280px) {
  .nav05_site {
    margin: 0 auto -100px; }
    .nav05_site .univ_site {
      margin: 0 0 0 30px;
      aspect-ratio: 570/245;
      width: calc((100% - 60px)/2); }
      .nav05_site .univ_site div {
        margin: 0 0 0 auto;
        width: calc(47% + 15px);
        text-align: center; }
      .nav05_site .univ_site img {
        position: absolute;
        bottom: 25%;
        left: -15px;
        width: 53%;
        max-width: 335px; }
      .nav05_site .univ_site small {
        display: block;
        padding: 40px 0 0;
        font: 1.6rem/1em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em; }
        .nav05_site .univ_site small:before {
          height: 25px;
          top: 0%;
          left: 50%;
          transform: translate(-50%, 0%); }
      .nav05_site .univ_site p {
        font: 1.9rem/1em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em;
        margin: 0 auto 15px; }
      .nav05_site .univ_site span {
        max-width: 120px;
        font: 1.4rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        padding: 5px 0 0; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .nav05_site {
    display: block;
    margin: 0 auto -120px; }
    .nav05_site .univ_site {
      width: 100%;
      margin: 0 auto;
      max-width: 480px; }
      .nav05_site .univ_site.official {
        margin-bottom: 50px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .nav05_site {
    width: calc(100% - 60px);
    display: block;
    max-width: 480px;
    margin: 0 auto -150px; }
    .nav05_site .univ_site {
      background: url("../images/index/nav05_site_sp.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 533/300;
      width: 100%;
      margin: 0 auto;
      max-width: 480px;
      display: flex;
      flex-direction: row;
      flex-wrap: center;
      justify-content: space-between;
      align-items: center;
      padding: 0 20px; }
      .nav05_site .univ_site p {
        font: 1.8rem/1em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em;
        margin: 0 auto 15px; }
      .nav05_site .univ_site img {
        position: relative;
        bottom: auto;
        left: auto;
        width: 52%;
        max-width: 335px;
        margin: 0 0; }
      .nav05_site .univ_site div {
        margin: 0;
        padding: 0;
        width: 46%;
        text-align: center; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .nav05_site {
    width: calc(100% - 40px);
    display: block;
    max-width: 330px;
    margin: 0 auto -150px; }
    .nav05_site .univ_site {
      background: url("../images/index/nav05_site_sp.png") center center no-repeat;
      background-size: 100% 100%;
      aspect-ratio: 533/300;
      width: 100%;
      margin: 0 auto;
      max-width: 319px;
      height: 180px;
      display: flex;
      flex-direction: row;
      flex-wrap: space-between;
      justify-content: space-between;
      align-items: center;
      padding: 0 0 0 10px; }
      .nav05_site .univ_site.official {
        margin-bottom: 15px; }
      .nav05_site .univ_site p {
        font: 1.6rem/1.3em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        letter-spacing: 0.05em;
        margin: 0 auto 10px;
        overflow: hidden;
        text-align: center;
        display: flex;
        flex-direction: column;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center; }
        .nav05_site .univ_site p br {
          display: block; }
      .nav05_site .univ_site div {
        margin: 0;
        padding: 0;
        width: calc(100% - 160px); }
      .nav05_site .univ_site small {
        display: block;
        padding: 30px 0 0;
        font: 1.3rem/1em "M PLUS Rounded 1c", sans-serif;
        font-weight: 400;
        letter-spacing: 0.05em;
        margin: 0 0 10px; }
        .nav05_site .univ_site small:before {
          height: 24px;
          top: -5px;
          left: 50%;
          transform: translate(-50%, 0%); }
      .nav05_site .univ_site img {
        position: relative;
        bottom: auto;
        left: auto;
        width: 160px;
        max-width: 160px;
        margin: 0 0; }
      .nav05_site .univ_site span {
        max-width: 100px;
        font: 1.2rem/1.5em "M PLUS Rounded 1c", sans-serif;
        font-weight: 500;
        padding: 5px 0 0;
        width: 100%; } }
/*max-width:480px*/
/****************************************/
@media (hover: hover) {
  .nav05_info a:hover {
    top: -5px; }
    .nav05_info a:hover:before {
      transform: translate(0%, -50%) rotate(-15deg); }

  .nav05_sns a:hover {
    top: -5px; }
    .nav05_sns a:hover:before {
      transform: translate(0%, -50%) rotate(-15deg); }

  .nav05_site .univ_site:hover {
    top: -5px; }
    .nav05_site .univ_site:hover small:before {
      transform: translate(-50%, 0%) rotate(-15deg); } }
@media (max-width: 768px) and (hover: hover) {
  .nav05_info a:hover {
    top: -5px; }
    .nav05_info a:hover:before {
      transform: translate(0%, 0%) rotate(-15deg); }

  .nav05_sns a:hover:before {
    transform: translate(-50%, 0%) rotate(-15deg); }

  .nav05_site .univ_site:hover {
    top: -5px; }
    .nav05_site .univ_site:hover small:before {
      transform: translate(-50%, 0%) rotate(-15deg); } }
/*max-width:768px*/
