@charset 'utf-8';

/*==============================================*/
/* 夜Cha!王(やっちゃおう)スマートフォン用CSS    */
/*                                              */
/* Shop Page                                    */
/*==============================================*/
/* Footer */
footer {
  padding-bottom: 120px;
}

/* Top Header */
h1.shop-line-header {
  margin: 0 auto;
  padding: 2px 5px;
  width: 640px;
  background-color: #333333;
  color: #ffffff;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  position: relative;
}
a.back-pref-page-button {
  width: 180px;
  height: 40px;
  line-height: 40px;
  display: block;
  position: absolute;
  right: 5px;
  top: 7px;
  font-size: 16px;
  color: #ffffff;
  background: #78b5e3;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  text-align: center;
}
a.back-pref-page-button:visited {
  color: #ffffff;
}
p.line-header-shop-name {
  font-size: 18px;
  font-weight: bold;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
p.line-header-shop-name a,
p.line-header-shop-name a:visited {
  color: #ffffff;
}
p.line-header-category-name {
  font-size: 14px;
  font-weight: normal;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
h1.shop-line-header.scrolled {
  margin-left: -320px;
  width: 640px;
  background: rgba(0, 0, 0, 0.8);
  position: fixed;
  top: 0;
  left: 50%;
  z-index: 1;
}
div.shop-header {
  margin: 0 auto;
  padding: 0;
  width: 640px;
  height: 200px;
  line-height: 200px;
  background-color: #cc0101;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  text-align: center;
  font-size: 40px;
  font-weight: bold;
  color: #ffffff;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
div.shop-sub-header {
  margin: 0 auto;
  padding: 5px;
  width: 640px;
  background-color: #eaeaea;
  border-top: 1px solid #b6b6b6;
  border-bottom: 1px solid #b6b6b6;
}
h2.shop-sub-title {
  margin: 10px 0;
  padding: 0;
  width: 100%;
  background-color: #eaeaea;
  font-size: 24px;
  font-weight: bold;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  color: #333333;
}
table.shop-ranking-data {
  margin: 5px auto 15px auto;
  padding: 0;
  width: 600px;
  border-collapse: collapse;
}
table.shop-ranking-data th,
table.shop-ranking-data td {
  padding: 5px;
  vertical-align: middle;
}
table.shop-ranking-data th {
  width: 300px;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  color: #720f0e;
  background-color: #f0dd56;
  border: 3px solid #f0dd56;
}
table.shop-ranking-data td {
  border: 3px solid #f0dd56;
  font-size: 14px;
  text-align: center;
}
table.shop-ranking-data th svg {
  margin-right: 10px;
  width: 26px;
  height: 26px;
  fill: #720f0e !important;
  vertical-align: middle;
  background-color: #f0dd56;
}
span.shop-ranking-number {
  margin-right: 10px;
  font-size: 32px;
  font-weight: bold;
  color: #720f0e;
}
span.shop-ranking-time {
  color: #aaaaaa;
}
p.shop-address {
  margin: 5px auto;
  padding: 10px;
  width: 600px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  font-size: 18px;
  text-align: center;
  background-color: #ffffff;
}
p.shop-address a {
  margin: 10px auto 0 auto;
  display: block;
  width: 540px;
  height: 50px;
  line-height: 50px;
  background-color: #00c2ff;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  font-weight: bold;
  color: #ffffff;
}
p.shop-address a svg {
  margin-right: 10px;
  width: 24px;
  height: 24px;
  fill: #ffffff !important;
  vertical-align: middle;
}
p.shop-sub-time {
  margin-top: 5px;
  padding: 0 10px;
  width: 100%;
  height: 32px;
  line-height: 32px;
  text-align: left;
  color: #000000;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
p.shop-sub-time span {
  margin-right: 5px;
  padding: 0 10px;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  background-color: #f84e7c;
  color: #ffffff;
}
a.shop-tel-button {
  margin: 10px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #fb9e26;
  border: 1px solid #e88704;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.shop-tel-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}
div.tel-caution-box {
  margin: 20px auto 10px auto;
  padding: 10px;
  width: 600px;
  background-color: #888888;
  color: #ffffff;
  font-size: 18px;
}
div.tel-caution-title {
  margin-bottom: 5px;
  height: 30px;
  line-height: 30px;
  background-color: #000000;
  color: #ffff00;
  font-size: 18px;
}
div.tel-caution-title svg {
  margin-left: 10px;
  margin-right: 10px;
  width: 20px;
  height: 20px;
  fill: #ffff00 !important;
}
a.shop-comment-button {
  margin: 10px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #78b5e3;
  border: 1px solid #2984c7;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.shop-comment-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}
a.shop-mail-button {
  margin: 10px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #00e100;
  border: 1px solid #00b300;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.shop-mail-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}
a.gals-profile-button {
  margin: 10px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #f84e7c;
  border: 1px solid #f7225c;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.gals-profile-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}

/* Today Working */
div.today-work-gals-box {
  margin: 10px auto;
  width: 630px;
}
div.today-work-gals-box ul {
  width: 630px;
}
div.today-work-gals-box ul li {
  width: 210px;
  display: inline-block;
}
div.work-gals-box {
}
div.work-gals-box a {
  display: block;
  width: 210px;
  height: 210px;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  overflow: hidden;
  border: double 9px #a30e2c;
}
div.work-gals-box a img {
  width: 100%;
}
p.work-gals-name {
  margin: 5px auto;
  width: 180px;
  height: 36px;
  line-height: 36px;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #a30e2c;
  color: #ffffff;
}
p.work-gals-age {
  margin: 5px auto 0 auto;
  width: 180px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  font-size: 16px;
}
p.work-gals-time {
  margin: 5px auto;
  width: 200px;
  height: 36px;
  line-height: 36px;
  text-align: center;
  color: #a30e2c;
  font-weight: bold;
  background-color: #ffff00;
}

/* Recommend Gals */
div.recommed-gals-box {
  margin: 10px auto;
  width: 630px;
}
div.recommed-gals-box ul {
  width: 630px;
}
div.recommed-gals-box ul li {
  width: 210px;
  display: inline-block;
}
div.recommed-gals-box a {
  display: block;
  width: 210px;
  height: 210px;
  overflow: hidden;
}
div.recommed-gals-box a img {
  width: 100%;
}
p.recommed-gals-name {
  margin: 5px auto;
  width: 180px;
  height: 36px;
  line-height: 36px;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #f84e7c;
  color: #ffffff;
}
p.recommed-gals-age {
  margin: 5px auto 0 auto;
  width: 180px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  font-size: 16px;
}
p.recommed-gals-msg {
  margin: 0 auto;
  width: 180px;
  height: 36px;
  line-height: 36px;
  text-align: center;
  font-size: 12px;
  color: #f84e7c;
  overflow: hidden;
  border-bottom: 2px solid #f84e7c;
}

/* Yacha News Box */
div.yacha-news-box {
  margin: 10px auto;
  width: 630px;
}
ul.news-list {
  margin: 0;
  width: 100%;
}
ul.news-list li {
  width: 630px;
  padding-top: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dashed #e5e5e5;
}
ul.news-list li table {
  width: 100%;
}
ul.news-list li table th {
  width: 80px;
  background-color: #b1ecae;
}
span.yacha-news-date {
  width: 100%;
  font-size: 12px;
  font-weight: bold;
  line-height: 18px;
  display: block;
  background-color: rgba(0, 0, 0, .8);
  color: #ffffff;
  text-align: center;
}
td.news-msg {
  width: 100%;
  vertical-align: top;
}
td.news-msg p {
  padding: 5px;
  width: 100%;
  height: 60px;
  position: relative;
  /*max-height: calc(18 * 1.2 * 2 * 1px);*/
  font-size: 18px;
  line-height: 27px;
  word-break: break-all;
  overflow: hidden;
  background-color: #eaeaea;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
td.news-category {
  height: 30px;
  text-align: left;
  vertical-align: middle;
}
td.news-category p {
  padding: 0 8px;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  font-weight: bold;
  display: inline-block;
  vertical-align: middle;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  color: #ffffff;
}
p.c0, p.c1 {
  background-color: #1a5f16;
}
p.c2 {
  background-color: #c140e0;
}
p.c3 {
  background-color: #ff3e97;
}
p.c4 {
  background-color: #f5823a;
}
div.yacha-news-message {
  margin: 0;
  padding: 10px;
  width: 600px;
  text-align: justify;
  text-justify: inter-ideograph;
}
table.yacha-news-shop-box {
  margin: 10px auto;
  padding: 0;
  width: 590px;
  height: 150px;
}
table.yacha-news-shop-box th {
  width: 150px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
table.yacha-news-shop-box td.rank-detail {
  position: relative;
  vertical-align: top;
}
table.yacha-news-shop-box td p {
  width: 480px;
}
div.yacha-news-image {
  margin: 0;
  padding: 10px;
  width: 600px;
  text-align: center;
}

/* Yacha Blog Box */
div.yacha-blog-box {
  margin: 10px auto;
  width: 630px;
}
table.blog-square-box {
  border-collapse: separate;
  border-spacing: 1px;
}
table.blog-square-box td {
  width: 210px;
  height: 210px;
  text-align: center;
  position: relative;
  border: 1px solid #ffffff;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  vertical-align: bottom;
}
table.blog-square-box td.all-view {
  border: 5px solid #cccccc;
  background-color: #eaeaea;
  vertical-align: middle;
}
p.blog-message {
  padding: 0 5px;
  width: 210px;
  height: 30px;
  line-height: 30px;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #ffffff;
  font-size: 18px;
  background-color: #000000;
  background-color: rgba(0, 0, 0, .8);
}
p.blog-date {
  padding: 0 5px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: left;
  color: #ffffff;
  font-size: 14px;
  background-color: #000000;
  background-color: rgba(0, 0, 0, .8);
}
p.blog-shop {
  padding: 0 5px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: left;
  color: #f84e7c;
  font-size: 14px;
  background-color: #eaeaea;
  background-color: rgba(255, 255, 255, .8);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
p.blog-gals {
  padding: 0 5px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: left;
  color: #f84e7c;
  font-size: 14px;
  font-weight: bold;
  background-color: #eaeaea;
  background-color: rgba(255, 255, 255, .8);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
div.blog-view-title {
  margin: 10px auto;
  width: 600px;
  height: 60px;
  line-height: 60px;
  text-align: center;
  background-color: #ffffff;
  font-size: 32px;
  font-weight: bold;
  color: #db133b;
}
p.blog-view-count-message {
  margin: 10px auto;
  width: 600px;
  text-align: center;
  color: #b6b6b6;
}

/* Button Box */
div.button-box {
  margin: 10px auto 30px auto;
  width: 630px;
}
a.all-view-button {
  margin: 0 auto;
  width: 500px;
  height: 48px;
  line-height: 48px;
  text-align: center;
  display: block;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  background-color: #50a1f3;
  font-weight: bold;
  color: #ffffff;
}

/* Price System Box */
div.shop-price-system-box {
  margin: 0 auto;
  padding-bottom: 20px;
  width: 620px;
}
div.shop-price-system-box table {
  margin: 0;
  width: 100%;
  border-collapse: collapse;
}
div.shop-price-system-box table th,
div.shop-price-system-box table td {
  padding: 5px;
  height: 50px;
  vertical-align: middle;
  border-bottom: 1px solid #bedcfc;
}
div.shop-price-system-box table th {
  width: 200px;
  background-color: #deedfe;
  font-weight: normal;
}
div.shop-price-system-box table td {
  width: 420px;
}
div.shop-price-system-box table td.shop-price-title {
  background-color: #4499f7;
  color: #ffffff;
  font-weight: bold;
}
div.shop-price-system-box table td.shop-price-title svg {
  margin: 0 10px 0 5px;
  width: 24px;
  height: 24px;
  fill: #ffffff !important;
  vertical-align: middle;
}
div.shop-price-system-box table td span.yen {
  font-size: 14px;
}
div.shop-price-system-box table td span.memo {
  font-size: 14px;
  color: #999999;
}

/* Shop Information Box */
div.shop-information-box {
  margin: 0 auto;
  padding: 10px;
  width: 640px;
  overflow: hidden;
}
div.shop-information-box iframe {
  max-width: 620px;
}
div.information-caution-box {
  margin: 0 auto 10px auto;
  padding: 10px;
  width: 640px;
  background-color: #888888;
  color: #ffffff;
  font-size: 18px;
}
div.information-caution-box a {
  color: #ffff00;
}
div.information-caution-title {
  margin-bottom: 5px;
  height: 30px;
  line-height: 30px;
  background-color: #000000;
  color: #ffff00;
  font-size: 18px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
div.information-caution-title svg {
  margin-left: 10px;
  margin-right: 10px;
  width: 20px;
  height: 20px;
  fill: #ffff00 !important;
}

/* Layer */
p.rank-shop {
  padding: 0 5px;
  background-color: #ef9c02;
  width: 440px;
  height: 36px;
  line-height: 36px;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #ffffff;
  font-weight: bold;
}
p.rank-state {
  padding: 0 10px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: right;
  color: #ffffff;
  font-size: 15px;
  font-weight: bold;
  background-color: #333333;
}
p.rank-time {
  margin-top: 5px;
  padding: 0 10px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: left;
  color: #000000;
  font-size: 18px;
  font-weight: bold;
}
p.rank-price {
  margin-top: 5px;
  padding: 0 10px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: left;
  color: #000000;
  font-size: 18px;
  font-weight: bold;
}
p.rank-message {
  margin-top: 5px;
  padding: 0 10px;
  width: 210px;
  height: 40px;
  max-height: 40px;
  line-height: 20px;
  text-align: left;
  color: #000000;
  font-size: 14px;
  position: relative;
  word-break: break-all;
  overflow: hidden;
}
p.rank-message {
  margin-top: 5px;
  padding: 0 10px;
  width: 210px;
  height: 40px;
  max-height: 40px;
  line-height: 20px;
  text-align: left;
  color: #000000;
  font-size: 14px;
  position: relative;
  word-break: break-all;
  overflow: hidden;
}
p.rank-message::before,
p.rank-message::after {
  position: absolute;
  background: #ffffff;
}
p.rank-message::before {
  content: '...';
  top: calc(14 * 1.2 * 1px);
  right: 0;
  width: 30px;
}
p.rank-message::after {
  content: '';
  width: 100%;
  height: 100%;
}
span.rank-icon {
  margin-right: 10px;
  width: 20px;
  height: 20px;
  background-color: #f84e7c;
  display: inline-block;
  text-align: center;
}
span.rank-icon svg {
  width: 14px;
  height: 14px;
  fill: #ffffff !important;
  vertical-align: middle;
}
span.rank-yen-title {
  margin-left: 5px;
  margin-right: 10px;
  font-size: 14px;
  width: 20px;
  height: 20px;
  background-color: #f84e7c;
  border-radius: 100%;
  -webkit-border-radius: 100%;
  -moz-border-radius: 100%;
  display: inline-block;
  text-align: center;
  vertical-align: middle;
  color: #ffffff;
}
span.rank-kara-title {
  font-size: 14px;
}
a.rank-telephone {
  width: 48px;
  height: 48px;
  background-color: #f84e7c;
  position: absolute;
  bottom: 0;
  right: 0;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  text-align: center;
  display: block;
}
a.rank-telephone svg {
  margin-top: 4px;
  width: 40px;
  height: 40px;
  fill: #ffffff !important;
}
a.rank-link {
  width: 48px;
  height: 48px;
  background-color: #f84e7c;
  position: absolute;
  bottom: 0;
  right: 0;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  text-align: center;
  display: block;
}
a.rank-link svg {
  margin-top: 10px;
  width: 28px;
  height: 28px;
  fill: #ffffff !important;
}
a.rank-sub-link {
  width: 48px;
  height: 48px;
  background-color: #f84e7c;
  position: absolute;
  bottom: 0;
  right: 60px;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  text-align: center;
  display: block;
}
a.rank-sub-link svg {
  margin-top: 10px;
  width: 28px;
  height: 28px;
  fill: #ffffff !important;
}
p.rank-gals {
  padding: 0 5px;
  background-color: #f84e7c;
  height: 36px;
  line-height: 36px;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #ffffff;
  font-weight: bold;
}
p.rank-profile {
  padding: 0 10px;
  width: 210px;
  height: 20px;
  line-height: 20px;
  text-align: right;
  color: #ffffff;
  font-size: 14px;
  background-color: #c2073a;
}
p.rank-gals-shop {
  padding: 0 10px;
  width: 210px;
  height: 36px;
  line-height: 36px;
  text-align: left;
  color: #f84e7c;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: bold;
}

/* Gals Page */
div.gals-today-works {
  margin: 0 auto;
  padding: 5px 0;
  width: 640px;
  background-color: #333333;
  color: #ffffff;
}
div.gals-today-works table {
  margin: 0 auto;
  width: 400px;
}
div.gals-today-works table th,
div.gals-today-works table td {
  padding: 5px;
  vertical-align: middle;
}
div.gals-today-works table th {
  width: 200px;
}
div.gals-today-works table th span {
  padding: 5px 0;
  display: block;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #db133b;
  vertical-align: middle;
}
div.gals-today-works table th span svg {
  width: 28px;
  height: 28px;
  fill: #ffffff !important;
  vertical-align: middle;
}
div.gals-today-works table td {
  color: #ffff00;
}
div.shop-gals-header {
  margin: 0 auto;
  padding: 5px;
  width: 640px;
  background-color: #eaeaea;
  border-top: 1px solid #b6b6b6;
  border-bottom: 1px solid #b6b6b6;
}
div.gals-title {
  margin: 0 auto;
  padding: 5px;
  width: 600px;
  font-weight: bold;
  color: #db133b;
  text-align: center;
}
div.gals-name {
  margin: 0 auto;
  padding: 5px;
  width: 600px;
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}
div.gals-size {
  margin: 0 auto;
  padding: 5px;
  width: 600px;
  text-align: center;
}
div.gals-boast {
  margin: 0 auto;
  padding: 5px;
  width: 600px;
  text-align: center;
}
span.boasts {
  margin: 0 auto;
  padding: 5px 0;
  width: 300px;
  display: block;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #f84e7c;
  vertical-align: middle;
  color: #ffffff;
}
span.boasts svg {
  margin-right: 5px;
  width: 28px;
  height: 28px;
  fill: #ffff00 !important;
  vertical-align: middle;
}
div.gals-line {
  margin: 0 auto;
  padding: 5px;
  width: 600px;
  text-align: center;
  color: #f84e7c;
}
div.photo-play-message {
  margin: 10px auto;
  padding: 5px 0;
  width: 600px;
  background-color: #ececec;
  text-align: center;
  font-size: 14px;
}
div.gals-photo-box {
  margin: 10px auto;
  width: 600px;
  height: 800px;
  border: 1px solid #ececec;
}
div.gals-photo {
  width: 600px;
  height: 800px;
  overflow: hidden;
}
div.gals-photo img {
  width: 100%;
}
div.gals-option-box {
  margin: 10px auto;
  width: 600px;
}
div.gals-option-box table {
  width: 100%;
}
div.gals-option-box table th,
div.gals-option-box table td {
  padding: 5px;
  vertical-align: middle;
}
div.gals-option-box table th {
  width: 250px;
}
div.gals-option-box table th span {
  width: 250px;
  height: 40px;
  line-height: 40px;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #e6ecf0;
  display: block;
}
div.gals-option-box table td span.yen {
  font-size: 14px;
}
div.gals-option-box table td span.memo {
  font-size: 14px;
  color: #999999;
}
div.gals-option-box table td span.no-price {
  color: #db133b;
}
div.gals-comment {
  margin: 20px auto 15px auto;
  padding: 7px 10px;
  width: 600px;
  position: relative;
  display: block;
  font-size: 16px;
  background: #fee7ed;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
}
div.gals-comment:before {
  content: '';
  position: absolute;
  top: -30px;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-bottom: 15px solid #fee7ed;
}
div.gals-comment p {
  margin: 0;
  padding: 0;
}
div.gals-shop-comment {
  margin: 10px auto;
  width: 600px;
  overflow: hidden;
}
div.gals-shop-comment .faceicon {
  float: left;
  margin-right: -90px;
  width: 80px;
}
div.gals-shop-comment .faceicon img {
  width: 100%;
  height: auto;
  border: solid 3px #ececec;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
}
div.gals-shop-comment .chatting {
  width: 100%;
}
div.says {
  display: inline-block;
  position: relative; 
  margin: 5px 0 0 105px;
  padding: 17px 13px;
  border-radius: 12px;
  background: #d7ebfe;
  width: 500px;
  font-size: 16px;
}
div.says:after {
  content: '';
  display: inline-block;
  position: absolute;
  top: 18px; 
  left: -24px;
  border: 12px solid transparent;
  border-right: 12px solid #d7ebfe;
}
div.says p {
  margin: 0;
  padding: 0;
}
p.no-data {
  margin: 10px auto;
  padding: 20px 0;
  width: 600px;
  text-align: center;
  background-color: #ececec;
}
ul.gals-line {
  margin: 0 auto;
  padding: 0;
  width: 600px;
  list-style: none;
}
ul.gals-line li {
  margin: 0 0 0 30px;
  padding: 0 1em;
  position: relative;
  display: inline-block;
  height: 30px;
  line-height: 30px;
  background-color: #f84e7c;
  border-radius: 0 3px 3px 0;
  color: #fff;
  font-size: 14px;
  text-decoration: none;
  -webkit-transition: .2s;
  transition: .2s;
}
ul.gals-line li::before {
  position: absolute;
  top: 0;
  left: -15px;
  content: '';
  width: 0;
  height: 0;
  border-color: transparent #f84e7c transparent transparent;
  border-style: solid;
  border-width: 15px 15px 15px 0;
  -webkit-transition: .2s;
  transition: .2s;
}
ul.gals-line li::after {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 2;
  display: block;
  content: '';
  width: 6px;
  height: 6px;
  margin-top: -3px;
  background-color: #fff;
  border-radius: 100%;
}
ul.gals-line li span {
  display: block;
  max-width: 100px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

/* Shop Bottom Menu */
div#shop-bottom-menu-box {
  margin: 0 0 0 -320px;
  padding: 2px 5px;
  width: 640px;
  height: 120px;
  position: fixed;
  bottom: 0;
  left: 50%;
  z-index: 99999;
  display: none;
}
div#shop-bottom-menu-box table {
  margin: 0;
  padding: 0;
  width: 640px;
  border-collapse: collapse;
}
div#shop-bottom-menu-box table td.normal {
  width: 128px;
  vertical-align: bottom;
  font-size: 14px;
}
a.shop-bottom-menu-item {
  margin: 0 auto;
  width: 120px;
  height: 120px;
  display: table;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  background-color: rgba(0 ,0, 0, .8);
  text-align: center;
  color: #ffffff;
}
a.shop-bottom-menu-item span {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
}
a.shop-bottom-menu-item:visited {
  color: #ffffff;
}
a.shop-bottom-menu-item svg {
  margin: 0 auto;
  width: 30px;
  height: 30px;
  fill: #ffffff !important;
  display: block;
}
a.shop-bottom-menu-item-tel {
  margin: 0 auto;
  width: 120px;
  height: 120px;
  display: table;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  background-color: rgba(0 ,0, 0, .8);
  text-align: center;
  color: #ffffff;
}
a.shop-bottom-menu-item-tel span {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
}
a.shop-bottom-menu-item-tel:visited {
  color: #ffffff;
}
a.shop-bottom-menu-item-tel svg {
  margin: 0 auto;
  width: 30px;
  height: 30px;
  fill: #db133b !important;
  display: block;
}
a.svg-blue svg {
  fill: #1da1f2 !important;
}
a.svg-green svg {
  fill: #00b300 !important;
}
a.svg-yellow svg {
  fill: #f0dd56 !important;
}
a.svg-pink svg {
  fill: #f84e7c !important;
}

/* Cast list */
div.cast-list-box {
  margin: 10px auto;
  width: 630px;
}
div.cast-list-box ul {
  width: 630px;
}
div.cast-list-box ul li {
  width: 210px;
  display: inline-block;
}
div.cast-list-box a {
  display: block;
  width: 210px;
  height: 210px;
  overflow: hidden;
  position: relative;
}
div.cast-list-box a img {
  width: 100%;
}
div.cast-list-box a span {
  padding: 5px;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 210px;
  text-align: center;
  display: block;
  z-index: 1;
  background-color: rgba(0 ,0, 0, .8);
  color: #ffff00;
}
p.cast-gals-name {
  margin: 5px auto;
  width: 180px;
  height: 36px;
  line-height: 36px;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #f84e7c;
  color: #ffffff;
}
p.cast-gals-name svg {
  margin-right: 5px;
  width: 28px;
  height: 28px;
  fill: #ffff00 !important;
  vertical-align: middle;
}
p.cast-gals-age {
  margin: 5px auto 0 auto;
  width: 180px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  font-size: 16px;
}

/* Shop Mail */
div.shop-mail-caution-box {
  margin: 0 auto;
  width: 640px;
}
div.shop-mail-caution-box p {
  margin: 10px auto;
  padding: 10px;
  width: 600px;
  background-color: #888888;
  color: #ffffff;
  font-size: 18px;
}
div.shop-mail-form-box {
  margin: 0 auto;
  width: 630px;
}
div.shop-mail-form-box table {
  width: 100%;
}
div.shop-mail-form-box table th,
div.shop-mail-form-box table td {
  padding: 10px 5px;
}
div.shop-mail-form-box table th {
  width: 200px;
  vertical-align: top;
}
div.shop-mail-form-box table th span {
  width: 200px;
  height: 40px;
  line-height: 40px;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  background-color: #e6ecf0;
  display: block;
}
div.shop-mail-form-box table td input {
  padding: 0 10px;
  width: 400px;
  height: 40px;
  line-height: 40px;
  font-size: 18px;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  border: 1px solid #cccccc;
}
div.shop-mail-form-box table td textarea {
  padding: 0 10px;
  width: 400px;
  height: 120px;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
  border: 1px solid #cccccc;
  overflow-y: auto;
  resize: none;
  font-size: 18px;
}
p.form-item-msg {
  margin-top: 5px;
  color: #aaaaaa;
  font-size: 16px;
}
p.form-item-msg span {
  font-size: 20px;
  font-weight: bold;
  color: #ef3d55;
}
p.form-item-required {
  margin-top: 5px;
  color: #ef3d55;
  font-size: 16px;
}
a.shop-send-mail-button {
  margin: 10px auto 30px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #4499f7;
  border: 1px solid #2984c7;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.shop-send-mail-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}
a.shop-no-mail-button {
  margin: 10px auto 30px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #696969;
  border: 1px solid #000000;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.shop-no-mail-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}
div.shop-mail-error-box {
  margin: 0 auto;
  width: 640px;
}
div.shop-mail-error-box p {
  margin: 10px auto;
  padding: 10px;
  width: 600px;
  background-color: #ef3d55;
  color: #ffffff;
  font-size: 18px;
  text-align: center;
}
div.shop-mail-error-box p span {
  padding: 5px;
  display: inline-block;
  background-color: #ffffff;
  color: #ef3d55;
  font-weight: bold;
  border-radius: 7px;
  -webkit-border-radius: 7px;
  -moz-border-radius: 7px;
}

/* Comment */
div.comment-write-button-box {
  margin: 0 auto;
  width: 640px;
}
a.comment-wirte-button {
  margin: 10px auto;
  padding: 20px 0;
  width: 480px;
  background-color: #78b5e3;
  border: 1px solid #2984c7;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  display: block;
}
a.comment-wirte-button svg {
  margin-right: 10px;
  width: 32px;
  height: 32px;
  fill: #ffffff !important;
  vertical-align: bottom;
}
div.comment-list-box {
  margin: 0 auto;
  width: 640px;
}
div.comment-box {
  margin: 10px auto;
  width: 600px;
  overflow: hidden;
}
div.comment-box .faceicon {
  float: left;
  margin-right: -90px;
  width: 80px;
  height: 80px;
  text-align: center;
  display: block;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  background: #89bbd4 url('../images/comment_user.png') no-repeat center center;
  position: relative;
}
div.comment-box .faceicon p {
  background-color: rgba(135, 135, 200, .75);
  width: 80px;
  height: 30px;
  line-height: 30px;
  color: #ffffff;
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: 14px;
}
div.comment-box .chatting {
  width: 100%;
}
p.comment-date {
  width: 100%;
  color: #aaaaaa;
  text-align: right;
}
p.comment-ip-msg {
  margin: 10px auto;
  padding: 10px;
  width: 600px;
  background-color: #add2fc;
  color: #ef3d55;
  font-size: 18px;
}

/* Works */
div.works-date-box {
  margin: 0 auto;
  width: 640px;
}
div.works-date-box table {
  margin: 10px auto;
  width: 630px;
}
div.works-date-box table td {
  padding: 5px;
  width: 105px;
  text-align: center;
  vertical-align: middle;
}
a.works-date-button {
  width: 90px;
  height: 90px;
  vertical-align: middle;
  display: table-cell;
  background-color: #add2fc;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  font-size: 24px;
  color: #ffffff;
}
a.works-date-button:visited {
  color: #ffffff;
}
a.date-active {
  background-color: #f84e7c;
}
span.date-week {
  font-size: 14px;
  display: block;
}
