@charset "UTF-8";
/* サイト内共通設定 
========================================================= */
:root {
--red: #d01919;
--white: #FFF;
--text: #012B5E;
--black: #000;
--back: #E0F2FF;
--content-light: 970px;
}

/* 全体背景 
========================================================= */
header,.performer,.about {
background-image: url(/p/event/musicletter-concert/images/back.png);
background-size: contain;
background-repeat: repeat;
background-position: center;
position: relative;
}
.info{
background-color: var(--black);
}
.movie,.program,.ticket{
background-color: var(--back);
}
.notice{
background-color: var(--white);
}

.footer {
background: #eee;
}

/* 各セクション間隔 */
.performer,.program,.about,.ticket,.notice {
padding: 60px 0;
}

.footer {
padding: 76px 0 30px;
}
.flex{
margin-left: auto;
margin-right: auto;
}
@media (max-width: 767px) {
header,.performer,.about {
background-image: url(/p/event/musicletter-concert/images/back-sp.png);
}
}


/* ページ内 共通
========================================================= */
h5,h6,p,ul,button,a.btn {
color: var(--text);
font-family: "BIZ UDGothic", sans-serif;
}

p,ul {
line-height: 1.75;
}

ul {
list-style: disc;
}

h2 {
margin: 25px 0 35px 0;
text-align: center;
font-size: 50px;
font-family: sans-serif;
font-weight: 600;
}
.container h2 {
color: var(--white);
}
.panel-body h2 {
color: var(--text);
}
.ticket h2,.notice h2{
color: var(--text);
}

h3 {
color: var(--text);
font-size: 35px;
font-family: sans-serif;
font-weight: 600;
}

h4 {
color: var(--text);
font-size: 30px;
font-family: sans-serif;
font-weight: 600;
margin-top: 10px;
}

h5 {
font-size: 25px;
margin-bottom: 10px;
margin-top: 25px;
font-weight: 600;
}

h5::before {
display: inline-block;
content: "";
background-image: url(/p/event/musicletter-concert/images/icon-swallow.png);
width: 38px;
height: 35px;
background-size: contain;
background-repeat: no-repeat;
background-position: left;
margin-bottom: -8px;
margin-right: 3px;
}

.panel-default{
border: none;
background-color: var(--white);
border-radius: 10px;
}
.panel-body{
padding: 25px;
}

@media (max-width: 767px) {

/* 各セクション間隔 */
.performer,	.about,	.ticket,.notice {
	padding: 25px 0;
}

.panel-body{
padding: 20px;
}

/* 見出し */
h2 {
	font-size: 30px;
	margin: 17px 0 17px 0;
}

h3 {
	font-size: 20px;
	margin: 10px 0 10px 0;
}

h4 {
	font-size: 20px;
	margin: 15px 0 10px;
}

h5 {
	font-size: 18px;
	margin-bottom: 10px;
	margin-top: 10px;
}

h5::before {
	width: 27px;
	height: 30px;
	margin-right: 5px;
}

/* 文字 */
ul li{
	font-size: 15px;
}
}

/* header */
header div.container {
height: 900px;
}
header div.container h1 img {
margin: 50px auto 20px;
width: 730px;
height: auto;
}
header div.container .panel-default{
	border: 5px solid #ccc;
	text-align: center;
	border-radius: 10pt;
	margin: 0px auto 20px;
	width: 80%;
	border-color: var(--text);
	font-size: 120%;
}
header div.container .flex a.btn,.performer button{
border: 4px solid;
border-color: var(--text);
color: var(--text);
box-sizing: border-box;
font-size: 18px;
display: block;
padding: 10px 16px;
border-radius: 10px;
}
header div.container .flex a.btn::after {
content: "";
background-image: url(/p/event/musicletter-concert/images/circle-chevron-down-solid.svg);
width: 18px;
height: 18px;
background-size: cover;
background-repeat: no-repeat;
float: right;
}
header div.container .flex a.btn:hover,.performer button:hover{
background-color: var(--back);
border-color: var(--text);
}

header span.credit {
position: absolute;
right: 1%;
bottom: 1%;
color: rgba(255, 255, 255, 0.3);
}

@media (min-width: 769px) {
	header div.container .panel-default br{
		display: none;
	}
}
@media (max-width: 768px) {

header div.container h1 img {
	width: auto;
	height: 65%;
}
header div.container .panel-default{
	width: 93%;
	font-size: 100%;
}
header div.container .flex {
	width: 93%;
	justify-content: center;
	bottom: 5px;
}
	header div.container .flex>div.col-xs-6 {
	margin-bottom: 20px;
	width: 48%;
	padding: 5px;
	padding-right: 5px;
}
}
@media (max-width: 680px) {
header div.container {
	height: 700px;
}
}
/* summary */
.summary .panel-default{
	width: var(--content-light);
	margin: 50px auto;
}
@media (max-width: 991px) {
	.summary .panel-default{
		width: 100%;
	}
	.summary .panel-default .panel-body{
padding: 35px;
	}
}
@media (max-width: 414px){
	.summary .panel-default{
	margin: 30px auto;
}
}
/* movie */
.movie .container{
padding: 50px;
width: var(--content-light);
}

.movie .container .movie-wrap {/*(YouTube動画をそのまま埋め込んでもレスポンシブする)*/
position: relative;
padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
height: 0;
overflow: hidden;
}
.movie-wrap iframe {
position: absolute;
border-radius: 10px;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
@media (max-width: 991px) {
.movie .container{
width: 100%;
}
}
@media (max-width: 414px) {
.movie .container{
padding: 40px 20px;
}
}
/* info */
.info .container{
padding: 20px;
}
.info .container p{
text-align: center;
}
/* parformer */
.performer .container{
width: var(--content-light);
}
.performer .container .flex{
justify-content: center;
}
.performer h3 {
font-size: 26px;
margin: 20px 0 0 0;
border: none;
text-align: left;
padding: 0;
}

.performer p {
font-size: 23px;
margin: 10px 0 10px;
}

.modal-header {
padding: 15px 15px 10px;
}

.modal-header {
position: relative;
}

h4.modal-title {
color: var(--black);
text-align: start;
padding: 0 20px;
font-size: 18px;
position: absolute;
bottom: 14px;
}

.modal-header button.close span {
color: var(--black);
}

.performer .modal-footer button {
color: var(--black);
}

.performer div.profile h3 {
margin: 0px 0 16px;
font-size: 18px;
color: var(--black);
}

.performer div.profile p {
font-size: 16px;
color: var(--black);
}

.performer div.profile a {
font-size: 16px;
font-family: "BIZ UDGothic", sans-serif;
}

@media (min-width: 768px) {
.modal-dialog {
	width: 70%;
}
}

@media (max-width: 1199px) {
.performer .flex>div {
	margin-bottom: 20px;
}
}

@media (max-width: 991px) {
.performer .container{
width: 100%;
}
.performer div.profile p {
	margin-top: 20px;
}
}

@media (max-width: 767px) {
.performer .container .flex .col-xs-6{
padding: 0 5px 0;
}
.performer .panel-body{
padding: 10px;
}
.performer p.siena-name {
	letter-spacing: -0.1em;
}

.performer h3 {
	margin-top: 12px;
	font-size: 16px;
}
.performer p {
	font-size: 16px;
}
.performer button {
	margin-top: 8px;
	border-width: 2px;
	font-size: 16px;
	padding: 8px 0px 4px;
	border-radius: 5px;
}

.btn-group-lg>.btn,	.btn-lg {
	padding: 8px 16px;
	font-size: 16px;
}

.performer .flex>div>p {
	font-size: 13px;
}

.modal-dialog {
	width: 90%;
}

h4.modal-title {
	font-size: 17px;
	position: absolute;
	bottom: 15px;
	padding-left: 10px;
}

.performer div.profile p {
	font-size: 16px;
}
}

@media (max-width: 414px) {
.performer div.profile p {
	font-size: 14px;
}
}

/* program */
.program .container{
width: var(--content-light);
}
.program .container .panel-default{
position: relative;
overflow: hidden;
}
.program .container .panel-body{
padding: 35px;
}
.program img.deco-parts-1 {
position: absolute;
width: 144px;
height: auto;
}
.program img.deco-parts-2 {
bottom: 0;
right: 0;
position: absolute;
width: 120px;
}

.program p {
font-size: 30px;
margin-bottom:75px;
text-align: center;
line-height: 1.3;
}
@media (max-width: 991px) {
.program .container{
width: 100%;
}
}
@media (max-width: 767px) {
.program img.deco-parts-1 {
	left: 0;
	width: 109px;
}

.program img.deco-parts-2 {
	right: 0;
	width: 82px;
}

.program p {
	font-size: 17px;
	margin: 35px 0;
}
}

@media (max-width: 414px) {
.program img.deco-parts-1 {
	top: 0px;
	width: 97px;
}

.program img.deco-parts-2 {
	right: 0;
	width: 74px;
}
}

/* about */
.about .panel-body{
padding: 30px;
}
.about .panel-body .flex{
    align-items: center;
}
.about .text-center {
font-size: 30px;
font-family: sans-serif;
font-weight: 600;
padding: 15px 0 15px;
line-height: 1.2;
}
.about .no {
font-size: 45px;
}
.about .center-block {
width: 660px;
}

.about .access p {
margin-bottom: 10px;
margin-left: 15px;
font-size: 16px;
}

.about ul {
margin-left: 40px;
}

.about a.text-right {
display: block;
margin-top: 15px;
text-decoration: underline;
color: var(--text);
}
.about a.text-right:hover {
opacity: 0.7;
}
@media (max-width: 991px) {
.about .panel-default{
	margin-bottom: 20px;
}
}
@media (max-width: 767px) {
.about .panel-default .col-xs-4{
		padding-right: 4px;
		padding-left: 2px;
}
.about .panel-default .col-xs-8{
	padding-right: 0;
	padding-left: 5px;
}
.about .text-center {
	font-size: 20px;
}
.about .img-responsive{
	width: 85%;
}
.about h3{
	font-size: 30px;
}
.about h4{
	font-size: 28px;
}
.about .no {
font-size: 35px;
}

.about .center-block {
	width: 90%;
}

.about .center-block .flex .date:nth-child(1) {
	margin-right: 4%;
}

.about .center-block .flex .date {
	background-color: #fff;
	padding: 20px 5px;
	text-align: center;
	margin-bottom: 45px;
	width: 48%;
}

.about .center-block .flex .date p {
	font-size: 22px;
}

.about .center-block .flex .date p .small {
	font-size: 75%;
}

.about .access p,
.about .access ul li,
{
font-size: 14px;
}

.about .access .flex>div:nth-of-type(2) {
margin-top: 10px;
}
}

@media (max-width: 414px) {
.about .img-responsive{
	width: 100%;
}
.about h3{
font-size: 25px;
}
.about h4{
font-size: 20px;
}
}

@media (max-width: 414px) {
.about .panel-body {
padding: 25px 15px;
}
.about .access iframe {
	height: 250px;
}
.about p {
	font-size: 15px;
}
.about ul {
	margin-left: 30px;
	font-size: 15px;
}
}

/* ticket */
.ticket .container{
width: var(--content-light);
}
.ticket .panel-body > h3 {
margin: 35px 0 35px;
text-align: center;
}

.ticket .text {
margin-bottom: 90px;
}

.ticket .flex .date {
background-color: #F5F5F5;
padding: 25px;
text-align: center;
width: 48%;
margin-bottom: 45px;
border-radius: 10px;
align-items: center;
justify-content: center;
}

.ticket .flex .date p {
color: var(--text);
font-size: 25px;
font-weight: 900;
line-height: 1.5;
font-family: sans-serif;
}
.ticket .flex .date p .small {
font-size: 70%;
}

.ticket-release h4 {
margin-bottom: 0;
}

.ticket-release p.text-center br{
display: none;
}

.ticket-info {
padding: 20px 30px 30px 30px;
margin-top: 45px;
}
.ticket-info .center-block{
width: 70%;
gap: 20px;
}

.ticket-info .date h4 {
background: linear-gradient(transparent 77%, #cce9ff 50%);
font-weight: 900;
padding: 6px;
width: fit-content;
margin: auto;
}
.ticket-info .fee h4 {
font-size: 25px;
margin-bottom: 10px;
margin-top: 25px;
}
.ticket-info .fee h4::before {
display: inline-block;
content: "";
background-image: url(/p/event/musicletter-concert/images/icon-swallow.png);
width: 38px;
height: 35px;
background-size: contain;
background-repeat: no-repeat;
background-position: left;
margin-bottom: -8px;
margin-right: 3px;
}

.ticket-info .flex>div {
padding-right: 10px;
padding-left: 10px;
}

.ticket-info table{
width: 90%;
}
.ticket-info table th{
background-color: #eee;
}
.ticket-info ul{
margin-left: 20px;
}

.ticket-info .play-guide{
gap: 4%;
margin-top: 15px;
}

.ticket-info .play-guide a.btn {
width: 48%;
margin-bottom: 15px;
color: var(--white);
background: #1F7CC1;
border:solid #1F7CC1 3px;
font-size: 16px;
display: block;
padding: 15px 10px;
border-radius: 10px;
}
.ticket-info a.btn::after {
display: inline-block;
content: "";
background-image: url(/p/event/musicletter-concert/images/arrow-up-right-from-square-solid-white.svg);
width: 18px;
height: 18px;
background-size: cover;
background-repeat: no-repeat;
float: right;
}
.ticket-info a.btn:hover::after{
background-image: url(/p/event/musicletter-concert/images/arrow-up-right-from-square-solid-green.svg);
}
.ticket-info a.ticket-sales-site {
margin-top: 25px;
width: 80%;
margin-left: auto;
margin-right: auto;
height: 80px;
padding: 28px 27px;
}
.ticket-info a.btn:focus,.ticket-info a.btn:active,.ticket-info a.btn:hover {
color: #1F7CC1;
background-color: var(--white);
border:solid #1F7CC1 3px;
}
.ticket-info a.btn::after:focus,.ticket-info a.btn::after:focus,.ticket-info a.btn::after:hover {
background-image: url(/p/event/musicletter-concert/images/arrow-up-right-from-square-solid-white.svg);
}
.ticket-contact {
margin-top: 50px;
padding-right: 15px;
padding-left: 15px;
}

.ticket-contact ul {
margin-left: 0;
list-style: none;
}

@media (max-width: 991px) {
.ticket .container{
width: 100%;
}
	.ticket-info .center-block{
width: 100%;
}
.ticket .flex .date {
	padding: 20px;
	margin-bottom: 0;

}
.ticket-info a.ticket-sales-site {
	width: 100%;
}
}

@media (max-width: 767px) {
.ticket .flex .date {
	width: 100%;
}
.ticket-info .fee h4 {
	font-size: 18px;
	margin-bottom: 10px;
	margin-top: 10px;
}
.ticket-info .fee h4::before {
	width: 27px;
	height: 30px;
	margin-right: 5px;
}
.ticket p {
	font-size: 16px;
}
.ticket .ticket-contact .ticket-info .col-xs-12 {
	width: 50%;
}
.ticket-info {
padding: 15px;
margin-top: 35px;
}
.ticket-release h4 {
	padding: 10px;
}
.ticket-release p.text-center br{
	display: inline;
}
.ticket-info h5 {
	font-size: 22px;
	margin-bottom: 20px;
	margin-top: 25px;
}

.ticket button a {
	padding: 10px 10px;
}

.ticket-contact {
	margin-top: 40px;
}

.ticket .ticket-contact {
	margin-top: 40px;
	margin-bottom: 30px;
}
}

@media (max-width: 474px) {
.ticket .ticket-contact .ticket-info .col-xs-12 {
width: 100%;
}
.ticket-info .play-guide a.btn {
font-size: 12px;
}
.ticket-info a.ticket-sales-site {
padding-right: 20px;
}
}
@media (max-width: 414px) {
.ticket-info a.btn {
	font-size: 16px;
}

.ticket-info a.btn::after {
	width: 16px;
	height: 16px;
	margin-top: 2px;
}
}

/* notice */
.notice .container{
width: var(--content-light);
}
.notice {
padding-right: 15px;
padding-left: 15px;
}

@media (max-width: 970px) {
.notice .container {
	width: 100%;
}
}

/* フッター */
.footer h2 {
color: var(--black);
background-color: transparent;
text-align: left;
font-size: 16px;
margin: 0;
font-family: "BIZ UDGothic", sans-serif;ight: 600;
}

.footer p {
color: var(--black);
font-family: "BIZ UDGothic", sans-serif;ight: 400;
margin-bottom: 10px;
}
.footer .archive ul li{
list-style: none;
}
.footer .archive ul li a{
text-decoration: underline;
color: var(--black);
}
.footer .archive ul li::before{
display: inline-block;
content: "";
background-image: url(/p/event/musicletter-concert/images/angle-right-solid-full.svg);
width: 18px;
height: 26px;
background-size: contain;
background-repeat: no-repeat;
background-position: left;
margin-bottom: -8px;
margin-right: 3px;
}
.footer .text-right a img{
	width: 390px;
}

@media (max-width: 767px) {
.footer {
	padding: 30px 0 50px;
}

.footer h2 {
	text-align: center;
	font-size: 14px;
	font-weight: 400;
}

.footer p {
	text-align: center;
	font-size: 14px;
}
.footer .archive ul{
	text-align: center;
}
.footer .text-right {
	text-align: center;
	margin-top: 25px;
}

.footer .text-right a img {
	width: 300px;
	height: auto;
}
}

/* ページトップ移動アイコン */
div#page_top {
position: relative;
}

p#page-top {
display: none;
position: fixed;
right: 2%;
bottom: 2%;
}

#page-top i {
color: #fff;
font-size: 50px;
}

#page-top i.glyphicon-circle-arrow-up:before {
text-shadow: 0 0 10px #272727;
}

@media (max-width: 767px) {
#page-top i {
	font-size: 40px;
}
}