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

/*------------------------------------------
  共通設定用
------------------------------------------*/

.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.3rem;
	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;
}

#contents {
    padding-bottom: var(--space-footer-top);
    margin-top: 0 !important;
    max-width:100%;
    margin: 0 auto;
    padding:0px;
}

:where(#contents) ul:not([class*=blk]):not([class*=l-]):not([class*=row])>li::before {
    position: absolute;
    left: 0;
    content: "";
    width: 0px;
    height: 0px;
    border-radius: 0px;
}
:where(#contents) ul:not([class*=blk]):not([class*=l-]):not([class*=row])>li {
    padding: 0px;
    position: relative;
    line-height: 1.5;
}

.content {
    width: 100%;
    margin: 0 auto;
    font-size: 10px;
    font-size: 1.0rem;
    overflow: hidden;
    color: #333;
}

.content h3, .g_content h3, .content_center h3, .g_content_wrapper h3 {
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: bold;
    margin-top: 60px;
    margin-bottom: 40px;
}

.content h4, .g_content h4, .content_center h4, .g_content_wrapper h4 {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    margin-top: 20px;
    margin-bottom: 20px;
}
figure.mv_logo img[src$=".svg"] {
  width: 270px !important;
  height: auto !important;
  display: inline-block;
}

figure.mv_logo {
  text-align: center;
  margin: 40px 0;
}

/*------------------------------------------
  共通設定用
------------------------------------------*/
.main {
    background: url("/dcms_media/image/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: 2.5rem;
    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: 1.5rem;
}
#point ul > li:last-child h4 {
    line-height: 3rem;
}
#point ul > li a {
    background: url(/service_shared/img/svg/icn_arrow_b.svg) no-repeat left 50% / 10px;
    padding-left: 10px;
    font-size: 1.0rem;
}


/*------------------------------------------
  仕様・料金
------------------------------------------*/
.textf_m {
    font-size: 10px !important;
    font-size: 1.0rem !important;
}
.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: 1rem;
    line-height: 1 !important;
    box-sizing: border-box;
    padding: 8px 3px 12px !important;
}
.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(/dcms_media/image/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 !important;
	background: #4d9feb;
	padding: 12px 20px !important;
	color: #fff;
	font-size: 20px;
	border-radius: 5px;
	width: 250px;
}
.price_tab {
    position: relative !important;
    background: #eaebed;
    padding: 12px 20px !important;
    color: #555;
    font-size: 20px;
    border-radius: 5px;
    width: 250px;
    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;
}
:where(#contents) ul:not([class*=blk]):not([class*=l-]):not([class*=row])>li {
    padding-left: 0rem;
    position: relative;
}

/*------------------------------------------
  サービスラインナップ
------------------------------------------*/
#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.0rem;
    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.0rem;
    font-weight: normal;
    line-height: 4;
}
#sla .flex > div:last-of-type p span {
    line-height: 1.5;
}
#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 {
    height: 600px;
}
.main .main_copy {
    position: absolute;
    left:0%;
}

    .main .mv_image {
        display: none;
    }
.main .mv_bnr {
        position: static;
        max-width: 312px;
        display: block;
        margin: 405px auto 0px auto;
    }
    #point ul {
        flex-wrap: wrap;
margin: 0px 20px;
    }
    #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%;
    }
.content {
    padding: 0 20px;
    }
}
@media screen and (max-width: 768px) {
    .main .main_copy h2 {
        font-size: 1rem;
    }
    .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;
    }
}







