@charset "utf-8";

#hanabi {
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
	font-size:14px;
}
#hanabi .pchide {
	display: none;
}
#hanabi .clrTxt {
    text-indent: -10000px;
    text-decoration: none;
    overflow: hidden;
    line-height: 0;
}

#hanabi #header {
	background: #080744 url("../images/head_bg.jpg") no-repeat top left / cover;
	position: relative;
	z-index: 0;
}
#hanabi #header:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 30px;
    background: -moz-linear-gradient(top,  rgba(0,0,0,0) 0%, rgba(0,0,0,0.1) 100%);
    background: -webkit-linear-gradient(top,  rgba(0,0,0,0) 0%,rgba(0,0,0,0.1) 100%);
    background: linear-gradient(to bottom,  rgba(0,0,0,0) 0%,rgba(0,0,0,0.1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#a6000000',GradientType=0 );
	bottom: 0;
}
#hanabi #header .container {
	padding: 0;
	min-height: 400px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}

#hanabi #header a {
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: 1;
}
#hanabi #header h1{
	margin-bottom: 20px;
}
#hanabi #header h1 img {
    width: 100%;
}
#hanabi #header h2{color: #fff600;font-size: 35px;}
#hanabi #header h3{color: #ffffff;font-size: 24px;}
#hanabi #header h2 span{font-size: 20px;}


#hanabi main > section {
	background: #FF6A00;
	padding: 50px 0;
}
#hanabi a.btn {
    display: block;
    width: 100%;
    max-width: 900px;
    background: #2B689C;
    border: 4px solid #fff;
    padding: 15px;
    color: #fff;
    text-decoration: none;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin: 10px auto;
    transition: .3s ease-in;
}
#hanabi a.btn:hover {
    background: #fff;
    color: #2B689C;
}



#outline > .container {
	max-width: 900px;
	margin: 0 auto;
}
#outline h1 {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    line-height: 1.8;
    letter-spacing: 0.03em;
    color: #fff;
    text-shadow: 0 0 15px rgb(255 255 255 / .4);
}
#outline .notes {
    background: #fff;
    padding: 20px;
    position: relative;
    margin: 60px 0 50px 0;
}
#outline .notes .badge {
    width: 70px;
    height: 70px;
    background: #ffffff;
    color: #ff6a00;
    margin-bottom: 10px;
    margin: -45px auto 0 auto;
    border-radius: 50%;
    font-size: 35px;
    line-height: 65px;
    text-align: center;
}
#outline .notes p {
    text-align: center;
    font-weight: bold;
    color: #ff6a00;
    font-size: 18px;
    margin-bottom: 10px;
}
#outline .notes p span {
    font-size: 130%;
    display: block;
    background: #ff4239;
    color: #fff;
    padding: .2em 0;
    margin-top: 0.2em;
}
#outline .notes ul {
    text-align: center;
}
#outline .notes li {
    text-align: center;
}
#outline .notes li:last-of-type {
    margin: 0;
}
#points {
	margin: 50px 0;
}
#points li {
    width: 100%;
    color: #fff;
    background: rgb(255 255 255 / .2);
    border-bottom: 1px solid rgb(255 255 255 / .3);
    display: flex;
}
#points li:first-of-type {
    border-top: 1px solid rgb(255 255 255 / .3);
}
#points li .inner {
    width: calc(60% - ((100% - 1280px) / 2));
    padding: 45px 20px 40px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    position: relative;
}
#points li .ttl {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 20px;
    padding-bottom: 15px;
    position: relative;
    text-shadow: 0 0 10px #ff6a00;
}
#points li .ttl:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 30%;
    height: 3px;
    background: rgb(255 255 255 / .5);
    border-radius: 5px;
}
#points li p {
    text-align: center;
    font-size: 18px;
    line-height: 1.8;
}
#points li figure {
    width: 40%;
    min-width: 360px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: 0;
    background: #fff;
}
#points li img {
    width: 100%;
    max-width: 500px;
}
#points li:nth-of-type(even) {
    flex-direction: row-reverse;
}
#points li .inner > span {
    font-size: 10px;
    position: absolute;
    background: #2B689C;
    color: #fff;
    width: 45px;
    height: 66px;
    box-shadow: 1px 1px 2px rgb(0 0 0 / 0.2);
    display: flex;
    flex-direction: column;
    font-weight: bold;
    align-items: center;
    justify-content: center;
    text-align: center;
    top: -5px;
    left: 3%;
}
#points li .inner > span span {
    display: block;
    font-size: 18px;
}


#credit {
    margin-top: 50px;
    border-top: 1px solid rgb(255 255 255 / .3);
    padding-top: 40px;
}
#credit table {
    width: 100%;
    color: #fff;
}
#credit table th,#credit table td {
    font-size: 16px;
    vertical-align: top;
}
#credit table th {
    width: 8%;
    min-width: calc(5em + 15px);
    padding: 10px 15px 10px 0;
    text-justify: inter-ideograph;
    -moz-text-align-last: justify;
    text-align-last: justify;
}
#credit table td {
    width: 42%;
    padding: 10px 0;
}



#hanabi main > #wishtree {
	background: #2B689C;
	position: relative;
	z-index: 1;
	padding-top: 70px;
}
#wishtree .spacer {
	display: block;
	position: absolute;
	top:0;
	left:0;
	width: 100%;
	height: 40%;
	background: radial-gradient(ellipse farthest-side at top center, rgba(0,0,0,0) 40%,#2b689c 100%) no-repeat center/150% 100%,
             url("../images/wishtree_ph01.jpg") no-repeat center center /cover fixed;
}
#wishtree h1 {
    width: 26%;
}
#wishtree h1 img {
    width: 100%;
}
#wishtree h1 + div {
    width: 70%;
}
#wishtree .desctiption {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#wishtree .desctiption h2 {
    text-align: center;
    font-size: 28px;
    font-weight: bold;
    line-height: 1.8;
    letter-spacing: 0.03em;
    color: #fff;
    text-shadow: 0 0 15px rgb(255 255 255 / .4);
}
#wishtree .desctiption h3 {
    background: #fff;
    margin-top: 20px;
    text-align: center;
    font-size: 28px;
    font-weight: bold;
    line-height: 1.8;
    letter-spacing: 0.03em;
    padding: 5px 0;
    color: #2b689c;
    box-shadow: 0 0 15px rgb(255 255 255 / .4);
}
#wishtree .sample {
    background: #fff;
    padding: 30px;
    margin-top: 70px;
    width: 100%;
    position: relative;
}
#wishtree .sample .badge {
    width: 70px;
    height: 70px;
    background: #ffffff;
    color: #ff6a00;
    margin-bottom: 10px;
    margin: -55px auto 0 auto;
    border-radius: 50%;
    font-size: 35px;
    line-height: 65px;
    text-align: center;
}
#wishtree .sample h3 {
    text-align: center;
    font-size: 25px;
    color: #2b689c;
}
/*#wishtree ul {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
}
#wishtree ul li {
    width: 31%;
    color: #fff;
}
#wishtree ul img {
    width: 100%;
}*/
#wishtree #present {
    margin-top: 70px;
    padding: 40px 0;
    position: relative;
    background: #fff;
}
#wishtree #present:before {
	content: "";
	position: absolute;
	width: 60px;
	height: 30px;
	top: -30px;
	left: 0;
	right: 0;
	margin: auto;
	background: linear-gradient(to bottom right, rgba(255, 255, 255, 0) 50%, #ffffff 51%) no-repeat left/50% 100%,
                linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #ffffff 51%) no-repeat right/50% 100%;
}
#wishtree #present p {
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.03em;
    color: #ff6a00;
    margin-bottom: 10px;
}
#wishtree #present .notes {
    margin-bottom: 25px;
}
#wishtree #present .notes li {
    text-align: center;
    font-size: 13px;
    margin-bottom: 5px;
    text-indent: -1em;
    padding-left: 1em;
}
#wishtree #present .btn {
    font-size: 40px;
    padding: 20px;
    background: #ffcd15;
    color: #2b689c;
    border: 4px solid transparent;
    margin-bottom: 0;
    border-radius: 20px;
}
#wishtree #present .btn:hover {
    background: #fff;
    color: #ff6a00;
    border: 4px solid #ffcd15;
}


#wishtree .bnarea .container {
    max-width: 900px;
    margin: 30px auto;
}
#wishtree .bnarea .toyotabn {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    width: 100%;
    max-width: 690px;
    min-height: 130px;
    background: #7dccf3;
    padding: 2% 0 1.2% 0;
    padding-left: 25%;
    color: #fff;
    text-decoration: none;
    text-align: center;
    font-size: 42px;
    line-height: 1.4;
    font-weight: bold;
    margin: 60px auto 0 auto;
    transition: .3s ease-in;
    position: relative;
}
#wishtree .bnarea .toyotabn:hover {
    background: #c5ebff;
}
#wishtree .bnarea .toyotabn img:first-of-type {
    width: 34%;
    max-width: 240px;
    position: absolute;
    left: 0.8%;
    top: 0;
    bottom: 0;
    margin: auto;
}
#wishtree .bnarea .toyotabn span {
	font-size: 70%;
	display: block;
}

