/* =========================================================
		common
========================================================= */
body {font-family: "Noto Sans JP","游ゴシック体",YuGothic,"游ゴシック Medium","Yu Gothic Medium","游ゴシック","Yu Gothic","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ","Meiryo",sans-serif; color: #1A1818; line-height: 1.6; margin: 0; padding: 0; letter-spacing: 1px; overflow-x: hidden; font-size: 16px;}
.pc-none{ display: none !important;}
.sp-none{ display: block;}
#wrapper{position: relative; background: #1a1818;}
a {transition: .3s;}
a:hover{opacity: 0.6;}
.en {font-family: "Grotesque MT Bold Extended", sans-serif; vertical-align: initial; line-height: 1;}
/* =========================================================
		TOP contents
========================================================= */
/*---TOP main---*/
.main_kv{background: url(../img/body_bg.jpg) no-repeat center top; background-size: cover; height:53vw; background-attachment: fixed;}
.main_pic{width: 88vw; margin: 0 auto; padding-top: 2.5vw;}
.oubo_span{background:#c10020; padding: 22px 0;}
.oubo_span p{color: #fff; font-weight: 700; font-size: 26px; line-height: 0.7; text-align: center; font-feature-settings: "palt";}
.oubo_span p span{font-size: 1.45em; font-family: Arial, Helvetica, "sans-serif";}
.oubo_span_end p{font-size: 36px; line-height: 1.6;}
.oubo_span_end2{padding:28px 0 22px; font-size: 28px;}
.cp_date{background: #c10020; padding: 16px 0; text-align: center;}
.cp_date img{width:62%; margin: 0 auto;}

.cp_date_coming{background: #c10020; padding: 24px 0; text-align: center;}
.cp_date_coming img{width:65%; margin: 0 auto;}

.cp_main_ttl{width: 830px; margin: 55px auto 20px;}
.cp_sub_copy{text-align: center; font-size: 38px; margin-bottom: 40px; font-weight: 600; color: #fff;}
span.marker {
        background: linear-gradient(transparent 75%, #c10020 10%);
    padding-bottom: 0;
}

.oubo_btn{margin:0 auto 65px;}
.oubo_btn a{display: block;
    margin: 0 auto 0;
    background: #c10020;
    border-radius: 3em;
    text-align: center;
    padding: 22px 0 22px;
    color: #fff;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 0px;
    text-align: center;
    text-decoration: none;
    position: relative;
    line-height: 1;
    transition: all .3s;
	border: 2px solid #fff;
    width: 300px;
}
.oubo_btn a:hover{transform: scale(1.02,1.02); opacity: 0.9;}
.oubo_btn a::after{
    content: "";
    width: 8px;
    height: 8px;
    border-bottom-style: initial;
    border-left-style: initial;
    border-bottom-color: initial;
    border-left-color: initial;
    transform: rotate(45deg);
    position: absolute;
    top: 52%;
    right: 8%;
    margin-top: -5px;
    border-width: 1px 1px 0px 0px;
    border-image: initial;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}



/*---product con---*/
.product_con{background: #f2eee8; width: 840px; padding: 50px 50px 60px; margin: 0 auto 45px;}
.product_con .bacardi_logo{width: 280px; margin: 0 auto 5px;}
.pro_sub_ttl{font-size: 20px; text-align: center; font-weight: 600;}
.product_con .product_box{margin: 40px auto 0; display: flex; justify-content: space-between;}
.product_con .product_box .bacardi_gold{width: 44%; padding: 25px 0 3px; background: #c10020; text-align: center;}
.product_con .product_box .bacardi_gold img{width: 85%; margin: 0 auto;}
.product_con .product_box .gold_detail{width: 51%; padding: 20px 0 0;}

.product_con .product_box .gold_detail h4{font-size: 50px; line-height: 0.9; padding-bottom: 7px; letter-spacing: 0;}
.product_con .product_box .gold_detail .gold_name{font-size: 18px; font-weight: 600; padding-bottom: 15px;}
.gold_detail .gold_att{font-size: 12px; padding-top: 20px;}

/*---present con---*/
.present_con{background: #f2eee8; width: 840px; padding: 55px 50px 50px; margin: 0 auto 45px;}
.section_ttl{font-size: 56px; padding-bottom: 0px; text-align: center; letter-spacing: 0;}
.present_con .present_pic{margin: 27px auto 0; width: 100%;}

/*---howto con---*/
.howto_con{background: #f2eee8; width: 870px; padding:60px 35px 50px; margin: 0 auto 35px;}
.howto_con ul{display: flex; justify-content: space-between; margin-top: 35px;}
.l-step_item {
    width: 23.5%;
	position: relative;
}
.l-step_inner{
	background: #fff;
	border: 1px solid #b19477;
	padding: 12px 6% 20px;
	height: 325px;
}
.l-step_item_img {
  width: 90%;
	margin: 0 auto;
}
.l-step_item_no {
	font-size: 22px;
	text-align: center;
	color: #b19477;
	letter-spacing: -0.5px;
	margin: 0 auto 13px;
}
.l-step_item_no span{font-size: 1.4em;}
.l-step_item_ttl {
    font-size: 16px;
    letter-spacing: 0px;
    padding-top: 13px;
	line-height: 1.35;
}
.l-step_item_txt{
	 margin-top: 6px;
    font-size: 14px;
	line-height: 1.5;
	font-weight: 500;
}
.l-step_item_att{
	margin-top: 8px;
    font-size: 12px;
    line-height: 1.4;
    letter-spacing: 0;
}
.step1pic{width: 21%;}


.oubo_kiyaku a{
	color: #fff;
    border: 1px solid #fff;
    font-size: 14px;
    width: 130px;
	padding: 9px 0;
	display: block;
    margin:10px auto 15px;
    text-align: center;
	font-weight: 500;
}
.oubo_kiyaku2 a{
	width: 200px;
 margin:0 auto 18px;
}
.kiyaku_att{font-size:14px; text-align: center; color: #fff;}





.btn_area{width: 960px; margin: 35px auto 95px;}
.btn_area .btn_cp_ttl{width: 350px; margin: 0 auto;}
.btn_area .btn_cp_copy{font-size: 26px; font-weight: 600; text-align: center; padding:3px 0 10px; color: #fff;}
.entry_area{display: flex;
    justify-content: center;
    margin: 0 auto;
    padding: 50px 0 0px;}
.entry_area .entry_btn a{
	position: relative;
	display: block;
    width: 330px;
    padding: 28px 0 23px;
    margin: 0 10px;
    background-color: #c10020;
	border: 2px solid #fff;
	color: #fff;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-align: center;
    text-decoration: none;
    
    transition: 0.2s;
    position: relative;
	line-height: 1;
	border-radius: 3em;
}
.entry_area .entry_btn a:hover{
	opacity: 0.85;
transform: translateY(0.2vw);
  box-shadow: 0 0 0 #a9120b;}
.entry_area .entry_btn a span{font-size: 1.25em;}
.entry_area .entry_btn a .subcopy{
background-color: #fff;
	color: #c10020;
border:2px solid #fff; 
border-radius: 3em;
position: absolute;
top: -25px;
left: 50%;
transform: translateX(-50%);
width: 55%;
padding: 10px 0;
font-size: 14px;
letter-spacing: 0.3px;
}
.entry_area .entry_btn a .subcopy::before {
    content: "";
    top: 34px;
    left: 46%;
    position: absolute;
    width: 0px;
    height: 0px;
    border: 8px solid;
    border-color: white transparent transparent transparent;
}
.entry_area .entry_btn a .subcopy::after {
    content: "";
    top: 31px;
    left: 46%;
    position: absolute;
    width: 0px;
    height: 0px;
    border: 8px solid;
    border-color: #fff transparent transparent transparent;
}
.entry_area .login_btn a{
	background-color: #fff;
	border: 2px solid #c10020;
	color: #c10020;
}
.entry_area .login_btn a .subcopy{background-color: #c10020; border:2px solid #c10020; color:#fff;}
.entry_area .login_btn a .subcopy::before {border-color: #c10020 transparent transparent transparent;}
.entry_area .login_btn a .subcopy::after {border-color: #c10020 transparent transparent transparent;}
.sign_btn a span, .login_btn a span{letter-spacing: 0; font-size: 14px;}






/*---mypage btnarea---*/
.my_btn_area{margin:40px auto 80px;}

.my_btn_area .btn_cp_ttl{width: 320px; margin: 0 auto;}
.my_btn_area .btn_cp_copy{font-size: 23px; font-weight: 600; text-align: center; padding:3px 0 10px; color: #fff;}

.oubo_main_btn{margin: 5px auto 30px;}
.oubo_main_btn a{
	display: table;
    margin: 0 auto 0;
    background: #c10020;
    border-radius: 50em;
    text-align: center;
    padding: 28px 0 28px;
    font-size: 26px;
	color: #f9f176;
    font-weight: 600;
    letter-spacing: 0px;
    text-align: center;
    text-decoration: none;
    position: relative;
    line-height: 1;
    transition: all .3s;
	border: 2px solid #fff;
	width: 500px;
}
.oubo_main_btn a::after {
    content: "";
    width: 8px;
    height: 8px;
    border-bottom-style: initial;
    border-left-style: initial;
    border-bottom-color: initial;
    border-left-color: initial;
    transform: rotate(45deg);
    position: absolute;
    top: 52%;
    right: 8%;
    margin-top: -5px;
    border-width: 1px 1px 0px 0px;
    border-image: initial;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}
.oubo_main_btn a span{font-size: 1.4em; color: #f9f176;}
.oubo_main_btn a img{width: 330px; margin: 0 auto; padding-bottom: 5px;}
.oubo_main_btn a:hover{transform: scale(1.02,1.02); opacity: 0.9;}

/*---highball---*/
.highball_area{background: url(../img/body_bg.jpg) no-repeat center top; background-size: cover; background-attachment: fixed; position: relative; padding: 75px 0;}
.highball_area .inner{margin: 0 auto;}


.highball_area .highball_con{width:816px; margin: 0 auto; padding: 15px 55px 55px;  border: 8px solid #7bc59b; background-color: #fff;}
.highball_con .high_ttl1{width: 86%; margin: 0 auto 10px;}
.highball_con .high_copy1{text-align: center; font-size: 19px; padding: 0 0 30px; font-weight: 500; line-height: 1.8;}
.highball_area .highball_ttl{background: #b29477; padding: 8px 0; color: #fff; font-size: 22px; font-weight: 600; margin-bottom: 30px; text-align: center;}

.highball_area .material_box{display: flex; margin-bottom: 60px;}
.highball_area .material{font-weight: 600; color: #b29477; font-size: 20px; padding-left: 25px; padding-right: 35px; margin-right: 25px; border-right: 1px solid #b29477;}
.highball_area .material_copy{font-weight: 600; line-height: 1.6;}
.highball_area .highball_way ul{margin: 0 auto 10px; display: flex; justify-content: space-between; align-items: center; width: 90%;}
.highball_area .highball_way ul li{width: 23.5%; border: 1px solid #b29477; padding: 5% 2% 2%; position: relative; height: 260px;}
.highball_way ul li .way_step{width: 25%; position: absolute; top: -20px; left: 50%; transform: translateX(-50%);}
.highball_area .highball_way ul li dt{padding-bottom: 10px; text-align: center;}
.highball_area .highball_way ul li dt img{width: 50%; margin: 0 auto;}
.highball_area .highball_way ul li:nth-child(5) dt img{width: 32%;}
.highball_area .highball_way ul li dd{font-size: 15px; text-align: center; font-weight: 600; letter-spacing: 0;}
.highball_area .highball_way ul .arrow_way{
	width: 0;
  height: 0;
	padding: 0 0;
  border-top: 30px solid transparent;
  border-right: none;
	border-left: 30px solid #b29477;
  border-bottom: 30px solid transparent;
}

.detail_btn a{
	display: block;
	margin: 45px auto 0;
	background: #1A1818;;
	border-radius: 3em;
	text-align: center;
    padding:24px 0 24px;
	color: #fff;
    font-size: 18px;
    font-weight: 600;
    letter-spacing:0px;
    text-align: center;
    text-decoration: none;
	position: relative;
	line-height: 1;
	transition: all .3s;
width: 310px;}
.detail_btn a:hover{
	opacity: 0.75;
}
.detail_btn a::after{
    content: "";
    width: 8px;
    height: 8px;
    border-bottom-style: initial;
    border-left-style: initial;
    border-bottom-color: initial;
    border-left-color: initial;
    transform: rotate(45deg);
    position: absolute;
    top: 52%;
    right: 8%;
    margin-top: -5px;
    border-width: 1px 1px 0px 0px;
    border-image: initial;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}

/*---music---*/
.music_con{width:846px; margin: 65px auto 0; padding: 70px 40px 60px;  border: 8px solid #c10020; background-color: #f2eee8; position: relative;}
.music_con .music_icon{width: 170px; top: -55px; left: -55px; position: absolute;}
.music_con .music_ttl{font-size: 50px; letter-spacing: -2px; text-align: center;}
.music_con .music_jp{font-size: 33px; letter-spacing: 0; text-align: center; padding-bottom: 15px; font-weight: 600;}
.music_con .music_copy{font-size: 19px; line-height: 1.8; text-align: center; padding-bottom: 35px; font-weight: 500;}

/* =========================================================
		footer
========================================================= */
footer{background: #1a1818;}
.footer-inner{ padding: 60px 0 40px; color: #fff;}
.footer-inner .cp_contact{display: table; margin: 0 auto 0;}
.footer-inner .cp_contact .inner{display: flex;}
.footer-inner .cp_contact .inner h3{font-size: 18px; margin-right: 37px;}
.footer-inner .cp_contact .inner p{padding-bottom: 3px; font-size: 15px; letter-spacing: 0.5px;}
.hp_link_area{display: table; margin: 45px auto 40px;}
.hp_link_area ul{display: flex;}
.hp_link_area ul li{margin: 0 10px;}
.hp_link_area ul li a{border: 1px solid #fff; padding: 12px 20px; font-size: 14px; font-weight: 600;}
.footer_logo{width:220px; margin: 30px auto 30px;}
.footer-inner .copyr{letter-spacing: 0; font-size: 12px; text-align: center;}




.l-footer_sub_caution{display: flex; justify-content: center; padding: 25px 0 30px;}
.l-footer_sub_caution ._lead{font-size: 13px;
    line-height: 1.5;
    padding-left: 10px;}



.totop {background: #c10020;; border-radius: 20px; width: 40px; height: 40px; display: inline-block; margin: 2%; z-index: 999;text-align: right; right: 0; bottom: 0; position: fixed; bottom: 40px; opacity: 0.8; display: none;}
.totop a { display: inline-block; position: relative; width: 41px; height: 40px;}
.totop a::after { position: absolute; content: ""; width: 13px; height: 13px; vertical-align: middle; border-top: 1px solid #fff; border-right: 1px solid #fff; -webkit-transform: rotate(315deg); transform: rotate(315deg); vertical-align: middle; right: 34%; top: 15px;}



/* =========================================================
	kiyaku regulation
========================================================= */
/* ---regulation----*/
.kiyaku_bg{
	   background: #f2eee8; position: relative;
	padding: 4% 0;
}
.kiyaku_area{background: rgba(255, 255, 255, 0.9); max-width: 900px; width: 80%; margin: 0 auto; padding: 6% 5% 6%; line-height: 1.7;}
.kiyaku_area .kiyaku_title1{
	font-size: 28px;
	margin-bottom: 20px;
	font-weight: 600;
}
.kiyaku_area .kiyaku_copy {
    font-size: 16px;
	padding-bottom: 8px;
}
.kiyaku_area .kiyaku_copy2 {
    font-size: 15px;
	padding-left: 8px;
}
.kiyaku_area .kiyaku_copy3 {
    font-size: 15px;
	padding-bottom: 8px;
}
.kiyaku_area .kiyaku_title {
    margin: 3.5% 0 5px;
	font-size: 18px;
}

.kiyaku_sub_title{margin: 15px 0 3px; font-size: 15px;}
.nopmargin{margin-top: 0;}


.kiyaku_area li {
    padding-left: 1em;
    text-indent: -1em;
}
.kiyaku_area .kiyaku_att3 li{
	 padding-left: 2.5em;
    text-indent: -2.5em;
}
.kiyaku_att_txt{font-size: 12px;}
.kiyaku_area li {
    font-size: 15px;
	padding-bottom: 5px;
}
.kiyaku_area p a{
	color: #1b0000;
	
}
.kiyaku_area p a:hover{
	opacity: 0.7;
}

.home_btn_r a{
	display: block;
    width: 240px;
    padding: 19px 0 19px;
    margin: 30px auto 15px;
    background-color: #1b0000;
    border: 2px solid #1b0000;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-align: center;
    text-decoration: none;
    transition: 0.2s;
    position: relative;
    line-height: 1;
    border-radius: 3em;
}
.home_btn_r a:hover{
    background-color: #fff;
    border: 2px solid #1b0000;
    color: #1b0000;
   
}

/* =========================================================
		top modal
========================================================= */
#wrap{
	display: none
	
	
}

.modal {
 display: block;
   
    	
	  background: #231815;
   
    position: fixed;
    text-align: center;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 200000;
	  }
#ageModal .modal__bg {
 background:url(../img/logo-mark-black.svg) 50% 43% no-repeat #1A1818; padding: 0;
    background-size: cover;
	flex-direction: column;
align-items: center;
position: fixed;
	display: flex;
	background-size: 100% auto;
}

.modal .modal__bg {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,.8);
}

.modal .modal__contents {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

#ageModal .modal__contentsInner {
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    padding: 0;
    transform: translate(-50%,-50%);
    background-size: contain;
}

#ageModal .age__dewarsLogo {
    width: 48.4589%;
    margin: 0 auto 0;
}


#ageModal .age__txt {
  margin-top: 5.13699%;
    font-weight: 400;
    font-size: 15px;
    letter-spacing: .06em;
    text-align: center;
    line-height: 1.3;
	color: #fff;
}

#ageModal .age__txt span {
    display: block;
    margin-top: .3em;
    font-size: 26px;
 font-weight: 500;
}


#ageModal .age__btns {
    display: flex;
    margin-top: 6.84932%;
    justify-content: center;
}



      #ageModal .age__btns > li {
      
        -webkit-transition: opacity .2s;
        -o-transition: opacity .2s;
        transition: opacity .2s; }
        #ageModal .age__btns > li:nth-of-type(1) {
          float: left; }
        #ageModal .age__btns > li:nth-of-type(2) {
          float: right; }
        #ageModal .age__btns > li:hover {
          opacity: .75; }


#ageModal .age__btns>li {
    width: 38%;
    margin: 0 1.5%;
}


button {
    width: 100%;
    padding: 0;
    background-color: transparent;
    border: none;
    font-family: inherit;
    cursor: pointer;
    outline: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.lock1{position: fixed; width: 100%;}
.age__btns button{
	    border: 2px solid #fff;
    padding: 12px 0;
	    width: 100%;
    font-size: 14px;
    font-weight: 600;
	color: #fff;
}

.modal .copyr{letter-spacing: 0; font-size: 12px; text-align: center; color: #fff;
 position: absolute;
	bottom:5%;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	width: 90%;
}
/* =========================================================
		tab
========================================================= */
@media screen and (max-width: 1100px) {
.main_kv{background-attachment: inherit;}
.line_bg{background-attachment: inherit;}
.highball_area{background-attachment: inherit;
	    background: url(../img/body_bg.jpg) repeat center top;}

}
