@charset "utf-8";

@media screen and (max-width: 768px) {
  .auth-card {
    padding: 24px 20px;
  }

  .auth-title {
    font-size: 24px;
  }

  .auth-form {
    gap: 12px;
  }

  .sp-fixed-side {
    display: block;
    position: fixed;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    z-index: 10;
    pointer-events: none; /* クリック不要ならこれでコンテンツ操作を邪魔しない */
  }

  .sp-fixed-side img {
    display: block;
    width: auto; /* 好きなサイズに調整 */
    height: 100%;
  }

  body {
    color: #fff;
    font-family: "Noto Serif JP", serif;
    margin: 0;
    font-size: 1px;
  }

  /* ロゴ */
  .logo {
    width: 100%;
    margin: 20px auto;
    display: block;
  }

  /* レイアウト */
  .wrap {
    margin: 0 auto;
  }

  .bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow: hidden;
  }

  .bg picture,
  .bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
