@charset "UTF-8";

/** PC-SP common
-----------------**/

.mballTop .mainFull * {
	box-sizing: border-box;
}

/** アンケートのあるなし
-----------------**/
/** デフォルト：アンケートあり **/
.chanceNoSurvey {
	display:none;
}
/** アンケートがないとき：bodyのclassにnoSurveyを追加 **/
.noSurvey .chanceSurvey {
	display:none;
}
.noSurvey .chanceNoSurvey {
	display:block;
}

/** heading **/
.hdg2, .hdg2Top {
	text-align:center;
	margin-left:auto;
	margin-right:auto;
}

/** KV **/
.mainVisual {
	width:100%;
	overflow: hidden;
	margin: 0 auto;
	text-align:center;
	padding:0;
}
.mainVisual .kvArea {
	width:100%;
	background:none;
	margin-bottom:10px;
	overflow: hidden;
}

/** sectionBox **/
.sectionBox {
	width:100%;
	margin:0 auto;
	padding-top:0;
	padding-bottom:0;
	height:auto;
	overflow:hidden;
}

/* prizeArea ***/
.itemBoxBuild {
	box-sizing: border-box;
	padding:0;
	overflow: hidden;
}
.itemBoxBuild .itemBox {
	box-sizing: border-box;
	list-style: none;
}
.itemBox .itemInnerBox {
	border:#ccc solid 1px;
	background-color:#fff;
	padding:10px;
}
.itemBox .itemInnerBox .prizeName {
	display:table;
	text-align:left;
	font-size:1.5rem;
	line-height:1.3;
	padding:0;
	border-collapse: collapse;
	width: 100%;
}
.itemBox .itemInnerBox .prizeName span {
	display:table-cell;
	vertical-align: middle;
	padding-left: 10px;
}
.itemBox .itemInnerBox .prizeName::before {
	content: "";
	display:table-cell;
	width:80px;
	height:80px;
	vertical-align: middle;
	padding:0;
	background-position: left center;
	background-repeat: no-repeat;
	background-size: contain;
	-webkit-background-size:contain;
}
.itemBox .itemInnerBox.prizeA .prizeName::before {
	background-image:url("/mball/premium/chance/img/icon_prize_a.png");
}
.itemBox .itemInnerBox.prizeB .prizeName::before {
	background-image:url("/mball/premium/chance/img/icon_prize_b.png");
}
.itemBox .itemInnerBox.prizeC .prizeName::before {
	background-image:url("/mball/premium/chance/img/icon_prize_c.png");
}
.itemBox .itemInnerBox.prizeD .prizeName::before {
	background-image:url("/mball/premium/chance/img/icon_prize_d.png");
}
.itemBox .itemInnerBox.prizeE .prizeName::before {
	background-image:url("/mball/premium/chance/img/icon_prize_e.png");
}
.itemBox .itemInnerBox.prizeF .prizeName::before {
	background-image:url("/mball/premium/chance/img/icon_prize_f.png");
}
.itemBox .itemInnerBox .prize {
	display: block;
	margin:10px auto;
	width:100%;
}
.itemInnerBox .lotteryNum {
	font-size:16px;
	font-size:1.6rem;
	margin-bottom:10px;
	padding-bottom:0;
	line-height:1.0;
	text-align: right;
}
.itemBox .itemInnerBox .lotteryNum span {
	font-size:32px;
	font-size:3.2rem;
	font-weight:bold;
}
.itemBox .itemInnerBox *[class*="Btn"] {
	margin:0 auto 10px;
	display:block;
}
.itemBox .itemInnerBox .memberStatus {
		margin-bottom: 0;
		text-align: center;
		font-size:14px;
		font-size:1.4rem;
}
.itemBox .itemInnerBox .memberStatus img {
	margin-right: 4px;
	padding-bottom: 2px;
	width:20px;
	vertical-align: text-bottom;
}

.prizeOption {
	margin:16px auto 0;
	padding:0;
}
.prizeOption > img {
	display: block;
	margin:0 auto;
	padding:0;
}


/** applyFrow **/
.applyFrow .styleBox01 {
margin-top: 40px;
}

.chanceSurvey > .flow > .flowHdg,
.chanceNoSurvey >.flow > .flowHdg {
margin-top: 10px;
}

.cpnApplicationStepOuter {
	background-color: #f4f8f3;
	padding: 40px 0 120px;
	margin: 60px 0;
}

.cpnApplicationStep {
	max-width: 900px;
	margin: 0 auto;
}

.cpnApplicationStep > ol > li {
	counter-increment:step;
	position: relative;
	display: flex;
	flex-direction: column;
	margin: 0 0 20px;
}

.cpnApplicationStep > ol > li::before {
	content:counter(step);
	position: absolute;
	top: 0;
	left: 16px;
	color: #fff;
	font-size: 25px;
	font-weight: bold;
	line-height: 48px;
	z-index: 1;
}

.cpnApplicationStep > ol > li::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background-color: #357500;
	color: #fff;
	border-radius: 50%;
	width: 48px;
	height: 48px;
}

.cpnApplicationStep > ol > li.chanceNoSurvey {
	display: none;
}
.noSurvey .cpnApplicationStep > ol > li.chanceNoSurvey {
	display: block;
}

.cpnApplicationStep li:last-child {
	margin-bottom: 0;
}

.cpnApplicationStepBox {
	padding: 0 0 0 96px;
	position: relative;
}

.cpnApplicationStepBox::before,
.cpnApplicationStepBox::after {
	content: "";
	width: 30px;
	height: 14px;
	position: absolute;
	background: url("/mball/premium/event/201908_festival/img/bg-arrow-01.png");
	top: 60px;
	left: 10px;
}

.cpnApplicationStepBox::after {
	top: 70px;
}

.cpnApplicationStepList li:last-child .cpnApplicationStepBox::before,
.cpnApplicationStepList li:last-child .cpnApplicationStepBox::after,
.cpnApplicationStepList li.type-last .cpnApplicationStepBox::before,
.cpnApplicationStepList li.type-last .cpnApplicationStepBox::after {
	content: none;
}

.cpnApplicationStepBoxInner {
	border: 2px solid #357500;
	padding: 30px;
	min-height: 160px;
	background-color: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.cpnApplicationStepBoxInnerContent {
	display: table;
	width: 100%;
	position: relative;
}

.cpnApplicationStepBoxInnerContent::before {
	content: "";
	background: url("/mball/premium/event/201908_festival/img/bg-arrow-02.png") no-repeat;
	width: 22px;
	height: 28px;
	position: absolute;
	top: -14px;
	left: -52px;
}


.cpnApplicationStepBoxInnerContent > .cpnApplicationStepBoxInnerContentImg,
.cpnApplicationStepBoxInnerContent > .cpnApplicationStepBoxInnerContentInfo {
	display: table-cell;
	vertical-align: top;
}

.cpnApplicationStepBoxInnerContent > .cpnApplicationStepBoxInnerContentImg {
	width: 10%;
}

.cpnApplicationStepBoxInnerContent > .cpnApplicationStepBoxInnerContentInfo {
	width: 90%;
	padding-left: 25px;
}

.cpnApplicationStepBoxInnerContentInfo > .hdg {
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.4;
	margin-bottom: 10px;
}

.cpnApplicationStepBoxInnerContentInfo > .text {
	margin: 0;
	display: block;
	line-height: 1.4;
}
.cpnApplicationStepBoxInnerContentInfo > .text + * {
	margin-top: 10px;
}

/** applyBtn **/
.applyBtn {
	text-align:center;
}

/** rcmndService **/
.rcmndService {
	padding-left:0;
	padding-right:0;
}
.rcmndService .styleBox01 {
	padding-top:0;
	margin-top:0;
}
.rcmndService .col2 {
	margin:0 auto;
	padding:0;
}
.rcmndService .chance_rcmnd_col2 .col2Item h3 {
	margin-top:0;
}
.chance_rcmnd_col2 .col2Item {
	padding:0;
	margin:0;
}

.rcmndService .midPriorityBtn {
	padding:6px 48px;
}

/** Footer **/
.chanceFooter {
	margin:0 auto;
}

/** cpn_date *ssi **/
.cpn_date {
	margin-top:0 !important;
	padding-top:0 !important;
	padding-bottom:0 !important;
	line-height:1.6;
}

/** contents_hidden **/
.noShow {
	display:none;
}

/** for PC
-----------------**/
body .pcNone {
	display:none;
}
body .spNone {
	display:block;
}
/*.styleBox01 {
	padding:0 !important;
	margin:0 auto !important;
}*/

.mainSub{
	width:950px;
	margin:0 auto;
	padding-bottom:0;
}

/** header **/
.hdg1Box .hdg1BoxInner .hdg1BoxBackButton {
	vertical-align:top;
}
.hdg1Box .hdg1BoxInner .hdg1BoxBackButton .hdg1BoxBackButtonInner > a {
	padding:0;
}
.hdg1Box .hdg1BoxInner .hdg1BoxBackButton .hdg1BoxBackButtonInner .backbtn {
	box-sizing: border-box;
	border: none;
}

/** heading **/
.hdg2,
* + section > .hdg2:first-child {
	font-size:40px;
	font-size:4rem;
	margin:140px auto 20px;
}

/** KV **/
.mainVisual .kvArea {
	position:relative;
	height:400px;
}
.mainVisual .topText {
	height: 100%;
	background:url(/mball/premium/chance/img/mainvisual.png?20190901) bottom center no-repeat;
	margin:0 auto;
}
.mainVisual .topText .lede {
	padding-top:32px;
}


/* prizeArea ***/
.itemBoxBuild {
	margin:0 auto;
	width:100%;
}
.itemBoxBuild .itemBox {
	width:306px;
	float: left;
	margin:0 16px 0 0;
}
.itemBox:nth-child(3n) {
	margin-right:0;
}
.itemBox:nth-child(n+4) {
	margin-top:16px;
}
.prizeArea div.styleBox01 > p {
	text-align:center;
}
.prize_s_item {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	margin-bottom: -3px;
}
.prize_s_prize_item img {
	vertical-align: top;
}

/** applyFlow **/
.applyFlow {
	padding-bottom: 60px;
}
.applyFlow .flow .flowHdg {
padding: 17px 0;
}
@media only screen and (min-width: 768px) {

.flow > .flowHdg {
padding: 17px 0;
}

.flow  > .flowHdg .primary {
font-size: 28.96px;
font-size: 2.896rem;
width: 185px;
padding: 8px 20px 0 40px;
}

.flow  > .flowHdg .primary .num {
font-size: 35px;
font-size: 3.5rem;
}

.flow > .flowHdg .secondary {
font-size: 26.24px;
font-size: 2.624rem;
padding: 9px 20px 3px 40px;
}

.flow .flowContent {
padding: 45px 0 20px 230px;
background-position: 83px bottom;
}

} /* mediaquey END*/

/** attInfo **/
.attInfo {
	background-color:#f4f8f3;
	padding-top:0;
	padding-bottom:60px;
}

[data-script-enabled='true'] .attInfo .accordion2Item,
[data-script-enabled='true'] .attInfo .accordionPanel,
[data-script-enabled='true'] .attInfo .accordionPanel {
display: block;
}

.attInfo .accordionBtn:after {
-webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
        transform: rotate(45deg);
}

.attInfo .accordionBtn.active:after {
-webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
        transform: rotate(0deg);
}

.attInfo .listOrder li {
	font-size: 12px;
	font-size: 1.2rem;
}
.attInfo .listOrder li + li {
	margin-top:14px;
}

/** applyBtn **/
.applyBtn {
	padding-bottom:140px;
}

/** rcmndService **/
.rcmndService {
	background:#f7f8f8;
	padding-top:1px;
	padding-bottom:140px;
}
.chance_rcmnd_col2 {
	width:800px;
	height:auto;
	margin:0 auto;
	padding:0;
	position:relative;
}
.chance_rcmnd_col2 .col2Item {
	width:390px;
	padding:0;
	margin:0;
}
.chance_rcmnd_col2 .imgArea {
	margin-right:20px;
}
.chance_rcmnd_col2 .txtArea {
	height:auto;
	margin:0;
	padding:0 0 32px;
}
.chance_rcmnd_col2 .txtArea .midPriorityBtn {
	position:absolute;
	right:0;
	bottom:0;
	margin:0;
}

/** for SP
------------------------------**/

@media only screen and (max-width: 767px) {

body .pcNone {
	display:block;
}
body .spNone {
	display:none;
}

/** header **/
a.premiumLink, .type-premiumChance {
	display: block;
}
.hdg1Box {
	margin-bottom: 0;
}
	.contentsInner {
	padding:16px;
}
.styleBox01 {
	margin-top:0! important;
}
.attentionHdg2 {
	margin-top: 0 !important;
}
.accordion {
	margin-bottom: 0 !important;
}
.mainSub{
	width:auto;
	margin:0 auto;
	padding:0;
}
* + section > .hdg2:first-child,
.hdg2 {
	font-size: 24px;
	font-size: 2.4rem;
	margin: 0 0 3px;
	padding: 12px 16px;
/*	background:#f4f8f3;*/
	border-top: 3px solid #223;
	box-shadow: 0 3px 6px rgba(0, 0, 0, .14);
	line-height: 1.3em;
}

/** KV **/
.mainVisual .kvArea {
	height:auto;
	background-size:cover;
}
.mainVisual .kvArea .topText {
	background:none;
	margin:0 auto;
}
.mainVisual .kvArea .topText img {
	margin:0 auto;
	width: 100%;
}
.mainVisual p {
	padding-left:16px;
	padding-right:16px;
}
.mainVisual .cpn_date {
	margin-bottom:20px;
}

/* prizeArea ***/
.itemBoxBuild {
	width:99%;
	margin:0 auto !important;
	padding:0;
}
.itemBoxBuild .itemBox {
	float:none;
	width:auto;
	margin-left:auto;
	margin-right:auto;
	margin-bottom:16px;
}
.itemBoxBuild .itemBox:last-of-type{
	margin-bottom: 0;
}
.itemBox .itemInnerBox {
	position:static;
}
.prizeArea div.styleBox01 > p {
	text-align:left;
}
/*.itemBox .itemInnerBox *[class*="Btn"] {
	position:relative;
	display:block;
	margin:10px auto 0;
	bottom:0;
	right:0;
}*/
.prize_s_item {
	display: block;
}

/** applyFlow **/
.applyFlow {
	padding-bottom:0;
}

.flow > .flowHdg {
padding: 10px 0;
}

.flow .flowContent {
padding: 17px 0 25px;
background: none;
}

.flow > .flowContent.last {
		padding-bottom: 0;
}

.chanceSurvey > .flowHdg,
.chanceNoSurvey > .flowHdg {
margin-top: 45px;
position: relative;
}

.chanceSurvey > .flowHdg:before,
.chanceNoSurvey > .flowHdg:before {
position: absolute;
top: -39px;
right: 0;
left: 0;
display: block;
width: 38px;
height: 19px;
margin: 0 auto;
content: '';
background-image: url(/mball/common/img/sprite/_sprite.png);
background-position: -174px -544px;
}

.cpnApplicationStepOuter {
	padding: 0 0 40px;
	margin-top: 30px;
}

.cpnApplicationStep {
	padding: 0;
}

.cpnApplicationStepBoxInner {
	padding: 20px;
	min-height: 0;
}

.cpnApplicationStepBoxInnerContent > .cpnApplicationStepBoxInnerContentImg {
	width: 20%;
}

.cpnApplicationStepBox {
	padding-left: 48px;
}

.cpnApplicationStepBoxInnerContent > .cpnApplicationStepBoxInnerContentInfo {
	padding-left: 15px;
}

.cpnApplicationStepBoxInnerContentImg > img {
	max-width: 50px;
}

.cpnApplicationStepBoxInnerContentInfo > .hdg {
	font-size: 1.8rem;
}

.cpnApplicationStep > ol > li::before {
	font-size: 1.8rem;
	line-height: 30px;
	left: 9px;
}

.cpnApplicationStep > ol > li::after {
	width: 30px;
	height: 30px;
}

.cpnApplicationStepBox::before,
.cpnApplicationStepBox::after {
	width: 1.8rem;
	height: 10px;
	background: url("/mball/premium/event/201908_festival/img/bg-arrow-01-sp.png") no-repeat;
	left: 6px;
}

.cpnApplicationStepBox::before {
	top: 40px;
}

.cpnApplicationStepBox::after {
	top: 50px;
}

.cpnApplicationStepBoxInnerContent::before {
	background: url("/mball/premium/event/201908_festival/img/bg-arrow-02.png") no-repeat;
	width: 11px;
	top: -14px;
	left: -31px;
}



/** attInfo **/
.attInfo {
	background-color:#fff;
	padding-top:0;
	padding-bottom:0;
}
.attInfo .notesBox2Innner{
	margin-bottom:0;
	padding-bottom:0;
}

.attInfo .styleBox01,
.attInfo .contentsInner {
	margin-bottom:0;
}

[data-script-enabled='true'] .attInfo .accordion2Item,
[data-script-enabled='true'] .attInfo .accordionPanel,
[data-script-enabled='true'] .attInfo .accordionPanel {
display: none;
}

/** accodion opend **/

.attInfo .hdg2Top:after, .attInfo .hdg2TopUnique:after {
    position: absolute;
    top: 0;
    right: 15px;
    bottom: 0;
    display: block;
    width: 15px;
    height: 15px;
    content: '';
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    -webkit-transform-origin: 50%;
    -ms-transform-origin: 50%;
    transform-origin: 50%;
    background: url(/mball/common/img/sp/icon/icon_plus.png);
    background-size: 15px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.attInfo .hdg2Top.active:after, .attInfo .active.hdg2TopUnique:after{
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
}

.mballTop .attentionBox .textTop2 {
font-size: 75%;
margin: auto 0 12px;
}


/** applyBtn **/
.applyBtn {
	padding-bottom:0;
}

/** rcmndService **/
.rcmndService {
	padding-bottom:0;
	margin-bottom:50px;
	border-bottom:1px solid #ccc;
}

.chance_rcmnd_col2,
.chance_rcmnd_col2 .col2Item {
	width:100%;
	height:auto;
}

.chance_rcmnd_col2 .imgArea {
	margin:0 auto;
	padding:16px 0 0;
}
.chance_rcmnd_col2 .imgArea > img {
	margin:0 auto;
	width:100%;
}

.chance_rcmnd_col2 .txtArea {
	padding-bottom:0 !important;
}
.chance_rcmnd_col2 .txtArea .midPriorityBtn {
	position:relative;
	margin:20px auto;
}
}
