@charset "UTF-8";

/* planprice ---------------------------------------*/

.planprice {
    width: 69.719vw;
    margin: 0 auto;
    padding: 11.5vw 0 6.9vw;
}

.planprice-title {
    text-align: center;
    display: flex;
    flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	flex-wrap: wrap;
	gap: 2.2vw;
    margin-bottom: 5.5vw;
}

.planprice-title span {
    font-size: max(2.188vw,24px);
    letter-spacing: 0.15em;
}

.planprice-title small {
    font-size: max(1.15vw,16px);
    letter-spacing: 0.1em;
}

.planprice-head {
    display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
    margin-bottom: 5.5vw;
}

.planprice-head-item {
    width: 33.2%;
    background: #838383;
    color: #fff;
    text-align: center;
    font-size: max(1.15vw,16px);
    letter-spacing: 0.15em;
    padding: 1.05vw 0.5vw;
}

.planprice-text {
    text-align: center;
    font-size: 20px;
    font-size: max(1.042vw,15px);
    margin-bottom: 1.25vw;
    letter-spacing: 0.15em;
}

.planprice-table-wrapper {
    margin-bottom: 5.2vw;
}

.planprice-table {
    display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
    border-bottom: 1px solid #000;
}

.planprice-table-item {
    width: 33.333%;
    vertical-align: middle;
    font-size: max(1.15vw,16px);
    padding: 1.46vw 0.2vw;
    letter-spacing: 0.1em;
    text-align: center;
    white-space: nowrap;
}

.planprice-table-item small {
    vertical-align: middle;
    font-size: max(0.833vw,12px);
}

.planprice-message {
    font-size: max(1.042vw,15px);
    margin-top: 9.4vw;
    margin-bottom: 3.9vw;
    text-align: center;
    line-height: 3;
}

.planprice-btn-group {
    display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-wrap: wrap;
    gap: 1.042vw;
}

.planprice-btn-wrapper {
	max-width: max(22.5vw, 432px);
    width: calc(50% - 0.521vw);
}

.planprice-btn {
    display: inline-block;
    position: relative;
	width: 100%;
	height: max(4.479vw, 86px);
    padding: 0 calc(95 / 1920 * 100vw) 0 calc(40 / 1920 * 100vw);
    font-size: max(1.042vw, 20px);
    line-height: max(4.479vw, 86px);
	background: #fff;
	border: 1px solid #909090;
	transition: all .6s ease;
}

.planprice-btn .icon_arrow {
	position: absolute;
	top: 50%;
	right: calc(26 / 1920 * 100vw);
	transform: translateY(-50%);
	width: max(2.24vw, 43px);
}

.planprice-btn:hover {
	opacity: 1;
	background: #909090;
	color: #fff;
}

.planprice-btn:hover .icon_arrow{background: #fff;}

.planprice-btn.is-disable {
    background: #D2D2D2;
    border: #D2D2D2;
    opacity: 0.4;
}

.planprice-btn.is-disable:hover {
    background: #D2D2D2;
    border: #D2D2D2;
    color: #000;
}

.planprice-btn.is-disable .icon_arrow {
    background: #000;
}

.planprice-btn.is-disable:hover .icon_arrow {
    background: #000;
}

.planprice-btn-notice {
    margin-top: 1vw;
    line-height: 2;
    font-size: max(0.833vw,12px);
    letter-spacing: 0.05em;
    text-align: center;
}


/* pc only */
@media screen and (min-width: 768px){
}


/* sp only */
@media screen and (max-width: 767px){

    /* planprice ---------------------------------------*/

    .planprice {
        width: 74.358vw;
        margin: 0 auto;
        padding: 21vw 0 17.1vw;
    }

    .planprice-title {
        gap: 4.5vw;
        margin-bottom: 20vw;
    }

    .planprice-title span {
        font-size: 4.615vw;
        letter-spacing: 0.15em;
    }

    .planprice-title small {
        font-size: 2.564vw;
        letter-spacing: 0.1em;
    }

    .planprice-table-head {
        text-align: center;
        background: #838383;
        color: #fff;
        font-size: 3.846vw;
        letter-spacing: 0.1em;
        line-height: 1.3;
        padding: 2.8vw 2vw;
        margin-bottom: 5vw;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
        gap: 1vw;
    }

    .planprice-table-head span {
        font-size: 2.564vw;
        line-height: 1.7;
    }

    .planprice-table-wrapper {
        margin-bottom: 10vw;
    }

    .planprice-table {
        border-bottom: none;
    }

    .planprice-table-item {
        width: 50%;
        font-size: 3.590vw;
        padding: 3.2vw 0;
        text-align: left;
        white-space: nowrap;
        line-height: 1.15;
        letter-spacing: 0.15em;
    }

    .planprice-table-item.is-sp-full {
        width: 100%;
        border-bottom: 1px solid #BBBBBB;
    }

    .planprice-table-item:last-of-type {
        text-align: right;
    }

    .planprice-table-item small {
        font-size: 2.564vw;
    }

    .planprice-message {
        font-size: 3.077vw;
        margin-top: 25.2vw;
        margin-bottom: 12vw;
        line-height: 2.7;
    }

    .planprice-btn-group {
        display: block;
    }

    .planprice-btn-wrapper {
        max-width: 100%;
        width: 100%;
    }

    .planprice-btn-wrapper + .planprice-btn-wrapper {
        margin-top: 4vw;
    }

    .planprice-btn {
        display: inline-block;
        position: relative;
        width: 100%;
        height: auto;
        padding: 4vw 2vw;
        font-size: 3.077vw;
        line-height: 1.1;
        background: #fff;
        border: 1px solid #909090;
        transition: all .6s ease;
    }

    .planprice-btn .icon_arrow {
		right: calc(11 / 390 * 100vw);
		width: calc(21 / 390 * 100vw);
    }

    .planprice-btn:hover {
        opacity: 1;
        background: #fff;
        color: #000;
    }

    .planprice-btn:hover .icon_arrow{background: #fff;}

    .planprice-btn.is-disable {
        background: #D2D2D2;
        border: #D2D2D2;
        opacity: 0.4;
    }

    .planprice-btn.is-disable:hover {
        background: #D2D2D2;
        border: #D2D2D2;
        color: #000;
    }

    .planprice-btn.is-disable .icon_arrow {
        background: #000;
    }

    .planprice-btn.is-disable:hover .icon_arrow {
        background: #000;
    }

    .planprice-btn-notice {
        margin-top: 3vw;
        line-height: 1.8;
        font-size: 2.564vw;
        letter-spacing: 0.1em;
    }
}


/* iphone5 iphoneSE用 */
@media screen and (max-width: 370px){


}