/*ページ内リンクで固定ヘッダに重なって隠れる問題を修正*/
/*--- html {
  scroll-padding-top: 100px;
}
 ---*/

/*-------------------------------------- */
/* ページ内リンクの位置調整
/*-------------------------------------- */
.inPageLink{
    padding-top: 100px;
    margin-top: -100px;
}



/*会社情報ページ 国旗画像追加*/
.title-tertiary.flag-cn:before{background-image:url("/img/company/partner/flag_cn.gif")}
.title-tertiary.flag-kr:before{background-image:url("/img/company/partner/flag_kr.gif")}
.title-tertiary.flag-ISRAEL:before{background-image:url("/img/company/partner/flag_ISRAEL.gif")}

/*製品情報ページヘッダー画像 modpagespeedの影響で画像が変わらない問題を修正*/
#main--image.main-product.lazyloaded {
  background-image: url("../../img/main/main-product.jpg?PageSpeed=off");/*?20180111*/
}

/*製品情報 お客様事例 一番最後の要素または単一の要素からボーダーを消す*/
.case--list:last-of-type {
  border-bottom: none;
}

/*MBDページヘッダー画像*/
#about-mbd > #main--image.main-about-mbd.lazyloaded {
  background-image: url("/img/main/main-about-mbd.jpg");
}

#accordion {
    width: 80%;
    margin: 0 auto;
}

.accordion-click, .accordion-content {
    padding: 10px;
}

.accordion-click {
    background-color: #4060B8;
    border-top-left-radius: 3px;
    border-top-right-radius: 3px;
    color: #fff;
    cursor: pointer;
    margin-top: 15px;
}

.accordion-content {
    border: 1px solid #4060B8;
    border-bottom-right-radius: 3px;
    border-bottom-left-radius: 3px;
}

#page {width:100%; overflow-x: hidden;}


/*-------------------------------------- */
/* サイドメニュー 論理タイトル
/*-------------------------------------- */
ul.sidenav-list li b{
    line-height: 1.3rem;
    font-weight: bold;
    padding-top: 5px;
    padding-bottom: 5px;
    padding-left: 20px;
    padding-right: 20px;
    display: block;
    color: #FFF;
}

/* -------------------------------------*/
/* Background Color
/*--------------------------------------*/
.bgBlue_Link {
    background-color: #f0f5fa!important;
}

/* -------------------------------------*/
/* Font
/*--------------------------------------*/
.fontBold {
	font-weight:bold!important;
}
.fontred {
	color:#CC0000!important;
}

.fontwhite {
	color:#FFFFFF!important;
}

.fontredClear {
	color:#FF0000!important;
}

.fontgary {
	color: #666!important;
}
.fontblack {
	color: #000000!important;
}
.fontgreen {
	color: #007700!important;
}


.fontSizeS{ font-size:10px;}
.fontSize_09{ font-size:90%;}



/*-------------------------------------- */
/* 字下げ
/*-------------------------------------- */

.indent1 {
	display:block;
	padding-left:1em;
	text-indent:-1em;
}
.indent2 {
	display:block;
	padding-left:2em;
	text-indent:-2em;
}


/*-------------------------------------- */
/* table
/*-------------------------------------- */

table.tableline th {
  background-color: #EEEEEE;
}

table.tableline th,
table.tableline td {
  border:1px solid #000000;
	padding:4px;
	display: table-cell;
  vertical-align: middle;
}

td.borderDotLineBottom, th.borderDotLineBottom{
	border-bottom:3px dotted #e8e8e8;
}

/*-------------------------------------- */
/* table
/*-------------------------------------- */

table.tableLayout th, .tableLayout td {
  padding: 0 10px 0 0;
  vertical-align: middle;
  border: 0px;
}

/*-------------------------------------- */
/* 画像のサイズを固定（拡大縮小させたくない時）
/*-------------------------------------- */

.img-size-fixed {
    max-width: none;
    width: auto;
    height: auto;
}

/*-------------------------------------- */
/* vertical-align
/*-------------------------------------- */
.verticalTop {
    vertical-align: top !important;
}
.verticalBottom {
    vertical-align: bottom !important;
}

/*-------------------------------------- */
/* YouTube Movie Size
/*-------------------------------------- */

.movieSize-L{
    width: 580px;
    height: 315;
}

/*-------------------------------------- */
/* Others ADD
/*-------------------------------------- */

.title-secondary.bd-btm {
    margin-bottom: 20px !important;
}

#product-content section li{
    margin-bottom: 10px !important;
}

#product-content section li > ul {
    margin-top: 10px !important;
}

.nowap {
		white-space:nowrap;
}

.displayBlock{
    display: block !important;
}

.clearboth {
	clear:both;
}

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.clearfix { display: inline-table; }

/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
/* End hide from IE-mac */


/*-------------------------------------- */
/* RESET
/*-------------------------------------- */

input[type="password"] {
    background-clip: padding-box;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 2px;
    color: #464a4c;
    display: block;
    font-size: 1rem;
    line-height: 1.25;
    padding: 0.8rem 1rem;
    transition: border-color 0.15s ease-in-out 0s, box-shadow 0.15s ease-in-out 0s;
    width: 100%;
}

input[type="text"], input[type="email"], input[type="tel"], input[type="password"], textarea {
    font-size: 16px;
}

.form-control, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], textarea, select {
	padding: 0.3em;
}

select.form-control:not([size]):not([multiple]), select:not([size]):not([multiple]) {
    height: calc(2em + 2px);
}

.select-wrap::after {
		font-size: 1em;
    top: 8px;
}
.select-wrap select {
    height: 2em !important;
    line-height:normal !important;
}

#product .select-wrap select {
    line-height:normal !important;
}

.inquiry--flow > .no-gutters{
 font-size: 0.8rem;
}

form .form-item{ padding-top:0.3rem !important;
}

ul.table-content { /*#product .table-content を解除*/
    padding-left: 40px;
}

.product-lower-list ul {/* #product .product-lower-list ulを解除*/
    list-style: none;
    padding: 0;
    margin: 0;
}

.product-lower-list ul li {/* #product .product-lower-list ulを解除*/
    margin-bottom: 10px;
}

.product-lower-list ul li a {/*#product .product-lower-list ul li aを解除*/
    position: relative;
    padding: 10px 30px 10px 28px;
    display: block;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    background-color: #f0f5fa;
    font-weight: bold;
    -webkit-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
    -moz-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
    -o-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
        transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    -moz-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    -o-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}

.product-lower-list ul li a::after {/*#product .product-lower-list ul li a::after を解除*/
    content: "";
    font-family: "icomoon";
    font-size: 10px;
    vertical-align: middle;
    color: #31319d;
    position: absolute;
    right: 10px;
    top: 50%;
    margin-top: -10px;
}

.product-lower-list ul li a:hover, .product-lower-list ul li a:focus, .product-lower-list ul li a:active {/*#product .product-lower-list ul li a:hover, .product-lower-list ul li a:focus, .product-lower-list ul li a:activeを解除*/
    text-decoration: none;
    background-color: #f1f1f1;
}

 /* table-contentはページ内リンクに使用 リストビュレットを三角下向きに変更 */
ul.table-content > li {
    list-style: none;
    position: relative;
    padding: 0 0 0 20px;
}

ul.table-content > li::before {
    content: "";
    position: absolute;
    top: 8px;
    left: -4px;
    border: 4px solid transparent;
    border-top: 6px solid #31319D ;
}

/*-------------------------------------- */
/* TOP ヒーローイメージの透過調整
　 ※色味は元画像の色調整のみ
/*-------------------------------------- */

#hero--image #seen-canvas.loaded {
    opacity: 0.1;
}

/*-------------------------------------- */
/* 音声Player(USC「Simcenter Flotherm」で使用)
/*-------------------------------------- */

@media(min-width:1200px){
    .plyr__default .plyr{
        padding-top: 0px !important;
    }
}

/*-------------------------------------- */
/* ユーザーインフォメーション
/*-------------------------------------- */
#inc_userinformation{
	display:none;
}

.usc-wrap .usc-wrap--block .lower-h5_bdbtm {
    margin-left: 5px;
    margin-right: 5px;
}

.info--archive__detail p{
    margin: 20px 0px 0px 0px;
}
.info--archive__detail dd{
    padding-bottom: 20px;
}
.info--archive__detail dd p.newsTitle{
    padding: 0px;
    margin-top: 10px;
}


/*-------------------------------------- */
/* USC ユーザーサポートセンター Flotherm
user\flotherm\station.html
/*-------------------------------------- */

.contentSation .usc-wrap .usc-wrap--inner .card .card-block.usc-wrap--content {
  border: none !important;
}

.usc-wrap .usc-wrap--inner .card .usc-wrap--content table.tableSation {
  margin: 0;
  width: calc(100%);
}

.usc-wrap .usc-wrap--inner .card .usc-wrap--content table.tableSation td:first-child {
 font-weight: normal;
}

.usc-wrap .usc-wrap--inner .card .usc-wrap--content table.tableSation td {
 text-align: left;
  border-bottom: solid 1px #000;
}
.usc-wrap .usc-wrap--inner .card .usc-wrap--content table.tableSation th {
	text-align: left;
}


@media (min-width: 1180px){
	table.tableSation  tr > td:last-child {
        width: 80px;
    }
}


/*-------------------------------------- */
/* 採用情報 「会社説明会」「インターンシップ」スケジュール
/*-------------------------------------- */

.sessionOnly{display:none;}/* 会社説明会のみ表示 /form/recruit/session/index.htmlにCSS直書き */

form span.area {
	display:inline-block;
  width: 7em;
	vertical-align:top;
}
form span.date {
	display:inline-block;
  width: 15em;
	vertical-align:top;
}
form span.dateonly {
	display:inline-block;
    width: 8em;
	vertical-align:top;
}
form span.place {
	display:inline-block;
	vertical-align:top;
}



/*-------------------------------------- */
/* 数値解析アカデミー
/*-------------------------------------- */

.seminar-detail table { height : auto !important;}/*WP入力時にテーブル高さを触るとテーブルサイズ縮小時、縦幅が短くなる問題を解消*/

.seminar-detail table tr > th,
.seminar-detail table tr > td:first-child{
  min-width: 100px !important;
	max-width: 100px !important;
}
.seminar-detail table tr > th:first-child,.seminar-detail table tr > td:first-child{
    width: 100px !important;
}

.seminar-detail table td.b3,.seminar-detail table td.b1,.seminar-detail table tr > td:nth-child(2) {
    max-width: calc(100% - 100px) !important;
    min-width: calc(100% - 100px) !important;
}


@media (max-width: 767px){
	.seminar-detail table tr > th,.seminar-detail table tr > td:first-child{
		white-space: normal!important;
	}
}

/*-------------------------------------- */
/* 数値解析アカデミー 検索ページ h1タイトルの中揃えボーダー飾り
/*-------------------------------------- */
.head-border {
 font-size:1.5rem;
 margin-bottom: 15px;
 display: flex;
 align-items: center;
}
.head-border:before,
.head-border:after {
 content: "";
 height: 1px;
 flex-grow: 1;
 background-color: #666;
}
.head-border:before {
 margin-right: 1rem;
}
.head-border:after {
 margin-left: 1rem;
}

/*-------------------------------------- */
/* 解析事例集 MP4動画の枠が必要な場合
/*-------------------------------------- */

.mp4-bd{
	border: 1px solid #666
}


/*-------------------------------------- */
/* ボタンの色変更
　　製品情報「GT」「mF」セミナー・コンサルページ
/*-------------------------------------- */
.btn-pagemove {
    font-weight: bold;
    background: #f0f5fa; //ボタンの背景色
    color: #31319d; //ボタンのテキストの色
    border: none;
}

.btn-pagemove:hover {
    color: #000;
    background: #f1f1f1 !important; //ボタンの上にポインタを持ってきたり、クリックしたりした時の背景色
    color: #1f1f63 !important; //ボタンの上にポインタを持ってきたり、クリックしたりした時のテキストの色
}

.btn-pagemove:not(:disabled):not(.disabled):active, .btn-pagemove:not(:disabled):not(.disabled).active, .show > .btn-pagemove.dropdown-toggle {
    color: #000;
    background: #f1f1f1 !important; //ボタンの上にポインタを持ってきたり、クリックしたりした時の背景色
    color: #1f1f63 !important; //ボタンの上にポインタを持ってきたり、クリックしたりした時のテキストの色
}


/*-------------------------------------*/
/*製品情報「GT」TOP
/*画像左テキスト右レイアウトとtable表組み　　　　
/*-------------------------------------*/
.container_bgimg-text {
  position: relative;
  text-align: left !important;
  margin: 30px 0 0 0;
}

.container_bgimg-text .image img {
  width: 30%;
  height: auto;
}

.container_bgimg-text .text-box {
  position: absolute;
  top: 50%;
  right: 0%;
  transform: translateY(-50%);
  background-color: #f0f5fa;
  padding: 20px;
  max-width: 600px;
}

.container_bgimg-text .text-box b {
  font-size: 1.2rem;
}
.container_bgimg-text .text-box p {
  margin-top: 10px;
  text-align: left;
}

@media only screen and (max-width: 1200px) {
  .container_bgimg-text {
    display: flex;
    flex-direction: column;
    text-align: center !important;
  }

  .container_bgimg-text .image img {
    width: 200px;
    height: auto;
    position: relative;
    z-index: 1;
  }

  .container_bgimg-text .text-box {
    position: relative;
    top: 0;
    right: 0;
    transform: translateY(0);
    background-color: #f0f5fa;
    padding: 20px;
    max-width: 600px;
    z-index: 2;
    margin-top: 20px;
  }
}



/* -------------------------------------*/
/* 製品情報ページ内お役立ち資料ボタン
/*--------------------------------------*/
 a.btn_oyakudachi {
    background-color: #ED7D31;
    padding: 5px 10px;
    display: block !important;
    color:#fff;
    font-weight: bold;
    text-decoration: none;
}
 a.btn_oyakudachi:hover{
opacity: .7;
}



/*-------------------------------------- */
/* White Paper 申込みフォーム枠
/*-------------------------------------- */
.form-waku {
    padding: 15px;
    margin-bottom: 50px;
    border-top: 1px solid #c7c7c7;
    border-bottom: 1px solid #c7c7c7;
    background-color: #fff;
    border-radius: 10px;
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}
.form-waku .select-wrap::after{
    right: 5px;
}
.form-waku .form-control{
    font-size: 0.9em;
}

/*-------------------------------------- */
/* Keep Going with Us
/*-------------------------------------- */

#keep #main--image > .container, #keep #main--image > h2{
background: linear-gradient(to right, rgba(252,221,0,0.9) 0%, rgba(252,221,0,0) 100%);
}

#main--image.main-keep.lazyloaded {
    background-image: url("/img/main/main-keep.jpg?20180112")
}

#keep #sec01 h3 {
    color: #2b2b3c;
    position: relative;
    padding-left: 30px;
    font-size: 1.9rem;
    line-height: 2.8rem
}
#keep #sec01 h3:before {
    content: "";
    position: absolute;
    left: 0;
    top: 7px;
    border-left: 7px solid #2b2b3c;
    height: calc(100% - 12px)
}
#keep #sec01 p {
    padding-left: 30px;
    line-height: 1.6rem
}
@media (max-width: 991px) {
    #keep #sec01 p {
        padding-left: 0;
        line-height: 1.6rem
    }
}
#keep #sec02, #keep #sec03, #keep #sec04 {
    background-color: #F0F5FA;
    padding: 30px 40px 20px;
    margin: 70px 0 150px;
    position: relative
}
@media (max-width: 991px) {
    #keep #sec02, #keep #sec03, #keep #sec04 {
        margin: 40px 0 40px
    }
}
@media (max-width: 767px) {
    #keep #sec02, #keep #sec03, #keep #sec04 {
        margin: 0 0 40px
    }
}
@media (max-width: 575px) {
    #keep #sec02, #keep #sec03, #keep #sec04 {
        margin: 0 0 20px
    }
}
#keep #sec02 .bg {
    background-image: url("/img/keep/img01@2x.jpg");
    right: 10px
}
@media (max-width: 991px) {
    #keep #sec02 .bg {
        right: 0;
        left: -40px
    }
}
@media (max-width: 767px) {
    #keep #sec02 .bg {
        left: -15px
    }
}
#keep #sec03 .bg {
    background-image: url("/img/keep/img02@2x.jpg");
    left: 10px
}
@media (max-width: 991px) {
    #keep #sec03 .bg {
        right: 0;
        left: -40px
    }
}
@media (max-width: 767px) {
    #keep #sec03 .bg {
        left: -15px
    }
}
#keep #sec04 .bg {
    background-image: url("/img/keep/img03@2x.jpg");
    right: 10px
}
@media (max-width: 991px) {
    #keep #sec04 .bg {
        right: 0;
        left: -40px
    }
}
@media (max-width: 767px) {
    #keep #sec04 .bg {
        left: -15px
    }
}
@media (max-width: 767px) {
    #keep #sec02, #keep #sec03, #keep #sec04 {
        padding: 0 15px 10px
    }
    #keep #sec02 h3, #keep #sec03 h3, #keep #sec04 h3 {
        margin-bottom: 10px !important
    }
}
#keep .keep-wrap {
    z-index: 1
}
#keep .keep-wrap .title-secondary, #keep .keep-wrap .seminar-detail h2.p14, .seminar-detail #keep .keep-wrap h2.p14 {
    font-size: 1.4rem
}
#keep .keep-wrap p {
    line-height: 1.8rem;
    font-size: .9rem
}
#keep .bg {
    -webkit-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    width: 90%;
    position: absolute;
    bottom: 20px;
    top: -65px
}
@media (max-width: 991px) {
    #keep .bg {
        position: relative;
        width: calc(100% + 80px);
        height: 300px;
        top: -30px
    }
}
@media (max-width: 767px) {
    #keep .bg {
        position: relative;
        width: calc(100% + 30px);
        height: 220px;
        top: 0;
        margin-bottom: 10px
    }
}
#about .banner{
    margin: 65px auto 65px;
}
#about .ex-box h4{
    color:#31319D;
}
@media (min-width: 767px) {
    .sp{
        display: none;
    }
    #about .ex-box h4{
        font-size:1.34rem;
    }
    #about .ex-box {
    font-size: 1.1rem;
    line-height: 1.6;
}
    #about .ex-box .btn-wrap{
        text-align: right;
    }
    #about .ex-box .btn{
        width:10.54rem;
    }
}
@media (max-width: 767px) {
    #about .banner{
        margin: 33px auto;
    }
    #about .ex-box h4{
        font-size:1.25rem;
        line-height: 1.5;
        margin-bottom: .2rem;
    }
    #about p.mt15.mb15{
        margin-top: 0 !important;
    }
    #about p.mt15.mb25{
        margin: 8px 0 15px !important;
    }
    #about .ex-box .btn-wrap{
        text-align: center;
    }
    #about .ex-box .small{
        font-size:.9rem;
    }
    #about .ex-box .btn{
        width:12.6rem;
        line-height: 1.2;
        font-size:1.2rem;
    }
    #about .btn-lh{
        line-height: 1.4;
        font-size:1.4rem;
        max-width: 100%;
        margin-bottom: 30px;
    }
}
.form-error {
    color: red;
}
.bgNormal{
    background:#EEEEEE;
}
.bgError{
    background:#FFEEEE;
}


.idaj-file-waiting {
    width:60px;
    font-size:10px;
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 3px;
    color:#ffffff;
    background-color:#05ca05;
    border-radius:3px;
    display: inline-block;
    border: none;
}

.idaj-file-sending {
    width:60px;
    font-size:10px;
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 3px;
    color:#ffffff;
    background-color:#22dd22;
    border-radius:3px;
    display: inline-block;
    border: none;
}
.idaj-file-finished {
    width:60px;
    font-size:10px;
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 3px;
    color:#ffffff;
    background-color:#31319d;
    border-radius:3px;
    display: inline-block;
    border: none;
}

.idaj-file-retry {
    width:60px;
    font-size:10px;
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 3px;
    color:#ffffff;
    background-color:#ffAAAA;
    border-radius:3px;
    display: inline-block;
    border: none;
}
.idaj-file-error {
    width:60px;
    font-size:10px;
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 3px;
    color:#ffffff;
    background-color:#ff4444;
    border-radius:3px;
    display: inline-block;
    border: none;
}

.idaj-file-clear {
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 10px;
    color:#ffffff;
    background-color:#05ca05;
    border-radius:3px;
    display: inline-block;
    border: none;
}
.idaj-file-clear:hover{
     background-color:#22dd22; /*ボタン色*/
}

.idaj-file-clear2 {
    font-weight: bold;
    text-decoration:none;
    text-align:center;
    padding:1px 3px;
    color:#ffffff;
    background-color:#05ca05;
    border-radius:3px;
    display: inline-block;
    border: none;
}
.idaj-file-clear2:hover{
     background-color:#22dd22; /*ボタン色*/
}
.idaj-adach-file {
    width:100;
    text-decoration:none;
    text-align:center;
    padding:1px 6px;
    color:#ffffff;
    background-color:#31319d;
    border-radius:3px;
    display: inline-block;
    border: none;
}
.idaj-adach-file:hover{
     background-color:#252576; /*ボタン色*/
}

.idaj-upload-continuously{
    text-decoration:none;
    text-align:center;
    color:#ffffff;
    background-color:#252576;
    display: inline-block;
    border: none;
    padding:15px 90px 15px 90px;
}
.idaj-upload-continuously:hover{
    color:#ffffff;
    text-decoration: none;
    background-color:#252576;
}
