@charset "utf-8";
/* CSS Document */

/*------------------------------------------
  共通設定用
------------------------------------------*/
body {
    opacity: 0;
}
.fade {
    opacity: 1;
    transition: .5s;
}
.content {
    width: 90%;
}
.flex {
    display: flex;
}
/* ボタン */
.c_top_btn a {
	min-width: 300px;
    max-width: 400px;
	display: block;
	padding: 15px 0;
	font-size: 1.6rem;
	text-align: center;
	color: #ddd;
	background: #2f5597;
	border-radius: 3px;
    margin: 30px auto 0;
}
.c_top_btn a:hover{
	text-decoration: none;
    opacity: .8;
    transition: .8s;
}

/*------------------------------------------
  共通設定用
------------------------------------------*/
.main {
    background: url("/sevice_shared/img/cloud/idcfcloud/new/img_mv.png") no-repeat 0 / cover;
    position: relative;
    overflow: hidden;
}
.main .main_copy {
    width: 70%;
    max-width: 600px;
    position: relative;
    z-index: 1;
    padding: 60px 0;
}
.main .main_copy h2 {
    margin: 0 auto 10px;
    font-size: 4rem;
    line-height: 1.3;
}
.main .main_copy p {
    font-weight: bold;
    text-align: center;
    position: relative;
    max-width: 400px;
    margin: 0 auto;
}
.main .main_copy p:before,
.main .main_copy p:after {
    content: '';
    position: absolute;
    width: 50px;
    height: 1px;
    background: #333;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}
.main .main_copy p:before {
    left: 0;
}
.main .main_copy p:after {
    right: 0;
}
.main .main_copy h1 {
    width: 270px;
    margin: 0 auto 30px;
    padding: 0;
}
.main_cta {
    justify-content: space-evenly;
}
.main_cta a {
	color: #fff;
    background: #2f5597;
	display: block;
    width: 250px;
    padding: 20px;
    border-radius: 3px;
    box-sizing: border-box;
    text-align: center;
}
.main_cta a:nth-of-type(2) {
    background: #4d9feb;
}
.main_cta a:hover {
	text-decoration: none;
	opacity: .8;
	transition: 0.2s linear;
}
.main .mv_image {
    position: absolute;
    top: 0;
    right: -100px;
    max-width: 800px;
    z-index: 0;
}
.main .mv_bnr {
    position: absolute;
    width: 280px;
    top: 50px;
    right: 0;
}


/*------------------------------------------
  選ばれるポイント
------------------------------------------*/
#point {
    position: relative;
    overflow-x: hidden;
    padding-bottom: 50px;
}
#point:after {
    content: '';
    position: absolute;
    width: 110%;
    height: 500px;
    background: #fff;
    border-radius: 100%;
    box-shadow: 0 12px 20px 0px rgba(0,0,0,0.1);
    bottom: 25px;
    left: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: -1;
}
#point ul {
    justify-content: space-between;
}
#point ul > li {
    width: 23.5%;
}
#point ul > li figure {
    width: 180px;
    margin: 0 auto;
}
#point ul > li p {
    margin-bottom: 20px;
}
#point ul > li h4 {
    line-height: 3rem;
}
#point ul > li:last-child h4 {
    line-height: 6rem;
}
#point ul > li a {
    background: url(/sevice_shared/img/svg/icn_arrow_b.svg) no-repeat left 50% / 10px;
    padding-left: 15px;
    font-size: 1.5rem;
}


/*------------------------------------------
  仕様・料金
------------------------------------------*/
.graph_area02 {
	display: none;
}
.graph_area01 td,
.graph_area02 td {
	color: #fff;
}
.wrap_server_type {
    justify-content: center;
}
.server_type {
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 10px;
}
.server_type:first-of-type {
    width: 500px;
}
.server_type:last-of-type {
    width: 370px;
}
.server_type li {
	width: 120px;
	color: #fff;
	font-size: 1.4rem;
	line-height: 1.1;
	box-sizing: border-box;
	padding: 8px 5px 9px;
}
.server_type.ha li {
    width: 80px;
}
.type_Light { background: #90C974; }
.type_Economy { background: #429e66; }
.type_Standard { background: #7BD4F1; }
.type_HighCPU { background: #A48AD4; }
.type_HighMEM { background: #2595C9; }
.type_UltraMEM { background: #2b6daf; }
.type_HighIO { background: url(/img/cloud/bg_highiohighsto.png); }
.type_GPU { background: #000; }
.type_Tank { background: #4B5C49; }

.server_type li.type_machine {
    flex: none;
    background: #333;
    width: 100%;
    margin-top: 5px;
}
.price_graph table {
	font-weight: bold;
}
.price_graph_table {
	position: relative;
}
.x-axis,.y-axis {
	display: inline-block;
	margin-left: 20px;
	padding: 2px 10px;
	background: #dedede;
	position: absolute;
}
.price_graph_table table {
	margin-top: 50px;
}
.y-axis {
	top: -25px;
	left: 0;
}
.x-axis {
	right: 18px;
	bottom: 0;
}
.price_graph table tr th,.price_graph table tr td { margin: 0 !important; padding: 0 !important; }
.price_graph table tr th:first-child { padding: 12px !important; }
.price_graph table tr th { background: none; font-weight: normal; border: none; }
.price_graph table tr > th { font-size: 14px; text-align: right; }
.price_graph table tr:last-child > th { text-align: center; }
.price_graph table tr td { border: 1px dotted #ccc; font-size: 12px; line-height: 15px;}
.price_graph table tr td span.price { font-size: 13px; font-weight: normal;}

.price_machine ul {
	display: none;
}
.price_machine ul {
	display: flex;
    justify-content: center;
}
.price_machine li:first-child {
	margin-right: 20px;
}
.price_machine li {
	text-align: center;
}
.price_tab_active {
	position: relative;
	background: #4d9feb;
	padding: 12px 20px;
	color: #fff;
	font-size: 20px;
	border-radius: 5px;
	width: 200px;
}
.price_tab {
	position: relative;
	background: #eaebed;
	padding: 12px 20px;
	color: #555;
	font-size: 20px;
	border-radius: 5px;
	width: 200px;
	cursor: pointer;
}
.price_tab_active:before {
	border-color: rgba(255, 255, 255, 0);
	border-top-color: #ffffff;
	border-width: 8px;
	margin-left: -8px;
}
.price_tab_active:after, .price_tab_active:before {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
}
.price_tab_active:after {
	border-color: rgba(149, 198, 213, 0);
	border-top-color: #4d9feb;
	border-width: 7px;
	margin-left: -7px;
}
#price table th p.type {
	color: #fff;
	text-align: center;
	padding: 3px;
	margin: 3px auto;
}


/*------------------------------------------
  サービスラインナップ
------------------------------------------*/
#service .content {
    overflow: visible;
}
#service ul {
    justify-content: space-between;
    flex-wrap: wrap;
}
#service li {
    background: #fff;
    text-align: center;
    width: 15.8%;
    margin-bottom: 10px;
}
#service li a {
    padding: 30px 10px;
    color: #333;
    box-sizing: border-box;
    height: 100%;
    display: block;
    font-size: 1.4rem;
    box-shadow: 0 0px 6px 1px rgba(0,0,0,0.1);
}
#service .list_last {
    margin-right: auto;
    margin-left: 11px;
}
#service li a:hover {
    text-decoration: none;
}
#service li figure {
    width: 60px;
    height: 60px;
    margin: 0 auto;
}
#service li p {
    margin-bottom: 0;
    line-height: 1.5;
}


/*------------------------------------------
  サービス品質
------------------------------------------*/
#sla {
    position: relative;
    overflow-x: hidden;
    padding-bottom: 50px;
}
#sla:after {
    content: '';
    position: absolute;
    width: 110%;
    height: 500px;
    background: #fff;
    border-radius: 100%;
    box-shadow: 0 12px 20px 0px rgba(0,0,0,0.1);
    bottom: 25px;
    left: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: -1;
}
#sla .content {
    width: 100%;
    max-width: none;
}
#sla h3 {
    background: #04BDE2;
    color: #fff;
}
#sla .flex {
    justify-content: center;
    align-items: center;
}
#sla .flex > div {
    text-align: center;
}
#sla .flex > div p {
    font-size: 40px;
    font-weight: bold;
}
#sla .flex > div p span {
    display: block;
    font-size: 1.3rem;
    font-weight: normal;
    line-height: 4;
}
#sla .flex > div:last-of-type p span {
    line-height: 2;
}
#sla .flex > figure {
    padding: 0 50px;
}


/*----------------------------------------------------------------------------------------------------
	for Tablet（1039px以下）
-----------------------------------------------------------------------------------------------------*/
@media (max-width: 1039px) {
    .main .main_copy {
        width: 100%;
        margin: 0 auto;
        padding-bottom: 0;
    }
    .main .mv_image {
        display: none;
    }
    .main .mv_bnr {
        position: static;
        max-width: 312px;
        display: block;
        margin: 30px auto;
    }
    #point ul {
        flex-wrap: wrap;
    }
    #point ul > li {
        width: 48%;
        margin-bottom: 30px;
    }
    #point ul > li:last-child h4 {
        line-height: 3rem;
    }
	.scroll_box {
		margin-bottom: 10px;
		padding-bottom: 10px;
	}
	.scroll_child {
		width: 1040px!important;
	}
    .wrap_server_type {
        display: block;
    }
    .server_type:first-of-type {
        width: 100%;
        margin: 0 0 20px;
    }
    .server_type:first-of-type li {
        width: 24%;
    }
    .server_type:last-of-type {
        width: 100%;
        margin: 0;
    }
    .server_type:last-of-type li {
        width: 32.5%;
    }
    .server_type:first-of-type li:last-of-type,
    .server_type:last-of-type li:last-of-type{
        width: 100%;
    }
}
@media screen and (max-width: 768px) {
    .main .main_copy h2 {
        font-size: 2rem;
    }
    .main .main_copy p:before,
    .main .main_copy p:after {
        width: 30px;
    }
    .main_cta {
        display: block;
    }
    .main_cta a {
        margin: 0 auto 5px;
    }
    #point ul > li {
        width: 100%;
    }
    #point ul > li h4 {
        margin-bottom: 10px;
    }
    #point ul > li p {
        margin-bottom: 10px;
    }
    #point:after,
    #sla:after {
        height: 250px;
    }
    .price_machine li {
        font-size: 1.5rem;
    }
    #service li {
        width: 49%;
    }
    #sla .flex {
        display: block;
    }
    #sla .flex > figure {
        width: 50px;
        margin: 0 auto;
    }
    #sla .flex h4 {
        margin-bottom: 0;
    }
    #sla .flex > div p {
        margin-bottom: 0;
    }
    #sla .flex > div p span {
        line-height: 2;
    }
    #service .list_last {
        margin-right: initial;
        margin-left: initial;
    }
}







