@charset "UTF-8";

/* CSS Document */

body {
    background: #000;
}
body.modal-open {
    height: 100vh;
    overflow-y: hidden;
}

/*====================================

    .nav_dot

====================================*/

.nav_dot {
    display: none;
}
.nav_dot {
}
.nav_dot li:last-child {
    transition: background 0.7s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    position: relative;
}
.nav_dot li:last-child:before {
    transition: background 0.7s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    content: "";
    display: inline-block;
    position: absolute;
    top: -24px;
    right: -20px;
    width: 100%;
    background: url(/images/circle.svg) no-repeat center center;
    background-size: 10px;
    height: 10px;
}
.nav_dot li:last-child {
    margin: 0;
}

/*====================================

    .wrap_body

====================================*/

.wrap_body {
    padding-top: 200px;
}
.wrap_body .block {
    width: 1100px;
    margin: 0 auto;
}
.wrap_body .block .cell {
    border-bottom: 1px solid #fff;
    padding-bottom: 40px;
    margin-bottom: 100px;
}
.wrap_body .block .cell .text_ph {
    display: table;
    width: 100%;
    margin-bottom: 40px;
}
.wrap_body .block .cell .text_ph .ph {
    display: table-cell;
    width: 50%;
    vertical-align: bottom;
}
.wrap_body .block .cell .text_ph .ph a {
    border: 4px solid #fff;
    display: block;
}
.wrap_body .block .cell .text_ph .ph a:hover {
    border: 4px solid #8e8e8f;
}
.wrap_body .block .cell .text_ph .text {
    display: table-cell;
    width: 50%;
    vertical-align: bottom;
    color: #fff;
    padding-left: 40px;
}
.wrap_body .block .cell .text_ph .text .main_ttl {
    margin-bottom: 20px;
}
.wrap_body .block .cell .text_ph .text .main_ttl img {
    height: 36px;
}
.wrap_body .block .cell .text_ph .text dl dt {
    float: left;
    margin-right: 10px;
    font-weight: 700;
    letter-spacing: .05em;
    font-size: 110%;
}
.wrap_body .block .cell .text_ph .text dl dd {
    font-weight: 500;
    letter-spacing: .05em;
    font-size: 110%;
}
.wrap_body .block .cell .text_ph .text dl dd ul li {
    float: left;
    margin-right: 10px;
}
.wrap_body .block .cell .text_ph .text dl dd ul li span {
    display: inline-block;
    width: 15px;
    height: 15px;
    margin-bottom: -2px;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
}
.wrap_body .block .cell .text_ph .text dl dd ul li .white {
    background: #fff;
}
.wrap_body .block .cell .text_ph .text dl dd ul li .yellow {
    background: #fff100;
}
.wrap_body .block .cell .text_ph .text dl dd ul li .red {
    background: #e60012;
}
.wrap_body .block .cell .text_ph .text dl dd ul li .blue {
    background: #106ca6;
}
.wrap_body .block .cell .text_ph .text dl dd ul li .green {
    background: #7db341;
}
.wrap_body .block .cell .text_ph .text dl dd ul li .black {
    background: #000;
    border: 1px solid #fff;
}

/*====================================

    .accordion

====================================*/

.accordion {
    width: 100%;
}
.accordion .button {
    width: 100%;
    height: 40px !important;
    cursor: pointer;
    position: relative;
    background: #000;
    border: none;
}
.accordion .button:after {
    content: "";
    background: url(../images/btn_open.svg) no-repeat;
    position: absolute;
    background-size: 158px;
    bottom: 0;
    right: 0;
    width: 158px;
    height: 40px;
    border: none;
}
.accordion .button.active:after {
    content: "";
    background: url(../images/btn_close.svg);
    background-size: 100%;
}
button:focus {
    outline: 0;
}
.accordion .nest {
    display: none;
    padding-top: 40px;
}
.accordion .nest ul {
    margin-right: -5.33%;
}
.accordion .nest ul li {
    float: left;
    width: 28%;
    margin-right: 5.33%;
    margin-bottom: 40px;
}
.accordion .nest ul li a {
    display: block;
    text-decoration: none;
}
.accordion .nest ul li a .ph {
    border: 4px solid #fff;
    margin-bottom: 10px;
}
.accordion .nest ul li a:hover .ph {
    border: 4px solid #8e8e8f;
}
.accordion .nest ul li a p {
    color: #fff;
    font-weight: 500;
    letter-spacing: .05em;
    font-size: 100%;
}

/*====================================

    .wrap_modal

====================================*/

.wrap_modal {
    display: none;
    position: fixed;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.8);
    z-index: 20;
    top: 0;
    left: 0;
    padding: 60px 0;
    overflow-y: scroll;
}
.wrap_modal .inner {
    background: #fff;
    width: 980px;
    margin: 0 auto;
    padding: 80px 80px;
    position: relative;
    overflow-y: scroll;
}
.wrap_modal .inner .close_x {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 40px;
}
.wrap_modal .inner .ttl {
    width: 100%;
    text-align: center;
    margin-bottom: 40px;
    font-weight: 700;
    letter-spacing: .05em;
    font-size: 170%;
}
.wrap_modal .inner .ph {
    padding-bottom: 80px;
}
.wrap_modal .inner .ph ul.cf {
    width: 100%;
    display: table;
    table-layout: fixed;
    margin-bottom: -40px;
}
.wrap_modal .inner .ph ul.cf > li {
    display: table-cell;
    vertical-align: middle;
}
.wrap_modal .inner .ph ul.cf > li.arrow {
    width: 4%;
}
.wrap_modal .inner .ph ul.cf > li.slider {
    width: 92%;
    padding: 0 80px;
}
.wrap_modal .inner .ph ul.cf > li.slider div.slider-parent {
    border: 1px solid #333;
}
.wrap_modal .inner .ph ul.cf > li.slider div.slider-parent div {
    outline: none;
}
.wrap_modal .inner .text {
    width: 100%;
    display: table;
    margin-bottom: 60px;
}
.wrap_modal .inner .text .list {
    width: 45%;
    display: table-cell;
}
.wrap_modal .inner .text .list dl dt {
    float: left;
    margin-right: 10px;
    font-weight: 700;
    letter-spacing: .02em;
    font-size: 110%;
}
.wrap_modal .inner .text .list dl dd {
    font-weight: 500;
    letter-spacing: .02em;
    font-size: 110%;
}
.wrap_modal .inner .text .list dl dd ul li {
    float: left;
    margin-right: 10px;
}
.wrap_modal .inner .text .list dl dd ul li span {
    display: inline-block;
    width: 15px;
    height: 15px;
    margin-bottom: -2px;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
}
.wrap_modal .inner .text .list dl dd ul li .white {
    background: #fff;
    border: 1px solid #000;
}
.wrap_modal .inner .text .list dl dd ul li .yellow {
    background: #fff100;
}
.wrap_modal .inner .text .list dl dd ul li .red {
    background: #e60012;
}
.wrap_modal .inner .text .list dl dd ul li .blue {
    background: #106ca6;
}
.wrap_modal .inner .text .list dl dd ul li .green {
    background: #7db341;
}
.wrap_modal .inner .text .list dl dd ul li .black {
    background: #000;
}
.wrap_modal .inner .text .chart {
    display: table-cell;
}
.wrap_modal .inner .text .chart .ttl {
    text-align: left;
    font-size: 110%;
    font-weight: 700;
    letter-spacing: .02em;
    margin-bottom: 10px;
}
.wrap_modal .inner .text .chart .ph {
    padding: 0;
    margin-bottom: 20px;
}
.wrap_modal .inner .text .chart .price {
    border-top: 1px solid #000;
    padding-top: 20px;
}
.wrap_modal .inner .text .chart .price dl dt {
    float: left;
    font-weight: 700;
    letter-spacing: .02em;
    margin-right: 1em;
    font-size: 110%;
}
.wrap_modal .inner .text .chart .price dl dd {
    float: left;
    font-weight: 500;
    letter-spacing: .03em;
    font-size: 110%;
}
.wrap_modal .inner .wrap_close {
    width: 100%;
    text-align: center;
}
.wrap_modal .inner .wrap_close a {
    display: inline-block;
    font-weight: 500;
    line-height: 1em;
    border: 1px solid #000;
    color: #000;
    text-decoration: none;
    font-weight: 700;
    padding: 0.6em 2em 0.4em;
    margin: 0 auto;
}
