@charset "UTF-8";
/**
 * KPM - common.css
 *
 * @copyright  2017 Arcphilia Inc.
 * @license    Proprietary
 * @version    1.0.0
 * @link       http://pan-marche.jp/css/common.css
 * @since      2017-06-02
 * @author     Kenta Shindo
 */

html {
  font-size: 62.5%; /* = 10px */
}

body {
  min-width: 1150px;
  color: #333;
  font-family: "TsukuGoPr5-R", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
  line-height: 2.4rem;

  -webkit-text-size-adjust: 100%;

  position: relative;
}

.sp {
  display: none;
}

.clearfix:after {
  display: block;
  visibility: hidden;
  clear: both;
  height: 0;
  content: " ";
  font-size: 0;
}

.bold,
b,
th {
  font-family: "TsukuGoPro-B", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
}

.zipcodeFont {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

button {
  font-family: "TsukuGoPr5-R", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

/* 筑紫ゴシック Pr5 R (本文) */
.fontTsukuGoPr5-R {
  font-family: TsukuGoPr5-R;
}

/* 筑紫ゴシック Pro B (太字) */
.fontTsukuGoPro-B {
  font-family: TsukuGoPro-B;
}

/* 筑紫ゴシック Pro E（アクセス） */
.fontTsukuGoPro-E {
  font-family: TsukuGoPro-E;
}

/* 筑紫明朝 Pr6 M（ページタイトル, エントリータブ日本語） */
.fontTsukuMinPr6-M {
  font-family: TsukuMinPr6-M;
}

/* 筑紫アンティークSゴシック Std B（カウントダウン, コンセプトタイトル, ページタイトル英語, エントリータブ英語） */
.fontTsukuAntiqueSGoStd-B {
  font-family: TsukuAntiqueSGoStd-B;
}

/* 筑紫オールド明朝 Pro R（コンセプト） */
.fontTsukuOldMinPro-R {
  font-family: TsukuOldMinPro-R;
}

/* セザンヌ Pro M */
.fontCezannePro-M {
  font-family: CezannePro-M;
}

/* セザンヌ Pro B */
.fontCezannePro-B {
  font-family: CezannePro-B;
}

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

a {
  color: #59463f;
}

select::-ms-expand {
  display: none;
}


/**
 * ヘッダー
 */

/* スマートフォンメニューを非表示 */
#globalHeader .spHeader,
#globalHeader .spSlideNav,
#globalHeader .spSlideNavCover,
#globalHeader .spNav {
  display: none;
}

#globalHeader {
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  font-family: 'CezannePro-M';
}
#globalHeader .subNav {
  width: 100%;
  min-width: 1150px;
  height: 40px;
  letter-spacing: .5px;
  background: #f1efe2;
}
#globalHeader .subNav .inner {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  text-align: right;
}
#globalHeader .subNav .inner ul {
  display: inline-block;
  margin: 7px 10px 0 0;
}
#globalHeader .subNav .inner ul li {
  display: inline-block;
  margin: 0 10px 0 0;
  vertical-align: middle;
}
#globalHeader .subNav .inner ul li > * {
  display: inline-block;
  text-decoration: none;
  color: #624a3f;
  border-bottom: 2px solid transparent;
  font-size: 1.2rem;
}
#globalHeader .subNav .inner ul li > a:hover {
  border-bottom-color: #624a3f;
}
#globalHeader .subNav .inner ul li > span {
  opacity: .5;
}
#globalHeader .subNav .inner ul li.subNavMypage {
  position: relative;
  padding: 0 0 0 15px;
}
#globalHeader .subNav .inner ul li.subNavMypage:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 11px;
  height: 22px;
  content: '';
  background-image: url(/images/common/icon/iconKey.png);
}
#globalHeader .subNav .inner .linkYhm,
#globalHeader .subNav .inner .linkKhm {
  position: relative;
  display: block;
  float: right;
  box-sizing: border-box;
  width: 170px;
  height: 30px;
  padding: 0 0 0 10px;
  text-align: left;
  text-decoration: none;
  color: #fff;
  border-radius: 3px;
  background-color: #5B4C3E;
  font-size: 1rem;
  line-height: 30px;
}
#globalHeader .subNav .inner .linkKhm {
  /*margin-left: 7px;*/
  margin: 5px 0 0;
}
#globalHeader .subNav .inner .linkYhm:after,
#globalHeader .subNav .inner .linkKhm:after {
  position: absolute;
  top: 50%;
  right: 9px;
  width: 5px;
  height: 9px;
  margin: -4px 0 0 0;
  content: '';
  background-image: url(/images/common/icon/iconLinkArrow_white.png);
}
#globalHeader .subNav .inner .linkYhm:hover,
#globalHeader .subNav .inner .linkKhm:hover {
  opacity: 0.8;
}
#globalHeader .mainNav {
  position: relative;
  z-index: 10;
  width: 100%;
  min-width: 1150px;
  height: 94px;
  letter-spacing: .1rem;
  background-image: url(/images/common/bgNav.png);
  background-repeat: repeat-x;
}
@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  #globalHeader .mainNav {
    background-image: url(/images/common/bgNav@2x.png);
    background-size: auto 94px;
  }
}
#globalHeader .mainNav .inner {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
#globalHeader .mainNav .inner .logo {
  position: absolute;
  top: -33px;
  left: 0;
  width: 96px;
}
#globalHeader .mainNav .inner .logo a {
  position: relative;
  z-index: 10;
}
#globalHeader .mainNav .inner .logo .hoverAnimal {
  position: absolute;
  z-index: 5;
  right: -68px;
  bottom: 1px;
  -webkit-transition: transform .3s ease;
       -o-transition: transform .3s ease;
          transition: transform .3s ease;
  -webkit-transform: rotate(-70deg);
      -ms-transform: rotate(-70deg);
       -o-transform: rotate(-70deg);
          transform: rotate(-70deg);
  -webkit-transform-origin: left bottom;
     -moz-transform-origin: left bottom;
      -ms-transform-origin: left bottom;
       -o-transform-origin: left bottom;
          transform-origin: left bottom;
}
#globalHeader .mainNav .inner .logo:hover .hoverAnimal {
  -webkit-transform: rotate(0deg);
      -ms-transform: rotate(0deg);
       -o-transform: rotate(0deg);
          transform: rotate(0deg);
}
#globalHeader .mainNav .inner ul {
  float: right;
  line-height: 88px;
}
#globalHeader .mainNav .inner ul li {
  display: inline-block;
  margin: 0 0 0 39px;
}
#globalHeader .mainNav .inner ul li > * {
  position: relative;
  display: inline-block;
  text-decoration: none;
  color: #fff;
  border-bottom: 2px solid transparent;
  font-size: 1.4rem;
  line-height: 2.8rem;
}
#globalHeader .mainNav .inner ul li > a:hover,
#pageAbout #globalHeader .mainNav .inner ul li.mainNavAbout a,
#pageAccess #globalHeader .mainNav .inner ul li.mainNavAccess a,
#pageTicket #globalHeader .mainNav .inner ul li.mainNavTicket a,
#pageCreators #globalHeader .mainNav .inner ul li.mainNavCreators a,
#pageWorkshop  #globalHeader .mainNav .inner ul li.mainNavWorkshop a,
#pageHistory #globalHeader .mainNav .inner ul li.mainNavHistory a,
#pageFaq #globalHeader .mainNav .inner ul li.mainNavFaq a,
#pageEntry #globalHeader .mainNav .inner ul li.mainNavEntry a {
  border-bottom-color: #fff354;
}
#globalHeader .mainNav .inner ul li > span {
  opacity: .5;
}
#globalHeader .mainNav .inner ul li > *:before {
  position: absolute;
  top: 50%;
  left: -16px;
  width: 6px;
  height: 10px;
  margin: -5px 0 0 0;
  content: '';
  background-image: url(/images/common/icon/iconMainNavArrow.png);
}
#globalHeader .mainNav .inner ul li.button > a {
  position: relative;
  box-sizing: border-box;
  width: 225px;
  height: 40px;
  padding: 0 0 0 20px;
  text-align: center;
  color: #463733;
  border-radius: 7px;
  background: #fff354;
  box-shadow: 0 0 5px rgba(0, 0, 0, .2);
  font-size: 1.5rem;
  line-height: 40px;
}
#globalHeader .mainNav .inner ul li.button > a:hover {
  background: #ffe533;
}
#globalHeader .mainNav .inner ul li.mainNavEntry.button > a:before {
  position: absolute;
  top: 50%;
  left: 16px;
  width: 18px;
  height: 18px;
  margin: -9px 0 0 0;
  content: '';
  background-image: url(/images/common/icon/iconPencil.png);
}
#globalHeader .mainNav .inner ul li.mainNavCreators.button > a:before {
  position: absolute;
  top: 50%;
  left: 17px;
  width: 16px;
  height: 18px;
  margin: -9px 0 0 0;
  content: '';
  background-image: url(/images/common/icon/iconHouse.png);
}

/* 過去の様子がナビゲーションに追加されるまでの余白調整 */
#globalHeader .mainNav .inner ul li.tmpMargin {
  margin: 0 0 0 50px;
}

/**
 * メイン
 */
#main {
  overflow: hidden;
  width: 100%;
  margin-top: -6px;
  padding: 134px 0 0 0;
  background-color: #fff;
  background-image: url(/images/common/bgMain.jpg);
  background-repeat: repeat-x;
  background-position: left 134px;
}
@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  #main {
    background-image: url(/images/common/bgMain@2x.jpg);
    background-size: 1600px 600px;
  }
}

/**
 * フッター
 */
#pageTopContainer {
  z-index: 20;
  display: block;
  overflow: hidden;
  width: 91px;
  height: 113px;
  pointer-events: none;
}
#pageTopContainer.absolute {
  position: absolute;
  bottom: 195px;
  right: 10px;
  pointer-events: auto;
}
#pageTopContainer.fixed {
  position: fixed;
  right: 10px;
  bottom: 0;
  pointer-events: auto;
}
#pageTopContainer a {
  position: absolute;
  top: 113px;
  left: 0;
  display: block;
  width: 91px;
  height: 103px;
  -webkit-transition: top .3s ease;
       -o-transition: top .3s ease;
          transition: top .3s ease;
}
#pageTopContainer.show a {
  top: 10px;
}
#pageTopContainer.show:hover a {
  top: 0;
}
#pageTopContainer a img {
  width: 100%;
  height: auto;
}
#globalFooter {
  position: relative;
  display: block;
  width: 100%;
  margin-top: -3px;
  background-image: url(/images/common/bgFooter.png);
  background-repeat: repeat-x;
  z-index: 20;
}
@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  #globalFooter {
    background-image: url(/images/common/bgFooter@2x.png);
    background-size: 21px 230px;
  }
}
#globalFooter .inner {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 0;
}
#globalFooter .inner .footerNav {
  display: inline-block;
  margin: 0 55px 0 0;
  list-style-type: none;
  vertical-align: top;
}
#globalFooter .inner .footerNav li {
  margin: 0 0 5px 0;
}
#globalFooter .inner .footerNav li > * {
  display: inline-block;
  text-decoration: none;
  color: #fff;
  border-bottom: 2px solid transparent;
  font-size: 1.3rem;
  line-height: 2rem;
}
#globalFooter .inner .footerNav li > a:hover {
  border-bottom-color: #f1dd7e;
}
#globalFooter .inner .footerNav li > span {
  color: #ab9d74;
}
#globalFooter .inner .footerNav li.strong a {
  color: #f1dd7e;
}
#globalFooter .inner .official {
  display: inline-block;
}
#globalFooter .inner .official .sns {
  margin: 0 0 20px 0;
  list-style-type: none;
}
#globalFooter .inner .official .sns li {
  display: inline-block;
  width: 30px;
  margin: 0 10px 0 0;
}
#globalFooter .inner .official .sns li a:hover {
  opacity: .8;
}
#globalFooter .inner .official .sponsorship {
  color: #fff;
  font-size: 1.1rem;
}
#globalFooter .inner .official .sponsorship .eventName {
  font-size: 1.3rem;
}
#globalFooter .inner .copyright {
  position: absolute;
  right: 0;
  bottom: 25px;
  width: 234px;
}



/**
 * コンテンツ 汎用フォーマット
 */
.row {
  display: block;
  width: 100%;
}
.row .inner {
  max-width: 1100px;
  margin: 0 auto;
}
.holidayTxt {
  margin: 0 auto 1em;
}

/* 下層ページページタイトル */
/*.pageTitleContainer {
  background-image: url(/images/common/bgPageTitleBack.png);
}*/
.pageTitleContainer .inner {
  height: 150px;
}
.pageTitleContainer .inner .pageTitle {
  padding-top: 55px;
  text-align: center;
  letter-spacing: .15em;
  color: #463733;
  font-family: TsukuMinPr6-M;
  font-size: 3.0rem;
}
.pageTitleContainer .inner .pageTitleEn {
  display: block;
  padding-top: 10px;
  text-align: center;
  letter-spacing: .15em;
  color: #c1b37d;
  font-family: TsukuAntiqueSGoStd-B;
  font-size: 1.6rem;
}

/* タイトル */
.titleBar {
  margin-top: 40px;
  padding: 8px 20px !important;
  color: #fff !important;
  -webkit-border-radius: 4px;
     -moz-border-radius: 4px;
          border-radius: 4px;
  background-color: #6c6041;
  background-image: none !important;
  font-family: TsukuGoPro-B !important;
  font-size: 1.6rem !important;
  line-height: 1.5;
}
.inner > div:first-child .titleBar {
  margin-top: 0;
}

/* マーカー */
.marker {
  background: linear-gradient(transparent 50%, #FFFF00 50%);
}

/* リンク */
.link {
  position: relative;
  display: inline-block;
  padding: 0 0 0 10px;
  vertical-align: middle;
  text-decoration: none;
}
.link:before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 5px;
  height: 9px;
  margin: -5px 0 0 0;
  content: '';
  background-image: url(/images/common/icon/iconLinkArrow.png);
}
.link:hover {
  opacity: .8;
}

.linkText {
  text-decoration: underline;
  color: #00668c;
}
.linkText:hover {
  text-decoration: none;
  opacity: .8;
}

/* 注意書きリスト */
.note {
  color: #888;
}
.note li {
  position: relative;
  padding: 0 0 0 1.1em;
  list-style: none;
  font-size: 1.3rem;
  line-height: 1.5;
}
.note li:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  content: "・";
}
.note.asterisk li:before {
  content: "※";
}
.note.reference li {
  padding-left: 3em;
}
.note.reference li:before {
  content: "参考：";
}
.note strong {
  color: #b20000;
}

/* 重要なコンテンツ */
.importantContent {
  display: block;
  margin: 20px 0;
  padding: 20px 20px 5px;
  border: 2px solid #b46659;
}
.importantContent .importantContentHeading {
  font-size: 1.6rem;
}
.importantContent p {
  margin: 0 0 15px 0;
}

.importantText {
  color: #b20000;
}

/* フォーム要素 */
/* テーブル */
.formContainer .formTitle {
  display: block;
  height: 40px;
  padding: 0 20px;
  color: #fff;
  border-radius: 4px;
  background-color: #6c6043;
  font-size: 1.6rem;
  line-height: 40px;
}
.formContainer .formTableTitle {
  padding: 0 0 0 25px;
  color: #463733;
  background-image: url(/images/common/icon/iconLead.png);
  background-repeat: no-repeat;
  background-position: left center;
  font-size: 1.6rem;
}
.formContainer .caption {
  max-width: 960px;
  margin: 0 auto;
  padding: 20px 0;
  text-align: left;
}
.formContainer .formTable {
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  border: 1px solid #ddd;
  background-color: #fff;
}
.formContainer .formTable + .formTable {
  margin: 10px auto 0;
}
.formContainer .formTable caption {
  position: relative;
  padding: 20px 0;
  text-align: left;
}
.formContainer .formTable caption .info {
  float: right;
  margin: -30px 0 0 0;
  padding: 5px 10px 3px;
  color: #c54641;
  border: 1px solid #c54641;
  font-weight: bold;
}
.formContainer .formTable caption .info + * {
  clear: both;
}
.formContainer .formTable caption strong {
  color: #b20000;
}
.formContainer .formTable th {
  width: 180px;
  padding: 0 0 0 20px;
  text-align: left;
  vertical-align: middle;
  border: 1px solid #ddd;
  background-color: #f1efe2;
  font-size: 1.3rem;
}
.formContainer .formTable th span {
  font-size: 1.1rem;
}
.formContainer .formTable td {
  padding: 15px 20px 15px 20px;
  vertical-align: middle;
  border: 1px solid #ddd;
}
.formContainer .formTable td .spLabel {
  display: none;
}
.formContainer .formTable td .field {
  display: inline-block;
  margin: 0 5px 8px 0;
  vertical-align: top;
}
.formContainer .formTable td .field.lLarge {
  margin-right: 0;
}
.formContainer .formTable td .field.noMarginContainer {
  margin: 0;
}
.formContainer .formTable td .field .fieldCheckbox {
  margin: 0 5px 10px 0;
}
.formContainer .formTable td .field .file {
  margin: 0 5px 5px 0;
}
.formContainer .formTable .note {
  color: #525252;
}
.formContainer .formTable td .errorText {
  margin: 0 0 5px 0;
}

/* オプション */
.formContainer .formTable.option td {
  padding: 5px 20px;
  border-right: 1px dotted #ddd;
  border-left: 1px dotted #ddd;
}
.formContainer .formTable.option td .specification {
  color: #777;
}

/* インプット */
.field {
  position: relative;
  width: 350px;
}
.field.short {
  width: 200px;
}
.field.sShort {
  width: 90px;
}
.field.ssShort {
  width: 60px;
}
.field.lLarge {
  width: 100%;
}
.field .fieldLabel {
  position: absolute;
  padding: 4px 10px;
  -webkit-transition: transform .2s ease-out;
          transition: transform .2s ease-out;
  -webkit-transform: translateY(3px);
          transform: translateY(3px);
  text-align: left;
  text-overflow: ellipsis;
  pointer-events: none;
  opacity: 0;
  color: #999;
  font-size: 1.1rem;
  line-height: 1;
}
.field input[type='text'],
.field input[type='email'],
.field input[type='password'] {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  height: 36px;
  padding: 10px;
  -webkit-transition: transform .2s ease-out;
          transition: transform .2s ease-out;
  border: 1px solid #ccc;
  border-radius: 3px;
  background-color: #f6f5ed;
  font-size: 1.4rem;
}
.field textarea {
  display: block;
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  height: 150px;
  padding: 10px;
  -webkit-transition: transform .2s ease-out;
          transition: transform .2s ease-out;
  border: 1px solid #ccc;
  border-radius: 3px;
  background-color: #f6f5ed;
  font-size: 1.4rem;
}
.field select {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  height: 36px;
  padding: 0 10px;
  border: 1px solid #ccc;
  border-radius: 3px;
  background-color: #f6f5ed;
  background-image: url(/images/common/icon/iconSelectArrow.png);
  background-repeat: no-repeat;
  background-position: right center;
  font-size: 1.4rem;

  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.field .fieldCheckbox {
  position: relative;
  display: inline-block;
  vertical-align: top;
}
.field .fieldCheckbox input {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
.field .fieldCheckbox label {
  display: block;
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  width: 135px;
  height: 35px;
  cursor: pointer;
  text-align: center;
  border: 1px solid #ccc;
  border-radius: 3px;
  background: #fff;
  background:    -moz-linear-gradient(top, #fff 0%, #f6f5ed 50%);
  background: -webkit-linear-gradient(top, #fff 0%,#f6f5ed 50%);
  background:         linear-gradient(to bottom, #fff 0%,#f6f5ed 50%);
  line-height: 35px;

  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f9f6f3',GradientType=0 );
}
.field .fieldCheckbox.btnBrown label {
  color: #fff;
  background: #867c71;
  background:    -moz-linear-gradient(top,  #867c71 0%, #6d6155 50%);
  background: -webkit-linear-gradient(top,  #867c71 0%,#6d6155 50%);
  background:         linear-gradient(to bottom,  #867c71 0%,#6d6155 50%);

  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#867c71', endColorstr='#6d6155',GradientType=0 );
}
.field .fieldCheckbox input:checked + label,
.field .fieldCheckbox.btnBrown input:checked + label {
  color: #fff;
  border-color: #df9224;
  background: #df9224;
}
.field .fieldCheckbox input:disabled + label,
.field .fieldCheckbox.btnBrown input:disabled + label {
  color: #fff;
  border-color: #ccc;
  background: #ccc;
}
.field .file {
  position: relative;
  display: inline-block;
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  width: 135px;
  height: 135px;
  vertical-align: top;
  border: 1px solid #ccc;
  border-radius: 3px;
  background-color: #f6f5ed;
  background-image: url(/images/common/bgImageSelect.png);
  background-repeat: no-repeat;
  background-position: center center;
}
.field .file .fileInput {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  overflow: hidden;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center;
  -webkit-background-size: contain;
          background-size: contain;
}
.field .file .fileInput input[type="file"] {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  cursor: pointer;
  opacity: 0;
  font-size: 200px;

  filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0);
}
.field .file .thumb {
  position: absolute;
  top: 50%;
  left: 50%;
  display: none;
  width: 120px;
  height: 120px;
  margin: -60px 0 0 -60px;
  background-repeat: no-repeat;
  background-position: center;
  -webkit-background-size: contain;
          background-size: contain;
}
.field .file .remove {
  position: absolute;
  top: -7px;
  right: -7px;
  display: none;
  width: 30px;
  height: 30px;
  cursor: pointer;
  background-image: url(/images/common/btnImageRemove.png);
}
.field .file.readImage {
  border-color: #6d6154;
  background-image: none;
}
.field .file.readImage .fileInput {
  display: none;
}
.field .file.readImage .thumb {
  display: block;
}
.field .file.readImage .remove {
  display: block;
}
.field.error input[type='text'],
.field.error input[type='email'],
.field.error input[type='password'],
.field.error textarea,
.field.error select,
.field .file.error {
  background-color: #ffdfe0 !important;
}
::-webkit-input-placeholder {
  color: #999;
}
/* 横並びのテキスト */
.fieldInlineText {
  display: inline-block;
  height: 36px;
  vertical-align: top;
  line-height: 36px;
}

/* 独立したインプット
主にパスワード入力フォーム・メールアドレスで利用します
*/
.inputBox {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  max-width: 700px;
  margin: 0 auto;
  padding: 20px 40px;
  text-align: center;
  background: #f1efe2;
}
.inputBox + .inputBox {
  margin: 10px auto 0;
}
.inputBox .label {
  display: block;
  margin: 0 0 5px 0;
  text-align: left;
  font-size: 1.4rem;
}
.inputBox .field {
  width: 100%;
}
.inputBox .field input[type='text'],
.inputBox .field input[type='email'],
.inputBox .field input[type='password'],
.inputBox .field textarea,
.inputBox .field select {
  background-color: #fff;
}

.inputBox.horizontal .label {
  display: inline-block;
  width: 130px;
  margin: 0 10px 0 0;
  vertical-align: middle;
  font-size: 1.3rem;
  line-height: 1.5;
}
.inputBox.horizontal .field {
  display: inline-block;
  max-width: 400px;
  vertical-align: middle;
}

/* 送信ボタン */
.formBtn {
  position: relative;
  text-align: center;
}
.formBtn button {
  display: inline-block;
  width: 88%;
  max-width: 300px;
  height: 50px;
  cursor: pointer;
  text-align: center;
  color: #fff;
  border: none;
  border-radius: 6px;
  background: #857b63;
  background:    -moz-linear-gradient(top,  #857b63 0%, #6c6043 50%);
  background: -webkit-linear-gradient(top,  #857b63 0%,#6c6043 50%);
  background:         linear-gradient(to bottom,  #857b63 0%,#6c6043 50%);
  font-size: 1.8rem;

  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#857B63', endColorstr='#6C6043',GradientType=0 );
}
.formBtn button:hover {
  opacity: .8;
}
.formBtn .linkBtn {
  display: inline-block;
  width: 80%;
  max-width: 300px;
  padding: 20px 10px;
  text-align: center;
  text-decoration: none;
  color: #fff;
  border-radius: 6px;
  background: #857b63;
  background:    -moz-linear-gradient(top,  #857b63 0%, #6c6043 50%);
  background: -webkit-linear-gradient(top,  #857b63 0%,#6c6043 50%);
  background:         linear-gradient(to bottom,  #857b63 0%,#6c6043 50%);
  font-size: 2.4rem;

  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#857B63', endColorstr='#6C6043',GradientType=0 );
}
.formBtn .linkBtn:hover {
  opacity: .8;
}
.formBtn .backLinkBtn {
  display: inline-block;
  margin: 0 30px 0 -50px;
  padding: 0 0 0 20px;
  vertical-align: bottom;
  text-decoration: none;
  background-image: url(/images/common/icon/iconLinkArrowBack.png);
  background-repeat: no-repeat;
  background-position: left center;
}
.formBtn .backLinkBtn:hover {
  opacity: .8;
}
.formBtn .formBtnNote {
  margin: 20px 0 0 0;
  text-align: center;
  font-size: 1.3rem;
}

/* エラーテキスト */
.errorText {
  min-height: 20px;
  padding: 0 0 0 25px;
  text-align: left;
  color: #b20000;
  background-image: url(/images/common/icon/iconError.png);
  background-repeat: no-repeat;
  background-position: left top;
  font-size: 1.3rem;
  line-height: 20px;
}

/* エラー通知 */
.errorInfo {
  position: relative;
  display: block;
  max-width: 560px;
  margin: 40px auto 20px;
  padding: 30px 20px 15px;
  text-align: center;
  color: #b20000;
  border: 1px solid #b20000;
  border-radius: 4px;
  background-color: #ffeff0;
}
.errorInfo:before {
  position: absolute;
  top: -20px;
  left: 50%;
  display: block;
  width: 40px;
  height: 40px;
  margin: 0 0 0 -20px;
  content: '';
  background-image: url(/images/common/imgError.png);
}

/* 完了案内 */
.saveResult {
  margin: 0 auto 20px auto;
  text-align: center;
}
.saveResult span {
  display: inline-block;
  width: 300px;
  margin: 0 0 10px 0;
  padding: 10px 0;
  animation: show .5s both;
  animation-delay: .5s;
  text-align: center;
  opacity: 0;
  color: #fff;
  border-radius: 3px;
  background: #b3665b;
  font-size: 1.3rem;
}
@keyframes show {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* フォーム完了ページ
メール送信完了ページ等のフォーマット */
.finishContent {
  padding: 50px 20px;
  text-align: center;
}
.finishContent .finishContentImg {
  margin: 0 0 30px 0;
}
.finishContent p {
  font-size: 1.6rem;
}
.finishContent span {
  font-size: 1.4rem;
}

/* 電話お問い合わせ */
.telInfoContainer {
  display: block;
  max-width: 360px;
  margin: 0 auto;
  padding: 10px 0;
  color: #463733;
}
.telInfoContainer > p {
  margin: 0 0 10px 0;
  text-align: center;
}
.telInfoContainer .telInfo {
  padding: 5px 0;
  text-align: center;
  background: #f1efe2;
}
.telInfoContainer .telInfo > .inner {
  padding: 10px 0;
  border-top: 1px dashed #6d6155;
  border-bottom: 1px dashed #6d6155;
}
.telInfoContainer .telInfo > .inner .name {
  margin: 0 0 10px 0;
}
.telInfoContainer .telInfo > .inner .number {
  margin: 0 0 10px 0;
  font-size: 2.8rem;
}
.telInfoContainer .telInfo > .inner .time {
  font-size: 1.3rem;
}


/**
 * 出店一覧
 */


.exhibitorItemList {
  width: 1245px;
  margin: 0 0 50px 0;
  list-style-type: none;
}
.exhibitorItem {
  float: left;
  width: 370px;
  height: 300px;
  margin: 0 45px 30px 0;
  background: #fff;
  cursor: pointer;
  position: relative;
}
.exhibitorItem:hover {
  opacity: .7;
}
.exhibitorItem a {
  text-decoration: none;
}

/* 日付 */
.exhibitorItem .date {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 15px;
  font-size: 13px;
  width: 90%;
}
.exhibitorItem .date li {
  float: left;
  margin: 0 10px 0 0;
  list-style-type: none;
}
.exhibitorItem .date p {
  display: block;
  text-align: center;
  color: #6b5f42;
  font-weight: bold;
  overflow: hidden;
  white-space: nowrap;
  width: 45px;
  height: 25px;
  line-height: 25px;
  font-size: 14px;
  background: #FEF9DE;
}
.exhibitorItem .date .eventSaturday {
  background: #b4e2e8;
}
.exhibitorItem .date .eventSunday {
  background: #F6E2E3;
}

/* アイコン */
.exhibitorItem .icon {
  position: absolute;
  top: 50px;
  left: 42px;
  width: 39px;
  height: 34px;
  -webkit-background-size: 39px 34px;
  background-size: 39px 34px;
}
/* アイコン : HANDMADE */
.exhibitorItem.entryType1 .icon {
  background-image: url(/images/creators/iconHandmadeBooth@2x.png);
}
/* アイコン : BREAD */
.exhibitorItem.entryType2 .icon {
  background-image: url(/images/creators/iconBreadBooth@2x.png);
}
/* アイコン : BAKE */
.exhibitorItem.entryType4 .icon {
  background-image: url(/images/creators/iconBakeBooth@2x.png);
}
/* アイコン : WITH */
.exhibitorItem.entryType5 .icon {
  background-image: url(/images/creators/iconWithBooth@2x.png);
}
/* アイコン : KITCHENCAR */
.exhibitorItem.entryType6 .icon {
  width: 50px;
  height: 31px;
  -webkit-background-size: 50px 31px;
  background-size: 50px 31px;
  background-image: url(/images/creators/iconKitchenCar@2x.png);
}

/* 出店タイプ */
.exhibitorItem .type {
  position: absolute;
  top: 100px;
  left: 12px;
  width: 102px;
  height: 36px;
  -webkit-background-size: 102px 36px;
  background-size: 102px 36px;
}
/* 出店タイプ : HANDMADE */
.exhibitorItem.entryType1 .type {
  background-image: url(/images/creators/titleHandmadeBooth@2x.png);
}
/* 出店タイプ : BREAD */
.exhibitorItem.entryType2 .type {
  background-image: url(/images/creators/titleBreadBooth@2x.png);
}
/* 出店タイプ : BAKE */
.exhibitorItem.entryType4 .type {
  background-image: url(/images/creators/titleBakeBooth@2x.png);
}
/* 出店タイプ : WITH */
.exhibitorItem.entryType5 .type {
  background-image: url(/images/creators/titleWithBooth@2x.png);
}
/* 出店タイプ : KITCHENCAR */
.exhibitorItem.entryType6 .type {
  top: 100px;
  left: 28px;
  width: 73px;
  height: 36px;
  -webkit-background-size: 73px 36px;
  background-size: 70px 36px;
  background-image: url(/images/creators/titleKitchenCar@2x.png);
}

/* 店舗エリア */
.exhibitorItem .place {
  position: absolute;
  top: 150px;
  left: 0;
  width: 125px;
  text-align: center;
  font-size: 1.7rem;
  color: #59453A;
  font-family: CezannePro-B;
}

/* 画像 */
.exhibitorItem .img {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 230px;
  height: 170px;
  -webkit-background-size: cover;
  background-size: cover;
  background-position: center;
}

/* 店舗名 */
.exhibitorItem .name {
  position: absolute;
  top: 210px;
  left: 0;
  width: 100%;
  padding: 0 15px;
  text-align: center;
  font-size: 2.3rem;
  color: #5F4A3F;
  background-image: url(/images/creators/bgName@2x.png);
  -webkit-background-size: 30px 23px;
  background-size: 30px 23px;
  font-family: CezannePro-M;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

/* ジャンル */
.exhibitorItem .tag {
  position: absolute;
  top: 254px;
  left: 0;
  width: 100%;
  padding: 0 15px;
  text-align: center;
  font-size: 1.5rem;
  color: #7A6C4A;
  font-family: CezannePro-M;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}




/**
 * コンテンツアニメーション
 * common.jsに記述された処理と連動しています
 *
 * e.g.
 * <div id="content" class="animation left2right" data-animation-delay="1000"> ... </div>
 * このようにクラス設定すると 左から右 に表示されるアニメーションになります。
 * また、 data-animation-delay 属性を設定すると、値のミリ秒分遅延して表示されます。
 */
.animation {
  transition: transform 1s ease, opacity 1s ease;
  opacity: 0;
}
.animation.show {
  opacity: 1;
}

/* left -> right */
.animation.left2right {
  transform: translateX(-30px);
}
.animation.left2right.show {
  transform: translateX(0);
}

/* right -> left */
.animation.right2left {
  transform: translateX(30px);
}
.animation.right2left.show {
  transform: translateX(0);
}

/* bottom -> top */
.animation.bottom2top {
  transform: translateY(30px);
}
.animation.bottom2top.show {
  transform: translateY(0);
}

/* top -> bottom */
.animation.top2bottom {
  transform: translateY(-30px);
}
.animation.top2bottom.show {
  transform: translateY(0);
}

/**
 * Retina用背景画像の指定
 */
@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  /**
   * ヘッダー
   */
  #globalHeader .subNav .inner ul li.subNavMypage:before {
    background-image: url(/images/common/icon/iconKey@2x.png);
    -webkit-background-size: 11px 22px;
            background-size: 11px 22px;
  }
  #globalHeader .subNav .inner .linkYhm:after {
    background-image: url(/images/common/icon/iconLinkArrow@2x.png);
    -webkit-background-size: 5px 9px;
            background-size: 5px 9px;
  }
  #globalHeader .mainNav .inner ul li > *:before {
    background-image: url(/images/common/icon/iconMainNavArrow@2x.png);
    -webkit-background-size: 6px 10px;
            background-size: 6px 10px;
  }
  #globalHeader .mainNav .inner ul li.mainNavEntry.button > a:before {
    background-image: url(/images/common/icon/iconPencil@2x.png);
    -webkit-background-size: 18px 18px;
            background-size: 18px 18px;
  }
  #globalHeader .mainNav .inner ul li.mainNavCreators.button > a:before {
    background-image: url(/images/common/icon/iconHouse@2x.png);
    -webkit-background-size: 16px 18px;
    background-size: 16px 18px;
  }

  /**
   * コンテンツ 汎用フォーマット
   */

  /* リンク */
  .link:before {
    background-image: url(/images/common/icon/iconLinkArrow@2x.png);
    -webkit-background-size: 5px 9px;
            background-size: 5px 9px;
  }

  /* フォーム要素 */
  /* テーブル */
  .formContainer .formTableTitle {
    background-image: url(/images/common/icon/iconLead@2x.png);
    -webkit-background-size: 16px 16px;
            background-size: 16px 16px;
  }

  /* インプット */
  .field select {
    background-image: url(/images/common/icon/iconSelectArrow@2x.png);
    -webkit-background-size: 13px 7px;
            background-size: 13px 7px;
  }
  .field .file {
    background-image: url(/images/common/bgImageSelect@2x.png);
    -webkit-background-size: 67px 53px;
            background-size: 67px 53px;
  }
  .field .file .remove {
    background-image: url(/images/common/btnImageRemove@2x.png);
    -webkit-background-size: 30px 30px;
            background-size: 30px 30px;
  }

  /* 送信ボタン */
  .formBtn .backLinkBtn {
    background-image: url(/images/common/icon/iconLinkArrowBack.png);
    -webkit-background-size: 8px 12px;
            background-size: 8px 12px;
  }

  /* エラーテキスト */
  .errorText {
    background-image: url(/images/common/icon/iconError@2x.png);
    -webkit-background-size: 20px 20px;
            background-size: 20px 20px;
  }

  /* エラー通知 */
  .errorInfo:before {
    background-image: url(/images/common/imgError@2x.png);
    -webkit-background-size: 40px 40px;
            background-size: 40px 40px;
  }
}
