@charset "UTF-8";
* {
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
}

body {
  background: #fff;
  font-family: Verdana, Roboto, "Droid Sans", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 14px;
  font-size: 1.4em;
  line-height: 1.4;
  color: #323232;
  -webkit-text-size-adjust: 100%;
}

a {
  color: #323232;
  text-decoration: underline;
}
a:hover {
  color: #323232;
  text-decoration: none;
}

img {
  max-width: 100%;
  vertical-align: middle;
}

p {
  margin: 0.5em 0 1em;
}
p:first-child {
  margin-top: 0;
}
p:last-child {
  margin-bottom: 0;
}

ul, ol {
  margin: 0 0 1em;
  padding: 0 0 0 2.5em;
  line-height: 1.6;
}
ul:last-child, ol:last-child {
  margin-bottom: 0;
}
ul ul, ul ol, ol ul, ol ol {
  margin: 0.5em 0;
  padding-left: 2em;
}
ul ul:last-child, ul ol:last-child, ol ul:last-child, ol ol:last-child {
  margin-bottom: 0.5em;
}

.container {
  overflow: hidden;
  margin: 0 10px;
}

@media (min-width: 640px) {
  .container {
    max-width: 980px;
    margin: 0 10px;
  }
}
@media (min-width: 1000px) {
  .container {
    margin-right: auto;
    margin-left: auto;
  }
}
/* ---------------------------------------------------------
 Header
--------------------------------------------------------- */
#header .main_img {
  padding-bottom: 3px;
  text-align: center;
  background: #000 url(http://www.playland-happy.co.jp/info/img/line.jpg) center bottom repeat-x;
}
#header .main_title {
  margin: 0;
  padding: 20px;
  text-align: center;
  background: #eee;
  font-size: 25px;
  font-size: 2.5rem;
}

/* ---------------------------------------------------------
 Navigation
--------------------------------------------------------- */
#nav .gnav {
  overflow: hidden;
  margin: 0;
  padding: 0;
  list-style: none;
}
#nav .gnav li {
  float: left;
  width: 33.3333%;
}
#nav .gnav li a {
  display: block;
  line-height: 3;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-size: 2rem;
  text-decoration: none;
  transition: .3s;
}
#nav .gnav li.sapporo a {
  background: #27ae60;
}
#nav .gnav li.sapporo a:hover, #nav .gnav li.sapporo a:active {
  background: #1e8449;
}
#nav .gnav li.hakodate a {
  background: #9d256d;
}
#nav .gnav li.hakodate a:hover, #nav .gnav li.hakodate a:active {
  background: #741b50;
}
#nav .gnav li.tomakomai a {
  background: #f1c40f;
}
#nav .gnav li.tomakomai a:hover, #nav .gnav li.tomakomai a:active {
  background: #c29d0b;
}
#nav .gnav li.chitose a {
  background: #3498db;
}
#nav .gnav li.chitose a:hover, #nav .gnav li.chitose a:active {
  background: #217dbb;
}
#nav .gnav li.otaru a {
  background: #e67e22;
}
#nav .gnav li.otaru a:hover, #nav .gnav li.otaru a:active {
  background: #bf6516;
}
#nav .gnav li.tobetsu a {
  background: #9b59b6;
}
#nav .gnav li.tobetsu a:hover, #nav .gnav li.tobetsu a:active {
  background: #804399;
}

@media (min-width: 640px) {
  #nav {
    background: #2a2a2a;
  }
  #nav .gnav {
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    list-style: none;
  }
  #nav .gnav li {
    float: left;
    width: 16.6666%;
  }
  #nav .gnav li a {
    display: block;
    line-height: 3;
    font-size: 20px;
    font-size: 2rem;
    color: #fff;
  }
}
/* ---------------------------------------------------------
 Main
--------------------------------------------------------- */
#main section {
  margin-top: 80px;
  margin-bottom: 50px;
}
#main .city_title {
  width: 162px;
  margin: 0 auto 30px;
  padding: 10px 0;
  border-bottom: 2px solid;
  text-align: center;
  font-size: 20px;
  font-size: 2rem;
}
#main .city_title.sapporo {
  color: #27ae60;
  border-color: #000000;
}
#main .city_title.hakodate {
  color: #9d256d;
  border-color: #9d256d;
}
#main .city_title.tomakomai {
  color: #f1c40f;
  border-color: #f1c40f;
}
#main .city_title.chitose {
  color: #3498db;
  border-color: #3498db;
}
#main .city_title.otaru {
  color: #e67e22;
  border-color: #e67e22;
}
#main .city_title.tobetsu {
  color: #9b59b6;
  border-color: #9b59b6;
}
#main .map {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 0;
  margin: 0 0 60px;
  padding-top: 75%;
}
#main .map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
#main .shop_list ul {
  overflow: hidden;
  margin: 0;
  padding: 0;
  list-style: none;
}
#main .shop_list li {
  overflow: hidden;
  margin: 0 0 30px;
}
#main .shop_list .shop_img {
  float: left;
  width: 50%;
}
#main .shop_list .info {
  position: relative;
  float: right;
  width: 46%;
  padding-bottom: 30px;
}
#main .shop_list .info h3 {
  margin: 0 0 10px;
  padding: 0 0 10px;
  border-bottom: 1px dotted #a6a6a6;
  line-height: 1;
  background: right top no-repeat;
  font-size: 20px;
  font-size: 2rem;
}
#main .shop_list .info h3.sapporo {
}
#main .shop_list .info h3.hakodate {
  background-image: url(../img/rbn_02.jpg);
}
#main .shop_list .info h3.tomakomai {
  background-image: url(../img/rbn_03.jpg);
}
#main .shop_list .info h3.chitose {
  background-image: url(../img/rbn_04.jpg);
}
#main .shop_list .info h3.otaru {
  background-image: url(../img/rbn_05.jpg);
}
#main .shop_list .info h3.tobetsu {
  background-image: url(../img/rbn_06.jpg);
}
#main .shop_list .info p {
  margin: 10px 0;
  font-size: 14px;
  font-size: 1.4rem;
}
#main .shop_list .info .btn {
  position: absolute;
  left: 0;
  bottom: 1px;
}

body.scroll #main .map {
  pointer-events: none;
}

@media (min-width: 640px) {
  #main .map {
    padding-top: 60%;
  }
  #main .map.map_md {
    float: left;
    width: 49%;
    padding-top: 30%;
  }
  #main .map.map_md + .shop_list {
    float: right;
    width: 49%;
  }
  #main .shop_list li {
    min-height: 160px;
  }
  #main .shop_list.col2 li:nth-child(odd) {
    width: 48%;
    float: left;
  }
  #main .shop_list.col2 li:nth-child(even) {
    width: 48%;
    float: right;
  }
}
/* ---------------------------------------------------------
 Footer
--------------------------------------------------------- */
#footer {
  position: relative;
  background: #000 url(http://www.playland-happy.co.jp/info/img/line.jpg) center top repeat-x;
}
#footer .logo {
  padding: 2em 0;
  text-align: center;
}
#footer .copyright {
  padding-bottom: 25px;
  text-align: center;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
}
#footer .pagetop {
  position: fixed;
  right: 2%;
  bottom: 20px;
  margin: 0;
  transition: .3s;
}
#footer .pagetop a {
  display: block;
  overflow: hidden;
  width: 49px;
  height: 49px;
  line-height: 49px;
  padding: 0;
  background: url(http://www.playland-happy.co.jp/info/img/btn_tp.png) no-repeat;
  background-size: 49px 49px;
  text-indent: 100%;
  white-space: nowrap;
}
#footer .pagetop.hide {
  opacity: 0;
}

@media (min-width: 640px) {
  #footer .logo {
    padding: 100px 0;
  }
  #footer .pagetop {
    right: 2%;
    bottom: 20px;
  }
  #footer .pagetop a {
    width: 97px;
    height: 97px;
    line-height: 97px;
    background-size: auto;
  }
}
video{
    margin: 0 auto;
    max-width: 980px;
    width: 100%;
    height: auto;
}
.youtube-wrap{
      margin: 0 auto;
      max-width: 980px;
}
.youtube {
      position: relative;
      width: 100%;
      padding-top: 56.25%;
}
.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}