html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 1vw;
  font: inherit;
  vertical-align: baseline; }

body {
  background-image: url("../img/back.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-attachment: fixed;
  margin: 0 auto;
  font-family: "M PLUS 1p";
  font-weight: 400;
  color: #274299; }
  @media screen and (max-width: 768px) {
    body {
      width: 1200px; } }

h2 {
  font-family: "Emblema One";
  font-size: xx-large;
  text-align: center;
  margin: 25px 0; }

.blue {
  color: #80d3dd; }

.red {
  color: #ff6460; }

a {
  text-decoration: none;
  color: #274299; }

img.bubble {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%; }

.intro {
  position: relative;
  width: 900px;
  height: 900px;
  text-align: center;
  margin: 0 auto;
  padding-top: 20px; }
  .intro .frame {
    position: absolute;
    border: solid #80d3dd 20px;
    height: 1000px;
    width: 870px;
    margin: 0 auto;
    top: -130px;
    left: 0;
    right: 0;
    background: white;
    z-index: -1; }
  .intro .intro-text {
    text-align: right;
    font-weight: 300;
    transform: rotate(-0.5deg); }
    .intro .intro-text .space {
      font-size: 35px; }
      .intro .intro-text .space span {
        background: #ffff21; }
      .intro .intro-text .space span.bold {
        font-weight: 900; }
      .intro .intro-text .space span.circle {
        letter-spacing: 2px; }
    .intro .intro-text p {
      margin-top: 20px;
      font-size: 15px;
      font-weight: 300;
      line-height: 30px; }
      .intro .intro-text p span {
        background: linear-gradient(transparent 70%, #ffff21 0%); }
  .intro img.logo {
    position: relative;
    text-align: center;
    mix-blend-mode: multiply;
    z-index: 10; }
  .intro img.top-nanahira {
    position: absolute;
    top: 85px;
    left: -150px;
    z-index: 2; }
  .intro img.top-caster {
    position: absolute;
    bottom: -45px;
    right: 59px;
    z-index: 3; }
  .intro img.top-catch {
    position: absolute;
    width: 62%;
    bottom: 0;
    left: 20px;
    z-index: 3; }

section {
  position: relative;
  background: white;
  width: 840px;
  margin: 45px auto;
  padding: 0 20px 40px 20px;
  border: solid #80d3dd 20px; }

section.s1 {
  height: 60px;
  width: 100%;
  background: green; }

section.s2 img.mini-ticket {
  width: 20%;
  position: absolute;
  top: 32%;
  left: -12%; }

section.s2 img.sticker {
  display: block;
  width: 80%;
  margin: 0 auto;
  margin-bottom: 40px; }

section.s2 .information {
  display: flex;
  align-items: flex-start; }
  section.s2 .information img.jacket {
    width: 45%;
    object-fit: contain;
    filter: drop-shadow(0 0 4px rgba(159, 214, 221, 0.75)); }
  section.s2 .information table {
    text-align: left;
    line-height: 45px;
    margin-left: 35px; }
  section.s2 .information th {
    color: #ff6460; }
  section.s2 .information td {
    padding-left: 20px; }

section.s2 .buy {
  width: 97%;
  margin: 30px auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start; }
  section.s2 .buy a.shop {
    width: 25%;
    margin: 5px 10px;
    padding: 10px 20px;
    background: #80d3dd;
    border-radius: 10px;
    color: white;
    font-size: larger;
    text-align: center;
    text-decoration: none; }

section.s2 .tracklist {
  width: 97%;
  margin: 30px auto 0 auto; }
  section.s2 .tracklist p {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    border-bottom: 4px dotted #80d3dd; }
  section.s2 .tracklist .num {
    flex-basis: 6%;
    margin-top: 5px;
    font-family: "Emblema One";
    color: #ff6460;
    font-size: xx-large; }
  section.s2 .tracklist .hidden {
    margin-top: 39px;
    outline: 4px white solid; }
  section.s2 .tracklist .title {
    flex-basis: 47%;
    font-size: large; }
  section.s2 .tracklist .credit {
    flex-basis: 47%;
    font-size: small; }

section.s2 img.busstop {
  width: 25%;
  position: absolute;
  bottom: -7%;
  right: -12%;
  z-index: 3; }

section.s3 {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
  background: white;
  overflow: hidden; }
  section.s3 .frame {
    position: absolute;
    border: solid #80d3dd 20px;
    border-top: none;
    height: 1000px;
    width: 880px;
    margin: 0 auto;
    top: 130px;
    left: -20px;
    background: white;
    z-index: -1; }
  section.s3 table {
    width: 100%;
    table-layout: fixed;
    text-align: left;
    line-height: 28px;
    z-index: 4; }
    section.s3 table tr.dummy {
      height: 15px; }
    section.s3 table th {
      font-family: "Emblema One";
      color: #ff6460;
      font-size: large;
      padding-left: 40px; }
    section.s3 table th.left {
      padding-left: 60px; }
    section.s3 table td.right {
      padding-left: 50px; }
  section.s3 img.confetto {
    display: block;
    margin: 40px auto; }
  section.s3 .twitter {
    margin: 20px auto 150px auto;
    text-align: center;
    z-index: 4; }

footer {
  position: relative;
  width: 100%;
  text-align: center;
  pointer-events: none; }
  @media screen and (max-width: 768px) {
    footer {
      margin-top: 0px; } }
  footer img.footer-wave {
    position: absolute;
    width: 120%;
    margin: 0 -15%;
    bottom: 0;
    left: 0;
    right: 0; }
  footer img.mini-drink {
    position: absolute;
    width: 12%;
    right: 150px;
    bottom: 120px; }
  footer img.footer-caster {
    position: absolute;
    left: -65px;
    bottom: 0px; }
