@charset "utf-8";

* {
  box-sizing: border-box;
  scroll-behavior: smooth;
}
::selection {
  background: #f2f1c3;
  color: #111;
}
html,
body {
  font-size: var(--font-base);
  line-height: 1.6;
  font-feature-settings: 'palt';
  background: url(../_img/top_bg2.webp);
  background-size: 80%;

  font-family: 'M PLUS 1p', sans-serif;
  font-weight: 500;
  font-style: normal;

  height: 100vh;
  overflow: hidden;
}

img {
  max-width: 100%;
}
.sp {
  display: block;
}
.pc {
  display: none;
}
img {
  max-width: 100%;
}
section {
}
:root {
  --font-sm: clamp(12px, 1.4vw, 12px);
  --font-base: clamp(17px, 0.7vw, 16px);
  --font-lg: clamp(18px, 2.4vw, 24px);
  --font-xl: clamp(22px, 4.8vw, 36px);
  --font-xxl: clamp(28px, 6.2vw, 48px);

  --space-1: clamp(6px, 1.2vw, 12px);
  --space-2: clamp(10px, 1.6vw, 16px);
  --space-3: clamp(12px, 2.2vw, 24px);
  --space-4: clamp(16px, 3vw, 32px);
  --space-5: clamp(24px, 4vw, 48px);
  --space-6: clamp(32px, 5vw, 64px);
}

/****************************************
全体
*****************************************/
main {
  display: flex;
  height: 100vh;
}
/****************************************
左右
*****************************************/
.side {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
}
h1 {
  max-width: 350px;
}
/****************************************
右ページ
*****************************************/
.side_cov {
  max-width: 260px;
  margin: 0 auto;
}
.side_btn {
  margin-top: 1rem;
}

/****************************************
中央
*****************************************/
.center {
  z-index: 100;
  width: 480px;
  max-width: 100%;
  height: 100vh;
  overflow-y: auto;
  box-shadow: 0 0 40px rgba(0, 0, 0, 0.4);
  background: url(../_img/bg.jpg);
}

/* ===== スマホ時 ===== */
@media (max-width: 768px) {
  body {
    overflow: auto;
  }

  .side {
    display: none;
  }

  .center {
    width: 100%;
    box-shadow: none;
  }
}
/****************************************
SNSボタン
*****************************************/
.sns_list {
  display: flex;
  width: 180px;
  margin: 0 auto;
}
.tw,
.fb,
.li {
  width: 33%;
  padding: 8%;
}
/****************************************
フッター
*****************************************/
footer {
  background-color: #000;
  text-align: center;
  width: 100%;
  padding: 2rem;
  color: #dadada;
  font-size: var(--font-sm);
}

/****************************************
/****************************************
/****************************************
/****************************************
SP
*****************************************/
@media screen and (max-width: 768px) {
  .sp {
    display: none;
  }

  .pc {
    display: block;
  }

  /****************************************
  SNSボタン
  *****************************************/
  .sns_list {
    width: 140px;
  }
}
