@charset "utf-8";


/*
*	Title: SCSK サービス詳細用
*	URI: 
*	Last Modified: 
*	Description: メインカラム（サービス詳細内容）
*/


/* スマホでロゴ画像の見え方を調整する →特に問題ないので調整不要 */
@media screen and (max-width:767px) and (min-width:1px) {
#apriori .apriori_logo {
/*    width: 60%!important;*/
}}
@media screen and (max-width: 640px){
#apriori .apriori_logo {
/*    width: 80%!important;*/
}}
#apriori .apriori_logo{
    float: right;
    margin: 0 0 0 auto;
}


/*---  製品資料ダウンロード  ---------------------------------*/
ul.dl_material li span.download-img {
    display: table-cell;
    vertical-align: middle;
    width:140px; 
    padding:10px 40px;
}
ul.dl_material li span.download-img img {
    width:60px!important;
}
ul.dl_material li span.download-text {
    display: table-cell;
    vertical-align: middle;
    height: 100%;
    width:calc(100% - 140px);
    font-weight:bold;
    font-size:120%!important;
}
.flx-ai--end{
align-items:flex-end;
}

/* aPrioriワークショップのリンクリストの日付のスマホ調整 */
@media screen and (max-width:767px) and (min-width:1px) {
#apriori ul.ttl-List.JS_Write li span.ttl-List-date,#apriori ul.sp-row-List.JS_Write span.ttl-List-date{
font-size: 14px!important;
left:1.2em!important;
margin-bottom: 5px!important;
}
#apriori ul.ttl-List.JS_Write li.narrow .ttl-List-text, #apriori ul.ttl-List.JS_Write  li.narrow .ttl-List-text-2Row{
padding-top: 28px!important;
}

/*---  製品資料ダウンロード  ---------------------------------*/
/* レスポンシブ対応 */
ul.dl_material li span.download-img {
    width:100px; 
    padding:10px 20px;
}
ul.dl_material li span.download-text {
    width:calc(100% - 100px);
}
}


/*aPrioriワークショップの開催中止のお知らせ部分（セミナーの表示部分を移植）*/
#apriori .over_red {
    color: #ff0000;
}
#apriori p.CancelledMessage {
    text-align: center;
    border: 1px solid #ff0000;
    padding: 10px;
}

#apriori .pw53{
    width: 53%;
}
.flx{
display:flex;
flex-wrap: wrap;
}
.flx-r-reverce{
flex-direction: row-reverse;
}


/*aPrioriワークショップ・セミナーの期間設定用*/
#apriori .ttl-List-date-between {
    display: table-cell;
    font-size: 12px;
    width: 100px;
    vertical-align: middle;
    text-align: center;
}
#apriori .sp-row-List.arwList li a:hover span.ttl-List-date-between span.between {
    text-decoration: none!important;
}
#apriori .sp-row-List span.ttl-List-date-between span.between {
    display: inline-block;
}
#apriori .sp-row-List span.ttl-List-date-between span.between:after {
    content: "|";
}
a.db:hover span{
opacity:.8;
}

#apriori a.bb-black {
    background-color: #000 !important;
    border: 1px solid #000 !important;
}
#apriori a.bb-black:hover {
    color: #000 !important;
    background-color: #FFFFFF !important;
}

/*aPrioriワークショップ・セミナーの期間設定用(スマホ表示用)*/
@media screen and (max-width: 767px) and (min-width: 1px){
#apriori .sp-row-List .ttl-List-date-between {
    font-size: 14px!important;
    display: block;
    float: left;
    width: auto;
    position: absolute;
    left: 1em;
    top: 13px;
}
#apriori .sp-row-List span.ttl-List-date-between span.between {
    display: inline!important;
}
#apriori .sp-row-List span.ttl-List-date-between span.between:after {
    content: "－ ";
}
#apriori .sp-row-List span.ttl-List-date-between br {
    display: none!important;
}
}

.top-img {
    position: relative;
}
.top-img .img-text {
    color: #FFF;
    font-size: 21px;
    font-weight: bold;
    position: absolute;
    top: 65%;
    right: 10px;
    transform: translateY(-50%);
    line-height: 120%;
}
@media screen and (max-width: 767px) and (min-width: 1px){
.top-img .img-text {
    font-size: 17px;
    left: 5px;
    width: calc(100% - 10px);
    text-shadow: 1px 1px 2px #000, -1px 1px 2px #000, 1px -1px 2px #000, -1px -1px 2px #000;
}
}
.custom-button {
  border-color: #042433;
  border-style: solid;
  border-width: 1px;
  background-color: #156082;
  color: white;
  text-decoration: none;
  padding: 10px 20px;
  display: inline-block;
  transition: all 0.3s ease;
}

.custom-button:hover {
  background-color: white;
  color: #042433;
}
.custom-button {
  border-color: #042433;
  border-style: solid;
  border-width: 1px;
  background-color: #156082;
  color: white;
  text-decoration: none;
  padding: 10px 20px;
  display: inline-block;
  transition: all 0.3s ease;
}

.custom-button:hover {
  background-color: white;
  color: #042433 !important; /* 重要度を上げて確実に適用 */
}

/* 全てのa要素のホバー状態をオーバーライド */
.custom-button:hover, 
.custom-button:focus,
.custom-button:active {
  color: #042433 !important;
  text-decoration: none;
}

.flex-container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

.top-lineup {
width: 300px;
border-top: 5px solid #1A2792;
border-left:1px solid #ccc;
border-right:1px solid #ccc;
border-bottom:1px solid #ccc;
margin-bottom: 1em;
}

.top-lineup:hover {
border-top: 5px solid #1A2792;
border-left:1px solid #1A2792;
border-right:1px solid #1A2792;
border-bottom:1px solid #1A2792;
}

.top-lineup a {
display: block;
height: 100%;

color: #000 !important;
}

.top-lineup a:hover {
background: #1A2792 !important;
color: #FFF !important;
text-decoration: none !important;
}

.top-lineup a span.lineup-text1 {
display: block;
color: #000;
font-weight: bold; /* テキストを太字にする */
position: relative;
padding-bottom: 5px;
padding: 10px;
}

.top-lineup a:hover span.lineup-text1 {
color: #FFF !important;
}

.top-lineup a span.lineup-text1:after {
font-family: "Font Awesome 5 Free";
content: "\f105";
font-weight: 900 !important;
position: absolute;
top: 100%;
right: 0;
margin-top: -33px;
color: #666;

width: 20px;
height: 20px;

}

.top-lineup a:hover span.lineup-text1:after {
background: #1A2792 !important;
color: #FFF;
}
.top-lineup a img {
width: 298px;
height: 170px;
object-fit: cover;
}

