@charset "utf-8";

/*==============================================================================
    cta style
============================================================================= */
.cta .bg { padding: 43px 0 40px; background: #f4f4f4 url(../images/cta_bg01.png)no-repeat 50% 0; background-size: cover; }
.cta .border-blue { padding: 0 0 24px; border: #06a0e8 solid 2px; background: #fff; box-shadow: 0px 11px 30px -9px #2f2f2f;}
.cta .ttl-block { position: relative; background: #06a0e8; background: linear-gradient(135deg,#1da7e7 13%,#08a1e8 14%); color: #fff; font-weight: bold; align-items: center; }
.cta .ttl-block:after { position: absolute; top: -10px; right: -40px; width: 258px; height: 154px; background: url(../images/cta_img01.png) no-repeat; content: ""; }
.cta .ttl-block .left-txt { width: 150px; border-right: #fff solid 1px; text-align: center; font-size: 22px; }
.cta .ttl-block h2 {padding: 28px 220px 28px 20px;  width: 825px; font-size: 32px;  }
.cta .btn-block { padding: 30px 46px 27px; }
.cta .btn-block dl { width: 428px; }
.cta .btn-block dt { margin: 0 0 15px; text-align: center; font-size: 24px; letter-spacing: .07rem; }
.cta .btn  {position: relative;  display: block; width: 430px; height: 104px; border-radius: 60px; color: #fff; text-align: center; font-weight: bold; font-size: 28px; line-height: 104px; }
.cta .btn:before  {position: absolute; top: 44px; right: 35px;  display: block; width: 15px; height: 15px; border-top: 2px solid #fff;border-right: 2px solid #fff; content: ""; transform: rotate(45deg); }
.cta .download-btn  { float: left; border-bottom: #227518 solid 5px; background: #55a04b; background: linear-gradient(#68b25e 49.9%,#59a450 50%); }
.cta .experience-btn  { float: right; border-bottom: #ba6f01 solid 5px; background: #fc9d08; background: linear-gradient(#fc9d08 49.9%,#ee9208 50%); }

.cta .contact-btn { position: relative; display: block; margin: 0 auto; width: 319px; height: 50px; border-bottom: #dfe6ec solid 4px; border-radius: 30px; background: #ecf0f3; text-align: center; line-height: 53px; }
.cta .contact-btn:before  {position: absolute; top: 22px; right: 45px;  display: block; width: 7px; height: 7px; border-top: 2px solid #5e5f5f;border-right: 2px solid #5e5f5f; content: ""; transform: rotate(45deg); }

/*==============================================================================
    header style
============================================================================= */
#header .bg { padding: 14px 0 15px; }
#header .logo  { float: left; margin: 12px 0 0; width: 205px; }
#header .btn-block  { float: right; width: 446px; }
#header .btn  {position: relative;  display: block; width: 216px; height: 50px; border-radius: 30px; color: #fff; text-align: center; line-height: 50px; }
#header .btn:before  {position: absolute; top: 20px; right: 20px;  display: block; width: 7px; height: 7px; border-top: 1px solid #fff;border-right: 1px solid #fff; content: ""; transform: rotate(45deg); }
#header .download-btn  { float: left;  background: #55a04b; background: linear-gradient(#68b25e 49.9%,#59a450 50%); }
#header .experience-btn  { float: right; background: #55a04b; background: linear-gradient(#fc9d08 49.9%,#ee9208 50%);}

/*==============================================================================
    hero style
============================================================================= */
.hero .bg { padding: 30px 0 18px; background: url(../images/hero_bg01.jpg)no-repeat 50% 0; background-size: cover; }
.hero .ttl-block {margin: 0 0 33px;  width: 552px; }
.hero .ttl-block .lead { position: relative; margin: 0 0 22px; height: 52px; background: #07a1e8; background: linear-gradient(115deg,#1da7e7 51%,#08a1e8 51%); color: #fff; text-align: center; letter-spacing: .03rem; font-weight: bold; font-size: 26px; line-height: 52px; }
.hero .ttl-block .lead:before { position: absolute; bottom: -15px; left: 0; width: 0; height: 0; border-width: 12px 12px 0 0; border-style: solid; border-color: #009fe8 transparent transparent transparent; content: ""; }
.hero .ttl-block .lead:after { position: absolute; right: 0; bottom: -15px; width: 0; height: 0; border-width: 0 12px 12px 0; border-style: solid; border-color: transparent #009fe8 transparent transparent; content: ""; }
.hero .device { position: absolute; top: 0; right: -76px; width: 476px; }
.hero .compare-block { position: relative; margin: 0 0 0 -10px; width: 990px; height: 380px; background: url(../images/hero_bg02.png)no-repeat 50% 0; background-size: cover; }
.hero .compare-block .company { position: absolute; top: 48px; left: 0; width: 250px; }
.hero .compare-block h2 { padding: 35px 0 15px 280px; letter-spacing: .08rem; }
.hero .list {margin: 0 0 0 29px;  width: 940px; }
.hero .item {padding: 3px 3px 16px;  width: 300px; background: #fff; }
.hero .item dt { background: #009fe8; color: #fff; text-align: center; font-size: 20px; }
.hero .item dd .graph { position: relative; margin: 0 auto; width: 268px; height: 87px; background: url(../images/hero_bg03.png)no-repeat; background-size: cover; }
.hero .item dd .graph .txt-01 { position: absolute; top: 25px; left: 0; width: 114px; text-align: center; font-weight: bold; }

.hero .item dd .graph .txt-02 { position: absolute; top:5px; right: 0; width: 114px; color: #009fe8; text-align: center; font-weight: bold; }
.hero .item dd .graph .txt-03 { position: absolute; right: 0; bottom:0; width: 114px; height: 43px; color: #fff; text-align: center; font-weight: bold; line-height: 43px; }

/*==============================================================================
    usecase style
============================================================================= */
.usecase .bg { padding: 47px 0 50px; background: url(../images/usecase_bg01.jpg)no-repeat 50% 0; background-size: cover; }
.usecase h2 { margin: 0 0 50px; text-align: center; letter-spacing: .1rem; font-weight: bold; font-size: 32px; }
.usecase h2 .sup { position: absolute; bottom: -30px; left: 0; width: 100%; text-align: center; font-weight: normal; font-size: 18px; }
.usecase .small-txt { position: absolute; bottom: -20px; left: 220px; font-size: 18px; }
.usecase .company-block .logo { padding: 22px 28px 12px; background: #fff;}
.usecase .industry-type { padding: 30px 73px 26px; background: rgba(255,255,255,.75); }
.usecase .industry-type .list { margin: 22px 0 0; }
.usecase .industry-type .item { display: table; box-sizing: border-box; margin: 0 0 10px; width: 271px; height: 61px; background: #447ba5; }
.usecase .industry-type .item .icon {position: relative;  display: table-cell; width: 49px; background: #009fe8; vertical-align: middle; }
.usecase .industry-type .item .icon:after { position: absolute; top: 0; right: -15px; width: 0;height: 0;border-width: 61px 15px 0 0;border-style: solid;border-color: #009fe8 transparent transparent transparent; content: ""; }
.usecase .industry-type .item .txt { display: table-cell; padding: 0 0 0 30px; color: #fff; vertical-align: middle; font-weight: bold; font-size: 22px; }
.usecase .industry-type .item .fs-18 { font-size: 18px; }

/*==============================================================================
    cost style
============================================================================= */
.cost .bg { padding: 60px 0 51px; background: url(../images/cost_bg01.png)no-repeat 50% 0; background-size: cover; }
.cost h2 { margin: 0 0 30px; color: #fff; text-align: center; font-size: 50px; }
.cost h2 .sup { position: absolute; top: -20px; left: 0; width: 100%; text-align: center; font-size: 18px; }
.cost .compare-block h3 {padding: 25px 0 0;  height: 187px; background: url(../images/cost_bg02.jpg)no-repeat; letter-spacing: .1rem; }
.cost .compare-block .graph {margin: 62px auto 0; padding: 0 66px;  width: 836px; height: 319px; background: url(../images/cost_graph01.png)no-repeat; background-size: cover; }
.cost .compare-block .before-block { float: left; width: 251px; }
.cost .compare-block .before-block dt { position: absolute; margin: -45px 0 0; width: 250px; text-align: center; }
.cost .compare-block .before-block dd .cost-type {padding: 18px 0 0 80px;  height: 78px; font-size: 15px; line-height: 1.4; letter-spacing: .06rem; }
.cost .compare-block .after-block {position: relative; float: right; width: 250px;  height: 319px; }
.cost .compare-block .after-block dt { position: absolute; margin: -45px 0 0; width: 250px; text-align: center; }
.cost .compare-block .after-block dd .txt-01 { position: absolute; top: 13px; right: -28px; padding: 55px 0 0; width: 184px; height: 184px; text-align: center; font-weight: bold; font-size: 19px; transform: rotate(-5deg); }
.cost .compare-block .after-block dd .txt-02 { position: absolute; right: 0; bottom: 0; width: 251px; height: 77px; color: #fff; text-align: center; font-weight: bold; font-size: 28px; line-height: 77px; }
.cost .btm-txt { padding: 18px 0; text-align: center; font-weight: bold; font-size: 58px; }

/*==============================================================================
    step style
============================================================================= */
.step .bg { padding: 49px 0; }
.step h2 { position: relative; padding: 20px 0; background: #07a1e8; background:linear-gradient(115deg,#1da7e7 51%,#08a1e8 51%); line-height: 1.2; }
.step h2:before { position: absolute; bottom: -20px; left: 0; width: 0; height: 0; border-width: 16px 18px 0 0; border-style: solid; border-color: #009fe8 transparent transparent transparent; content: ""; }
.step h2:after { position: absolute; right: 0; bottom: -20px; width: 0; height: 0; border-width:0 18px 16px 0; border-style: solid; border-color: transparent #009fe8 transparent transparent; content: ""; }
.step .slider-block { margin: 30px 0 60px; }
.step .slider-block h3 { margin: 0 0 24px; letter-spacing: .07rem; }
.step .bx-wrapper { float: right; width: 736px;}
.step .slider-item { width: 736px!important; }
.step .slider-item .bg-gray {margin: 0 0 0 auto; padding: 35px 40px 35px 32px;  width: 736px; border-left: #447ba5 solid 8px; background: #f4f4f4; }
.step .slider-item .pic { width: 330px; }
.step .slider-item .detail-block { width: 295px; }
.step .slider-item .detail-block dt {padding: 0 0 3px; border-bottom: #333 solid 1px;  color: 22px; color: #009fe8; font-weight: bold; font-size: 22px; }
.step .slider-item .detail-block dd { padding: 14px 0 25px; }

/*pager*/
#step-pager { float: left; margin: 19px 0 0; width: 220px; }
#step-pager .pager { position: relative; margin: 0 0 15px; padding: 13px 0; width: 220px; background: #447ba5; color: #fff; text-align: center; font-weight: bold; font-size: 18px; line-height: 1.4; }
#step-pager .pager:after {position: absolute ;bottom: 0;left: 0;width: 220px;height: 45px;border-top-left-radius: 25%;border-top-right-radius: 25%;background: #37729f;content: "";}
#step-pager .pager.active {box-sizing: border-box;  padding: 11px 0; border: #447ba5 solid 3px; background: #fff; color: #447ba5; }
#step-pager .pager.active:before { position: absolute; top: 50%; right: -12px; margin-top: -5px; width: 0; height: 0; border-width: 5px 0 5px 10px; border-style: solid; border-style: solid; border-color: transparent transparent transparent #447ba5; content: ""; }
#step-pager .pager.active:after { width: 214px; background: #e9edf1; }

.step .movie-block h3 { margin: 0 0 40px; letter-spacing: .07rem; }
.step .movie-block .pc { position: relative; margin: 0 0 0 258px; width: 677px; }
.step .movie-block .circle { position: absolute; top: 50px; left: -140px; padding: 70px 0 0; width: 222px; height: 222px; background: url(../images/step_circle01.png)no-repeat; background-size: cover; line-height: 1.2; }
.step .movie-block .txt-01 { position: absolute; top: 120px; left: 0; width: 100%; color: #fff; text-align: center; font-weight: bold; font-size: 23px; }
.step .movie-block .txt-01:before { position: absolute; bottom: -80px; left: 50%; display: inline-block; margin-left: -32px; width: 64px; height: 64px; border: 2px solid #fff; border-radius: 64px; content: ""; line-height: 64px; -webkit-transition: .2s; transition: .2s; }
.step .movie-block .txt-01:after {position: absolute;bottom: -58px;left: 50%;margin-left: -3px;width: 0;height: 0;border-width:11px 0 11px 16px;border-style: solid;border-color: transparent transparent transparent #fff;content: "";}
.step .movie-block .pc:hover .txt-01:before { background: #fff; }
.step .movie-block .pc:hover .txt-01:after {position: absolute;bottom: -58px;left: 50%;margin-left: -3px;width: 0;height: 0;border-width:11px 0 11px 16px;border-style: solid;border-color: transparent transparent transparent #2f72a8;content: "";}

/*==============================================================================
    example style
============================================================================= */
.example .bg { padding: 80px 0 48px; background: #f4f4f4 url(../images/example_bg01.png)no-repeat 50% 0; }
.example h2 { position: relative; margin: 0 0 40px; padding: 0 0 10px; border-bottom: #333333 solid 5px; text-align: center; font-size: 47px; }
.example h2:after {position: absolute;bottom: -13px;left: 50%;margin-left: -7px;width: 0;height: 0;border-width: 8px 7px 0 7px;border-style: solid;border-color: #fff transparent transparent transparent;content: "";}
.example h2:before {position: absolute;bottom: -20px;left: 50%;margin-left: -15px;width: 0;height: 0;border-width: 20px 15px 0 15px;border-style: solid;border-color: #000 transparent transparent transparent;content: "";}
.example .lead .logo { width: 448px; }
.example .lead .right-txt { display: inline-block; width: 200px; color: #747474; line-height: 1.2;}
.example .slider-item { padding: 47px 0 42px;  border-top: #447ba5 solid 8px; background: #fff; }
.example .slider-item .profile-block { float: left; margin: 0 0 0 60px; padding: 2px 2px 0; min-height: 420px; width: 318px; background: #f4f4f4; }
.example .slider-item .profile-block dl { padding: 18px 0; font-size: 14px; }
.example .slider-item .profile-block dt { float: left; clear: both; margin: 0 15px 0 0; width: 78px; text-align: right; }
.example .slider-item .profile-block dd {overflow: hidden; margin: 0 0 9px;  width: 220px; }
.example .slider-item .detail-block { float: right; margin: 0 65px 0 0; width: 485px; }
.example .slider-item .detail-block h3 { margin: 0 0 14px; padding: 0 0 5px; border-bottom: solid #000 1px; letter-spacing: .03rem; font-weight: bold; font-size: 30px; }
.example .slider-item .detail-block h4 { margin: 25px 0 15px; text-align: center; font-weight: bold; font-size: 24px; }
.example .slider-item .detail-block .graph-block {margin: 0 auto;  width: 432px; }
.example .slider-item .detail-block .graph-bg { width: 432px; height: 140px; background: url(../images/example_bg02.png)no-repeat 50% 0; background-size: cover; }
.example .slider-item .detail-block .before { position: relative; float: left; width: 185px; height: 140px; }
.example .slider-item .detail-block .before dt { position: absolute; bottom: -30px; left: 0; width: 100%; text-align: center; font-weight: bold; }
.example .slider-item .detail-block .before dd { height: 140px; text-align: center; font-weight: bold; font-size: 24px; line-height: 140px; }
.example .slider-item .detail-block .after { position: relative; float: right; width: 185px; height: 140px; }
.example .slider-item .detail-block .after dt { position: absolute; bottom: -30px; left: 0; width: 100%; text-align: center; font-weight: bold; }
.example .slider-item .detail-block .after .txt-01 { height: 68px; text-align: center; font-weight: bold; font-size: 24px; line-height: 68px; }
.example .slider-item .detail-block .after .txt-02 { height: 72px; color: #fff; text-align: center; font-weight: bold; font-size: 32px; line-height: 72px; }

/*pager*/
#example-pager { margin: 30px 0 23px; padding: 0 20px; }
#example-pager .pager { position: relative; padding: 22px 0; width: 300px; background: #447ba5; color: #fff; text-align: center; font-weight: bold; font-size: 18px; line-height: 1.4; }
#example-pager .pager:after {position: absolute;bottom: 0;left: 0;width: 300px;height: 55px;border-top-left-radius: 25%;border-top-right-radius: 25%;background: #37729f;content: "";}
#example-pager .pager.active {box-sizing: border-box;  border: #447ba5 solid 3px; background: #fff; color: #447ba5; }
#example-pager .pager.active:before { position: absolute; bottom: -13px; left: 50%; margin-left: -7px;  width: 0; height: 0; border-width: 14px 7px 0 7px; border-style: solid; border-color: #447ba5 transparent transparent transparent; content: ""; }
#example-pager .pager.active:after { width: 294px; background: #e9edf1; }

/*controler*/
.example .bx-wrapper { position: relative; }
.example .bx-wrapper .bx-prev { position: absolute; top: 225px; left: -39px; z-index: 100;width: 75px; }
.example .bx-wrapper .bx-next { position: absolute; top: 225px; right: -39px; z-index: 100; width: 75px; }

/*==============================================================================
    approach style
============================================================================= */
.approach .bg {padding: 62px 0 22px;  min-width: 980px; background: url(../images/approach_bg01.jpg) 50% 0; background-size: cover; color: #fff; }
.approach h2 { margin: 0 0 42px; }
.approach .item {margin: 0 0 20px;  width: 230px; }
.approach .item dt { position: relative; padding: 8px 0; background: #08a1e8; text-align: center; font-weight: bold; font-size: 18px; }
.approach .item dt:after { position: absolute; bottom: -6px; left: 0; width: 0;height: 0;border-width: 7px 230px 0 0;border-style: solid;border-color: #08a1e8 transparent transparent transparent; content: ""; }
.approach .item dd { padding: 7px 0 0; background: #fff; }

/*==============================================================================
    casestudy style
============================================================================= */
.casestudy .bg {padding: 85px 0 12px;  min-width: 980px; background: url(../images/casestudy_bg01.jpg)no-repeat 50% 0; }
.casestudy h2 { margin: 0 0 35px; letter-spacing: .08rem; }
.casestudy h2 .sup { position: absolute; top: -34px; left: 0; width: 100%; text-align: center; font-size: 18px; }
.casestudy .balloon { position: relative; margin: 0 auto 55px; padding: 0 0 0 54px; width: 430px; height: 43px; background: #009fe8; line-height: 43px; }
.casestudy .balloon:before { position: absolute; top: 9px; left: 20px; width: 26px; height: 26px; background: url(../images/casestudy_icon01.png)no-repeat; background-size: cover; content: ""; }
.casestudy .balloon:after { position: absolute; bottom: -9px; left: 50%; margin-left: -5px; width: 0; height: 0; border-width: 10px 5px 0 5px; border-style: solid; border-color: #009fe8 transparent transparent transparent; content: ""; }
.casestudy .item {margin: 0 0 30px;  width: 300px; border: #8f8f8f solid 2px; }
.casestudy .item:hover { opacity: .8; cursor: zoom-in; }
.casestudy .item dt { height: 43px; background: #009fe8; color: #fff; text-align: center; font-size: 18px; line-height: 43px; }
.casestudy .item dd { position: relative; padding: 48px 0 0; height: 182px; text-align: center; font-weight: bold; font-size: 18px; line-height: 1.4; }
.casestudy .item dd.two-line { padding: 36px 0 0; }
.casestudy .item dd:after { position: absolute; top: 95px; left: 50%; margin-left: -18px; width: 36px; height: 36px; background: url(../images/casestudy_icon02.png)no-repeat; background-size: cover; content: ""; }
.casestudy .item-01 dd { background: url(../images/casestudy_img01.jpg)no-repeat; }
.casestudy .item-02 dd { background: url(../images/casestudy_img02.jpg)no-repeat; }
.casestudy .item-03 dd { background: url(../images/casestudy_img03.jpg)no-repeat; }
.casestudy .item-04 dd { background: url(../images/casestudy_img04.jpg)no-repeat; }
.casestudy .item-05 dd { background: url(../images/casestudy_img05.jpg)no-repeat; }
.casestudy .item-06 dd { background: url(../images/casestudy_img06.jpg)no-repeat; }

/*==============================================================================
    pdca style
============================================================================= */
.pdca .bg {padding: 122px 0 27px;  min-width: 980px; background: url(../images/pdca_bg01.jpg)no-repeat 50% 0; background-size: cover; }
.pdca .lead .balloon { position: relative; display: inline-block; margin: 0 0 45px; padding: 0 32px; height: 70px; border: #fff solid 2px; background: rgba(38,173,235,.8); font-size: 34px;line-height: 70px; }
.pdca .lead .balloon:after {position: absolute; bottom: -12px; left: 50%; margin-left: -3px; width: 0; height: 0; border-width: 10px 3px 0 3px; border-style: solid; border-color: #009deb transparent transparent transparent; content: ""; }
.pdca .lead .balloon:before { position: absolute; bottom: -17px; left: 50%; margin-left: -6px; width: 0; height: 0; border-width: 17px 6px 0 6px; border-style: solid; border-color: #fff transparent transparent transparent; content: ""; }
.pdca h2 { float: left; margin: 82px 0 0 35px; width: 565px; letter-spacing: .1rem; }
.pdca h2:after { position: absolute; bottom: -40px; left: 0; width: 100%; height: 26px; background: url(../images/pdca_border01.png); content: ""; }
.pdca h2 .sup { position: absolute; top: -20px; left: 0; width: 100%; text-align: center; font-weight: normal; font-size: 18px; }
.pdca .circle { float: right; margin: 20px 56px 32px 0; width: 308px; }
.pdca .item { position: relative; margin: 0 0 10px; width: 485px; background: #fff; }
.pdca .item-01,.pdca .item-04 { background: #f4f4f4; }
.pdca .item-01:before { position: absolute; top: 83px; right: -17px; z-index: 5;width: 23px; height: 95px; background:url(../images/pdca_arrow01.png)no-repeat; background-size: cover; content: ""; }
.pdca .item-01:after {position: absolute;bottom: -53px;left: 234px;z-index: 5;width: 23px;height: 95px;background:url(../images/pdca_arrow01.png)no-repeat;background-size: cover;content: "";transform: rotate(-90deg);}
.pdca .item-04:before { position: absolute; top: 83px; left: -17px; z-index: 5; width: 23px; height: 95px; background:url(../images/pdca_arrow01.png)no-repeat; background-size: cover; content: ""; transform: rotate(-180deg);}
.pdca .item-04:after {position: absolute;top: -53px;left: 234px;z-index: 5;width: 23px;height: 95px;background:url(../images/pdca_arrow01.png)no-repeat;background-size: cover;content: "";transform: rotate(90deg);}
.pdca .item-01 { background: #f4f4f4; }
.pdca .item .ttl-block { display: table; padding: 10px 0; background: #447ba5; color: #fff; text-align: center; }
.pdca .item-02 .ttl-block,.pdca .item-03 .ttl-block { background: #009fe8; }
.pdca .item .ttl-block .yellow { display: table-cell; width: 115px; border-right: #fff solid 1px; vertical-align: middle; font-weight: bold; font-size: 18px; }
.pdca .item .ttl-block h3 { display: table-cell; width: 365px; vertical-align: middle; font-size: 24px; }
.pdca .item .detail-block { padding: 23px 20px 30px; }
.pdca .item .detail-block .photo { float: left; width: 150px; }
.pdca .item .detail-block  .txt { float: right; width: 272px; line-height: 1.7; }

/*==============================================================================
    faculty style
============================================================================= */
.faculty .bg { padding: 68px 0 75px; }
.faculty h2 { margin: 0 0 42px; letter-spacing: .05rem; }
.faculty .slider-item { padding: 33px 30px 60px 56px; width: 980px!important;border-top: #447ba5 solid 8px;background: #f4f6f8; }
.faculty .slider-item .txt-block  { float: left; width: 415px; }
.faculty .slider-item .txt-block .bg-black { position: relative; margin: 0 0 15px; padding: 0 0 0 16px; width: 404px; height: 49px; background: #333; color: #fff; font-weight: bold; line-height: 49px; }
.faculty .slider-item .txt-block .bg-black:after { position: absolute; top: 0; right: -9px; width: 0; height: 0; border-width: 49px 9px 0 0; border-style: solid; border-color: #333 transparent transparent transparent; content: ""; }
.faculty .slider-item .txt-block h3 {margin: 0 0 15px;  width: 110%; font-weight: bold; font-size: 32px; }
.faculty .slider-item .pic { float: right; margin: 37px 0 0; width: 473px; }

/*pager*/
#faculty-pager { margin: 30px 0 23px; padding: 0 20px; }
#faculty-pager .pager { position: relative; margin: 0 0 20px; padding: 22px 0; width: 300px; background: #447ba5; color: #fff; text-align: center; font-weight: bold; font-size: 18px; line-height: 1.4; }
#faculty-pager .pager:after {position: absolute;bottom: 0;left: 0;width: 300px;height: 55px;border-top-left-radius: 25%;border-top-right-radius: 25%;background: #37729f;content: "";}
#faculty-pager .pager.active {box-sizing: border-box; padding: 19px 0;  border: #447ba5 solid 3px; background: #fff; color: #447ba5; }
#faculty-pager .pager.active:before { position: absolute; bottom: -13px; left: 50%; margin-left: -7px;  width: 0; height: 0; border-width: 14px 7px 0 7px; border-style: solid; border-color: #447ba5 transparent transparent transparent; content: ""; }
#faculty-pager .pager.active:after { width: 294px; background: #e9edf1; }

/*controler*/
.faculty .bx-wrapper { position: relative; }
.faculty .bx-wrapper .bx-prev { position: absolute; top: 159px; left: -39px; z-index: 100;width: 75px; }
.faculty .bx-wrapper .bx-next { position: absolute; top: 159px; right: -39px; z-index: 100; width: 75px; }

/*==============================================================================
    support style
============================================================================= */
.support .ttl-bg {margin: 0 0 36px; padding: 76px 0 0;  min-width: 980px; height: 330px; background: url(../images/support_bg01.jpg)no-repeat 50% 0; background-size: cover; letter-spacing: .1rem; }
.support .lead { margin: 0 0 26px; }
.support .flow-block h3 { position: absolute; top: -12px; left: 21px; z-index: 5; display: inline-block; padding: 8px 15px; background: #447ba5; color: #fff; font-size: 18px; }
.support .flow-block h3:before { position: absolute; top: 0px; left: -5px; width: 0; height: 0; border-width: 0 0 12px 6px; border-style: solid; border-color: transparent transparent #1b5078 transparent; content: ""; }
.support .flow-block h3:after { position: absolute; top: 0px; right: -5px; width: 0; height: 0; border-width: 12px 0 0 6px; border-style: solid; border-color: transparent transparent transparent #1b5078; content: ""; }
.support .flow-01 { float: left; width: 498px; }
.support .flow-02 { float: left; width: 274px; }
.support .flow-03 { float: left; width: 188px; }
.support .flow dt { position: relative; margin: 0 0 25px; padding: 12px 0 0; height: 80px; color: #fff; text-align: center; font-weight: bold; font-size: 20px; line-height: 1.3; }
.support .flow-01 dt {z-index: 3;  background: #05a0e8; }
.support .flow-01 dt:before { position: absolute; top: 0; right: -25px; width: 0; height: 0; border-width: 40px 0 40px 25px; border-style: solid; border-color: transparent transparent transparent #fff; content: ""; }
.support .flow-01 dt:after { position: absolute; top: 0; right: -23px; width: 0; height: 0; border-width: 40px 0 40px 24px; border-style: solid; border-color: transparent transparent transparent #05a0e8; content: ""; }
.support .flow-02 dt:before { position: absolute; top: 0; right: 0px; width: 0; height: 0; border-width: 40px 0 40px 25px; border-style: solid; border-color: transparent transparent transparent #fff; content: ""; }
.support .flow-02 dt:after { position: absolute; top: 0; right: 2px; width: 0; height: 0; border-width: 40px 0 40px 24px; border-style: solid; border-color: transparent transparent transparent #447ba5; content: ""; }
.support .flow-03 dt:after { position: absolute; top: 0; right: -24px; width: 0; height: 0; border-width: 40px 0 40px 24px; border-style: solid; border-color: transparent transparent transparent #447ba5; content: ""; }
.support .flow dd { margin: 0 0 18px; }
.support .flow-01 .txt-01 { position: relative; float: left; width: 265px; text-align: center; }
.support .flow-01 .txt-02 { position: relative; float: right; margin: 0 20px 0 0; width: 210px; text-align: center; }
.support .flow-01 .txt-01:after,.support .flow-01 .txt-02:after { position: absolute; top: -22px; left: 50%; margin-left: -9px; width: 0; height: 0; border-width: 0 9px 15px 9px; border-style: solid; border-color: transparent transparent #05a0e8 transparent; content: ""; }
.support .flow-02 dt,.support .flow-03 dt { background: #447ba5; }
.support .flow-02 dd,.support .flow-03 dd { position: relative; text-align: center; }
.support .flow-02 dd:after,.support .flow-03 dd:after { position: absolute; top: -22px; left: 50%; margin-left: -9px; width: 0; height: 0; border-width: 0 9px 15px 9px; border-style: solid; border-color: transparent transparent #447ba5 transparent; content: ""; }
.support .detail-item { width: 220px; border: #05a0e8 solid 1px; }
.support .detail-item-01 { width: 305px; }
.support .detail-item h4 { position: relative; height: 36px; background: #05a0e8; color: #fff; font-weight: bold; text-align: center; line-height: 36px; }
.support .detail-item-01 h4:after,.support .detail-item-02 h4:after { position: absolute; top: 0; right: -1px; width: 1px; height: 100%; background: #fff; content: ""; }
.support .detail-item-04 { margin: 0 0 0 20px; border-color: #447ba5; }
.support .detail-item-04 h4 { background: #447ba5; }
.support .detail-item .txt { padding: 14px 0; background: #f4f6f8; text-align: center; font-size: 14px; }

/*==============================================================================
    plan style
============================================================================= */
.plan .bg { padding: 68px 0 48px; }
.plan .ttl-block { margin: 0 0 68px; letter-spacing: .08rem; }
.plan .ttl-block .alphabet { position: relative; margin: 0 0 20px; text-align: center ;font-weight: bold; font-size: 20px; }
.plan .ttl-block .alphabet:after { position: absolute; bottom: -30px; left: 50%; width: 2px; height: 25px; background: #000; content: ""; }
.plan table { position: relative; margin: 0 0 34px; border-collapse: separate;font-weight: bold; }
.plan table:after { position: absolute; right: 252px; bottom: -9px; width: 250px; height: 10px; background: #009deb;  content: ""; }
.plan th, .plan td {box-sizing: content-box; padding: 15px 0;  width: 232px; border-bottom: #cfd0d0 solid 1px; background: #f4f6f8; vertical-align: middle; text-align: center; font-size: 18px; line-height: 1.2; }
.plan .starter { background: #f7b400; }
.plan .basic { position: relative; background: #1c69b3; color: #fff; }
.plan .basic .recommend { position: absolute; top: -40px; left: 0; width: 250px; height: 40px; background: #05a0e8; text-align: center; line-height: 40px; }
.plan .enterprise { background: #447ba5; color: #fff; }
.plan th.fs-28, .plan td.fs-28 { font-size: 28px; }
.plan th:first-child,.plan td:first-child { width: 225px; background: #fff; text-align: left; font-size: 16px; }
.plan th:nth-child(3),.plan td:nth-child(3) { position: relative; width: 250px; border-right: #fff solid 20px; border-left: #fff solid 20px;}
.plan td:nth-child(3) { overflow: hidden; }
.plan th:nth-child(3):before,.plan td:nth-child(3):before { position: absolute; top: 0; left: 0; width:10px; height: 150%; background: #05a0e8; content: ""; }
.plan th:nth-child(3):after,.plan td:nth-child(3):after { position: absolute; top: 0; right: 0; width:10px; height: 150%; background: #05a0e8; content: ""; }
.plan td .border-bottom { border-bottom: #05a0e8 solid 10px; }

/*==============================================================================
    security style
============================================================================= */
.security .bg {padding: 40px 0 50px;  min-width: 980px; background: url(../images/security_bg01.jpg)no-repeat 50% 0; background-size: cover; }
.security h2 {margin: 0 0 60px;  line-height: 1.3; }
.security h2 .sup {position: absolute;top: -28px;left: 0;width: 100%;text-align: center;font-size: 18px;}
.security .list {margin: 0 0 35px auto; padding: 36px 0 14px;  width: 756px; background: #fff; }
.security .item {margin: 0 auto 18px; padding: 0 0 0 27px;  width: 679px; height: 82px; border-bottom: #333 solid 2px; border-left: #333 solid 8px; font-size: 24px;align-items: center; }
.security .item .icon { width: 164px; }
.security .btm-txt { height: 83px; background: #447ba5; line-height: 83px; }

/*==============================================================================
    faq style
============================================================================= */
.faq .bg { padding: 48px 0 48px; background: #f5fafe; }
.faq .ttl-block { margin: 0 0 42px; letter-spacing: .12rem; }
.faq .ttl-block .alphabet { position: relative; margin: 0 0 40px; text-align: center ;font-weight: bold; font-size: 20px; }
.faq .ttl-block .alphabet:after { position: absolute; bottom: -30px; left: 50%; width: 2px; height: 25px; background: #000; content: ""; }
.faq .faq-item {margin: 0 0 32px;  width: 450px; }
.faq .faq-item dt { display: table; margin: 0 0 18px; height: 74px; border-bottom: #447ba5 solid 1px; }
.faq .faq-item .q-icon { display: table-cell; width: 66px; background: #447ba5; color: #fff; vertical-align: middle; text-align: center; font-size: 36px; }
.faq .faq-item .q-txt { display: table-cell; padding: 0 0 0 20px; width: 384px; background: #fff; color: #447ba5; vertical-align: middle; font-weight: bold; font-size: 20px; line-height: 1.3; }
.faq .faq-item dd { display: table; }
.faq .faq-item dd .a-icon { display: table-cell; width: 66px; color: #05a0e8; text-align: center;  font-size: 36px; }
.faq .faq-item dd .txt-block { display: table-cell; padding: 10px 0; width: 384px; vertical-align: top;  font-size: 18px; line-height: 1.3; }
.faq .faq-item dd .txt-block .txt + .txt { margin: 30px 0 0;  }

/*==============================================================================
    company style
============================================================================= */
.company .bg { padding: 50px 0 82px; }
.company .ttl-block { margin: 0 0 55px; letter-spacing: .12rem; }
.company .ttl-block .alphabet { position: relative; margin: 0 0 40px; text-align: center ;font-weight: bold; font-size: 20px; }
.company .ttl-block .alphabet:after { position: absolute; bottom: -30px; left: 50%; width: 2px; height: 25px; background: #000; content: ""; }
.company .logo { margin: 20px 0 0 49px;  width: 274px; }
.company .detail-block {padding: 0 0 0 28px;  width: 610px;border-left: #00417c solid 2px; }
.company .detail-block dt { float: left; clear: both; width: 84px; font-weight: bold; font-size: 18px; }
.company .detail-block dd { margin: 0 0 23px; }
.company .detail-block dd:last-child{ margin: 0; }

/*==============================================================================
    footer style
============================================================================= */
#footer { padding: 26px 0; background: #333; }

/*==============================================================================
    modal style
============================================================================= */
#modal-bg {position: fixed; top: 0; left: 0; z-index: 10000;  display: none; width: 100%; height: 100%; background: rgba(0,0,0,.6); }
.modal-item {position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 10001;  display: none; margin: auto; width: 880px; height: 499px; }
.modal-item .close-btn { position: absolute; top: -50px; right: 0; width: 50px; height: 50px; }
.modal-item .bg-white {overflow: scroll;  width: 880px; height: 500px; background: #fff; }
.modal-item .bg-white img {max-width: inherit;  width: auto; }
.modal-item h2 { margin: 0 0 22px; padding: 0 0 19px; border-bottom: #595959 solid 1px; text-align: center; }
.modal-item .artist-item { float: left; margin: 0 0 12px; width: 25%; list-style: disc inside; font-size: 18px; line-height: 1.3; }
.modal-item .link-txt { margin: 17px 0 0; text-align: center; }
.modal-item .link-txt a { color: #047edc; font-size: 20px; }

#modal-movie {position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 10001;  display: none; margin: auto; width: 880px; height: 499px; }
#modal-movie .close-btn { position: absolute; top: -50px; right: 0; width: 50px; height: 50px; }

