@charset "utf-8";

/* ========================================
    ■ 必須設定
======================================== */
/* reset
----------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
  font-family: 'Noto Sans JP', sans-serif;
}
body { line-height: 1; }
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section { display: block; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
h1,
h2,
h3,
h4,
h5,
h6 { font-weight: inherit; }
a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    /* color:#ffffff !important; */
}
ins {
    background-color: #ff9;
    color: #666666;
    text-decoration: none;
}
mark {
    background-color: #ff9;
    color: #666666;
    font-style: italic;
    font-weight: bold;
}
del { text-decoration: line-through; }
abbr[title], dfn[title] {
    border-bottom: 1px dotted;
    cursor: help;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}

h4{
  margin-bottom:0;
}
th {
    text-align: left;
    vertical-align: top;
    font-weight: normal;
}
td {
    vertical-align: middle;
    padding:14px 0 16px;
}
hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}
input, select, textarea, img { vertical-align:middle; }
ul, dl, ol { list-style: none; }
em { font-style: normal; }
* {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}

html { font-size: 16px; }


body {
  color: #666666;
  font-size:19px;
  line-height: 1.631;
  background: #fff;
  -webkit-text-size-adjust: 100%;
}

a {
    color: #1e93e4;
    text-decoration: none;
    transition: 0.2s ease;
}

a:hover {
    text-decoration: none;
    transition: 0.2s ease;
}

a::before, a:hover::before,
a::after, a:hover::after {
    transition: 0.2s ease;
}

img,
video,
object {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
    border: none;
}


iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

iframe .display-b{
  display: block;
}


/* ========================================
    ■ General
======================================== */



.g-wrapper{
    min-width: 1380px;
    margin-top: 72px;
}

.wrap {
    position: relative;
    /* width: 1200px; */
    width: 1380px;
    margin: 0 auto;

}

.clearfix {
    overflow: hidden;
    zoom: 1;
}
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

.hover:hover {
    opacity: 0.9;
    transition: 0.2s ease;
}


.scrollbar::-webkit-scrollbar {
    background: #ccc;
    width: 10px;
}
.scrollbar::-webkit-scrollbar-thumb { background: #aaa; }






/* ========================================
■ keyv main
======================================== */
.key{
   background-color: #14123a;
}


.keyv .mv.dc-gateway-mv {
    position: relative;
    text-align: center;
    color: #fff;

    background:
        url(/images/lp/dc_gateway/banner_Gateway_bg1.webp)
        center top / auto 100% no-repeat,
        linear-gradient(
            90deg,
            #000813 0%,
            #000621 100%
        );

    height: 680px;
    overflow: hidden;
    align-items: center;
}


/* mv 안에 있는 텍스트/이미지들을 위로 */
.keyv .mv > * {
  position: relative;
  z-index: 2;
}



.keyv .mv .logo{
  width: 1150px;
  margin: 0 auto;
  padding-top: 25px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}




.mv_wrap{
  display: flex;
  justify-content: space-around;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  padding: 55px 0;
}



.mainV_area{
  display: flex;
  flex-direction: row;
  justify-content: center;
  width: 45%;
  padding-top: 0;
}

.mainV_area{
    width:100%;
    height: auto;
}



.mainV_area img{
  width: 88%;
  height: auto;
}



/* ========================================
■ footer start
======================================== */


footer{
  min-width:1200px;
}

.footer{
    text-align: center;
}

.footer .wrap{
  padding-bottom: 40px;
      padding-top: 40px;
      font-size: 17px;
      font-weight: 100;
}


#page_top a {
    position: relative;
    display: block;
    width: 60px;
    height: 60px;
    text-decoration: none;
}


#page_top {
    position: fixed;
    bottom: 1.5%;
    opacity: 1;
    border-radius: 50%;
    z-index: 100;
    right: 1.5%;
}


/* ========================================
■ footer end
======================================== */






/* ========================================
■ section header start ▼
======================================== */

#header {
      z-index: 999;
      background-color: #fff;
      box-shadow: 0px 3px 3px 0px rgb(0 0 0 / 15%);
      position: fixed;
      top: 0;
      width: 100%;
}


#lp_leftContents {
    width: 66%;
    min-width:370px;
}



#lp_leftContents li {
    height: 50px;
    display: flex;
    align-items: center;
}


#lp_leftContents li a{
    color:#2C363C;
    font-weight: 700;
}

#lp_leftContents li a:hover{
    color:#3578e3;
}



/********* TOP MENU NAVI CSS ************/
#lp_leftContents li a.ExToggle:after {
    position: absolute;
    content: "";
    width: 7px;
    height: 7px;
    transform: rotate(135deg);
    opacity: .4;
    top: -2px;
    bottom: 0;
    left: 74px;
    border-top: solid 2px #4f5f6d;
    border-right: solid 2px #4f5f6d;
    margin: auto;
}



#lp_rightContents #lp_gnav {
    padding: 0px 14px 0 0px;
}

#lp_rightContents {
    padding: 9px 10px 5px 0px;
    /* width:30%; */
}


li.navi_cta {
    width: 50%;
    text-align: center;
    height: 40px;
    border-radius: 50px;
    font-weight: bold;
    font-size: 16px;
    position: relative;
    border: 1.5px solid #3578e3ba;
    min-width: 170px;
    background-color: #fff;
}

li.navi_cta:hover {
  border: 1px solid #ffffff;
  box-shadow: 0px 2px 7px 0px rgba(0, 0, 0, 0.2);
  cursor:pointer;transform:scale(1.02,1.02);transition:transform .2s;
}



li.navi_cta a{
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding-top: 5px;
  color: #3578e3;
}


li.navi_cta a:hover{
  color: #3578e3;
}

.cta_orange {
    background-color: #FF114A !important;
    border: 1px solid #FF114A !important;
    margin-left: 10px;
}

.cta_orange a{
      color:#fff !important;
}


.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    z-index: 200;
    transition: background-color .3s ease;
    background: #ffffff;
    box-shadow: 0px 3px 4px 0px #02021d59;
}


.header__container {
    max-width: 1400px;
    height: 75px;
    padding: 0px 20px;
    margin: auto;
    display: flex;
    align-items: center;
}


.header .maegaMenu .is opne{
  height:170px;
}


.header__navi {
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content:flex-start;
}

.header__navi--left {
    display: flex;
    align-items: center;
    font-size:16px;
}

.header__navi--left li{
  margin-right: 25px;
  margin-left: 25px;
}




.header__navi--right {
    display: flex;
    align-items: center;
    justify-content: space-between;
}


.header p {
    margin: 0;
    color:#ffffff;
    font-weight: 700;
}


.header_logo {
    width: 17%;
    margin-right: 24px;
    min-width: 240px;
}



.sp_toggle_menu {
    position: fixed;
    top: 65px;
    left: 0;
    margin-top: -100vh;
    width: 100vw;
    height: calc(100vh - 64px) !important;
    overflow-y: scroll;
    background-color: #fff;
    transition: margin .3s ease !important;;
}

.sp_toggle_menu.active{
  margin-top: 0;
  border-top: 1px solid #d8d8d8;
}


.sp_toggle_menu{
  display: block;
}

.sp_toggle__list {
  height: 0;
  background-color: #fff;
  transition: height .3s ease;
  overflow: hidden;
}

.sp_toggle__list.is-open {
  display: block;
  transition: height .3s ease;
  overflow: hidden;
  height: 220px;
}


.sp_toggle_contents{
    padding: 25px;
}

.sp_toggle_menu {
    font-size: 17px;
}

.sp_toggle_title {
    position: relative;
    margin-bottom: 25px;
    font-weight: 600;
}

.sp_t_title3{
margin-bottom:0;
}

.sp_toggle_title a{
    color: inherit;
}

.sp_toggle_item {
    font-size: 15px;
    padding: 10px 20px;
}


.sp_toggle_title i{
  transform: rotate(0deg);
  transition: transform .3s ease;
  color: #b9bfc5;
}

.sp_toggle_title.is-open i{
  transform: rotate(180deg);
  color: #b9bfc5;
}

i.fa.fa-angle-down {
    position: absolute;
    right: 0;
    top: 5px;
}

.sp_toggle_item a{
  position: relative;
  padding-left: 5px;
}


.sp_toggle_item a:before{
  content: "";
  position: absolute;
  width: 8px;
  height: 2px;
  background-color: #158aff;
  top: 57%;
  left: -15px;
  transform: translateY(-50%);
}


.sp_toggle_cta_area{
  border-top: 1px solid #d8d8d8;
}



/* ========================================
■ section header end　▲
======================================== */













/* ========================================
■ section itreview logo area start ▼
======================================== */

.main_bottom_area {
    background-color: #fff;
    padding: 35px 0px 40px;
    background: url(/images/lp/dc_trustcenter/trustcenter_bg_line.svg) no-repeat 15% center;
    background-size: cover;
    position: relative;
    width: 100%;
}


.main_bottom_inner {
    position: relative;
    text-align: center;
    max-width: 1180px;
    width: 100%;
    margin: 0px auto;
}


.main_bottom_inner .statement {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 32px;
    font-weight: 700;
    line-height: 1.6;
    margin-bottom: 32px;
    color: rgb(8 11 14 / 80%);
    position: relative;
}

.itreview_icon {
    width: 100%;
    margin: 2px auto 15px;
    text-align: center;
}

.itreview_icon img {
    width: 99%;
}


/* ========================================
■ section itreview logo area end　▲
======================================== */












/* ========================================
■ section 悩み start ▼
======================================== */


.section_distress {
    padding: 80px 0 65px;
    background: linear-gradient(0deg, #ffffff 10%, #ebf3ff 100%);
}



.strength_title {
    color: #262b34;
    text-align: center;
    font-size: clamp(3.6em, 5vw, 68px);
    font-weight: 700;
    line-height: 1.25;
    margin: 0 21px;
    padding-bottom: 15px;
    letter-spacing: 0px;
    padding-top: 2px;
}

.blue_font_distress {
  color: #3578e3;
  font-size: 78px;
  letter-spacing: -9.6px;
}


.blue_font_distress:before {
    content: "・";
    display: inline-block;
    position: absolute;
    top: -32px;
    font-size: 40px;
    padding-left: 11px;
}


.distress_area_distress {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin: 30px 0 15px;
    border-radius: 15px;
}


.area_hidden {
    clear: both;
}


.distress_con_distress  {
    width: 32%;
    display: flex;
    flex-direction: column;
    align-items: center;
    align-content: space-between;
}



.distress_img_box_distress  {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
}


.dist_hukidashi {
    font-size: 27px;
    position: absolute;
    font-weight: bold;
    line-height: 1.4;
    color: #3578e3;
    text-align: center;
}



.hukidashi_a {
    top: 4.8%;
    letter-spacing: -1px;
}


.hukidashi_b {
    top: 4.8%;
    letter-spacing: -1px;
}

.hukidashi_c {
   top: 4.8%;
   letter-spacing: -1px;
}


img.distress_img {
    width: 96%;
    max-width: 100%;
}



    .distree_wrapper {
      display: flex;
      border: 2.5px solid #d31530;
      border-radius: 10px;
      overflow: hidden;
      width: 96%;
      margin-top:24px;
    }


    .distree_left_box {
      background-color: #d31530;
      color: #fff;
      padding: 12px 18px;
      font-weight: bold;
      font-size: 22px;
      text-align: center;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 22%;
      border-radius: 4px 0px 0px 4px;
    }



    .distree_right_box {
      background-color: #fff;
      color: #d31530;
      padding: 12px 18px;
      font-weight: bold;
      font-size: 26px;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 78%;
      text-align: center;
      line-height: 1.4;
    }


/* ========================================
■ section 悩み end ▲
======================================== */









/* ========================================
■ section 解決 start ▼
======================================== */


.section_solution {
    font-size: 17px;
    position: relative;
    background: #f4f8ff;
    background: linear-gradient(0deg, #ffffff 10%, #ebf3ff 100%);
    padding: 70px 0;
}



.merit_view_top{
    width: 100%;
    font-size: 66px;
    color: #273037;
    padding: 5px 0 0px;
    text-align: center;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -0.7px;
}


.merit_view_top:before,
.merit_view_top:after {
content: "";
height: 2px;
flex-grow: 1;
background-color: #cad8f6d1;

}


.merit_view_top:before {
  margin-right: 2rem;
}


.merit_view_top:after {
  margin-left: 2rem;
}



.contents_nobox{
    margin-top: 30px;

}

.chap_subtxt {
    font-size: 23px;
    line-height: 1.5;
    font-weight: 100;
    color: #575d62;
    margin-top: 0px;
    text-align: center;
    margin-bottom:20px;
    padding-top:5px;
}

.chap_subtxt_b {
    font-size: 32px;
    line-height: 1.4;
    font-weight: 600;
    color: #333333;
    margin-top: 0px;
    text-align: center;
    margin-bottom: 16px;
}

.examination_ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
}

.examination_ul > li {
    background-color: #fff;
    border-radius: 10px;
    box-sizing: border-box;
    text-align: center;
    width: 32%;
    margin: 0px;
    border: 2px solid #3578e3;
    box-shadow: 0px 0px 7px #a7afba59;
}


.examination_ul h4 {
    line-height: 1.3;
    font-size: 34px;
    padding: 12px 0px 12px;
    background-color: #3578e3;
    text-align: center;
    font-weight: 700;
    color: #fff;
    width: 100%;
    margin: 0px auto;
    border-radius: 6px 6px 0px 0px;
}


.examination_ul li > div {
    overflow: hidden;
}

.dc-card-image {
  position: relative;

  display: flex;
  align-items: center;
  justify-content: center;

  height: 250px;
  padding: 20px 20px 0;

  background: #fff;
}



.dc-card-image::before {
    content: "";
    position: absolute;
    width: 176px;
    height: 176px;
    border-radius: 50%;
    border: 12px solid #eaf4fc;
    background: #fff;
}

.dc-card-image img {
    position: relative;
    z-index: 1;
    max-width: 120px;
    max-height: 120px;
    width: auto;
    height: auto;
}


.dc-card-image-nas img {
    width: 150px;
    transform: translateY(12px);
}


.dc-card-image-backup img {
    width: 140px;
    transform: translate(6px, 3px);
}


.dc-card-image-hybrid img {
    max-width:134px;
    max-height: 134px;
    transform: translate(0, 0);
}




.share_img{
  height: 280px;
  width:100%;
  margin:14px auto;
  display: flex;
  align-items: center;
  justify-content: center;
}




p.share_item_cont {
  font-size: 23px;
  padding: 18px;
  background-color: #eff7ff;
  line-height: 1.45;
  text-align: left;
  border-radius: 0px 0px 9px 9px;
  color: #575757;
  height: 175px;
  border: 0px;
}



.merit-img1, .merit-img2,.merit-img3 {
    width: 50%;
    height: auto;
    margin-top: 0;
}



/* 1) 카드 3개를 가로로 + 같은 높이로 */
.examination_ul{
  display: flex;
  gap: 20px;              /* 간격은 상황에 맞게 */
  align-items: stretch;   /* li 높이 통일 */
  padding: 0;
  margin: 0;
  list-style: none;
}

.examination_ul > li{
  flex: 1;
  display: flex;  /* li 내부 div를 늘리기 위함 */
}

/* 2) 카드 내부 레이아웃 */
.examination_ul > li > div{
  display: flex;
  flex-direction: column;
  width:100%;
  height: 100%;
}

/* 3) 타이틀 높이 통일 (2줄 기준) */
.examination_ul h4{
  line-height: 1.3;
  min-height: calc(1.2em * 2);
  margin: 0 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
}


.examination_ul .share_item_cont{
  margin-top: auto;
}



.examination_ul .share_item_cont{
  line-height:1.6;
  min-height:calc(2.7em * 3); /* 3줄 기준 */
  margin:0;
}


/* 카드 안 리스트 */
.share_list{
  list-style: none;
  line-height: 1.6;
  margin: 0;
  background-color: #eff7ff;
  padding: 26px 15px 30px;
  min-height: calc(1.6em * 3); /* 3줄 기준 */
  height: auto;
  flex: 1;
  border-radius: 0 0 10px 10px;
  width:100%;
}



/* 불릿 + 텍스트 정렬 */
.share_list li{
  position: relative;
  padding-left: 1.4em;
  line-height: 1.45;
  color: rgb(60 72 82 / 90%);
  text-align: left;
  font-size: 22px;
}








.share_list li:nth-child(1){
  margin-bottom:10px;
}


.share_list li:nth-child(3){
  margin-top:10px;
}




/* ● 점 */
.share_list li::before{
  content: "●";
  position: absolute;
  left: 11px;
  top: 10px;
  color: #7CB3F0;
  font-size: 10px;
}



font.strength_blue_span::before {
    top: 64px;
}



.merit_view_line{
  letter-spacing:-3px;
  display:block;
  line-height:1.3;
  padding-left:34px;

  background:
    linear-gradient(#cad8f6,#cad8f6) left 150px / 130px 2px no-repeat,
    linear-gradient(#cad8f6,#cad8f6) right 150px / 130px 2px no-repeat;
}


/* ========================================
■ section　解決 end ▲
======================================== */








/* ========================================
■ section サービス start ▼
======================================== */


.section_service {
    font-size: 17px;
    background: #f7f8ff;
    background: #fff;
    padding: 70px 0 65px;
    position: relative;
    background: url(/images/lp/directcloud_storagetiering/bg_pattern.svg) center center no-repeat;
    background-size: cover;
}




.service_point_title{
  padding-top: 3px;
  padding-bottom: 25px;
  margin: 0 auto;
  font-size: 56px;
  color: #2a2f42;
  text-align: center;
  font-weight: 700;
  line-height: 1.55;
}



.scene_title {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    background-color: #2d7ccb;
    border-radius: 20px 20px 0 0;
}


.scene_title h4 {
    font-size: 38px;
    color: #fff;
    padding: 13px 0px 15px;
    letter-spacing: -.3px;
    font-weight: bold;
}


.scene_title_area_p{
  padding: 0;
  font-size: 24px;
  color: #c1defa;
}





.bcp_contents_box {
  padding: 40px;
  border: solid 1px #9ab8d9;
  border-radius: 0px 0px 8px 8px;
  background-color: #fff;
}



.bcp_utilization_ul {
    align-items: center;
    margin-top: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
}


.sec_option_li {
    width: 37%;
    background-color: #fff;
    box-sizing: border-box;
    border-radius: 10px;
    border: 1px solid #D1DFF2;
    position: relative;
}


.util_li_batsu {
    position: absolute;
    top: -28px;
    left: 0px;
    width: 100%;
}

.util_li_batsu img {
    width: 11%;
}


.bcp_img_area {
    background-color: #f3f9fd;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    border-radius: 10px 10px 0 0;
    box-sizing: border-box;
    min-height: 300px;
    height: auto;
}



.util_li_img1 img {
    width: 46%;
}


.util_li_text_area {
  box-sizing: border-box;
  padding: 5px 22px 22px;
  height: auto;
  min-height: 200px;
}



.option_title {
    padding: 20px 0 6px;
    font-weight: bold;
    margin: 0;
    color: #0078c7;
    font-size: 28px;
}


.bcp_in_ul li {
  text-align: left;
  text-indent: -20px;
  padding-left: 20px;
  margin-bottom: 5px;
  font-size: 19px;
  line-height: 1.4;
}



.bcp_util_ul_li_center {
    width: 26%;
    padding-top: 4px;
}


.bcp_util_ul_li_center:nth-child(2){
  position: relative;
}


.bcp_util_ul_li_center img {
  width: 70%;
  padding-top: 160px;

}




.hukidashi_bcp_util {
    position: absolute;
    width: 100%;
    margin: 0 auto;
}


.hukidashi_bcp_util p{
  background-color: #ffe0e0;
  font-size: 22px;
  padding: 22px 14px 20px;
  border-radius: 22px;
  width: 82%;
  line-height: 1.25;
  position: relative;
}


.hukidashi_bcp_util p::after {
  content: '';
  position: absolute;
  border-width: 14px 0 10px 46px;
  border-style: solid;
  border-color: transparent transparent transparent #ffe0e0;
  top: 122px;
  transform: rotate(51deg);
  left: 21%;
}



.sec_option_li {
    width: 37%;
    background-color: #fff;
    box-sizing: border-box;
    border-radius: 10px;
    border: 1px solid #D1DFF2;
    position: relative;
}

.util_li_maru {
    position: absolute;
    top: -32px;
    left: 0px;
    width: 100%;
}

.util_li_img2 img {
    width: 48%;
}


.util_li_maru img {
    width: 12%;
}








/* ========================================
■ section サービス end ▲
======================================== */












/* ========================================
■ section 主要機能 start ▼
======================================== */



.section_function {
    font-size: 17px;
    position: relative;
    background: #f4f8ff;
    background: linear-gradient(0deg, #ffffff 10%, #f5faff 65%, #deedff 100%);
}



.initiative_contents {
    background: url(/images/lp/lp_enterprise/bg_pattern_enterprise.png) 50% 25%;
    background-size: cover;
    padding: 70px 0;
}


.balloon-set{
  position: absolute;
  display: flex;
  align-items: center;
  gap: 22px;
  z-index: 10;
  top: 39px;
  right: 27px;
}


.b-set1{
}


.b-set2{
  max-width: 100%;
  top: 40px;
}


.b-set3{
  max-width: 52%;
}





.balloon-text{
  background-color: #ffe0e0;
  padding: 18px 20px 18px 20px;
  border-radius: 12px;
  position: relative;
  font-size: 19px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  text-align: center;
  width: 100%;
  color: #37393e;
  line-height: 1.5;
  display: inline-block;
}

.balloon-text::after{
  content: '';
  position: absolute;
  border-width: 10px 0 10px 30px;
  border-style: solid;
  border-color: transparent transparent transparent #ffe0e0;
}



.b-text1{

}


.b-text1::after{
  right: -29px;
  top: 48px;
}


.b-text2{

}

.b-text2::after{
  right: -25px;
  top: 40px;
}

.b-text3{

}

.b-text3::after{
  right: -29px;
  top: 34px;
}

.b-text4{

}

.b-text4::after{
  right: -29px;
  top: 36px;
}


.b-text5{

}

.b-text5::after{
  right: -30px;
  top: 22px;
}



.b-text6{

}

.b-text6::after{
  right: -30px;
  top: 35px;
}



.balloon-icon img {
  width: 100%;
  min-width: 110px;
  max-width:110px;
}


.function_con{
width: 100%;
box-sizing: border-box;
background-color: #ffffff;
border-radius: 7px;
box-shadow: 0px 0px 7px #c0c6cdd9;
border: 1px solid #d6dce2;
}


.menu1_con_area {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex-wrap: wrap;
  justify-content: space-between;
}




.system_stability {
    border: 2px solid #3383da;
    border-radius: 16px;
}

.system_stability:nth-child(1) {
    width: 100%;
}


.system_stability:nth-child(2) {
    width: 100%;
    margin-top:20px;
}



.system_stability .title {
    margin: 0;
    text-align: center;
    padding: 12px 10px 14px;
    font-size: 29px;
    font-weight: bold;
    line-height: 1.45;
    background-color: #3383da;
    color: #fff;
    border-radius: 12px 12px 0 0;
    height: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}


.system_stability .title span {
    font-size: 18px;
    font-weight: 100;
    display: block;
    margin-top: 3px;
    color: #b1d7ff;
    letter-spacing: 0pt;
}

.stability_img {
  height: auto;
  padding: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  border-radius: 15px;
}


.stability_text p {
    font-size: 18px;
}


.stability_text {
    padding: 18px 20px;
    background-color: #ebf5ff;
    line-height: 1.5;
    border-radius: 0 0 18px 18px;
    height: 198px;
}







/* tab design ↓↓  */
    .tab-btn {
      padding: 6px 0 18px 0px;
      display: flex;
      flex-direction: column;
      gap: 25px;
      width: 294px;
      min-width: 280px;
      height: 100%;
  }


    .func_tab {
        flex-basis: 11%;
        text-align: center;
        position: relative;
        width:100%;
    }


    .func_tab a {
      display: block;
      position: relative;
      font-size: 24px;
      padding: 13px 15px 15px 20px;
      text-decoration: none;
      line-height: 36px;
      color: #f1f5ff;
      cursor: pointer;
      font-weight: 100;
      text-align: left;
      letter-spacing: 0px;
      border: 2px solid transparent;
      width:100%;
  }

    .func_tab a.is-active {
        background-color: #FFFFFF;
        color: #0e276d;
        font-weight: 700;
        border-radius: 8px;
        font-size: 24px;
        border: 2px solid transparent;
        padding: 13px 13px 15px 20px;
        line-height: 36px;
        min-width: 290px;
        width: 100%;
    }

    .func_tab a:hover {
      border-radius: 8px;
      border: 2px solid #ffffffc4;
      text-decoration: none !important;
      opacity: 1.0 !important;
      width:100%;
  }


    .tab-cont-box{
      width: 77%;
      border-radius: 12px;
      background-color: #fff;
    }


    .tab_menu {
      display: flex;
      align-items: center;
      gap: 6px 40px;
      border-radius: 20px;
      padding: 16px;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
      width: 100%;
      margin: 0 auto;
      background: linear-gradient(90deg, #4fa4fc 0%, #2d89ef 25%, #1475d6 97%);
      box-shadow: 0 3px 6px rgba(0, 0, 0, .15);
    }


    .tab_menu_box {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      align-items: flex-start;
      justify-content: space-between;
      width: 100%;
      margin: 0 auto;
      height: 100%;
    }


    p.tab_item_p {
        margin-bottom: 20px;
        font-size: 22px;
        line-height: 1.5;
        color: #666;
        padding-left: 5px;
        padding-right: 12px;
        letter-spacing: -0.75px;
    }


    .tab_item_subtxt {
      font-size: 18px;
      color: #707070;
  }


    .tab_item_img {
      border: 1px solid #c6cad5cc;
      background-color: #f9faff;
      padding: 25px;
      border-radius: 10px;
      position: relative;
    }




    .item_img_menu2{
      text-align: center;
      padding: 18% 25px 25px;
    }


    .item_img_menu3{
      text-align: center;
      padding: 168px 25px 25px;
    }


    .item_img_menu4{
      padding: 160px 25px 25px;
    }



    .tab-contents-item,
    .tab-contents-item-sec,
    .tab-contents-item-thi {
      display: none;
      width: 100%;
      height: auto;
      justify-content: center;
      border-radius: 12px;
      padding: 35px 30px;
  }


  .tab-contents-item.is-active,
  .tab-contents-item-sec.is-active,
  .tab-contents-item-thi.is-active
   {
      display: flex;
      background-color: #ffffff;
  }


  .tab-contents-item>p,
  .tab-contents-item-sec>p,
  .tab-contents-item-thi>p {
      margin: auto;
      height: auto;
      opacity: 0;
  }




  .tab-contents-item.is-active>div,
  .tab-contents-item-sec.is-active>div,
  .tab-contents-item-thi.is-active>div {
    animation:  fadeinAnime 1s forwards;
    width:100%;
  }


    @keyframes fadeinAnime{
        from {
          opacity: 0;
        }
        to {
          opacity: 1;
        }
    }



    .features_title {
      font-size: 34px;
      line-height: 1.4;
      padding: 0 12px 10px 4px;
      color: #25292f;
      font-weight: bold;
      letter-spacing: -0.5px;
    }






/* tab design end  */


/* 吹き出し（午前4時〜6時…） */
.balloon_bcp_img01{
  position: absolute;
  top: 42.5%;
  left: 61%;
  transform: translateX(-50%);

  background-color: #ffe0e0;
  color: #333;
  padding: 14px 18px;
  border-radius: 14px;

  font-size: 19px;
  line-height: 1.4;
  text-align: center;

  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  z-index: 5;
}

/* ▼ 삼각형 */
.balloon_bcp_img01::after{
  content: "";
  position: absolute;
  bottom: -55px;
  left: 50%;
  transform: translateX(-50%);

  width: 0;
  height: 0;
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 70px solid #ffdeda;
}






.function_point_title{
  padding-top: 3px;
  padding-bottom: 25px;
  margin: 0 auto;
  font-size: 56px;
  color: #2a2f42;
  text-align: center;
  font-weight: 700;
  line-height: 1.55;
}


.contents_page_td {
  color: #555;
  font-size: 20px;
  padding: 13px 16px;
  line-height: 1.45;
}


.contents_page_td.title {
  color: #fff;
  font-size:22px;
}




      .table_level_point{
        position: absolute;
        border: 3px solid #ff5001;
        width: 353px;
        right: 0%;
        height: 61px;
        top: 168px;
      }


      .level_point_hukidashi{
        background-color: #F06C6C;
        padding: 18px 20px 18px 20px;
        border-radius: 12px;
        position: relative;
        font-size: 24px;
        box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
        text-align: center;
        width: 36%;
        color: #fff;
        line-height: 1.3;
        display: inline-block;
        left: 64%;
        top: 10px;
    }




    .level_point_hukidashi::after {
      content: '';
      position: absolute;
      border-width: 14px 0 14px 32px;
      border-style: solid;
      border-color: transparent transparent transparent #F06C6C;
      rotate: 180;
      transform: rotate(270deg);
      top: -26px;
      left: 46%;
    }





/* ========================================
■ section 主要機能 end ▲
======================================== *








/* ========================================
■ 主要機能比較 start ▼
======================================== */


.dc-compare-table-wrap{
    overflow-x:auto;
    margin-top:5px;
}

.dc-compare-table{
    width:100%;
    border-collapse:collapse;
    background:#fff;
    border:2px solid #bfc5d1;
    table-layout:fixed;
}






.dc-compare-table td{
    padding:18px 20px;
    border:1px solid #d6dbe4;
    vertical-align:middle;
    line-height:1.7;
}

.dc-head-row td{
    background:#8f96a6;
    color:#fff;
    text-align:center;
    font-size:27px;
    font-weight:700;
}


.dc-compare-table td:first-child{
    background:#f5f5f7;
    color:#555555;
    font-size:21px;
    font-weight:700;
    text-align:left;
    width:17%;
}

.dc-compare-table td:nth-child(2){
    background:#edf5ff;
    border-left:4px solid #2962dd;
    border-right:4px solid #2962dd;
    width:29%;
}

.dc-compare-table tr:last-child td:nth-child(2){
    border-bottom:4px solid #2962dd;
}



.dc-head-row .dc-head-item{
  background: #8f96a6 !important;
  color: #fff !important;
  text-align: center !important;


}


.dc-head-row .dc-head-gateway{
  background: #2962dd !important;
  border-top: 2px solid #2962dd !important;
  color: #fff;
}


.dc-head-row .dc-head-nas{
    background:#8f96a6;
    color:#fff;
    line-height: 1.25;
    width:26%;
}

.dc-head-row .dc-head-cloud{
    background:#8f96a6;
    color:#fff;
    width:29%;
}

.dc-item{
    position:relative;
    padding-left:28px;
    font-size:19px;
    font-weight:100;
    color:#555555;
    line-height: 31px;
}

.item-point{
    color:#333;
    font-weight:700;
}



.dc-item + .dc-item{
    margin-top:10px;
}

.dc-item.good::before{
    content:"●";
    position:absolute;
    left:0;
    color:#2574f5;
    font-size: 15px;
}

.dc-item.bad::before{
    content:"▲";
    position:absolute;
    left:0;
    color:#ef4b3f;
    font-size: 16px;
}

.dc-item.warn::before{
    content:"▲";
    position:absolute;
    left:0;
    color:#f3a11a;
    font-size: 16px;
}


span.dc-title-sub {
    display: block;
    font-weight: 100;
    font-size: 17px;
    margin-left: -10px;
    color: #8f8f8f;
}


.dc-sub{
  color: #858383;
  font-weight: 100;
  font-size: 17px;
}


span.dc-head-sub {
    display: block;
    font-weight: 100;
    font-size: 19px;
    color: #dcdbdb;
}


span.dc-sub.dc-sub_break {
    /* display: block; */
    margin-left: -5px;
}

.dc-sub.dc-sub_break {
    margin-left: 18px;
}


.dc-compare-sp{
  display:none;
}



@media screen and (max-width:768px){
  .dc-compare-table-wrap{
    display:none;
  }

  .dc-compare-sp{
    display:block;
  }

  .dc-sp-table{
    margin-top:16px;
    width:100%;
  }


  table.zip_table1.dc-sp-table.dc-sp-gateway {
    border: 2px solid #2962dd;
}

  .dc-sp-head{
    background:#8f96a6 !important;
    color:#fff !important;
    text-align:center !important;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.1;
    padding: 15px 0 16px;
  }

  .dc-sp-head.gateway{
    background:#2962dd !important;
  }

  .dc-sp-head span{
    font-size:14px;
    font-weight:400;
    color:#e6e6e6;
  }

  .dc-sp-label{
    width:35%;
    background:#f5f5f7 !important;
    color:#333 !important;
    font-size:14px;
    font-weight:700;
    text-align:left;
    vertical-align:middle;
    padding: 0 12px;
  }

  .dc-sp-label span{
    font-size: 13px;
    font-weight: 400;
    color: #888;
    margin-left: -6px;
  }

  .dc-sp-text{
    font-size: 14px;
    font-weight: 700;
    line-height: 1.6;
    color: #333;
    word-break: break-all;
    padding: 10px 12px 10px 32px;
    position: relative;
    background-color: #fff;

  }

  .dc-sp-text .good::before{
    content:"● ";
    color:#2574f5;
    position: absolute;
    left: 12px;
    font-size: 13px;
  }

  .dc-sp-text .bad::before{
    content:"▲ ";
    color:#ef4b3f;
    position: absolute;
    left: 12px;
    font-size: 13px;
  }

  .dc-sp-text .warn::before{
    content:"▲ ";
    color:#f3a11a;
    position: absolute;
    left: 12px;
    font-size: 13px;
  }

  .dc-sp-text .note{
    color: #858383;
    font-size: 13px;
    font-weight: 400;
    margin-left: -8px;
  }


  .dc-sub {
      color: #858383;
      font-weight: 100;
      font-size: 13px;
      margin-left: -8px;
  }


  .mark_space{
    display:block;
    margin-top:8px;
  }

}


/* ========================================
■ 主要機能比較　end　▲
======================================== */









/* ========================================
■ section scene 利用シーン　start
======================================== */


.section_scene {
    font-size: 17px;
    background: #f7f8ff;
    background: #fff;
    padding: 70px 0 65px;
    position: relative;
    background-size: cover;
    background: linear-gradient(0deg, #ffffff 10%, #ebf3ff 100%);
}


.scene_area{
  margin-top:0px;
  position: relative;
  z-index:33;
  border-radius: 15px;
}

.scene_point_title{
  padding-top: 3px;
  padding-bottom: 6px;
  margin: 0 auto;
  font-size: 56px;
  color: #2a2f42;
  text-align: center;
  font-weight: 700;
  line-height: 1.55;
}

.scene_title_p{
  text-align: center;
  font-size: 28px;
  margin-bottom: 22px;
  color: rgb(8 11 14 / 80%);
}



.bcp_use_scene_ul {
    align-items: center;
    width: 100%;
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}


.sec_option_li {
    width: 37%;
    background-color: #fff;
    box-sizing: border-box;
    border-radius: 10px;
    border: 1px solid #D1DFF2;
    position: relative;
}


.bcp_use_scene_ul li:nth-child(1) {
    width: 40%;
    z-index: 2;
    margin: 0;
}

.bcp_use_scene_ul li:nth-child(2) {
    width: 9%;
    padding-top: 28px;
    position: absolute;
    left: 37.5%;
    z-index: 1;
}

.bcp_use_scene_ul li:nth-child(3) {
    width: 55%;
    margin: 0;
    border: 1px solid #0078c7;
}

.bcp_use_scene_after {
    background-color: #3578e3 !important;
}




.bcp_use_scene_ul h5 {
    background-color: #6A81A2;
    margin: 0;
    border-radius: 8px 8px 0 0;
    font-size: 26px;
    letter-spacing: 0.3pt;
    padding: 11px 0 11px 0;
    font-weight: bold;
    color: #fff;
}


.bcp_scene_li_img1 {
    box-sizing: border-box;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    height: auto;
    min-height: 432px;
}


.bcp_scene_li_img2 {
    box-sizing: border-box;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fafdff;
    border-radius: 0px 0px 9px 9px;
    height: auto;
    min-height: 432px;
}



.backup_comparison {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    width:100%;
    border-radius: 8px 8px 8px 8px;
    background-color: #fff;
}


.comparison_item {
    width: 45.5%;
    background-color: #eef7fd;
    border-radius: 22px;
}


.comparison_item_title {
    background: #3578e3 ;
    font-size: 30px;
    font-weight: bold;
    color: #fff;
    padding: 13px 0 8px;
    border-radius: 12px 12px 0 0;
    text-align: center;
}



.comparison_item_imgarea_onp {
  padding: 28px;
  border: 2px solid #98A1B2;
  border-radius: 0 0 22px 22px;
  height: auto;
  min-height: 460px;
  text-align: center;
  background-color: #f4f4f4;
}




.comparison_item_imgarea {
    padding: 28px;
    border: 2px solid #3578e3;
    border-radius: 0 0 22px 22px;
    height: auto;
    min-height: 460px;
    text-align: center;
    background-color: #fff;
}



ul.onp_details {
  text-align: left;
  padding-top: 23px;
  font-size: 19px;
  text-indent: -19px;
  padding-left: 16px;
}

ul.scene_fir_ul li {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  background-color: #ffffff;
  padding: 10px 24px 10px 10px;
  box-sizing: border-box;
  border-radius: 10px;
  box-shadow: 2px 2px #e9edf6;
  border: 1.5px solid #c2c6ce;
  margin-top:14px;
}



ul.scene_fir_ul li:nth-child(1) {
    margin-top: 0;
}


ul.scene_fir_ul li:nth-last-child(1) {
    margin-bottom: 0;
}


ul.scene_fir_ul li img {
  width: 80px;
  margin-right: 14px;
}


p.scene_li_p {
    color: #727E96;
    font-size: 23px;
    font-weight: bold;
}


.fukidasi {
    background-color: #90b4dc;
    width: 100%;
    /* border: 2.3px solid #6a81a2; */
    padding: 13px 0 12px;
    border-radius: 10px;
    font-size: 24px;
    font-weight: bold;
    color: #ffffff;
    position: relative;
    display: inline-block;
    box-sizing: border-box;
    margin: 0 0 25px;
}


.fukidasi:before {
    content: "";
    position: absolute;
    bottom: -23.5px;
    left: 49.7%;
    margin-left: -15px;
    /* border: 12px solid transparent;
    border-top: 12px solid #a1afc3; */
    z-index: 2;
}


.fukidasi:after {
    content: "";
    position: absolute;
    bottom: -40px;
    left: 50%;
    margin-left: -17px;
    border: 13px solid transparent;
    border-top: 13px solid #90b4dc;
    z-index: 1;
}


.fukidasi_red {
  background: #F06C6C;
  color: #fff;
  border: 2.3px solid #F06C6C;
  font-size: 32px;
  padding: 5px 0 6px;
}


.fukidasi_red:before {
    border-top: 13px solid #f06c6c;
}


.fukidasi_red:after {
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 36px solid #f06c6c;
}





.onpre_text_p{
  width: 100%;
  padding: 0;
  border-radius: 10px;
  font-size: 27px;
  font-weight: bold;
  color: #596377;
  position: relative;
  display: inline-block;
  box-sizing: border-box;
  margin: 0 0 22px;
}






.bcp_com_item {
    width: 100%;
    height: 350px;
}


.comparison_arrow{
  width: 6%;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
}



.balloon-text{
      padding: 18px 20px 14px 20px;
}






/* ========================================
■ section scene　利用シーン end
======================================== */








/* ========================================
■ section 料金プラン start ▼
======================================== */


.section_price{
background: #f7f8ff;
background: #fff;
padding: 70px 0 65px;
position: relative;
background: linear-gradient(0deg, #ffffff 10%, #f5faff 65%, #deedff 100%);
}



.dc-plan {
    padding: 0;
    width: 100%;
    margin: 20px auto 0;
}

.price_table {
    width: 100%;
    text-align: center;
    background-color: #fff;
    position: relative;
    font-size: 21px;
    border: 2px solid #c9d2dd;
    color: #555;
    box-shadow: 0px 0px 7px #a7afba59;
}

.price_talbe_plan {
    background-color: #3578e3;
    color: #fff;
    font-weight: bold;
    padding: 18px 0px;
    border: 1px solid rgb(116 162 210 / 57%);
    font-size: 23px;
    letter-spacing: -0.65px;
}


.price_talbe_plan_point {
    background-color: #0061d5;
    color: #fff;
    font-weight: bold;
    padding: 18px 0px;
    border: 1px solid rgb(147 164 182 / 62%);
    line-height: 27px;
}


.price_table_l {
    text-align: left;
    background: #f5f6f9;
    color: #555;
    font-size: 21px;
    padding: 16px 0px 20px 25px;
    line-height: 1.35;
    height: 80px;
}

.price_table_r {
    background: #ffffff;
    font-weight: 100;
    font-size: 25px;
}

.point_price_all {
    font-size: 28px !important;
    font-weight: 700;
}

.cost_comm_data_all {
    font-size: 21px;
    padding-left: 3px;
    font-weight: 100;
}

.price_b_br {
    background-color: #ffffff;
    /* color: #000; */
    font-size: 24px;
}



.orange_tb_box {
    border: 2px solid #e30500;
    border-right: 0;
    box-sizing: border-box;
    background-color: #f67c00;
    color: #fff;
    font-weight: 100;
    font-size: 23px;
    letter-spacing: -0.5pt;
    line-height: 1.25;
}



td.price_table_l.orange_tb_box.orange_box_cold {
    border-top: 1px solid #e6b480;
}



.add_data_txt1 {
    font-size: 18px;
    letter-spacing: 0.1pt;
    line-height: 29px;
    color: #ffffffb8;
}


.orange_price_stb_box1 {
    color: #444444;
    font-weight: 800;
    font-size: 23px;
    border: 2px solid #e30500;
    border-right: 0;
    border-left: 1px solid #74839a80;
    border-right: 1px solid #74839a80;
    padding: 18px 0px;
}


.orange_price_stb_box2 {
    color: #444;
    font-weight: 800;
    font-size: 25px;
    border: 2px solid #e30500;
    border-left: 1px solid #74839a80;
    padding: 30px 0px;
}


.price_stand_offer_table {
    background-color: #FFFCDA;
}


.orange_box_warm {
    border-bottom: none;
}


.orange_box_cold {
    border-top: 1px solid #74839a80;
}

.blur-txt {
    filter: blur(5px);
}



.cost_comm {
    font-size: 16px;
    padding-left: 3px;
    font-weight: 100;
}



.all_btn_size {
    width: 100%;
    margin: 0 auto;
    max-width: 158px;
}


.btn_link_apply_red {
    height: 38px;
    color: #ffffff;
    text-align: center;
    background: #FF114A;
    line-height: 38px;
    border-radius: 50px;
}

a.btn_link_a2 {
    font-size: 14.5px;
    color: #ffffff;
    text-align: center;
    text-decoration: none;
    display: block;
}


.table_disc {
    margin-top: 9px;
}


.table_disc li {
    font-size: 14px;
    color: #9398a5;
    margin-top: 0px;
    margin-left: 1px;
}



/* ========================================
■ section 料金プラン end ▲
======================================== */





/* ========================================
■ section サービス仕様  start ▼
======================================== */



.section_Specifications{
background: #f7f8ff;
background: #fff;
padding: 70px 0 65px;
position: relative;
background: linear-gradient(90deg, #f5f8ff 0%, #f2f7ff 50%, #eef6ff 100%);
}



.flex_box {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;

}

.flex_2colum {
    width: 49%;
}



.service_s_point_title{
  padding-top: 3px;
  padding-bottom: 6px;
  margin: 0 auto;
  font-size: 56px;
  color: #2a2f42;
  text-align: center;
  font-weight: 700;
  line-height: 1.55;
}



/* ========================================
■ section サービス仕様 end ▲
======================================== */







.plan_point_title{
padding-top: 3px;
padding-bottom: 6px;
margin: 0 auto;
font-size: 56px;
color: #2a2f42;
text-align: center;
font-weight: 700;
line-height: 1.55;

}










/* ========================================
■ section お客様の声 start ▼
======================================== */

.section_customer {
  padding: 70px 0;
  background: #f0f7ff;
  position: relative;
  width: 100%;
  background-size: cover;
  background: url(/images/lp/directcloud_storagetiering/bg_pattern.svg) center center no-repeat;
}



.voice_point_title{
  padding-top: 3px;
  padding-bottom: 25px;
  margin: 0 auto;
  font-size: 56px;
  color: #2a2f42;
  text-align: center;
  font-weight: 700;
  line-height: 1.55;
}



.feedback_area {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
    margin-top:5px;
}



.feedback_img{
  position:relative;
  margin: 0 auto;
  text-align: center;
}



.feedback_img img{
width:80%;
}


.feedback_item {
    width: 48%;
}


.feedback_img p{
    font-size: 20px;
}



.voice_tdbox{
    box-shadow: 0px 0px 8px 0px #a7afba8c;
    border-radius: 11px;
}

.feedback_img p {
  position: absolute;
  width: 64%;
  text-align: center;
  line-height: 1.45;
  font-size: 21px;
  letter-spacing: -1.5px;
}


.feedback_item.voice1 .feedback_img p{
  left: 33.5%;
  top: 29%;
}


.feedback_item.voice2 .feedback_img p{
  left: 31.5%;
  top: 29%;
}


.feedback_item.voice3 .feedback_img p{
  left: 34%;
  top: 29.5%;
}

.hukidashi_span_red{
  font-weight: 700;
  color: #E2043E;
  font-size: 26px;
}

img.voice1_img {
    width: 90%;
    padding-left: 5px;
}

img.voice2_img {
    width: 100%;
    padding-left: 5px;
}

img.voice3_img {
    width: 90%;
    padding-left: 8px;
}


.voice_title {
    text-align: center;
    background-color: #3578e3;
    color: #fff;
    font-weight: bold;
    font-size: 29px;
    padding: 12px 0px 10px;
    border-radius: 8px 8px 0 0;
}

.voice_contents_area {
    background-color: #fff;
    padding: 20px 22px 25px 25px;
    border: 2px solid #3578e3;
    border-radius: 0 0 10px 10px;
}


.voice_p {
    line-height: 1.6;
    font-size: 22px;
    height: 300px;
    color: #333333;
    letter-spacing: 0px;
}


.voice_profile li {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  font-size: 20px;
}

.v_p_title {
    width: 31%;
    text-align: center;
    background-color: #dcebfd;
    margin: 13px 0 5px;
    border-radius: 6px;
    padding: 6px;
}


.v_p_text {
  padding-left: 20px;
  padding-top: 8px;
}


.yell_line{
  background: linear-gradient(transparent 75%, #fcff38d6 10%);
  font-weight: 700;
}




/* ========================================
■ section  お客様の声　end　▲
======================================== */








/* ========================================
■ section  よくある質問 start　▼
======================================== */



.section_faq{
    font-size: 17px;
    position: relative;
    background: #f4f8ff;
    background: linear-gradient(0deg, #ffffff 10%, #f5faff 65%, #deedff 100%);
    padding: 70px 0;
}


.scene_faq_title{
  padding-top: 1px;
  padding-bottom: 0px;
  margin: 0 auto;
  font-size: 61px;
  color: #2e3846;
  text-align: center;
  font-weight: 700;
  line-height: 1.55;
}



.faq_area{
    padding-top: 25px;
}



.faq {
    margin-top: 8px;
}


.faq li {
  padding: 25px 20px 29px 30px;
  font-size: 24px;
  line-height: 1.6;
}

.faq li.q {
    border-bottom: 2px solid #ecf1fb;
    cursor: pointer;
    background: #ffffff;
    position: relative;
    display: flex;
    align-items: center;
}




li.q:before {
    content: " Q ";
    display: inline-block;
    padding: 0px 14px 4px;
    font-weight: bold;
    font-size: 30px;
    color: #3d94ec;
    font-family: system-ui;
    background-color: #ecf6ff;
    border-radius: 100px;
    margin: 4px 11px 0px 0px;
}


li.q summary {
	list-style: none;
	cursor: pointer;
}

li.q summary::-webkit-details-marker {
	display: none;
}

li.q details{
display: inline-block;
}

li.q summary::after{
	position: absolute;
  width: 15px;
  height: 15px;
  top: calc(50% - 10px);
  right: 40px;
  border-right: 4px solid #a4adc982;
  border-bottom: 4px solid #a4adc982;
  box-sizing: border-box;
  content: "";
  transform: rotate(45deg);
  transition: top 0.4s ease-out, transform 0.4s ease-out;
}

li.q details[open] summary::after{
	top: calc(50% - 5px);
	transform: rotate(-135deg);
}


.faq li.a {
    display: none;
    color: #666;
    text-indent: -19px;
    padding-left: 60px;
    background-color: #ffffff;
    /* margin-bottom: 2px; */
    padding: 22px 70px 28px 128px;
    border-bottom: 2px solid #ecf1fb;
}


li.a:before {
  content: " A ";
  display: inline-block;
  padding: 0px 14px 3px 33px;
  font-weight: bold;
  font-size: 32px;
  color: #ff104a;
  font-family: system-ui;
  margin: 0;
  line-height: 1.45;
  background-color: #ffe5cbc7;
  border-radius: 100px;
  margin: 4px 8px 0px -42px;
}

/* ========================================
■ section  よくある質問 end　▲
======================================== */




.footer{
    text-align: center;
}

.footer .wrap{
  padding-bottom: 20px;
      padding-top: 20px;
      font-size: 17px;
      font-weight: 100;
}


#page_top a {
    position: relative;
    display: block;
    width: 60px;
    height: 60px;
    text-decoration: none;
}


A:visited {
    color: #0F76CC;
    text-decoration: none;
}


#page_top {
    position: fixed;
    bottom: 1.5%;
    opacity: 1;
    border-radius: 50%;
    z-index: 5;
    right: 1.5%;
}




.invisible {
    display: none;
}




/* ========================================
■ section-value
======================================== */



.blue_font {
  color: #3578e3;
  font-size: 78px;
  letter-spacing: 2px;
}

.blue_font:before {
  content: "・";
    display: inline-block;
    position: absolute;
    top: -20px;
    font-size: 40px;
    padding-left: 15px;
}

.blue-left-space{
  padding-left: 5px;
}






td {
    vertical-align: middle;
    border: 1px solid #d8dee3;
}




/* ========================================
■ cta start
======================================== */

.index_cta{
   padding: 30px 0 55px;
  background: transparent linear-gradient(124deg, #1d71c4 20%, #0e63b7 100%) 0% 0% no-repeat;
  color: #fff;
  text-align: center;
  font-weight: 700;
  position: relative;
 }

 .index_cta:after {
   display: block;
   content: "";
   width: 100%;
   height: 100%;
   position: absolute;
   top: 0;
   left: 0;
   background: transparent url(/images/lp/dc_gateway/gateway_cta_bg1.png) 0% 0% no-repeat;
   background-size: cover;
}


 .index_cta_l{
   background: url(/images/contents/bg_office1.jpg) center / cover no-repeat;
   color: #fff;
   min-width: 1200px;
   padding: 50px 0 40px 0;
 }

 .cta_contents{
   display: flex;
   justify-content: space-between;
   align-items: flex-start;
   flex-wrap: wrap;
 }

 .cta_wrap {
   position: relative;
   max-width: 1390px;
   width: 100%;
   margin: 0 auto;
   z-index: 100;
   padding: 0px 0px;
 }

 .cta_item {
   width: 32%;
   padding-top: 18px;
 }

 .cta_text {
   width: 100%;
   padding: 0.75em 0em 2em;
 }

 h4.cta_maintxt{
  font-weight: 700;
    font-size: 60px;
    text-align: center;
    color: #ffffff;
    margin-top: 0px;
    line-height: 1.4;
    letter-spacing: -0.8pt;
    margin-bottom: 3px;
 }

 .data_downtxt{
    text-align: center;
    color: #5f5f5f;
    font-size: 24px;
 }

 h4.cta_maintxt1{
  font-weight: bold;
  font-size: 41px;
  text-align: center;
  color: #ffffff;
  margin-top: 0px;
  line-height: 1.4;
  letter-spacing: -0.5px;
}



.cta_btn_area_cont {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: wrap;
    margin-top: 5px;
    gap: 0 25px;
}


.main_btn_contents_area {
    display: flex;
    justify-content: center;
    padding: 7px 0px 5px;
    flex-direction: column;
    align-items: center;
    gap: 33px;
    flex-direction: row;
    width: 86%;
}


.main_btn_boxtd_contents {
    width: 45%;
    text-align: center;
    height: 65px;
    border-radius: 50px;
    font-weight: bold;
    font-size: 25px;
    line-height: 1.8;
    position: relative;
    flex: 1 1;
    max-width: 44%;
    margin-top: 7px;
}








 h5.cta_subtxt{
    font-size: 30px;
    text-align: center;
    line-height: 1.0;
    color: #d0e8ff;
    font-weight: 100;
    margin-bottom: 5px;
    margin-top: 2px;
 }




 .cta_btn_area {
   display: flex;
   justify-content: center;
   align-items: center;
   flex-direction: row;
   flex-wrap: wrap;
   margin-top:20px;
 }


 .btn_trial{
   background: #FF114A;
   width: 40%;
   color: #fff !important;;
   text-align: center;
   border-radius: 68px;
   height: 65px;
   position: relative;
   font-size: 25px;
   font-weight: bold;
   margin-right: 20px;
   display: flex;
   align-items: center;
   justify-content: center;
 }

 .btn_trial:hover,
 .btn_trial:focus,
 .btn_trial:active{
   box-shadow: 0px 3px 8px 0px rgba(0, 0, 0, 0.25);
   cursor:pointer;transform:scale(1.04,1.04);transition:transform .2s;
 }

 .btn_trial a{
   display: flex;
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   align-items: center;
   justify-content: center;
   color: #fff !important;;
   font-size: 24px;
   text-decoration: none;
   letter-spacing: -0.3pt;
 }

 .btn_trial a:hover,
 .btn_trial a:active{
   text-decoration: none;
 }


 .btn_down {
     background: #fff;
     width: 40%;
     text-align: center;
     border-radius: 68px;
     height: 65px;
     position: relative;
     font-size: 24px;
     font-weight: bold;
     display: flex;
     align-items: center;
     justify-content: center;
     border: 2px solid #e5e5e5;
     color: #4C4C4C !important;;
 }

 .btn_down:hover,
 .btn_down:focus,
 .btn_down:active{
   box-shadow: 0px 3px 8px 0px rgba(0, 0, 0, 0.25);
   cursor:pointer;transform:scale(1.04,1.04);transition:transform .2s;
 }

 .btn_down a{
   display: flex;
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   align-items: center;
   justify-content: center;
   color: #4c4c4c !important;
   font-size: 24px;
   text-decoration: none;
   letter-spacing: -0.3pt;
 }

 .btn_down a:hover,
 .btn_down a:active{
   color: #378ee4 !important;
   text-decoration: none;
 }


 .appbt-mv-button-text {
     margin-bottom: 7px;
     font-size: 19px;
     font-weight: 500;
     text-align: center;
     color: #dbebff;
 }



 .appbt-mv-button-text:before, .appbt-mv-button-text:after {
     content: "";
     display: inline-block;
     position: absolute;
     width: 5.3%;
     height: 1px;
     background: #b8cee9;
     top: 19px;
 }


 .appbt-mv-button-text:before {
     transform: rotate(53deg);
     left: 18.2%;
 }


 .appbt-mv-button-text:after {
     transform: rotate(-53deg);
 }


 .app-btn-tertiary {
   background: #fff;
   color: #00348a;
   /* border: 2px solid #5aa8f2; */
 }

 .app-btn-tertiary:hover,
 .app-btn-tertiary:focus {
   box-shadow: 0px 3px 8px 0px rgba(0, 0, 0, 0.2);
   cursor:pointer;transform:scale(1.04,1.04);transition:transform .2s;
 }

 .app-btn1 {
    display: inline-block;
    padding: 17px 32px 18px;
    transition: .2s;
    border: 0;
    border-radius: 62px;
    font-weight: 700;
    line-height: normal;
    text-align: center;
}

 .app-btn-contents1 {
     font-size: 18px;
     display: flex;
     align-items: center;
     width: 100%;
     height: 80px;
     margin: 0 auto;
     padding: 0 40px 2px 50px;
     gap: 0 16px;
 }




 .app-btn-contents-image-wb {
    width: 54px;
    padding-top: 3px;
}

.app-btn-contents-text1 {
    flex: 1 1;
    font-size: 29px;
    text-align: left;
    padding-left: 5px;
    color: #3578e3;
}

.app-btn-contents-arr1 {
    width: 24px;
    height: 24px;
    margin-left: auto;
    pointer-events: none;
  }



.app-btn-contents-image-wb {
    width: 54px;
    padding-top: 3px;
}



.app-btn-primary {
  background: #ff114a;
  color: #ffffff !important;
  /* border: 2px solid #e97894; */
}

.app-btn-primary:hover,
.app-btn-primary:focus {
  box-shadow: 0px 3px 8px 0px rgba(0, 0, 0, 0.2);
  cursor:pointer;transform:scale(1.04,1.04);transition:transform .2s;
}

.app-btn-contents-image-b {
    width: 67px;
}


.app-btn-contents-text1-w {
    flex: 1 1;
    font-size: 29px;
    text-align: left;
    padding-left: 5px;
    color: #ffffff;
}

.appbt-mv-button-text1 {
    margin-bottom: 7px;
    font-size: 19px;
    font-weight: 500;
    text-align: center;
    color: #dbebff;
}

.appbt-mv-button-text1:before, .appbt-mv-button-text1:after {
    content: "";
    display: inline-block;
    position: absolute;
    width: 5%;
    height: 1px;
    background: #b8cee9;
    top: 18px;
}


.appbt-mv-button-text1:before {
    transform: rotate(53deg);
    left: 15.8%;
}

.appbt-mv-button-text1:after {
    transform: rotate(-53deg);
}


 /* ========================================
 ■ cta end
 ======================================== */




/************** メリット　**************/


.eng_box_line {
  text-align: center;
  margin: 0 auto;
}

.eng_title_s1 {
  font-size: 24px !important;
}

.eng_title_top1 {
  display: inline-block;
  font-size: 23px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 0px;
  line-height: 1.45;
  background-color: #ffffff;
  color: #3578e3;
  padding: 2px 25px 5px;
  border-radius: 40px;
  border: solid 1.5px rgb(44 145 245 / 80%);
}



/***************   table border css   *****************/



.pc_on{
    display: block;
}

.br_pc {
    display: block;
}

.sp_on {
    display: none;
}

.br_sp {
    display: none;
}



.bcp_area_arrow{
  width: 8%;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
}


.bcp_area_arrow img{
  width:100%;
}


.feedback_huki_span{
  font-size:20px;
}




.Specifi_level4{
  background: #F06C6C;
  width: 50%;
  border-radius: 8px;
  text-align: center;
  padding: 6px 13px 10px;
  font-size: 33px;
  font-weight: bold;
  margin: 22px auto;
  color: #fff;
}





.gateway_flow_wrap{
  display:flex;
  gap:24px;
}

.gateway_flow_left{
    flex: 0.9264;
}

.gateway_flow_right{
  flex:1.15;
}

.gateway_flow_left,
.gateway_flow_right{
  border: 1px solid #9ab8d9;
  border-radius: 18px;
  background: #f3f9ff;;
  box-shadow: 0 0 7px #a7afba59;
  padding:20px;
}

.gateway_flow_left img,
.gateway_flow_right img{
  width:100%;
  height:auto;
}

@media(max-width:768px){
  .gateway_flow_wrap{
    flex-direction:column;
  }
}






/*    -----------------------------------  header sp   ----------------------------------- */

@media screen and (max-width: 480px) {


  .keyv .mv{
    background-position-x: -2px;
    height: 224px;
  }


.keyv .mv .logo {
  width: 100%;
  padding: 20px 15px 0;
  }


.g-wrapper {
    min-width: 100%;
    margin-top: 65px;
}


h2.catch img{
  width: 100%;
  margin-top: 34px;
  padding: 0 25px;
}


.wrap {
    width: 100%;
    padding:0 20px;
  }


  .mainV_area img {
      width: 92%;
      height: auto;
  }


.merit_view_top:after,
.merit_view_top:before{
   display: none;
  }


.distress_area {
    padding: 20px;
  }



.distress_con {
  width: 100%;
  margin: 0 auto;
}


.distress_con:nth-child(2) {
    margin: 25px 0;
}


.distress_img_box{
  height: 220px;
}



.function_point_title{
  font-size: 39px!important;
  line-height: 1.25;
  padding-bottom: 20px;
  padding-top: 8px;
}



.scene_point_title {
  font-size: 32px !important;
  line-height: 1.25;
  padding-bottom: 13px;
  padding-top: 5px;
}

.gr_func_point {
    font-size: 11px;
    color: #9398a5;
    margin-top: 9px;
}


.service_point_title {
  font-size: 28px !important;
  line-height: 1.25;
  padding-bottom: 16px;
  padding-top: 0px;
}


.voice_point_title {
  font-size: 39px!important;
  line-height: 1.25;
  padding-bottom: 16px;
  padding-top: 8px;
}




.section_scene{
      padding: 30px 0;
}

.scene_area {
    padding: 0;
}



h2.merit_view_top {
  font-size: 2.2rem;
  display: block;
  line-height: 1.6;
  padding: 0;
}


.blue_font{
  font-size:42px;
}



.blue_font:before{
  font-size: 29px;
  padding-left: 5px;
  top: 37px;
}


.blue_font_area{
  margin-top:7px;
}


.blue-left-space {
    padding-left: 0;
}


.eng_title_s1 {
    font-size: 16px !important;
    padding: 2px 20px;
}


.chap_subtxt {
  font-size: 18px;
  line-height: 1.4;
  margin-top: 0;
  letter-spacing: -0.4px;
  margin-bottom:13px;
  text-align: left;
  padding-top: 0;
}


h3.link_send_section_title {
    padding: 5px 12px 7px;
}


.pc_on {
  display: none !important;
}


.br_pc
 {
    display: none;
}


.sp_on{
      display: block;
}


.br_sp {
    display: block;
}





 #header{
    width:100%;
  }

  .header {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      z-index: 999;
      background-color: #fff;
      transition: background-color .3s ease;
      box-shadow: 0px 0px 3px 0px rgb(0 0 0 / 15%);
  }


  .header_logo {
      min-width: 210px;
      margin-right: 0;
      padding-top: 4px;
    }

  .header__container {
    width: 100%;
    padding: 0px 20px;
    justify-content: space-between;
    position: relative;
    z-index: 10;
    height: 65px;
    background: #fff;
    }


  .header__navi {
        display: none;
    }


  .sp_hamburger_Btn{
    height: 22px;
    width: 27px;
  position: relative;
  }


  .hamburger_Btn_line {
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    border-radius: 4px;
    background-color: #3578e3;
    transform-origin: right;
    transition: background-color .3s ease, transform .3s ease;
  }



  .hamburger_Btn_line:nth-child(2) {
      top: 10px;
  }

  .hamburger_Btn_line:nth-child(3) {
      top: 20px;
  }


  .sp_hamburger_Btn.active .hamburger_Btn_line:nth-child(1){
      transform: translateY(0px) rotate(-45deg);
  }

  .sp_hamburger_Btn.active .hamburger_Btn_line:nth-child(2){
    opacity:0;
  }

  .sp_hamburger_Btn.active .hamburger_Btn_line:nth-child(3){
    transform: translateY(0px) rotate(45deg);
  }

  .sp_toggle_menu {
    margin-top: -30vh;
  }


.sp_toggle_menu{display:none;}

.sp_toggle_menu {
    position: fixed;
    top: 65px;
    left: 0;
    margin-top: -100vh;
    width: 100vw;
    height: calc(100vh - 64px) !important;
    overflow-y: scroll;
    background-color: #fff;
    transition: margin .3s ease !important;;
}

.sp_toggle_menu.active{
  margin-top: 0;
  border-top: 1px solid #d8d8d8;
}


.sp_toggle_menu{
  display: block;
}

.sp_toggle__list {
  height: 0;
  background-color: #fff;
  transition: height .3s ease;
  overflow: hidden;
}

.sp_toggle__list.is-open {
  display: block;
  transition: height .3s ease;
  overflow: hidden;
  height: 220px;
}


.sp_toggle_contents{
    padding: 25px;
}

.sp_toggle_menu {
    font-size: 17px;
}

.sp_toggle_title {
    position: relative;
    margin-bottom: 25px;
}



.sp_toggle_title a{
    color: inherit;
}

.sp_toggle_item {
    font-size: 15px;
    padding: 10px 20px;
}


.sp_toggle_title i{
  transform: rotate(0deg);
  transition: transform .3s ease;
  color: #b9bfc5;
}

.sp_toggle_title.is-open i{
  transform: rotate(180deg);
  color: #b9bfc5;
}



.sp_toggle_item a{
  position: relative;
  padding-left: 5px;
}


.sp_toggle_item a:before{
  content: "";
  position: absolute;
  width: 8px;
  height: 2px;
  background-color: #158aff;
  top: 57%;
  left: -15px;
  transform: translateY(-50%);
}


.sp_toggle_cta_area{
  border-top: 1px solid #d8d8d8;
}


#lp_rightContents {
    padding: 25px;
    flex-direction: column;
}

li.navi_cta {
    width: 100%;
    height: 50px;
    margin-bottom: 15px;
}

li.navi_cta a {
    top: 4px;
    font-size: 19px;
}



.section_distress {
    padding: 35px 0;
}

.section_service{
    padding: 50px 0;
}



  h2.strength_title {
      margin: 0;
      font-size: 37px !important;
      line-height: 1.4;
  }


  .blue_font_distress {
      font-size: 40px;
      letter-spacing: -5px;
  }


  .blue_font_distress:before {
      content: "・";
      display: inline-block;
      position: absolute;
      top: -18px;
      font-size: 29px;
      padding-left: 8px;
  }



.distress_area_distress{
      flex-direction: column;
      justify-content: center;
      margin: 20px 0 0;
}

.distress_con_distress{
  width: 100% !important;
  margin-bottom: 0;
}


.distress_con_distress:nth-child(2) {
    margin: 50px 0;
}


.dist_hukidashi {
    font-size: 21px !important;
    justify-content: center;
    width: 100%;
}




.hukidashi_a {
  left: 0;
  top: 29px;
  letter-spacing: -1px;
  padding: 0px 15px;
}


.hukidashi_b {
  left: 0%;
  top: 13px;
  letter-spacing: -1px;
  padding: 0px 15px;
}


.hukidashi_c {
  left: 0%;
  top: 15px;
  letter-spacing: -1px;
  padding: 0px 15px;
}


.distree_wrapper{
      flex-direction: column;
}


.distree_left_box{
  width: 100%;
  padding: 4px 20px;
  font-size: 22px;
}


.distree_right_box{
  width: 100%;
padding: 10px 20px;
font-size: 21px;
}



.contents_nobox{
      margin-top: 20px;
}


.examination_ul h4{
  font-size: 24px;
  padding: 10px 0px 10px;
  min-height: calc(1.3em * 2);
}


.share_img{
  height: auto;
  width: 100%;
  padding: 20px 0px;
}



.share_img3 p{
  letter-spacing: -1.5px;
}


p.share_item_cont{
  font-size:20px;
  height: auto;
  padding: 18px 20px;
}



.examination_ul{
      flex-direction: column;
}



.dc-card-phrase{
  font-size: 22px;
}



.examination_ul li{
  width:100%;
  font-size: 17px;

}


.examination_ul li:nth-child(2){
  margin:14px 0 0;
}


.dc-card-image{
      padding: 10px 20px 0;
      height: 155px;
}


    .dc-card-image::before {
        width: 110px;
        height: 110px;
        border: 8px solid #eaf4fc;
    }


.dc-card-image-nas img {
    width: 70px;
    transform: translateY(9px);
}


.dc-card-image-backup img {
    width: 70px;
    transform: translate(3px, 0px);
}

.dc-card-phrase {
    font-size: 19px;
}



.dc-card-image-hybrid img {
    max-width: 80px;
    max-height: 80px;
    transform: translate(0, 0);
}


.share_list li {
    padding-left: 1.7em;
}



.balloon-set{
  top: 10px;
  right: inherit;
  width: 100%;
  flex-wrap: wrap;
}


.balloon-text{
  font-size: 16px;
  padding: 12px 10px;
  width: 64%;
  line-height: 19px;
  text-align: left;
}


.b-text1::after{
  right: -18px;
  top: 44px;
  transform: rotate(360deg);
}


.b-set1,
.b-set2,
.b-set3,
.b-set4{
  max-width: 100%;
  top: 15px;
}


.b-set5,
.b-set6{
  max-width: 100%;
  left: 12px;
  top: 180px;
}

.b-text2::after {
    right: -18px;
    top: 32px;
}


.b-text3::after {
    right: -18px;
    top: 30px;
}


.b-text4::after {
    right: -18px;
    top: 37px;
}

.b-text5::after{
  right: -18px;
  top: 26px;
}

.b-text5::after{
  right: -18px;
top: 22px;
}



.b-text6::after{
  right: -18px;
top: 46px;
}



.balloon-icon img{
  width: 100%;
  min-width: 64px;
  max-width: 64px;
}



.balloon-icon {
  top: -40px;
  left: 5px;
}



.scene_faq_title{
  font-size: 2.1rem !important;
  line-height: 1.25;
  padding-bottom: 16px;
  padding-top: 8px;
}




/* tab start */




.tab_menu{
  padding: 12px;
}


.tab_menu_box{
      padding:0;
}



.custom-select-box {
    position: relative;
    width: 100%;
    margin: 20px auto;
    line-height: 31px;
}


.selected-option {
    padding: 10px 40px 12px 14px;
    border: 1px solid #ccc;
    border-radius: 8px;
    background: white;
    cursor: pointer;
    position: relative;
    font-weight: bold;
    color: #2d3045;
    font-size: 20px;
}


.selected-option::after {
    position: absolute;
    display: block;
    content: '';
    width: 9px;
    height: 9px;
    top: 45%;
    right: 15px;
    margin-top: -3px;
    border-bottom: 2px solid #575757;
    border-right: 2px solid #575757;
    transform: rotate(45deg) translateY(-50%);
    transition: all .4s ease-in-out;
    transform-origin: 50% 0;
}


.dropdown-options {
    position: absolute;
    top: 110%;
    left: 0;
    right: 0;
    border: 1px solid #ccc;
    border-radius: 8px;
    background: white;
    display: none;
    z-index: 13;
    box-shadow: 0px 3px 8px 2px rgb(0 0 0 / 42%);
    font-size: 18px;
    line-height: 1.3;
}



.dropdown-options div {
    padding: 12px 14px;
    cursor: pointer;
    font-weight: 700;
    color: #2d3045;
}



.main_btn_boxtd {
    width: 100%;
    max-width: 100%;
}



.tab-contents-item,
.tab-contents-item-sec,
.tab-contents-item-thi{
   padding:25px 14px;
}

p.tab_item_p{
  padding-left: 0px;
  font-size: 17px;
  line-height: 1.4;
  margin-bottom: 12px;
}


.movie_contents01 {
    margin-top: 45px;
}


p.tab_item_p1 {
    margin-bottom: 8px;
    font-size: 17px;
    line-height: 1.5;
    color: #575757;
    padding-left: 0;
}


.tab_item_img{
  padding: 70px 15px 15px;
}


.tab_item_movie{
  padding: 8px;
}

.tab_item_bg {
  padding: 8px;
}


.tab-cont-box {
    width: 100%;
}


.tab-contents-item,
.tab-contents-item-sec,
.tab-contents-item-thi{
background-color: #fff;

}





/*  tab end */






.tab_item_img_gradient {
    border: 2px solid #4174d1;
    padding: 0;
    border-radius: 10px;
    background: linear-gradient(90deg, #fdeff2, #fff9e6, #e6f7ff);
}



.features_title{
    font-size: 24px;
    padding: 0 4px 10px 4px;
    line-height: 32px;
    letter-spacing: -0.5px;
}



.voice_title{
  font-size: 22px; ;
}



.voice_profile li{
  font-size: 16px;
}



.voice_contents_area{
  padding: 20px 15px 25px;
}


section.section_customer {
    padding: 50px 0;
}

.feedback_area{
    flex-direction: column;
    align-content: center;
}

.feedback_item {
    width: 100%;
}

.feedback_item.voice2 {
    margin: 25px 0 0;
}

.voice_p{
      height: auto;
      font-size: 18px;
}

.voice_profile {
    margin-top: 20px;
}


.feedback_img p{
  font-size: 14px;
}

.hukidashi_span_red{
    font-size: 17px;
}




/*********************** faq start *****************/

.section-faq {
    padding: 70px 20px;
}


.faq_area {
  padding-top: 7px;
}



li.q {
    display: flex;
    justify-content: flex-start;
    padding: 15px 5px 15px 15px;
    align-items: flex-start !important;
}


li.q:before {
    padding: 0;
    font-size: 18px;
    border-radius: 999px;
    margin: 0;
    width: 30px;
    height: 30px;
    text-align: center;
    margin-right: 10px;
}


li.q details{
  width: 76%;
  font-size: 18px;
  line-height: 1.4;
}


li.q summary::after {
    width: 10px;
    height: 10px;
    border-right: 3px solid #a4b4c982;
    border-bottom: 3px solid #a4b4c982;
    right: 15px;

}


.faq li.a{
padding: 15px 15px 15px 57px;
font-size: 16px;
position: relative;
text-indent: 0;
}


li.a:before{
padding: 0;
font-size: 18px;
border-radius: 999px;
margin: 0;
width: 30px;
height: 30px;
text-align: center;
margin-right: 0;
text-indent: 0px;
position: absolute;
left: 17px;
}



/*  faq end  */





/*  cta  start*/


.index_cta {
    min-width: 100%;
    padding: 30px 0 50px 0;
}


.cta_wrap {
    width: 90%;
    margin: 0 auto;
}


.cta_contents {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: column;
}


.cta_item {
    width: 75%;
}


.cta_text {
    width: 100%;
}

h5.cta_subtxt {
    text-align: center;
    font-size: 17px;
    line-height: 1.45;
    margin-bottom: 3px;
}


h5.cta_subtxt:before, h5.cta_subtxt:after {
    content: "";
    display: inline-block;
    position: absolute;
    width: 6.2%;
    height: 1.5px;
    background: #a3a3a3;
    top: 205px;
}

h5.cta_subtxt:before{
  transform: rotate(53deg);
  left: -2%;
}

h5.cta_subtxt:after {
    transform: rotate(-53deg);
    right: -5px;
}


h4.cta_maintxt {
    font-size: 23px;
    line-height: 1.4;
    letter-spacing: -2px;
}

.cta_btn_area {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 15px;
}


.btn_trial {
    width: 98%;
    height: 50px;
    margin-right: 0;
    margin-bottom: 10px;
}

.btn_down {
    width: 98%;
    height: 50px;
}

.btn_trial a, .btn_down a {
    font-size: 19px;
}


/*  cta end*/




.mv_wrap{
      padding: 30px 0px;
      flex-direction: column;
}


.mainV_area{
  width:100%;
}




.bcp_contents_box {
  padding: 30px 20px;
}


.bcp_utilization_ul {
    flex-direction: column;
}

.sec_option_li {
    width: 100%;
}


.bcp_util_ul_li .bcp_img_area {
    height: 190px;
    min-height: auto;
}

.util_li_batsu {
    top: -19px;
}

.option_title {
  font-size: 19px;
  letter-spacing: -0.5px;
}

.bcp_in_ul li {
    font-size: 17px;
}

.bcp_util_ul_li_center {
    width: 100%;
}


.bcp_util_ul_li:nth-child(3) {
    margin-top: -2px;
}

.util_li_maru {
    top: -20px;
}



.bcp_contents_box {
    padding: 20px;
}




.bcp_use_scene_ul{
  flex-direction: column;
}


.bcp_use_scene_ul li {
    width: 100% !important;
}


.bcp_use_scene_ul h5 {
    padding: 7px 0 7px 0;
    font-size: 22px;
}

.bcp_scene_li_img1, .bcp_scene_li_img2 {
    min-height: auto;
}


.bcp_use_scene_ul li:nth-child(2) {
    padding: 0;
    width: 28% !important;
    padding-top: 0;
    position: initial;
    left: 37.5%;
    z-index: 1;
    top: 2px;
    margin-top: -15px;
}

.bcp_use_scene_ul li:nth-child(2) img {
    width: 40px;
    transform: rotate(90deg);
}

.bcp_use_scene_ul h5 {
    padding: 7px 0 7px 0;
    font-size: 20px;
}

.bcp_scene_li_img1, .bcp_scene_li_img2 {
    min-height: auto;
}



.bcp_util_ul_li_center:nth-child(2) {
    position: relative;
    display: flex;
}


.hukidashi_bcp_util p{
  padding: 14px 12px 14px;
  left: 27%;
  top: 23px;
  width: 47%;
  text-align: left;
  font-size: 18px;
  line-height: 1.4;
}


.hukidashi_bcp_util p::after{
  border-width: 14px 3px 5px 25px;
  top: 36px;
  transform: rotate(171deg);
  left: -15%;
}


.util_li_text_area{
      padding: 5px 14px 15px;
}



.bcp_util_ul_li_center img{
  width: 45%;
  padding-top: 12px;
}



.main_btn_area {
    padding-top: 15px;
    flex-direction: column;
    gap: 10px;
}

.main_btn_boxtd {
    max-width: 100%;
    width: 100%;
    margin-top: 5px;
}

.main_btn_boxtd a {
    height: 60px;
    padding: 1px 23px 3px 34px;
}

.app-btn-contents-image-w {
    width: 40px;
    padding-top: 5px;
}

.app-btn-contents-text {
    font-size: 22px;
}




.main_bottom_area {
    padding: 22px 17px 18px;
}


.main_bottom_inner .statement {
    font-size: 21px;
    line-height: 1.3;
    margin-bottom: 27px;
}


.itreview_icon {
    width: 100%;
    margin: 5px auto 15px;
    text-align: center;
}

.itreview_icon img {
    width: 97%;
}



.feedback_item.voice3 .feedback_img p{
  left: 34%;
  top: 26.5%;
}


.scene_title_p{
  text-align: left;
  font-size: 18px;
  margin-bottom: 18px;
}



.item_img_menu1{
    padding: 15px;
}

.item_img_menu2{
    padding: 15px 15px 30px;
}

.item_img_menu3{
    padding: 115px 15px 15px;
}




.initiative_contents {
    padding: 50px 0;
}


footer.footer p {
    padding: 0 20px;
}


footer{
  min-width: 100%;
}





.contents_page_td{
  font-size: 16px;
  padding: 13px 10px;
}



.stability_img{
  padding:16px;
}


.system_stability .title {
    font-size: 23px;
    padding: 10px 10px 12px;
}


.scene_title{
  padding: 15px 20px !important;
  line-height: 1.3;
  margin-top: 0 !important;
}

.scene_title h4{
  font-size:25px;
  letter-spacing: -1.2px;
  padding: 6px 0px 6px;
}


.scene_title_area_p{
  padding: 0;
  font-size: 16px;
  color: #c1defa;
  margin-top: 7px;
}


.backup_comparison{
  flex-direction: column;
}


.comparison_item{
  width:100%;
}


.comparison_item_imgarea_onp{
      padding: 16px;
      border-top: none;
}

.comparison_item_title {
  font-size: 22px;
  padding: 10px 0 8px;
}


.fukidasi{
  padding: 8px 18px 10px;
  font-size: 18px;
  line-height: 1.3;
}

ul.scene_fir_ul li{
    padding: 5px 14px 5px 3px;
    margin-top: 10px;
}


p.scene_li_p{
      font-size: 16px;
      line-height: 1.4;
      text-align: left;
}



.bcp_area_arrow{
  width:100%;
  align-items: center;
  position: relative;
}


.bcp_area_arrow img{
  width: 27%;
  transform: rotate(90deg);
  display: block;
  transform-origin: center;
  position: absolute;
  top: -2px;
}


.comparison_item2{
  margin-top:80px;
}



.comparison_item_imgarea{
  padding: 24px 15px;
}


p.fukidasi.fukidasi_red span{
  font-size:26px !important;
}


.bcp_use_scene_ul li:nth-child(3){
      margin-top: 20px;
}


.feedback_huki_span{
  font-size:12px;
}

img.voice3_img {
    width: 100%;
    padding-left: 3px;
}


img.voice1_img {
    width: 100%;
    padding-left: 3px;
}

.feedback_item.voice2 .feedback_img p{
  top: 27%;
}

.feedback_item.voice1 .feedback_img p {
    left: 33.5%;
    top: 29.5%;
}


.keyv .mv::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0) 25%,
    rgba(0, 0, 0, 0) 50%,
    rgba(0, 0, 0, 0) 75%,
    rgba(0, 0, 0, 0) 100%
  );
  z-index: 1;
}




.merit_view_line{
  letter-spacing:-1px;
  padding-left:0;

  background:
    linear-gradient(#cad8f6,#cad8f6) left 85px / 70px 2px no-repeat,
    linear-gradient(#cad8f6,#cad8f6) right 85px / 70px 2px no-repeat;
}


.flex_box{
      flex-direction: column;
}

.flex_2colum {
    width: 100% !important;
}



.Specifi_level4{
  width: 100%;
  padding: 9px 13px 10px;
  font-size: 22px;
  margin: 14px auto 28px;

}


.DR_talbe_width1{
  width:39% !important;
}


.DR_talbe_width2{
  width:61% !important;
}



ul.scene_fir_ul li img {
  width: 74px;
  margin-right: 10px;
}

.onpre_text_p{
  line-height: 1.3;
  font-size: 20px;
  margin: 0 0 12px;
}

.onp_details li {
    margin-bottom: 4px;
}


ul.onp_details{
  text-align: left;
  padding-top: 21px;
  font-size: 16px;
  text-indent: -19px;
  padding-left: 16px;
  margin-bottom: 4px;
}


.share_list{
    padding: 15px 15px 17px;
}



.dc-plan.sp_on {
    margin: 6px auto 0;
}


.price_table:nth-child(1) {
    margin-top: 0;
}



.price_table{
    margin-top: 20px;
    border-top: none;

}


.price_talbe_plan {
    width: 50%;
    padding: 15px 0px;
    font-size: 23px;
}


.price_table_l {
    font-size: 18px;
    padding: 12px;
    line-height: 1.3;
    width: 52%;
    height: 65px;
}

.price_table_r {
    font-size: 17px;
    padding: 12px 10px;
    width: 55%;
}


.point_price_all {
    font-size: 21px !important;
    font-weight: 700;
    padding: 12px 8px;
}


.orange_price_stb_box {
    border-right: 2px solid #e30500;
}

.orange_price_stb_box {
    border-right: 2px solid #e30500;
    font-weight: bold;
}


.balloon_bcp_img01{
  top: 57.5%;
  left: 50%;
  font-size: 15px;
  padding: 10px 12px;
  width: 90%;
}


.balloon_bcp_img01::after{
  bottom: 29px;
  left: -17%;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-top: 29px solid #ffdeda;
  transform: rotate(90deg);
  display: none;
}












/*  料金 table start */

/* 料金　アコーディオン　start */

.details_blue_box {
    border: 1px solid #d8dfea;
    width: 100%;
    margin: 0 auto;
}



.summary_blue{
    background-color: #f0f0f0;
}


.details-summary {
  position: relative;
  display: block;
  padding: 20px 15px;
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  line-height: 1.4;
  color: #ffffff;
  background-color: #3578e3;
	&:hover {
		cursor: pointer;
	}

	.btn {
		position: absolute;
        top: 39%;
        right: 5%;
        width: 18px;
        height: 18px;
        transform-origin: center center;
        transition-duration: 0.2s;

        &:before,
        &:after {
            content: "";
            background-color: #ffffff;
            border-radius: 10px;
            width: 16px;
            height: 2px;
            position: absolute;
            top: 7px;
            left: 0;
            transform-origin: center center;
        }
        &:before {
            width: 2px;
            height: 16px;
            top: 0;
            left: 7px;
        }
    }


	&.is-active {
		.btn {
			-webkit-transform: rotate(-180deg);
			transform: rotate(-180deg);
			&:before {
            	content: none;
        	}
		}
    }
}



.btn_orange::before,
.btn_orange::after{
 background-color: #e30500 !important;
}

.details-summary::-webkit-details-marker {
	display: none;
}

.details-content {
	padding: 0px;
}

.close-btn {
	display: block;
	margin: 10px auto 30px;
	padding: 8px 32px;
  background: #a7b4c2;
  color: #ffffff;
	text-align: center;
	border: none;
	border-radius: 5px;
	cursor: pointer;
}


.close-btn p {
		margin: 0 0 20px;
		color: #000;
		font-size: 18px;
		text-align: left;
  }


.close-btn p:last-of-type {
	margin: 0 0 40px;
}


.details-content {
	padding: 0px;
	.close-btn {
		display: block;
		margin: 7px auto 30px;
		padding: 8px 32px;
		background: #00a5a0;
		color: #0061D5;
		text-align: center;
		border: none;
		border-radius: 5px;
		cursor: pointer;
		&:hover {
			opacity: 0.8;
		}
	}

	}


.details-content
.close-btn {
    display: block;
	  margin: 10px auto 30px;
    padding: 12px 70px 10px;
    background: #a7b4c2;
    color: #ffffff;
    text-align: center;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 15px;
}



.business_plan, .premium_plan, .enterprise_plan {
    margin-top: 6px;
}


/* 料金　アコーディオン　end */



.table_disc {
    margin-top: 0;
    padding: 15px;
}


.cost_comm{
      font-size: 14px;
}



.dc-sp-scroll {
  position: relative;
  overflow: auto;
}

.dc-price-strong {
  font-size: 20px;
  font-weight: bold;
}

.dc-option-head {
  border-bottom: none;
  background-color: #E05702;
  font-weight: 600;
  text-align: left;
  font-size: 18px;
}

.dc-orange-top-border {
  border-top: 1px solid #e6b480;
}

.dc-no-border-bottom {
  border-bottom: none;
}

.dc-price-pad-b5 {
  padding-bottom: 5px;
}

.dc-summary-blue-2 {
  background-color: #0061d5;
}

.dc-note-sup {
  font-size: 14px;
  color: #ffffffb8;
}

.dc-note-sup-xxs {
  font-size: 1px;
  color: #ffffffb8;
}

.dc-subline-1tb {
  font-size: 14px;
  display: block;
  text-indent: -6px;
  line-height: 20px;
  color: #ffffffb8;
}

.dc-border-bottom-red {
  border-bottom: 2px solid #e30500;
}

.dc-btn-link-white {
  color: #ffffff !important;
}



/*  料金 table end */


.section_price{
  padding: 30px 0;
}


.table_level_point {
    position: absolute;
    border: 3px solid #ff5001;
    width: 43%;
    right: 7.5%;
    height: 52px;
    top: 90.94%;

}


.level_point_hukidashi{
      font-size: 16px;
      width: 80%;
      left: 21%;
      top: 10px;
      padding: 14px 20px 16px 20px;
}

font.strength_blue_span::before {
    top: 94px;
}


.merit_view_line{
  background: none;
}




.plan_point_title {
    font-size: 39px !important;
    line-height: 1.25;
    padding-bottom: 15px;
    padding-top: 8px;
}


.service_s_point_title{
  font-size: 39px !important;
  line-height: 1.25;
  padding-bottom: 10px;
  padding-top: 8px;
}




.faq{
  margin-top:0;
}



.b-set2{
  position: inherit;
}


.balloon-text.b-text2 {
    font-size: 15px;
    width: 66%;
}


.level_point_hukidashi::after{
  top: -20px;
  left: 61%;

}


.section_solution,.section_faq,.section_Specifications{
  padding: 30px 0;
}





}


/* ========================================
   DirectCloud Gateway LP override
======================================== */

/* .dc-gateway-lp .dc-gateway-mv {
  height: 620px;
  background: linear-gradient(
    135deg,
    #0d3d79 0%,
    #0f6fc9 52%,
    #eaf5ff 100%
  ) !important;
} */

.dc-mv-copy {
  width: 90%;
  text-align: left;
  color: #fff;
}

.dc-mv-kicker {
  margin-bottom: 16px;
  color: #e4f2ff;
  font-size: 30px;
  font-weight: 700;
  letter-spacing: .02em;
}

.dc-mv-copy p {
  font-size: 43px;
  line-height: 1.25;
  font-weight: 700;
  letter-spacing: -1.5px;
  text-align: center;
  margin-top: 8px;
  color: #a2ccff;
}


.gr_func_point{
    font-size: 13px;
    color: #9398a5;
    margin-top: 8px;
}

.dc-mv-copy_line{
  font-size: 50px;
  line-height: 1.25;
  font-weight: 100;
  letter-spacing: -1.5px;
  text-align: center;
  margin-top: 8px;
  color: #b5d7ff9c;
  font-family: sans-serif;
}



.dc-mv-note {
  margin-top: 25px;
  color: #eaf5ff;
  font-size: 20px;
}

.dc-img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 360px;
  border: 3px dashed #8cb9e8;
  border-radius: 18px;
  background: #f7fbff;
  color: #3383da;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: .08em;
  text-align: center;
}

.dc-mv-placeholder {
  width: 42%;
  min-height: 390px;
  background: rgba(255, 255, 255, .92);
}

.dc-distress-textbox {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 96%;
  min-height: 190px;
  padding: 20px;
  border: 2px solid #a9d1ff;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 0 7px #a7afba59;
  color: #2666b8;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
}

.dc-source-list {
  width: 96%;
  min-height: 210px;
  margin-top: 18px;
  padding: 20px 22px;
  border: 1px solid #d7e8fb;
  border-radius: 10px;
  background: #fff;
  text-align: left;
}

.dc-source-list li {
  position: relative;
  margin-bottom: 8px;
  padding-left: 1.1em;
  color: #555;
  font-size: 18px;
  line-height: 1.5;
}

.dc-source-list li::before {
  content: "●";
  position: absolute;
  top: .1em;
  left: 0;
  color: #3578e3;
  font-size: 9px;
}

.dc-card-phrase {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px 20px;
  background: #fff;
  color: rgb(60 72 82 / 100%);
  font-size: 24px;
  font-weight: 700;
  line-height: 1.35;
}

.dc-placeholder-section {
  margin-top: 20px;
  border: 1.5px solid #9ab8d9;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 0 7px #a7afba59;
  padding:30px;
}



.scene-placeholder-section{
  background: #ffffff;
  position: relative;
  justify-content: space-between;
  margin-top: 15px;
  padding: 0px;
  border-radius: 14px;
  border: 2.5px solid #3784d9;
  box-shadow: 0px 0px 7px #a7afba59;
  background-color: #ffffff;
}


.scene-placeholder-section + .scene-placeholder-section
{
    margin-top:40px;
}


.scene-placeholder-section h3 {
  margin-bottom: 10px;
  color: #fff;
  font-size: 40px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  background: #3578e3;
  padding: 20px;
  border-radius: 10px 10px 0 0;
}


.scene-placeholder-section p{
  padding: 10px 0px 18px 2px;
  font-size: 25px;
  line-height: 1.5;
  color: rgb(80 96 110 / 90%);
  text-align: center;
}



.scene-image-area{
    padding: 0px 35px 35px;
}

.scene-image-area1{
    padding: 30px 35px 35px;
}


img.dc-scene-image {
    background: #f3f9ff;
    border: 1.5px solid #d9e4f3;
    border-radius: 15px;
    padding:35px;
}

.dc-placeholder-section p{
  text-align: center;
  font-size: 26px;
  margin-bottom: 20px;
  }




.dc-scene-placeholder {
  width: 100%;
  margin: 0 auto;
  min-height: 540px;
}

.dc-system-section {

}

.dc-system-sub {
  margin-bottom: 22px;
  color: #60728a;
  line-height: 1.5;
  text-align: center;
}

.dc-feature-lead {
  margin: 10px 0 28px;
  padding: 0;
  border-radius: 18px;
  color: #333;
  font-size: 23px;
  line-height: 1.45;
  text-align: center;
}

.dc-feature-lead p + p {
  margin-top: 12px;
}

.dc-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.dc-feature-card {
  overflow: hidden;
  border: 2px solid #3578e3;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 0 7px #a7afba59;
}

.dc-feature-card h3 {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 78px;
  padding: 16px 12px;
  background: #3578e3;
  color: #fff;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
}

.dc-feature-card p {
  padding: 20px;
  color: #555;
  font-size: 18px;
  line-height: 1.45;
  text-align: left;
}

.dc-feature-card p + p {
  padding-top: 0;
  color: #2d7ccb;
  font-weight: 700;
  text-align: center;
}



/* ----------------------------------------
   動画
---------------------------------------- */
.link_send_section {
    margin-bottom: 50px;
}

.link_send_section:last-child {
    margin-bottom: 0;
    margin-top: 65px;
}

h3.link_send_section_title {
  font-size: 31px;
  font-weight: 800;
  color: #1d2537;
  line-height: 1.45;
  margin: 0 0 8px;
  padding-left: 16px;
  border-left: 4px solid #3678e2;
  background: transparent;
  padding: 0px;
  border-radius: 0px;
  text-align: left;
  padding-left: 15px;
}


.feature_movie_box{
  padding: 0px !important;
}

.movieimg_area{
  width: 100%;
  margin: 0 auto;
	padding: 18px 16px;
	background: #f7f8fc;
	border: 1px solid #d5dbec;
}

.movie_video_wrap{
  position: relative;
  width: 100%;
}

.movie_video{
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  background: #fff;
  border: 1.5px solid #e0e5e9d3;
}

.movie_play_btn{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 120px;
  height: 84px;
  border: 0;
  border-radius: 24px;
  background: #ff0000;
  cursor: pointer;
  z-index: 3;
  padding: 0;
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

.movie_play_btn::before{
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-35%, -50%);
  width: 0;
  height: 0;
  border-top: 18px solid transparent;
  border-bottom: 18px solid transparent;
  border-left: 30px solid #fff;
}

.movie_video_wrap.is-playing .movie_play_btn{
  opacity: 0;
  pointer-events: none;
}

@media screen and (max-width: 767px){
  .movie_play_btn{
    width: 88px;
    height: 62px;
    border-radius: 18px;
  }

  .movie_play_btn::before{
    border-top: 13px solid transparent;
    border-bottom: 13px solid transparent;
    border-left: 22px solid #fff;
  }
}



/* ----------------------------------------
   Feature section corrected to match PPT text only
---------------------------------------- */

.dc-feature-grid-ppt {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.dc-feature-card {
  overflow: hidden;
  border: 2px solid #3578e3;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 0 7px #a7afba59;
}

.dc-feature-card h3 {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  padding: 16px 12px;
  background: #3578e3;
  color: #fff;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
}

.dc-feature-card .dc-card-image {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 210px;
  padding: 20px 20px 0;
  background: #fff;
}

.dc-feature-card .dc-card-image::before {
  content: "";
  position: absolute;
  width: 150px;
  height: 150px;
  border: 10px solid #edf3fa;
  border-radius: 50%;
  background: #fff;
}

.dc-feature-card .dc-card-image img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100px;
  height: auto;

}

.dc-feature-card .dc-card-image img.sync_img1  {
    transform: translateY(8px);
}



.dc-feature-card .dc-card-image img.sync_img2 {
  transform: translateY(1px);
  width:90px;
}


.dc-feature-card .dc-card-image img.sync_img3  {
    transform: translate(4px, 1px);
    width:90px;
}

.dc-feature-card .dc-card-image img.sync_img4  {
    transform: translate(4px, 4px);
}





.dc-feature-card .dc-card-phrase {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px 12px 16px;
  background: #fff;
  color: #303946;
  font-size: 21px;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
}

.dc-feature-text {
  min-height: 210px;
  padding: 20px 18px 20px;
  background: #eef8ff;
  color: #555;
  font-size: 19px;
  line-height: 1.75;
  text-align: left;
}



ul.share_list.dc-feature-text li {
    font-size: 18px;
    padding-left: 1.2em;
}


ul.share_list.dc-feature-text li::before {
    left: 5px;
    top:10px;
}




/* icon position adjustment */
.dc-card-image-sync img {
  width: 112px;
  transform: translate(0, -2px);
}

.dc-card-image-access img {
  width: 112px;
  transform: translate(2px, -3px);
}

.dc-card-image-auto-backup img {
  width: 110px;
  transform: translate(3px, -2px);
}

.dc-card-image-user img {
  width: 112px;
  transform: translate(2px, -3px);
}

@media screen and (max-width: 768px) {
  .dc-feature-grid-ppt {
    display: block;
  }

  .dc-feature-card {
    margin-bottom: 18px;
  }

  .dc-feature-card h3 {
    min-height: auto;
    font-size: 22px;
  }

  .dc-feature-card .dc-card-image {
    height: 220px;
  }

  .dc-feature-text {
    min-height: auto;
    font-size: 17px;
  }
}


/* ----------------------------------------
   Gateway LP fixed:
   distress image placeholder keeps PPT speech-bubble artwork as one image
---------------------------------------- */

.dc-distress-img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 96%;
  min-height: 260px;
  border: 2px dashed #9ab8d9;
  border-radius: 18px;
  background: #f8fbff;
  color: #7c8fa8;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}




.difference_point {
    margin-top: 25px;
    padding: 50px 40px 50px;
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0px 0px 7px 0px #d3d5d8bf;
}



.detail_contents1 {
    /* padding: 30px 5px; */
    text-align: left;
}

.differnce_h4 {
    font-weight: bold;
    color: #378ee4;
    padding: 3px 0px 0px 0px;
    line-height: 1.35;
    font-size: 40px;
    letter-spacing: -0.5px;
    text-align: center;
}

.detail_con_p {
    padding: 10px 0px 18px 2px;
    font-size: 24px;
    line-height: 1.5;
    color: rgb(80 96 110 / 90%);
    text-align: center;
}


.detail_contents2 {
    padding: 65px 0px 0px;
    margin-top: 0px;
}



/* ----------------------------------------
   Responsive
---------------------------------------- */

@media screen and (max-width: 768px) {
  .dc-feature-grid-ppt {
    display: block;
  }

  .dc-feature-grid-ppt .dc-feature-card {
    margin-bottom: 18px;
  }

  .dc-distress-img-placeholder {
    min-height: 210px;
  }
}

@media screen and (max-width: 767px) {
  .dc-mv-copy,
  .dc-mv-placeholder {
    width: 100%;
  }

  .dc-mv-copy h1 {
    font-size: 34px;
  }

  .dc-mv-kicker {
    font-size: 22px;
  }

  .dc-img-placeholder {
    min-height: 240px;
    font-size: 18px;
  }

  .dc-scene-placeholder {
    min-height: 300px;
  }

  .dc-feature-grid {
    grid-template-columns: 1fr;
  }

  .dc-feature-card h3 {
    min-height: auto;
    font-size: 22px;
  }

  .dc-feature-card p,
  .dc-feature-lead {
    font-size: 17px;
  }

  .dc-source-list {
    min-height: auto;
  }


  .difference_point {
    margin-top: 0;
    padding: 24px;
  }


.differnce_h4{
      text-align: left;
      font-size: 24px;
}


.detail_con_p{
  padding: 10px 0px 13px 0px;
  font-size: 18px;
  text-align: left;
}



.dc-placeholder-section{
  padding: 16px;
}


.keyv .mv.dc-gateway-mv{
  background-image:url("/images/lp/dc_gateway/banner_Gateway_bg1_mob.png");
  background-repeat:no-repeat;
  background-position:center -35px;
  background-size:100% auto;
  height:530px;
}


.title_logo {
    width: 100%;
    margin: 14px auto 0;
}


.mv_wrap {
    padding: 10px 0px;
  }


  .dc-mv-copy, .dc-mv-placeholder {
      padding: 10px 20px;
  }


.dc-mv-copy p {
    font-size: 23px;
    margin-top: 5px;
    letter-spacing: -0.5px;
  }

  .dc-mv-copy_line {
      font-size: 25px;

  }

.share_list li::before {
      top: 6px;
}



.chap_subtxt_b{
      font-size: 20px;
}



.scene-placeholder-section h3 {
  font-size: 21px;
  padding:8px 12px;
  line-height: 1.3;
}


.scene-placeholder-section{
  margin-top:0;
}

.scene-placeholder-section p {
    padding: 5px 20px 16px;
    text-align: left;
    font-size:16px;
  }


  .scene-image-area1 {
      padding: 10px 18px 18px;
  }

  .scene-image-area1 {
      padding: 4px 16px 15px;
  }


  img.dc-scene-image {
      border-radius: 4px;
      padding: 10px;
  }

  .scene-image-area {
      padding: 0 18px 18px;
  }


  .gateway_flow_left, .gateway_flow_right {
      border-radius: 8px;
      padding: 10px;
  }


.hukidashi_a{
          top: 15px;
}



/* cta start*/


.index_cta {
    padding: 35px 0;
}

.cta_wrap {
    width: 90%;
    margin: 0 auto;
}

.cta_contents {
    flex-direction: column;
}


.cta_text {
    width: 100%;
    padding: 0;
}

h5.cta_subtxt {
    font-size: 20px;
    line-height: 1.3;
    margin-bottom: 5px;
}

h4.cta_maintxt {
    font-size: 32px;
    line-height: 1.25;
    width: 98%;
    margin: 0 auto 0;
}

.main_btn_contents_area {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 20px;
}

.main_btn_boxtd_contents {
    max-width: 100%;
    width: 100%;
    margin-top: 2px;
}

.appbt-mv-button-text {
    width: 100%;
    font-size: 16px;
    margin-bottom: 2px;
}

.appbt-mv-button-text:before {
    left: 7.7%;
    top: 16px;
}

.appbt-mv-button-text:after {
    right: 8%;
    top: 16px;
}

.app-btn-contents1 {
    padding: 0 20px 0;
    position: relative;
    height: 60px;
}

.app-btn-contents-image-wb {
    width: 35px;
    position: absolute;
    left: 55px;
    top: 10px;
}

.app-btn-contents-text1 {
    font-size: 20px;
    text-align: center;
    padding-left: 65px;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}

.app-btn-contents-arr1 {
    width: 20px;
    height: 20px;
}


.appbt-mv-button-text1 {
    font-size: 16px;
    margin-bottom: 4px;
}

.appbt-mv-button-text1:before {
    transform: rotate(53deg);
    left: 6%;
}


.appbt-mv-button-text1:before, .appbt-mv-button-text1:after {
    top: 16px;
    right: 24px;
}

.appbt-mv-button-text1:before, .appbt-mv-button-text1:after {
    top: 16px;
    right: 24px;
}


.app-btn-contents1 {
    padding: 0 20px 0;
    position: relative;
    height: 60px;
}

.app-btn-contents-image-b {
    width: 41px;
    position: absolute;
    left: 50px;
}

.app-btn-contents-text1-w {
        font-size: 20px;
        height: 60px;
        text-align: center;
        padding-left: 65px;
        display: flex;
        align-items: center;
        justify-content: center;
    }


    .app-btn-contents-arr1 {
        width: 20px;
        height: 20px;
    }


    h5.cta_subtxt:before {
      display: none;
    }


    h5.cta_subtxt:after {
      display: none;
    }

/* cta end*/








}
