@import url(https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700&display=swap&subset=japanese);
:root {
  --white: #fff;
}
* {
  font-family: Noto Sans JP, Yu-Gothic, 游ゴシック, sans-serif;
}
body {
  background: #f1f1f1;
  width: 100%;
  max-width: 420px;
  margin: auto;
}
.only-pc {
  display: none;
}
header {
  padding: 30px 8% 0;
}
header img {
  max-width: 100%;
}
main {
  padding: 15px 7%;
}
.shop-label {
  color: #00b0a8;
  text-align: center;
  font-weight: bold;
  padding: 4px 0;
  font-size: 1.2rem;
  border: solid 3px #00b0a8;
}
#congestion {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-top: 30px;
}
#congestion,
.circle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.circle {
  border-radius: 100%;
  width: 290px;
  height: 290px;
}
.circle img {
  width: 47%;
  display: block;
}
.status {
  font-size: 1.5625rem;
  text-align: center;
  letter-spacing: 0.125rem;
}
.bar,
.status {
  font-weight: 700;
  margin-top: 20px;
}
.bar {
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-self: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
}
.bar img {
  max-width: 80%;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  height: 40px;
  display: block;
}
.bar span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  height: 40px;
  font-size: 1.25rem;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}
.bar span:first-child {
  background-color: #29abe2;
  margin-right: -1px;
}
.bar span:last-child {
  background-color: #ed1c24;
  margin-left: -1px;
}
#clock {
  margin-top: 45px;
  padding: 6px;
  background-color: #fff;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.125rem;
}
#clock .time {
  letter-spacing: 0.25rem;
  margin-top: 8px;
}
#clock .time span {
  font-size: 1.8em;
}
.close-button {
  font-weight: bold;
  color: #fff;
  background-color: #00b0a8;
  text-align: center;
  padding: 5px 0;
  font-size: 1.1rem;
  margin-top: 45px;
  letter-spacing: 2px;
  width: 100%;
}
.page-peach .close-button {
  background-color: #E74566;
}
.close-button:hover {
  cursor: pointer;
  opacity: .8;
}
@media (min-width: 767.98px) {
  .only-pc {
    display: block;
  }
  .only-sp {
    display: none;
  }
}
@media (min-width: 575.98px) {
  header {
    margin-top: 40px;
  }
}
@media (max-width: 576px) {
  .circle {
    width: 250px;
    height: 250px;
  }
  .bar,
  .status {
    margin-top: 15px;
  }
  .status {
    font-size: 1.5rem;
  }
  .bar img {
    height: 35px;
  }
  .bar span {
    height: 35px;
  }
  #clock {
    margin-top: 15px;
  }
  #clock .time {
    letter-spacing: 0.25rem;
    margin-top: 0;
  }
  #clock .time span {
    font-size: 1.4em;
  }
  .close-button {
    margin-top: 25px;
  }
}
@media (max-width: 413.98px) {
  header {
    padding: 20px 8% 0;
  }
  .circle {
    width: 220px;
    height: 220px;
  }
  .status {
    font-size: 1.3rem;
  }
  .bar img {
    height: 30px;
  }
  .bar span {
    height: 30px;
    font-size: 1rem;
  }
  #clock {
    margin-top: 15px;
  }
  #clock .time span {
    font-size: 1.2em;
  }
}
@media (max-width: 374.98px) {
  #congestion {
    margin-top: 15px;
  }
  .circle {
    width: 150px;
    height: 150px;
  }
  .status {
    font-size: 1rem;
  }
  #clock .time span {
    font-size: 1.1em;
  }
}
