@charset 'utf-8';

/***** Base Design *****/
body {
  width: 100%;
  min-width: 1120px;/*1434px;*/
  background-color: #000;
  letter-spacing: -0.06em;
  font-family: "LogoTypeGothicCondense07","游ゴシック","Yu Gothic",YuGothic,"ヒラギノ角ゴ ProN W3","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"Meiryo UI","MS PGothic","ＭＳ Ｐゴシック", sans-serif;
  color: #fff;
}
body.page_concept {
  background-image: url('./../../images/concept/concept_movie_bg.jpg');
  background-repeat: repeat-y;
  background-position: left top;
  background-size: auto;
}
a {
  color: #fff;
}


/***** Layout *****/
#container {
  overflow: hidden;
  position: relative;
  min-height: 100%;
}
.box_content {
  padding: 0;
}
body:not(.home):not(.page_concept):not(.page_staff):not(.page_staff_s) .box_content {
  margin-bottom: -145px;
  padding-top: 78px;
  padding-bottom: 280px;
  background-color: #e1dbcd;
  background-image: url('./../../images/common/common-img-mv-bottom.png'),url('./../../images/common/common-bottom-bg01.png'),url('./../../images/common/common-bg01.png');
  background-repeat: no-repeat, no-repeat, repeat-y;
  background-position: center top, center bottom, center top;
  background-size: auto 63px, auto 230px, auto 830px;
  color: #000;
}
body.page_concept .box_content {
  /*min-height: 1440px;*/
  margin-bottom: -145px;
  padding-bottom: 280px;
  background-image: url('./../../images/common/common-bottom-bg01.png'),url(./../../images/index/index-bg02.png);
  background-repeat: no-repeat,no-repeat;
  background-position: center bottom,center bottom -155px;
  background-size: auto 230px,auto 1440px;
}
body.page_staff .box_content {
  height: 1725px;
  margin-top: -197px;
  margin-bottom: -275px;/*-605px;*/
  padding-top: 960px;
  background-color: #000;
  background-image: url('./../../images/common/common-bottom-bg02.png'),url('./../../images/staff/staff-bg01.jpg');
  background-repeat: no-repeat, no-repeat;
  background-position: center bottom, center top;
  background-size: auto 354px, auto 1334px;
  color: #fff;
}
body.page_staff_s .box_content {
  margin-bottom: -145px;
  padding-top: 78px;
  padding-bottom: 280px;
  background-color: #e1dbcd;
  background-image: url('./../../images/common/common-img-mv-bottom.png'),url('./../../images/staff/staff-s-bottom-bg01.png'),url('./../../images/common/common-bg01.png');
  background-repeat: no-repeat, no-repeat, repeat-y;
  background-position: center top, center bottom, center top;
  background-size: auto 63px, auto 844px, auto 830px;
  color: #000;
}
body:not(.home):not(.page_concept):not(.page_staff) .box_content a {
  color: #000;
}


/***** Header *****/
header {
}
.box_header01 {
  height: 63px;
  background-image: url('./../../images/common/header-bg01.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: auto 63px;
}
.box_header01_in {
  position: relative;
  z-index: 3;
  padding-top: 12px;
  padding-right: 15px;
  text-align: center;
  letter-spacing: 0.03em;
}
.box_header01_in .txt_header_com01 {
  margin-right: 21px;
}
.box_header01_in .txt_header_telno {
  position: relative;
  top: -4px;
  margin-right: 5px;
  vertical-align: top;
  font-size: 1.6rem;
  color: #ffdf4b;
}
.box_header01_in .txt_header_business_time {
}
.box_header01_in_fixed {
  display: none;
}
/*
.box_header02 {
  width: 1100px;
  height: 10px;
  margin: 0 auto;
  background-color: #ff0000;
}*/
.box_header_menu {
  position: relative;
  top: -23px;
  z-index: 5;
  width: 1220px;
  height: 175px;
  margin: 0 auto;
  background-image: url('./../../images/common/header-menu-bg01.png');
  background-repeat: no-repeat;
  background-position: left top;
  background-size: auto 175px;
}
.page_catalog .box_header_menu {
  background-image: url('./../../images/common/header-menu-bg01-v02.png');
}
.box_header_menu li {
  position: absolute;
  letter-spacing: normal;
  font-size: 1.4rem;
  text-shadow: 0 0 2px rgba(0,0,0,1), 0 0 3px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,1);
}
.box_header_menu li.li_logo {
  top: 22px;
  left: 93px;
}
.box_header_menu li.li_map {
  top: 92px;
  left: 285px;
}
.box_header_menu li.li_concept {
  top: 35px;
  left: 312px;
  letter-spacing: 0.03em;
}
.box_header_menu li.li_rental {
  top: 78px;
  left: 441px;
  letter-spacing: -0.1em;
}
.box_header_menu li.li_product {
  top: 20px;
  left: 523px;
  letter-spacing: 0.1em;
}
.box_header_menu li.li_gift {
  top: 49px;
  left: 685px;
  letter-spacing: 0.1em;
}
.page_catalog .box_header_menu li.li_gift {
  top: 101px;
  left: 680px;
}
.box_header_menu li.li_catalog {
  top: 41px;
  left: 660px;
  letter-spacing: 0.1em;
}
.box_header_menu li.li_business {
  top: 21px;
  left: 852px;
  letter-spacing: 0.1em;
}
.box_header_menu li.li_staff {
  top: 73px;
  left: 998px;
  letter-spacing: 0.03em;
}
.box_header_menu li.li_company,
.box_header_menu li.li_news,
.box_header_menu li.li_contact {
  display: none;
}


/***** HmbMenu *****/
.boxHmbMenu {
  display: none;
}


/***** Top *****/
.box_mv {
  overflow: hidden;
  position: relative;
  z-index: -1;
  width: 100%;
  height: 597px;
  margin-top: -238px;
}
body.home .box_mv {
  height: 1131px;
}
body.page_concept .box_mv {
  height: 1131px;
}
.box_mv_in {
  position: absolute;
  top: 0;
  left: 50%;
  width: 2000px;
  height: 100%;
  transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: auto 597px;
}
body.page_404 .box_mv_in {
  background-image: url('./../../images/404/404-mv.jpg');
}
body.page_business .box_mv_in {
  background-image: url('./../../images/business/business-mv.jpg');
}
body.page_catalog .box_mv_in {
  background-image: url('./../../images/catalog/catalog-mv.jpg');
}
body.page_company .box_mv_in {
  background-image: url('./../../images/company/company-mv.jpg');
}
body.page_concept .box_mv_in {
  width: 100%;
}
body.page_concept .box_mv_in video {
  width: 100%;
}
body.page_contact .box_mv_in {
  background-image: url('./../../images/contact/contact-mv.jpg');
}
body.page_gift .box_mv_in {
  background-image: url('./../../images/gift/gift-mv.jpg');
}
body.home .box_mv_in {
  background-image: url('./../../images/index/index-bg01.jpg');
  background-size: auto 1131px;
}
body.page_news .box_mv_in {
  background-image: url('./../../images/news/news-mv.jpg');
}
body.page_product .box_mv_in {
  background-image: url('./../../images/product/product-mv.jpg');
}
body.page_rental .box_mv_in {
  background-image: url('./../../images/rental/rental-mv.jpg');
}
body.page_staff_s .box_mv_in.no01 {
  background-image: url('./../../images/staff/staff-s-mv01.jpg');
}
body.page_staff_s .box_mv_in.no02 {
  background-image: url('./../../images/staff/staff-s-mv02.jpg');
}
body.page_staff_s .box_mv_in.no03 {
  background-image: url('./../../images/staff/staff-s-mv03.jpg');
}
.box_mv .ttl_mv {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(20%);
  -ms-transform: translateX(-50%) translateY(20%);
  font-size: 3.5rem;
  font-weight: 700;
  color: #000;
}
body.page_staff_s .box_mv .ttl_mv {
  transform: translateX(-50%) translateY(-27%);
  -ms-transform: translateX(-50%) translateY(-27%);
}
.box_mv .txt_mv01 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(360%);
  -ms-transform: translateX(-50%) translateY(360%);
}
.box_mv .txt_mv01 > span {
  display: inline-block;
  padding: 2px 15px 4px 15px;
  background-color: rgba(255,255,255,0.8);
  font-size: 2.0rem;
  letter-spacing: -0.1em;
  color: #000;
}


/***** Footer *****/
footer {
}
.box_footer {
  position: relative;
  height: 919px;
  background-image: url('./../../images/common/footer-bg01.png');
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: auto 799px;
}
.box_footer01 {
  position: relative;
  z-index: 5;
  right: 200px;/*105px;320px;*/
  width: 1434px;
  height: 919px;
  margin: 0 auto;
  background-image: url('./../../images/common/footer-bg02.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: auto 919px;
}
.box_footer_news {
  position: absolute;
  top: 252px;
  left: 1057px;1075px;
  width: 269px;
  color: #fff;
}
.box_footer_news .btn_uptotop {
  display: none;
}
.box_footer_news a {
  color: #fff;
}
.box_footer_news .box_list {
  width: 236px;
  margin-left: 18px;
  font-size: 1.25rem;
}
.box_footer_news .box_list .box_list_one {
  margin-bottom: 27px;
}
.box_footer_news .box_list .box_date {
  margin-bottom: 11px;
}
.box_footer_news .box_list .box_cont {
  line-height: 1.4;
}
.box_footer_news .box_link_to_archive {
  text-align: right;
}
.box_footer_news .link_to_archive {
  display: inline-block;
  padding: 2px 15px 2px 42px;
  background-image: url('./../../images/common/footer-news-icn-arrow01.png');
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 31px auto;
  font-size: 1.13rem;
}
.box_footer_menu {
  position: absolute;
  top: 410px;
  left: 790px;
  color: #fff;
}
.box_footer_menu a {
  color: #fff;
}
.box_footer_menu li {
  margin-bottom: 55px;
  text-align: center;
  letter-spacing: 0.05em;
  font-size: 1.4rem;
  text-shadow: 0 0 3px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,1), 0 0 10px rgba(0,0,0,1);
}
.box_footer_menu li:nth-child(1) {
  margin-bottom: 57px;
  transform: rotate(-1deg);
  -ms-transform: rotate(-1deg);
}
.box_footer_menu li:nth-child(2) {
  margin-bottom: 49px;
  transform: rotate(-3deg);
  -ms-transform: rotate(-3deg);
}
.box_footer_menu li:nth-child(3) {
  margin-bottom: 59px;
}
.box_footer_menu li.li_map,
.box_footer_menu li.li_news,
.box_footer_menu li.li_contact {
  display: none;
}
.box_footer_info {
  position: absolute;
  top: 178px;
  left: 329px;
  width: 450px;
  text-align: center;
  color: #070604;
}
.box_footer_logo {
  margin-bottom: 40px;
}
.box_footer_company_info {
  transform: rotate(4.4deg);
  -ms-transform: rotate(4.4deg);
  font-weight: 700;
}
.box_footer_company_info .box_address {
  margin-bottom: 19px;
  padding-right: 25px;
}
.box_footer_company_info .txt_company_name {
  margin-bottom: 28px;
  font-size: 2.0rem;
}
.box_footer_company_info .txt_zipcode {
  margin-right: 11px;
  font-size: 1.4rem;
}
.box_footer_company_info .txt_address {
  vertical-align: top;
  font-size: 1.7rem;
}
.box_footer_company_info .box_telfax {
  padding-right: 27px;
  font-size: 1.68rem;
}
.box_footer_company_info .txt_telno {
  margin-right: 22px;
}
.box_copyright {
  position: absolute;
  z-index: 6;
  bottom: 40px;
  left: 0;
  width: 100%;
  text-align: center;
  letter-spacing: normal;
  font-size: 1.2rem;
  color: #fff;
}
.box_copyright .mark_copy{
  font-family: Verdana, Roboto, "Droid Sans";
}


/***** Common Contents *****/
.box_rope {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 50%;
  transform: translateX(2450%);
  -ms-transform: translateX(2450%);
  width: 20px;
  height: 100%;
  background-image: url('./../../images/common/common-rope-bg01.png');
  background-repeat: repeat-y;
  background-position: center top;
  background-size: 20px auto;
}
.box_rope_board {
  position: absolute;
  z-index: 6;
  top: 220px;
  left: 50%;
  transform: translateX(347%);
  -ms-transform: translateX(347%);
  width: 126px;
  height: 390px;/*226px;*/
  padding-top: 30px;
  background-image: url('./../../images/common/common-rope-board-bg01.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 126px auto;
  transition: 1.0s;
}
.box_rope_board li {
  text-align: center;
  letter-spacing: -0.1em;
  font-size: 1.38rem;
}
.box_rope_board li:nth-child(1) {
  margin-bottom: 55px;
  transform: rotate(-4deg);
  text-shadow: 0 0 2px rgba(0,0,0,1), 0 0 3px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,1);
}
.box_rope_board li:nth-child(2) {
  margin-bottom: 34px;
  transform: rotate(4deg);
  line-height: 1.2;
  text-shadow: 0 0 2px rgba(0,0,0,1), 0 0 3px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,1);
}
.box_rope_board li:nth-child(3) {
  margin-bottom: 108px;
  padding-left: 3px;
}
/****************/
.img_index_plant_l {
  display: none;
}
/****************/
.img_index_plant {
  position: absolute;
  z-index: 6;
  pointer-events: none;
}
.img_index_plant01_s {
  top: 0;/*-110px;*/
  right: 0;
}
.img_index_plant02_s {
  top: 0;
  left: 0;
}
.img_index_plant03_s {
  top: 930px;
  left: 0;
}
body:not(.home) .img_index_plant03_s {
  top: 222px;
  width: 620px;
}
.img_index_plant04_s {
  top: 850px;
  right: 0;
}
body:not(.home) .img_index_plant04_s {
  top: 375px;
}
.img_index_plant05_s {
  top: 420px;
  left: 0;
}
/****************/
.box_bottom_contact {
  height: 516px;
  margin-bottom: -320px;
  background-image: url('./../../images/common/bottom-contact-bg01.png');
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 1016px auto;
}
.box_bottom_contact .ttl {
  margin-bottom: 40px;
  padding-top: 15px;
  text-align: center;
}
.box_bottom_contact .box_bottom_contact_in {
  text-align: center;
}
.box_bottom_contact .box_base_com {
  margin-bottom: 18px;
}
.box_bottom_contact .box_cont01 {
  margin-bottom: 63px;
}
.box_bottom_contact .box_cont01 .txt_telno{
  margin-right: 18px;
  padding-left: 40px;
  background-image: url('./../../images/common/bottom-contact-icn-tel.png');
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 31px auto;
  vertical-align: middle;
  letter-spacing: 0.03em;
  font-size: 2.43rem;
  font-weight: 700;
}
.box_bottom_contact .box_cont01 .dl_reception_time {
  position: relative;
  bottom: -3px;
  display: inline-block;
  font-size: 1.05rem;
  font-weight: 700;
}
.box_bottom_contact .box_cont01 .dl_reception_time > dt {
  display: inline-block;
  margin-right: 9px;
}
.box_bottom_contact .box_cont01 .dl_reception_time > dd {
  display: inline-block;
  letter-spacing: 0.03em;
}
.box_bottom_contact .box_link {
  padding-right: 80px;
  text-align: right;
}
.box_bottom_contact .box_link .link_to_contact {
  display: table;
  width: 349px;
  height: 44px;
  margin-left: auto;
  background-image: url('./../../images/common/bottom-contact-btn-bg01.png');
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 100% auto;
  text-align: left;
  font-size: 1.45rem;
  color: #fff !important;
  text-shadow: 0 0 1px #000, 0 0 3px #000, 0 0 5px #000, 0 0 8px #000;
}
.box_bottom_contact .box_link .link_to_contact .link_in {
  display: table-cell;
  padding-left: 65px;
  padding-right: 60px;
  background-image: url('./../../images/common/bottom-contact-icn-mail.png'),url('./../../images/common/bottom-contact-icn-arrow01.png');
  background-repeat: no-repeat,no-repeat;
  background-position: 5% center,89% center;
  background-size: 39px auto, 31px auto;
  vertical-align: middle;
}
.box_bottom_contact .box_link .link_to_contact .link_in .small {
  font-size: 1.2rem;
}

