@charset "utf-8";
/* CSS Document */

/*------------------------------------------------------------------
--------------------------------------------------------------------
　　　　　　　　　　　horipro専用css
--------------------------------------------------------------------
------------------------------------------------------------------*/
#contents {
	max-width: inherit;
}
#horipro {
	font-size: 1.6rem;
}
.inner {
	max-width: 1040px;
	width: 100%;
	margin: 0 auto;
	padding: 0 20px;
}
.sp-show,
.br-599 {
	display: none;
}
.sup {
	display: block;
	margin-left: 1em;
	text-indent: -1em;
	font-size: 1.3rem;
	font-weight: normal;
}
.txt_link {
	color: #fff;
	text-decoration: underline;
}
.txt_link:hover {
	text-decoration: none;
}
.link-new02 {
	margin-left: 3px;
	padding-left: 32px;
}
.reg_size {
	font-size: 2.0rem;
	vertical-align: bottom;
	line-height: 0.5rem;
}

/*------------------------------------------------------------------
背景
------------------------------------------------------------------*/
.bg_bk {
	background: #000;
}
.bg {
	margin: 3px 0;
	background: linear-gradient(0, #000 0% 40%, #640a34 100%);
}

/*------------------------------------------------------------------
メインビジュアル
------------------------------------------------------------------*/
.main-img {
	margin: 0;
	text-align: center;
}

/*------------------------------------------------------------------
リード文
------------------------------------------------------------------*/
.lead_txt {
	margin-top: 15px;
	color: #fff;
	font-family: "Noto Serif JP", serif;
	font-size: 1.9rem;
	font-weight: bold;
	text-align: center;
}

/*------------------------------------------------------------------
メニューアンカー
------------------------------------------------------------------*/
.menu {
	display: flex;
	display: -webkit-flex;
	justify-content: center;
	-webkit-justify-content: center;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	margin-top: 20px;
}
.menu li {
	width: calc(100% / 4 - 8px);
	margin-right: 10px;
	margin: 0 10px 15px 0;
}
.menu li:last-of-type {
	margin-right: 0;
}
.menu li a {
	position: relative;
	display: block;
	padding-bottom: 22px;
	transition: .25s ease;
}
.menu li a:before {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) rotate(90deg);
	content: '\e902';
	font-family: 'jttweb' !important;
	color: #d7bb74;
}
.menu li a:hover {
	transform: translateY(5px);
}
.menu li a img {
	border: 1px solid;
	border-image: linear-gradient(to right, #84774c 0%, #d9c490 17%, #baa765 33%, #f4ead2 50%, #baa765 67%, #d9c490 83%, #84774c 100%) 1;
}

/*------------------------------------------------------------------
上演作品
------------------------------------------------------------------*/
.stage_wrap {
	border-bottom: 8px solid;
	border-image: linear-gradient(to right, #84774c 0%, #d9c490 17%, #baa765 33%, #f4ead2 50%, #baa765 67%, #d9c490 83%, #84774c 100%) 1;
	overflow: hidden;
}
.stage_wrap:last-of-type {
	border-bottom: 0;
}
.stage_box {
	display: flex;
	display: -webkit-flex;
	justify-content: center;
	-webkit-justify-content: center;
	align-items: center;
	-webkit-align-items: center;
	flex-direction: row-reverse;
	-webkit-flex-direction: row-reverse;
	padding: 40px 0 30px;
}
.stage_box h2 {
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
    color: #fff;
    margin-bottom: 40px;
    font-size: min(2.5vw, 2.7rem);
}
.stage_box figure {
	width: 33%;
}
.stage_box figure img {
	border: 2px solid;
	border-image: linear-gradient(to right, #84774c 0%, #d9c490 17%, #baa765 33%, #f4ead2 50%, #baa765 67%, #d9c490 83%, #84774c 100%) 1;
	box-shadow: 0 0.2rem 0.4rem rgba(0, 0, 0, 0.2);
}
.stage_box .intro_wrap {
	width: 45%;
	margin-right: 60px;
}
.stage_box .txt_wrap {
	color: #fff;
	font-family: "Noto Serif JP", serif;
	font-weight: bold;
}
.stage_box .intro_txt {
	text-spacing-trim: space-all;
}
.stage_box .venue {
    text-align: left;
    margin-top: 25px;
    font-family: 'Yu Gothic Medium', '游ゴシック Medium', YuGothic, '游ゴシック体', '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    font-weight: normal;
}
.btn_lp {
	padding: 22px 14px;
	background: rgb(58 73 101 / 32%);
}
.btn_lp .inner {
    overflow: visible;
}
.btn_lp .btn_txt {
    color: #fff;
    text-align: center;
    margin-bottom: 15px;
    font-size: 2rem;
    font-weight: bold;
}
.btn_lp .btn_txt span {
    position: relative;
    padding: 0 65px;
}
.btn_lp .btn_txt span:before,
.btn_lp .btn_txt span:after {
    position: absolute;
    content: "";
    width: 50px;
    height: 0.3rem;
    background: #fff;
    transform: translateY(-50%) scaleY(0.5);
    top: 50%;
}
.btn_lp .btn_txt span:before {
    left: 0;
}
.btn_lp .btn_txt span:after {
    right: 0;
}
.btn_list {
    display: flex;
    display: -webkit-flex;
    justify-content: center;
    -webkit-justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}
.btn_list li {
    width: calc(100% / 3 - 8px);
    min-width: 175px;
}
.btn_lp a {
	position: relative;
    margin: 0 auto;
	display: block;
	max-width: 400px;
	width: 100%;
	padding: 15px 25px;
	border-radius: 50px;
	color: #fff;
	font-weight: bold;
	text-align: center;
	transition: .25s ease;
	overflow: hidden;
	z-index: 0;
}
.btn_lp a:after {
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
	content: '\e902';
	font-family: 'jttweb' !important;
	font-size: 1.2rem;
}
.btn_lp a:hover {
	transform: scale(1.05);
}
/*ハリー・ポッター*/
.harrypotter {
	position: relative;
	background: #00001c;
    z-index: 0;
}
.harrypotter:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 100%;
    background-image: url(/plan/tokushu/entertainment/horipro/images/bg_cloud.webp);
    background-repeat: no-repeat;
    background-position: left top;
    background-size: cover;
    opacity: 0.18;
    z-index: -1;
}
.harrypotter h2 {
    font-weight: 600;
    color: #e4d68c;
}
.harrypotter .btn_lp a {
	background-image: url(/plan/tokushu/harrypotter/images/bg_btn.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 100% auto;
    color: #000;
}
/*メリー・ポピンズ*/
.marypoppins {
	position: relative;
    background: linear-gradient(10deg, rgb(174 145 227) 0%, rgb(47 131 183) 47%, rgb(21 74 158) 78%, rgb(25 57 94) 100%);
    z-index: 0;
}
.marypoppins:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 100%;
    background-image: url(/plan/tokushu/entertainment/horipro/images/bg_cloud02.webp);
    background-repeat: repeat;
    background-position: left top;
    background-size: 35% 65%;
    z-index: -1;
}
@media screen and (min-width: 1400px) {
.marypoppins:before {
    background-size: 35% 80%;
}
}
.marypoppins h2 {
    color: #ffffff;
    text-shadow: 3px 3px 3px rgb(219 0 0 / 80%);
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 600;
}
.marypoppins .btn_lp {
    background: rgb(0 34 152 / 37%);
}
.marypoppins .btn_lp a {
    border: 1px solid;
    box-shadow: 0 2px 4px rgb(26 54 73 / 40%);
    background: #d10c1c;
}

/*------------------------------------------------------------------
　　　　　　　　　　　　　　スマホ用(画面幅999px以下) 
------------------------------------------------------------------*/
@media screen and (max-width: 999px) {
#horipro {
	font-size: 1.5rem;
}
.inner {
	padding: 0 14px;
}
.pc-show {
	display: none;
}
.sp-show {
	display: block;
}
.sup {
	font-size: 1.2rem;
}
.link-new02 {
	padding-left: 30px;
}

/*------------------------------------------------------------------
リード文
------------------------------------------------------------------*/
.lead_txt {
	font-size: min(2.6vw, 1.7rem);
}

/*------------------------------------------------------------------
メニューアンカー
------------------------------------------------------------------*/
.menu li {
	width: calc(100% / 3 - 5px);
}
.menu li:nth-of-type(2n)  {
	margin-right: 0;
}

/*------------------------------------------------------------------
上演作品
------------------------------------------------------------------*/
.stage_box {
	display: block;
	padding: 30px 0 25px;
}
.stage_box h2 {
    margin-bottom: 28px;
    font-size: min(5.3vw, 2.5rem);
}
.stage_box figure {
    max-width: 400px;
    width: 58%;
	margin: 0 auto;
}
.stage_box figure img {
	border-width: 1.5px;
}
.stage_box .intro_wrap {
	width: 100%;
	margin: 20px 0 0;
}
.stage_box .txt_wrap {
	text-align: center;
}
.stage_box .intro_txt {
	display: inline-block;
	text-align: left;
}
.btn_list {
    gap: 8px;
}
.btn_list li {
    width: calc(100% / 3 - 6px);
}
.btn_lp .btn_txt {
    font-size: 1.8rem;
}
/*ハリー・ポッター*/
.harrypotter:before {
	opacity: 0.2;
}
/*メリー・ポピンズ*/
.marypoppins:before {
    background-size: 60% 40%;
}
}

/*------------------------------------------------------------------
　　　　　　　　　　　　　　スマホ用(画面幅599px以下) 
------------------------------------------------------------------*/
@media screen and (max-width: 599px) {
#horipro {
	font-size: 1.4rem;
}
.br-599 {
	display: block;
}

/*------------------------------------------------------------------
リード文
------------------------------------------------------------------*/
.lead_txt {
	margin-top: 10px;
	font-size: min(3.5vw, 1.4rem);
}

/*------------------------------------------------------------------
メニューアンカー
------------------------------------------------------------------*/
.menu {
	margin-top: 17px;
}
.menu li {
	width: calc(100% / 2 - 5px);
	margin: 0 10px 10px 0
}
.menu li:nth-of-type(2n) {
	margin-right: 0;
}
.menu li a {
	padding-bottom: 18px;
}
.menu li a:before {
	font-size: 1.2rem;
}

/*------------------------------------------------------------------
上演作品
------------------------------------------------------------------*/
.stage_box {
	padding: 27px 0 22px;
}
.stage_box figure {
	width: 80%;
}
.btn_lp {
	padding: 20px 14px;
}
.btn_lp li {
    width: 100%;
}
.btn_lp a {
    font-size: 1.5rem;
}
/*ハリー・ポッター*/
.harrypotter:before {
    background-repeat: repeat-y;
    background-size: 100% auto;
    opacity: 0.1;
}
/*メリー・ポピンズ*/
.marypoppins:before {
    background-size: 60% 28%;
}
}