@charset "UTF-8";
@font-face {
  font-family: "FontAwesome";
  font-style: normal;
  font-weight: normal;
  src: url("../font/fontawesome-webfont.eot") format("embedded-opentype"), url("../font/fontawesome-webfont.woff") format("woff"), url("../font/fontawesome-webfont.ttf") format("truetype"), url("../font/fontawesome-webfont.svg") format("svg");
}
@font-face {
  font-family: "notoLight";
  src: url("../font/NotoSansCJKjp-Light.eot?#iefix") format("embedded-opentype"), url("../font/NotoSansCJKjp-Light.woff") format("woff"), url("../font/NotoSansCJKjp-Light.otf") format("opentype");
}
@font-face {
  font-family: "notoRegular";
  src: url("../font/NotoSansCJKjp-Regular.eot?#iefix") format("embedded-opentype"), url("../font/NotoSansCJKjp-Regular.woff") format("woff"), url("../font/NotoSansCJKjp-Regular.otf") format("opentype");
}
@font-face {
  font-family: "notoBold";
  src: url("../font/NotoSansCJKjp-Bold.eot?#iefix") format("embedded-opentype"), url("../font/NotoSansCJKjp-Bold.woff") format("woff"), url("../font/NotoSansCJKjp-Bold.otf") format("opentype");
}
.notoB {
  font-family: "notoBold";
}

* {
  box-sizing: border-box;
}

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

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

.spOnly {
  display: none;
}

body {
  font-family: "メイリオ",Meiryo,Osaka,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  font-size: 14px;
  color: #333333;
  line-height: 1.5em;
  min-width: 1020px;
}

#header {
  border-top: 6px solid #fda0b1;
  margin: 0 0 35px;
}
#header .inner {
  width: 1020px;
  margin: 0 auto;
}
#header .inner h1 {
  font-size: 12px;
  margin: 4px 0 15px;
}
#header .inner .headerLogo {
  float: left;
}
#header .inner .headerContactArea {
  float: right;
}

#footer {
  background: #F2F2F2;
}
#footer .inner {
  margin: 0 auto;
  padding: 30px 0;
  width: 1020px;
  text-align: center;
}
#footer .inner .fotterContact li {
  display: inline-block;
  margin: 0 15px;
}
#footer .copyright {
  background: #fda0b1;
  color: #fff;
  text-align: center;
  line-height: 40px;
}
#footer .copyright small {
  font-size: 13px;
}

/*-------------------------------------------------------------
 * 下層レイアウト
 *-----------------------------------------------------------*/
.underTitle {
  background: url(../images/shared/under_main_bg01.png) no-repeat center 0;
  background-size: cover;
  height: 200px;
  text-align: center;
  padding: 75px 0 0;
  margin: 0 0 50px;
}
.underTitle h2 {
  background: url(../images/shared/under_main_bg02.png) no-repeat center 0;
  font-family: 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', '游明朝','YuMincho', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
  font-size: 30px;
  line-height: 53px;
}

#underMiddle {
  margin: 0 auto 110px;
  width: 1020px;
}
#underMiddle .contents {
  float: left;
  width: 700px;
}
#underMiddle .contents p {
  margin: 0 0 5px;
}
#underMiddle .sideNavi {
  float: right;
  width: 270px;
}
#underMiddle .sideNavi .sideInner {
  width: 270px;
}
#underMiddle .sideNavi .sideInner .cart {
  border: 10px solid #f5f5f5;
  border-radius: 3px;
  box-shadow: 0 1px 0 #e6e6e6;
  padding: 15px;
  margin: 0 0 30px;
}
#underMiddle .sideNavi .sideInner .total {
  border: 10px solid #f5748d;
  border-radius: 3px;
  box-shadow: 0 1px 0 #e6e6e6;
  padding: 15px 15px;
}
#underMiddle .sideNavi .sideInner .total .title {
  font-family: "notoBold";
  text-align: center;
  margin: 0 0 10px;
  position: relative;
}
#underMiddle .sideNavi .sideInner .total .title:before {
  border-top: 1px solid #333;
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 100%;
  z-index: 0;
}
#underMiddle .sideNavi .sideInner .total .title span {
  background: #fff;
  position: relative;
  z-index: 9999;
  padding: 0 10px;
}
#underMiddle .sideNavi .sideInner .total .totalPrice {
  font-family: "notoBold";
  font-size: 25px;
  text-align: right;
  line-height: 1.5em;
}
#underMiddle .sideNavi .sideInner .total .totalPrice .small {
  font-size: 15px;
  letter-spacing: -0.1em;
  margin: 0 0 0 5px;
}
#underMiddle .sideNavi .sideInner .total .tax {
  font-family: "notoBold";
  font-size: 20px;
  border-bottom: 1px solid #333;
  text-align: right;
  padding: 0 0 10px;
  margin: 0 0 15px;
}

/*-------------------------------------------------------------
 * シミュレーション結果
 *-----------------------------------------------------------*/
.resultHeader {
  padding: 15px 0 0;
}

.resultContents p {
  margin: 0 0 5px;
}

.resultStage01 {
  margin: 0 0 30px;
}
.resultStage01 .peopleArea {
  background: #fff !important;
  border: 10px solid #f5f5f5;
  border-radius: 3px;
  float: left;
  padding: 15px;
  width: 49%;
}
.resultStage01 .totalPriceArea {
  float: right;
  width: 49%;
}
.resultStage01 .totalPriceArea .title {
  font-family: "notoBold";
  font-size: 22px;
  text-align: center;
  margin: 0 0 15px;
  position: relative;
}
.resultStage01 .totalPriceArea .title:before {
  border-top: 1px solid #333;
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 100%;
  z-index: 0;
}
.resultStage01 .totalPriceArea .title span {
  background: #fff;
  position: relative;
  z-index: 9999;
  padding: 0 10px;
}
.resultStage01 .totalPriceArea .price {
  font-family: "notoBold";
  font-size: 30px;
  text-align: right;
}
.resultStage01 .totalPriceArea .price .small {
  font-size: 15px;
  letter-spacing: -0.1em;
}
.resultStage01 .totalPriceArea .tax {
  font-family: "notoBold";
  text-align: right;
}

.resultStage02 .detailPrice {
  overflow: hidden;
  background: #f5f5f5;
  border-radius: 4px;
  font-family: "notoBold";
  font-size: 18px;
  padding: 7px 10px 7px 30px;
  margin: 0 0 10px;
  position: relative;
}
.resultStage02 .detailPrice:before {
  font-family: "FontAwesome";
  content: "\f0c8";
  color: #f5748d;
  font-size: 15px;
  position: absolute;
  left: 10px;
}
.resultStage02 .detailPrice span {
  float: right;
}
.resultStage02 .detailPrice02 {
  overflow: hidden;
  border-bottom: 1px dashed #333;
  font-family: "notoBold";
  font-size: 15px;
  padding: 0 0 5px;
  margin: 0 0 10px;
}
.resultStage02 .detailPrice02 span {
  float: right;
  text-align: right;
}
.resultStage02 .leftArea {
  float: left;
  width: 31%;
}
.resultStage02 .centerArea {
  float: left;
  margin: 0 35px;
  width: 31%;
}
.resultStage02 .rightArea {
  float: right;
  width: 31%;
}

.resultStage03 .button01 a {
  float: left;
  width: 70%;
}
.resultStage03 .button02 a {
  float: right;
  width: 25%;
}

@media print {
  .noprint {
    display: none;
  }

  .print_page {
    width: 172mm;
    height: 251mm;
    page-break-after: always;
  }

  .print_page:last-child {
    page-break-after: auto;
    /* 最後のページの改ページを防ぐ */
  }
}
/*------------
 * 下層パーツ
 --------------*/
.h301 {
  border-bottom: 3px solid #f5748d;
  font-family: 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', '游明朝','YuMincho', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
  font-size: 23px;
  line-height: 1.2em;
  padding: 0 0 10px;
  margin: 0 0 20px;
}

.h401 {
  border-bottom: 1px dashed #333;
  font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  font-weight: bold;
  font-size: 20px;
  line-height: 1.2em;
  padding: 0 0 10px;
  margin: 0 0 20px;
}

.h501 {
  border-left: 7px solid #f5748d;
  font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  font-weight: bold;
  font-size: 18px;
  margin: 0 0 10px;
  padding: 0 0 0 10px;
}

.button01 {
  text-align: center;
}
.button01 a,
.button01 input{
  color: #fff;
  background: #f5748d;
  border: 1px solid #f5748d;
  border-radius: 3px;
  display: inline-block;
  font-family: "notoRegular";
  font-size: 16px;
  margin: 0 auto;
  padding: 15px 40px;
  text-decoration: none;
  transition: 0.5s;
}
.button01 a:hover,
.button01 input:hover{
  background: #fff;
  color: #f5748d;
  cursor:pointer;
}

.button02 {
  text-align: center;
}
.button02 a {
  color: #fff;
  background: #333;
  border: 1px solid #333;
  border-radius: 3px;
  display: inline-block;
  font-family: "notoRegular";
  font-size: 16px;
  margin: 0 auto;
  padding: 15px 40px;
  text-decoration: none;
  transition: 0.5s;
}
.button02 a:hover {
  background: #fff;
  color: #333;
}

.listStyle01 li {
  position: relative;
  list-style: circle inside;
  line-height: 1.3em;
}

.tableStyle01 {
  background: #fff;
  border-collapse: collapse;
  border: 1px solid #dddddd;
  border-width: 1px 0;
  width: 100%;
}
.tableStyle01 th {
  background: #f5f5f5;
  border: 1px solid #dddddd;
  font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  font-weight: bold;
  padding: 5px;
  text-align: left;
  vertical-align: middle;
}
.tableStyle01 td {
  border: 1px solid #dddddd;
  padding: 5px;
  text-align: right;
}

.selectionItems > li {
  position: relative;
  margin: 0 0 30px;
}
.selectionItems > li.active label {
  border: 10px solid #f5748d;
}
.selectionItems > li .radio {
  height: 1px;
  width: 1px;
  position: absolute;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}
.selectionItems > li label {
  cursor: pointer;
  display: block;
  border: 10px solid #f5f5f5;
  border-radius: 3px;
  box-shadow: 0 1px 0 #e6e6e6;
  padding: 15px;
}
.selectionItems > li label .price {
  font-family: "notoBold";
  font-size: 22px;
  margin: 0 0 10px;

}
.selectionItems > li label .price dt {
  float: left;
  position: relative;
  padding: 0 0 0 23px;
}
.selectionItems > li label .price dt:before {
  font-family: "FontAwesome";
  content: "\f0c8";
  color: #f5748d;
  font-size: 15px;
  position: absolute;
  left: 0;
}
.selectionItems > li label .price dd {
  float: right;
  text-align: right;
}
.selectionItems > li label .price dd .yen {
  font-size: 15px;
}
.selectionItems > li label .price dd .small {
  font-size: 14px;
}
.selectionItems > li label .planItems {
  overflow: hidden;
  margin: 0 0 10px;
}
.selectionItems > li label .planItems li {
  float: left;
  width: 10%;
  margin: 0 8px 0 0;
}
.selectionItems > li label .planItems li:nth-child(9n) {
  margin: 0;
}
.selectionItems > li label .imageArea {
  float: right;
  width: 40%;
}
.selectionItems > li label .imageArea .otherImage {
  margin: 10px 0 0;
}
.selectionItems > li label .imageArea .otherImage li {
  float: left;
  width: 31%;
  margin: 0 9px 0 0;
}
.selectionItems > li label .imageArea .otherImage li:nth-child(3n) {
  float: right;
  margin: 0;
}
.selectionItems > li label .imageArea .otherImage li:nth-child(3n+1) {
  clear: both;
}
.selectionItems > li label .imageArea02 ul li {
  float: left;
  width: 48%;
}
.selectionItems > li label .imageArea02 ul li:nth-child(2n) {
  float: right;
}
.selectionItems > li label .readArea {
  float: left;
  width: 58%;
}

.number_of_people {
  border-collapse: collapse;
  width: 100%;
}
.number_of_people th {
  padding: 5px;
  font-family: "notoBold";
  vertical-align: middle;
  text-align: left;
  width: 15%;
}
.number_of_people td {
  padding: 5px;
}

input[type="text"] {
  background: #DFDFDF;
  border: 1px solid #DFDFDF;
  border-radius: 2px;
  box-sizing: border-box;
  text-align: right;
  padding: 0 3px;
  margin: 0 10px 0 0;
  width: auto;
}

input[type="number"] {
  background: #DFDFDF;
  border: 1px solid #DFDFDF;
  border-radius: 2px;
  box-sizing: border-box;
  text-align: right;
  padding: 0 3px;
  margin: 0 10px 0 0;
  width: 12%;
}

/*-------------------------------------------------------------
 * common
 *-----------------------------------------------------------*/
.fixed:after {
  clear: both;
  content: "";
  display: block;
}

.deco {
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.bold {
  font-weight: bold;
}

/*Block*/
.short {
  margin: 0 0 20px;
}

.tall {
  margin: 0 0 40px;
}

/*color*/
.red {
  color: #fa2338;
}

/*font*/
.fs12 {
  font-size: 12px;
}

.fs22 {
  font-size: 22px;
}

/*margin*/
.mb0 {
  margin-bottom: 0 !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

/*text-align*/
.tac {
  text-align: center;
}

.tar {
  text-align: right;
}

.tal {
  text-align: left;
}

/*layout*/
.layout_imageR > .large {
  float: right;
  margin: 0 0 15px 15px;
  width: 40%;
}
.layout_imageR > .medium {
  float: right;
  margin: 0 0 15px 15px;
  width: 35%;
}
.layout_imageR > .small {
  float: right;
  margin: 0 0 15px 15px;
  width: 20%;
}
.layout_imageR .read {
  overflow: hidden;
}

.layout_imageL > .large {
  float: left;
  margin: 0 15px 15px 0;
  width: 40%;
}
.layout_imageL > .medium {
  float: left;
  margin: 0 15px 15px 0;
  width: 35%;
}
.layout_imageL > .small {
  float: left;
  margin: 0 15px 15px 0;
  width: 20%;
}
.layout_imageL .read {
  overflow: hidden;
}

.col3 > li {
  margin: 0 13px 0 0;
  float: left;
  width: 32%;
}
.col3 > li:nth-child(3n) {
  float: right;
  margin: 0;
}
.col3 > li:nth-child(3n+1) {
  clear: both;
}

.option_item_01{
  position:relative;
}
.option_item_01 .disabled_layer{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:#000;
  z-index:9999;
  opacity:0.3;
  display:none;
}
.option_item_01 .disabled_layer p{
  text-align:center;
  padding:30% 0 0;
  color:#fff;
  font-size:24px;
  letter-spacing:0.1em;
}
.button03 {
  text-align: center;
  padding:30px 0 0;
}
.button03 input {
  color:#fff;
  background: #333;
  border: 1px solid #333;
  border-radius: 3px;
  display: inline-block;
  font-family: "notoRegular";
  font-size: 14px;
  margin: 0 auto;
  padding: 5px 40px;
  text-decoration: none;
  transition: 0.5s;
}
.button03 input:hover {
  background: #fff;
  color: #333;
  cursor:pointer;
}

/* single */
/*---投稿大枠---*/
.detailpostdata {
  text-align:left;
}
/*---配置　右---*/
.alignright {
  float:right;
  margin-left:30px;
  margin-bottom:30px;
}
/*---配置　左---*/
.alignleft {
  float:left;
  margin-right:30px;
  margin-bottom:30px;
}
/*---配置　中央---*/
.aligncenter {
  clear:both;
  display:block;
  margin:0 auto 30px;
}
.detailpostdata ol,
.detailpostdata ul{
  margin-bottom:30px;
}
/*---リスト　順序あり---*/
.detailpostdata ol li {
  list-style-type:decimal;
  font-size:100%;
  margin:0 0 0 25px;
  padding:0;
}
/*---リスト　順序なし---*/
.detailpostdata ul li {
  list-style:outside square;
  font-size:100%;
  margin:0 0 0 20px;
  padding:0;
}
/*---テーブル---*/
.detailpostdata table {
  brder-left:1px solid #bfbfbf;
  brder-top:1px solid #bfbfbf;
  brder-right:1px solid #bfbfbf;
}
.detailpostdata table th {
  brder-bottom:1px solid #bfbfbf;
}
.detailpostdata table td {
  brder-bottom:1px solid #bfbfbf;
}
/*---フォント---*/
.detailpostdata em {
  font-style:italic !important;
}
.detailpostdata p{
  margin:0 0 30px;
}
.detailpostdata blockquote{
  line-height: 1.8;
  margin:0 0 30px 0px;
  padding:20px 30px;
  position:relative;
  background:#f7f7f7;
}
.contents .detailpostdata blockquote p:last-child{
  margin:0;
}
.detailpostdata blockquote:before{
  font-family:'FontAwesome';
  content:"\f10d";
  color:#bdc3c8;
  position:absolute;
  top:15px;
  left:10px;
}
.detailpostdata blockquote:after{
  font-family:'FontAwesome';
  content:"\f10e";
  color:#bdc3c8;
  position:absolute;
  right:10px;
  bottom:15px;
}
