
@charset "UTF-8";
.r-mainvisual--tibco {
  background-image: url(/service/TIBCO/images/bg_mainvisual2.png);
}
@media screen and (min-width: 768px) {
  .r-mainvisual--tibco .mainvisual__inner {
    height: 370px;
  }
}
@media screen and (max-width: 767px) {
  .r-mainvisual--tibco .mainvisual__inner {
    text-align: center;
    padding: 76px 20px 60px;
  }
}
.r-mainvisual--tibco .with-photo {
  padding-top: 0;
}
.r-mainvisual--tibco .with-photo__txt {
  text-align: left;
}
@media screen and (max-width: 767px) {
  .r-mainvisual--tibco .with-photo__txt {
    text-align: center;
  }
}
.r-mainvisual--tibco .btn a {
  margin: 16px 0 0 0;
}
@media screen and (max-width: 767px) {
  .r-mainvisual--tibco .btn a {
    width: 160px;
    margin: 16px auto 0;
  }
}
@media screen and (max-width: 767px) {
  .r-mainvisual--tibco .sp-reverse > .with-photo__txt {
    margin-bottom: 40px;
  }
}

.r-mainvisual--tibco-under {
  background-image: url(/service/TIBCO/images/bg_mainvisual2.png);
  background-position: center center;
}
@media screen and (max-width: 767px) {
  .r-mainvisual--tibco-under {
    background-size: 2080px auto;
  }
}

.r-video-thumbnail {
  position: relative;
  display: block;
}
.r-video-thumbnail img {
  vertical-align: top;
}
.r-video-thumbnail:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  pointer-events: none;
  display: block;
  height: 60px;
  width: 60px;
  background-color: #2b9af3;
  border-radius: 1000px;
  z-index: 2;
  opacity: 1;
  -webkit-transition: background-color 250ms ease;
  transition: background-color 250ms ease;
  margin-top: -30px;
  margin-left: -30px;
}
.r-video-thumbnail:hover:before {
  background-color: #0887a9;
}
.r-video-thumbnail:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  pointer-events: none;
  margin-top: -11.75px;
  margin-left: -7.5px;
  border-left: 22.5px solid #fff;
  border-top: 12.75px solid transparent;
  border-bottom: 12.75px solid transparent;
  z-index: 2;
}

.r-mainvisual--tibco__title {
  width: 200px;
}
@media screen and (max-width: 767px) {
  .r-mainvisual--tibco__title {
    margin: auto;
  }
}
.r-mainvisual--tibco__title img {
  width: 100%;
}

.r-mainvisual--tibco__lead {
  font-size: 2.5rem;
  margin-top: 10px;
  line-height: 1.36;
  font-weight: bold;
}

.r-mainvisual--tibco__text {
  margin-top: 10px;
  line-height: 1.5;
  font-weight: bold;
}

.r-mainvisual--tibco__btn {
  margin-top: 20px;
}

.TIBCO .caseLogoArea {
  background: #fff !important;
  margin: 0;
  overflow: hidden;
  position: relative;
  padding: 0 !important;
  height: 100px;
}

.TIBCO .caseLogoArea ul {
  float: left;
  font-size: 0;
}
.TIBCO .caseLogoArea ul:last-of-type {
  margin-left: -90px;
}

.TIBCO .caseLogoArea ul li {
  display: inline-block;
  padding: 0;
  max-width: 180px;
}

.TIBCO .caseLogoArea ul li img {
  width: auto;
  padding: 0px 0;
}

.r-mainvisual--tibco {
  background-image: url(/service/TIBCO/images/bg_mainvisual2.png);
}

.r-filter__block {
  width: 100%;
  background: #f6f6f6;
  padding: 18px 20px;
}

.r-category__title {
  color: #999999;
  font-size: 16px;
  font-weight: bold;
}

.r-label__inner {
  width: 880px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}

.r-category {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-bottom: 20px;
  border-bottom: 1px solid #ffffff;
}

.r-category02 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-bottom: 20px;
  border-bottom: 1px solid #ffffff;
  margin-top: 20px;
}

.r-label__wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}

.r-filter__flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 1ch;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  width: 220px;
}

.r-checkbox-input {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: start;
  -webkit-justify-content: start;
      -ms-flex-pack: start;
          justify-content: start;
  padding-bottom: 6px;
}
.r-checkbox-input input[type=checkbox i] {
  border: 2px solid #b5b5b5 !important;
}

.r-uncheck-btn_style {
  padding: 0;
  background: unset;
  border: none;
  color: #2b9af3;
  font-weight: bold;
  font-size: 16px;
  cursor: pointer;
}
.r-uncheck-btn_style:hover {
  opacity: 0.8;
}

.r-uncheck-btn__wrapper {
  margin-left: 70px;
  padding-top: 15px;
}

.r-card_wrapper {
  width: 990px;
  margin: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .r-card_wrapper {
    width: 100%;
  }
}
.r-card_wrapper:after {
  content: "";
  display: block;
  width: 298px;
}
@media screen and (max-width: 767px) {
  .r-card_wrapper:after {
    display: none;
  }
}

.r-card_box {
  position: relative;
}
@media screen and (min-width: 768px) {
  .r-card_box {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 767px) {
  .r-card_box {
    margin-top: 30px;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .r-card_box:first-of-type {
    margin-top: 0px;
  }
}
.r-card_box_wrap {
  text-decoration: none;
  display: block;
  position: relative;
  width: 298px;
  height: 375px;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .r-card_box_wrap {
    width: 100%;
    height: auto;
    -webkit-box-shadow: 0 0 12px 0 rgba(51, 51, 51, 0.15);
            box-shadow: 0 0 12px 0 rgba(51, 51, 51, 0.15);
  }
}
@media screen and (min-width: 768px) {
  .r-card_box_wrap:hover {
    -webkit-box-shadow: 0 0 12px 0 rgba(51, 51, 51, 0.15);
            box-shadow: 0 0 12px 0 rgba(51, 51, 51, 0.15);
    background: #fff;
  }
}
@media screen and (min-width: 768px) {
  .r-card_box_wrap:hover .r-card_bg {
    opacity: 0;
  }
}
@media screen and (min-width: 768px) {
  .r-card_box_wrap:hover .r-card_lead {
    color: #2b9af3;
  }
}
@media screen and (min-width: 768px) {
  .r-card_box_wrap:hover .r-card_info {
    opacity: 1;
  }
}
.r-card_box_wrap:hover .r-card_category span {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 768px) {
  .r-card_box_wrap:hover .r-card_category span {
    background: #707070;
    color: #fff;
  }
}

.r-card-seminar-wrap {
  text-decoration: none;
  display: block;
  width: 298px;
  padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .r-card-seminar-wrap {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .r-card-seminar-wrap.r-card-seminar-wrap--end {
    padding-bottom: 0;
  }
}

.r-card_header {
  position: relative;
}
.r-card_header img {
  vertical-align: top;
}
.r-card-seminar-wrap--end .r-card_header:after {
  content: "";
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.r-card_header:before {
  content: "受付中";
  background: url(/service/TIBCO/images/icon_seminar_bg.png);
  background-size: 100% auto;
  width: 48px;
  height: 40px;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  padding-top: 6px;
  color: #fff;
  position: absolute;
  right: 10px;
  top: 0;
  z-index: 2;
}
.r-card-seminar-wrap--end .r-card_header:before {
  content: "終了";
  color: #333;
  background: url(/service/TIBCO/images/icon_seminar_bg_off.png);
  background-size: 100% auto;
}

.r-card_bg {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  z-index: 0;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.r-card_bg.r-card_bg--left img {
  -o-object-position: left center;
     object-position: left center;
}
.r-card_bg.r-card_bg--right img {
  -o-object-position: right center;
     object-position: right center;
}
.r-card_bg:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: -webkit-linear-gradient(128.42deg, rgba(10, 10, 12, 0.15) 0%, rgba(10, 10, 12, 0.9) 100%);
  background: linear-gradient(321.58deg, rgba(10, 10, 12, 0.15) 0%, rgba(10, 10, 12, 0.9) 100%);
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .r-card_bg:before {
    display: none;
  }
}
.r-card_bg img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
  width: 100%;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .r-card_bg img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 190px;
    border-radius: 10px 10px 0 0;
  }
}
@media screen and (max-width: 767px) {
  #displaylist_resources .r-card_bg img {
    border-bottom: 1px solid #e5e5e5;
  }
}

.r-card_info_wrap {
  padding: 10px 20px;
}
@media screen and (max-width: 767px) {
  .r-card_info_wrap {
    padding: 135px 20px 20px;
  }
}
.r-card-seminar-wrap .r-card_info_wrap {
  padding: 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .r-card_info_wrap--resources {
    padding: 190px 20px 20px;
  }
}

.r-card_category {
  padding-top: 0px;
  padding-bottom: 10px;
  text-align: left;
  position: relative;
}
@media screen and (max-width: 767px) {
  .r-card_category {
    padding-top: 10px;
  }
}
.r-card_category span {
  background-color: #f6f6f6;
  color: #333333;
  font-weight: bold;
  padding: 5px;
  border-radius: 4px;
  font-size: 12px;
}
.r-card_category span:nth-child(n+2) {
  margin-left: 8px;
}
@media screen and (max-width: 767px) {
  .r-card_category span {
    background: #707070;
    color: #fff;
  }
}

.r-card_logo {
  width: 160px;
  height: 64px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #fff;
}
.r-card_logo img {
  width: auto;
  max-height: 34px;
  max-width: 140px;
}

.r-card_date {
  font-size: 1.4rem;
  font-weight: bold;
  margin-top: 10px;
}

.r-card_lead {
  font-size: 1.8rem;
  font-weight: bold;
  color: #fff;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .r-card_lead {
    color: #2b9af3;
  }
}
.r-card-seminar-wrap .r-card_lead {
  color: #2b9af3;
}

.r-card_title {
  font-size: 1.8rem;
  font-weight: bold;
  color: #2b9af3;
  margin-top: 10px;
  min-height: 82px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .r-card_title {
    min-height: auto;
  }
}
.r-card_title a {
  color: #2b9af3;
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .r-card_title a:hover {
    opacity: 0.7;
  }
}

.r-card_company_name {
  color: #000;
  display: inline-block;
  font-weight: bold;
}

.r-card_info_text {
  color: #000;
  display: inline-block;
  /* font-weight: bold; */
  font-size: 1.6rem;
  font-weight: normal;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

.r-card_more_text {
  color: #2b9af3;
  margin-top: 1em;
  position: absolute;
  left: 20px;
  bottom: 20px;
}
@media screen and (max-width: 767px) {
  .r-card_more_text {
    position: static;
  }
}

.r-card_contents {
  z-index: 1;
  padding-top: 10px;
  height: 100%;
  position: relative;
}
.r-card-seminar-wrap .r-card_contents {
  position: static;
}

.r-card_info {
  opacity: 0;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  text-align: left;
  padding: 10px 0;
}
@media screen and (max-width: 767px) {
  .r-card_info {
    opacity: 1;
    padding: 10px 0 0;
  }
}

.r-card_tr {
  font-size: 1.2rem;
  color: #fff;
}
.r-card-seminar-wrap .r-card_tr {
  font-size: 1.4rem;
}
.r-card_tr td {
  padding: 2px 0;
}

.r-card_td01 {
  width: 75px;
  color: #b5b5b5;
  font-weight: bold;
}

.r-card_td02 {
  color: #333333;
  font-weight: normal;
}

.r-card_table {
  margin-top: 10px;
  width: 100%;
}

.r-card_btn {
  text-align: center;
  margin-top: 20px;
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.r-card_btn a {
  min-width: 160px;
}
.r-card-seminar-wrap--end .r-card_btn {
  display: none;
}

.r-pagenation {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 100px;
}
.r-pagenation li {
  width: 30px;
  height: 30px;
  margin: 0 5px;
}
.r-pagenation li.active a {
  background-color: #707070;
  color: #fff;
}
.r-pagenation li a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  color: #2b9af3;
  background-color: #ececec;
  text-align: center;
  text-decoration: none;
  border-radius: 5px;
}
@media screen and (min-width: 768px) {
  .r-pagenation li a.current {
    background-color: #707070;
    color: #fff;
  }
}
@media screen and (min-width: 768px) {
  .r-pagenation li a:hover {
    background-color: #707070;
    color: #fff;
  }
}

.r-casenumber {
  width: 990px;
  margin: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .r-casenumber {
    width: 100%;
  }
}

.r-casenumber_txt {
  text-align: left;
  margin: 0 0 18px 0;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.5;
  color: #999;
}
@media screen and (max-width: 767px) {
  .r-casenumber_txt {
    margin-bottom: 0;
  }
}
.r-casenumber_txt span {
  margin: 0 5px 0 0;
  font-size: 1.6rem;
  color: #333;
}
/*レスポンシブ*/
@media screen and (max-width: 767px) {
  section {
    width: 100%;
  }
  .r-category {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 20px;
  }
  .r-category02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .r-category02 .r-label__inner {
    -webkit-box-orient: unset;
    -webkit-box-direction: unset;
    -webkit-flex-direction: unset;
        -ms-flex-direction: unset;
            flex-direction: unset;
    width: 90%;
    margin: 0 auto;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .r-category02 .r-filter__flex {
    width: 45%;
  }
  .r-category__text {
    margin-bottom: 5px;
  }
  .r-label__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 90%;
    margin: 0 auto;
  }
  .r-filter__block {
    width: 100%;
    background: #f6f6f6;
    padding: 0px 18px;
  }
  .r-uncheck-btn__wrapper {
    margin-left: 0px;
    padding-top: 15px;
    padding-bottom: 15px;
  }
  .r-acd {
    max-width: 100%;
  }
  .r-acd-hidden {
    display: none !important;
  }
  .r-acd-open {
    display: block;
    padding: 20px 0px 9px 0;
    cursor: pointer;
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    position: relative;
  }
  .r-acd-open::before {
    content: "";
    width: 20px;
    height: 3px;
    background: #2b9af3;
    position: absolute;
    top: 60%;
    right: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .r-acd-open::after {
    content: "";
    width: 20px;
    height: 3px;
    background: #2b9af3;
    position: absolute;
    top: 60%;
    right: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .r-acd-hidden:checked + .r-acd-open:after {
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
  }
  .r-acd-close {
    display: block;
    height: 0;
    overflow: hidden;
    margin: 10px 0 0 0;
    padding: 0;
    opacity: 0;
    line-height: 1.7em;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    border-top: 1px solid #ffffff;
  }
  .r-acd-hidden:checked + .r-acd-open + .r-acd-close {
    height: auto;
    opacity: 1;
  }
}
.r-footer-logo--tibco {
  width: 132px;
}

.r-footer-text--tibco {
  width: 170px;
  font-size: 15px;
  font-weight: 400;
  color: #fff;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .r-footer-text--tibco {
    width: auto;
  }
}

.r-data-filter-container dl {
  margin-bottom: 10px;
}
.r-data-filter-container dt {
  margin-bottom: 10px;
}
.r-data-filter-container button {
  margin-right: 10px;
  margin-bottom: 6px;
  min-height: 2.2em;
  cursor: pointer;
}

.hide {
  display: none !important;
}

.first,
.last {
  display: none;
}

/* 220915 TIBCO header adjust */
@media screen and (min-width: 768px) {
  body.TIBCO {
    margin-top: 128px;
  }
}
@media screen and (max-width: 767px) {
  body.TIBCO {
    margin-top: 0 !important;
    padding-top: 101px;
  }
}
@media screen and (min-width: 768px) {
  body.TIBCO.tibco-under {
    margin-top: 180px;
  }
}
@media screen and (max-width: 767px) {
  body.TIBCO #container {
    padding-top: 0 !important;
  }
}

@media screen and (min-width: 768px) {
  .service-header,
  .lnav-wrap,
  .subnav-wrap {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    -webkit-transition: -webkit-transform 0.4s ease;
    transition: -webkit-transform 0.4s ease;
    transition: transform 0.4s ease;
    transition: transform 0.4s ease, -webkit-transform 0.4s ease;
    position: fixed;
    width: 100%;
    top: 0;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
}

@media screen and (min-width: 768px) {
  .service-header {
    top: 0;
    z-index: 99;
    background-color: #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .lnav-wrap {
    top: 70px;
    z-index: 98;
  }
}

@media screen and (min-width: 768px) {
  .subnav-wrap {
    display: none;
    margin-top: 0;
    background-color: #f8f8f8;
    width: 100%;
    min-width: 990px;
    top: 128px;
    z-index: 97;
  }
}
@media screen and (max-width: 767px) {
  .subnav-wrap {
    padding: 0 20px;
    width: 100%;
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .header--unpinned {
    -webkit-transform: translateY(-58px);
            transform: translateY(-58px);
  }
}

@media screen and (min-width: 768px) {
  .header-sub--unpinned {
    -webkit-transform: translateY(-58px);
            transform: translateY(-58px);
  }
}

@media screen and (min-width: 768px) {
  .subnav__title {
    height: 26px;
  }
}
@media screen and (min-width: 768px) {
  .subnav__title img{
    height: 26px;
  }
}
@media screen and (max-width: 767px) {
  .subnav__title {
    height: 18px;
    width: 100%;
    height: 42px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    background-color: #ececec;
    position: relative;
    padding-right: 9px;
  }
}

@media screen and (min-width: 768px) {
  .subnav__title a:hover {
    opacity: 0.6;
  }
}

@media screen and (min-width: 768px) {
  .subnav {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .subnav {
    padding: 0px 17px 20px;
    background-color: #ececec;
    display: none;
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .subnav li {
    margin-left: 30px;
  }
}
@media screen and (max-width: 767px) {
  .subnav li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding-left: 1px;
    padding-top: 6px;
  }
}

@media screen and (max-width: 767px) {
  .subnav li:first-child {
    border-top: solid 1px #999;
    padding-top: 15px;
  }
}

@media screen and (max-width: 767px) {
  .subnav li::before {
    content: "・";
    position: relative;
    margin-left: -2px;
  }
}

@media screen and (min-width: 768px) {
  .subnav__item-name > a {
    font-size: 16px;
    line-height: 1.43;
    text-align: left;
    color: #333;
    text-decoration: none;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    height: 51px;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .subnav__item-name > a {
    font-size: 12px;
    line-height: 1.5;
    text-align: left;
    color: #333;
    text-decoration: none;
  }
}

@media screen and (min-width: 768px) {
  .subnav__item-name > a::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 0;
    bottom: 0;
    background-color: #2B9AF3;
    left: 0;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
}

@media screen and (min-width: 768px) {
  .subnav__item-name > a:hover::after,
.current .subnav__item-name > a::after {
    height: 3px;
  }
}

/* 
.subnav__item-trial{
  padding: 2px 10px 3px 7px;
  border-radius: 15px;
  border: solid 1px #2b9af3;
  background-color: #2b9af3;
  color: #fff;
  font-size: 13px;
  font-weight: bold;
  transition: all .3s;
} */
@media screen and (min-width: 768px) {
  .subnav__item-trial {
    padding: 1px 10px 1px 10px;
    border-radius: 13px;
    border: solid 1px #2b9af3;
    background-color: #2b9af3;
    color: #fff;
    font-size: 13px;
    font-weight: bold;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    height: 20px;
  }
}

@media screen and (max-width: 767px) {
  .subnav__item-name-trial > a {
    padding: 3px 9px 3px 9px;
    border-radius: 15px;
    border: solid 1px #2b9af3;
    background-color: #2b9af3;
    color: #fff;
    font-size: 11px;
    font-weight: bold;
    opacity: 1;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-decoration: none;
  }
}

@media screen and (max-width: 767px) {
  .subnav__title:before,
.subnav__title::after {
    content: "";
    position: absolute;
    right: 20px;
    top: 50%;
    width: 16px;
    height: 2px;
    background-color: #333;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
}

@media screen and (max-width: 767px) {
  .subnav__title:before {
    -webkit-transform: translateY(-50%) rotate(0deg);
            transform: translateY(-50%) rotate(0deg);
  }
}

@media screen and (max-width: 767px) {
  .subnav__title::after {
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
  }
}

@media screen and (max-width: 767px) {
  .subnav__title.is-active:after {
    -webkit-transform: translateY(-50%) rotate(0deg);
            transform: translateY(-50%) rotate(0deg);
  }
}

@media screen and (min-width: 768px) {
  .lnav-second__wrap::before {
    content: "";
    position: absolute;
    width: 200vw;
    height: 100vh;
    background-color: rgba(51, 51, 51, 0.8);
    left: -100vw;
    top: 0;
    z-index: -1;
    pointer-events: none;
  }
}

@media screen and (min-width: 768px) {
  .lnav-second__wrap__inner {
    z-index: 2;
    background: #fff;
    padding: 20px;
  }
}

@media screen and (min-width: 768px) {
  .lnav-second__wrap {
    position: absolute;
    z-index: 2;
    top: 0;
    left: auto;
    display: block;
    visibility: hidden;
    width: auto;
    min-height: 100%;
    margin-top: 58px;
    padding: 0px;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
    opacity: 0;
    background: transparent;
  }
  .lnav-second--fourcolumn {
    position: absolute;
    left: 50%;
    width: 990px;
    margin-left: -495px;
  }
}

.subnav-item {
  display: none;
}
@media screen and (min-width: 768px) {
  .subnav-item {
    border-bottom: solid 1px #b5b5b5;
  }
}
@media screen and (max-width: 767px) {
  .subnav-item {
    margin: 40px auto;
  }
}

@media screen and (min-width: 768px) {
  .TIBCO.subnav-spotfire .subnav-item--spotfire {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 767px) {
  .TIBCO.subnav-spotfire .subnav-item--spotfire {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .TIBCO.subnav-data-science .subnav-item--data-science {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 767px) {
  .TIBCO.subnav-data-science .subnav-item--data-science {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .TIBCO.subnav-data-virtualization .subnav-item--data-virtualization {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 767px) {
  .TIBCO.subnav-data-virtualization .subnav-item--data-virtualization {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .TIBCO.subnav-ebx .subnav-item--ebx {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 767px) {
  .TIBCO.subnav-ebx .subnav-item--ebx {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .TIBCO.subnav-streaming .subnav-item--streaming {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 767px) {
  .TIBCO.subnav-streaming .subnav-item--streaming {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .subnav-wrap-pc {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .subnav-wrap-pc {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .subnav-wrap-sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .subnav-wrap-sp {
    display: block;
  }
}



/* 導入事例カルーセル　20250709追記

====================================================*/
.r25-example-case-slider {
  position: relative;
  margin-top: -20px;
}

.r25-example-case-slider .slick-slide {
  box-shadow: none;
}

/* .slick-activeを持つときだけbox-shadowを付与 */
.r25-example-case-slider .slick-slide.slick-active {
  box-shadow: 3px 3px 20px 0 rgba(66, 96, 138, .12) !important;
}

.r25-example-case-slider .slick-list {
  padding: 20px 0;
}

/* slick関連の細かい調整 */
@media screen and (min-width: 768px) {
  .r25-example-case-slider {
    margin-top: 60px;
  }
  .r25-example-case-slider .slick-slide {
    margin-right: 48px;
    box-sizing: border-box;
    position: relative;
    z-index: 2;
    height: auto;
  }

  .r25-example-case-slider .slick-list {
    margin-right: -48px;
  }
  .r25-example-case-slider .r25-slick-arrow__wrap {
    width: 990px;
  }
}

@media screen and (max-width: 767px) {
  .r25-example-case-slider .slick-slide {
    width: 90%;
    margin: 0 20px;
    position: relative;
    text-align: center;
  }
}

/* PC時にカードが3つ以下の時のスタイル（カルーセル無効時） */
@media (min-width: 768px) {
  .r25-example-case-slider .no-slick-carousel {
    display: flex;
    gap: 48px;
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .r25-example-case-slider .no-slick-carousel > a {
    flex: 0 0 calc((100% - (48px * 2)) / 3);
    max-width: calc((100% - (48px * 2)) / 3);
    width: auto;
    box-sizing: border-box;
    margin: 0 !important;
    padding: 0 !important;
  }
}

/* SP時にカードが1つの時のスタイル（カルーセル無効時） */
@media (max-width: 767px) {
  .r25-example-case-slider .no-slick-carousel {
    display: block;
    gap: 0;
  }
  .r25-example-case-slider .no-slick-carousel > a {
    width: 100%;
    margin: 0 !important;
    padding: 0 !important;
  }
}

/* spotfire ライセンス種別

====================================================*/
.r25-spotfire-table-licence {
  border: none;
}

.r25-spotfire-table-licence thead th {
  background-color: #42608a;
  border: solid #fff;
  text-align: center;
  color: #fff;
  font-weight: bold;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence thead th {
    border-width: 0 0 4px 0;
    height: 60px;
    font-size: 1.8rem;
    line-height: 1.33;
  }
}

.r25-spotfire-table-licence thead th:nth-of-type(2) {
  background-color: #062045;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence thead th:nth-of-type(2) {
    border-width: 0 0 4px 2px;
  }
}

.r25-spotfire-table-licence tbody th {
  background-color: #b0bfc7;
  font-weight: 500;
  text-align: center;
  color: #fff;
  border: solid #fff;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence tbody th {
    font-size: 1.6rem;
    line-height: 1.5;
    border-width: 0 2px 4px 0;
    width: 62px;
    padding: 0;
  }
}

.r25-spotfire-table-licence tbody td {
  font-weight: bold;
  text-align: left;
  color: #333;
  background-color: #d9e3ed;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence tbody td {
    font-size: 1.6rem;
    line-height: 1.5;
    /*    font-family: Lato; */
    border: solid #fff;
    border-width: 0 2px 4px 0;
    width: 336px;
    height: 100px;
    padding: 30px 22px 30px 20px;
  }
}

.r25-spotfire-table-licence tbody td:nth-of-type(2) {
  background-color: #dee2ea;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence tbody td:nth-of-type(2) {
    font-weight: 500;
    border-width: 0 0 4px 2px;
    min-width: 590px;
  }
}

.r25-spotfire-table-licence tbody tr:last-of-type th {
  border-bottom: none;
}

.r25-spotfire-table-licence tbody tr:last-of-type td {
  border-bottom: none;
}

.r25-spotfire-table-licence thead th {
  border-color: #f4f4f4;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence thead th {
    border-width: 0 0 6px 0;
  }
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence thead th:nth-of-type(2) {
    border-width: 0 0 6px 2px;
  }
}

.r25-spotfire-table-licence tbody th {
  border-color: #f4f4f4;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence tbody th {
    border-width: 0 2px 6px 0;
  }
}

.r25-spotfire-table-licence tbody td {
  border-color: #f4f4f4;
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence tbody td {
    border-width: 0 2px 6px 0;
  }
}

@media screen and (min-width: 769px) {
  .r25-spotfire-table-licence tbody td:nth-of-type(2) {
    border-width: 0 0 6px 2px;
  }
}

.r25-spotfire-table-licence tbody tr:nth-of-type(1) td {
  border-bottom: 4px solid #f4f4f4;
}

.r25-spotfire-table-licence tbody tr:nth-of-type(4) th {
  border-bottom: none;
}

.r25-spotfire-table-licence tbody tr:nth-of-type(4) td {
  border-bottom: 4px solid #f4f4f4;
}


@media screen and (max-width: 768px) {
  .r25-spotfire-table-licence-sp__block {
    margin-top: 10px;
  }

  .r25-spotfire-table-licence-sp__block:nth-child(3),
  .r25-spotfire-table-licence-sp__block:nth-child(4) {
    margin-top: 20px;
  }

   .r25-spotfire-table-licence-sp__block .block01__title {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: #42608a;
    color: #fff;
    font-weight: bold;
    font-size: 1.8rem;
    line-height: 1.33;
    height: 40px;
    width: 100%;
  }

  .r25-spotfire-table-licence-sp__block .block01__txt {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 1.6rem;
    line-height: 1.5;
    width: 100%;
    height: 60px;
    font-weight: bold;
    text-align: left;
    color: #333;
    background-color: #d9e3ed;
  }

  .r25-spotfire-table-licence-sp__block .block01__sub {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: #b0bfc7;
    font-weight: 500;
    text-align: center;
    color: #fff;
    font-size: 1.6rem;
    line-height: 1.5;
    width: 60px;
    height: 100%;
    margin-right: 20px;
  }

  .r25-spotfire-table-licence-sp__block .block02 {
    margin-top: 4px;
  }

  .r25-spotfire-table-licence-sp__block .block02__title {
    background-color: #062045;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #fff;
    font-weight: bold;
    font-size: 1.8rem;
    line-height: 1.33;
    height: 40px;
    width: 100%;
  }

  .r25-spotfire-table-licence-sp__block .block02__txt {
    text-align: left;
    font-size: 1.6rem;
    line-height: 1.5;
    width: 100%;
    padding: 17px 20px 15px;
    font-weight: 500;
    color: #333;
    background-color: #dee2ea;
  }
}

/* spotfire お客さまの声

====================================================*/
.testimonial-section {
    width: 100%;
    margin: 0 auto;
    font-family: sans-serif;
    padding: 80px 0;
  }
  @media (max-width: 768px) {
    .testimonial-section {
      padding: 40px 0;
      }
    }
  
  .testimonial-grid-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: start;
    gap: 30px;
  }
  @media (max-width: 768px) {
    .testimonial-grid-container {
        grid-template-columns: 1fr;
      }
    }
  
  .testimonial-item {
    display: flex;
    flex-direction: column-reverse; /* ここを変更：吹き出しが上 */
    text-align: center;
    height: 100%;
  }
  
  .testimonial-header {
    position: relative;
    display: flex;
    align-items: center;
    z-index: 2; /* 吹き出しより手前に表示 */
    margin-top: 20px;
    gap: 10px;
    margin-left: 50px;
  }
  
  .testimonial-person-icon {
    width: 50px;
    height: 50px;
    height: auto;
    box-sizing: border-box;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  @media (max-width: 768px) {
    .testimonial-person-icon {
      width: 40px;
      height: 40px;
    }
  }
  
  .testimonial-person-icon img {
    width: 100%;
    height: auto;
    display: block;
  }
  
  /* 名前と会社名 */
  .testimonial-person-info {
    line-height: 1.4;
    flex: 1;
    text-align: left;
  }
  
  .testimonial-person-name {
    font-weight: medium;
    line-height: 1.7;
    font-size: 18px;
  }
  @media (max-width: 768px) {
    .testimonial-person-name {
      font-size: 14px;
    }
  }
  
  .testimonial-bubble {
    position: relative;
    background: #FFFFFF;
    border-radius: 10px;
    padding: 20px;
    width: 100%;
    box-sizing: border-box;
    text-align: left;
    filter: drop-shadow(3px 6px 20px #42608A1F);
    z-index: 1;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
  }
  
  .testimonial-bubble::before {
      content: "";
      position: absolute;
      bottom: -28px;
      left: 47px;
      width: 36px;
      height: 30px;
      background-color: #ffffff;
      clip-path: polygon(50% 100%, 0% 0%, 100% 0%);
      transform: translate(-50%, 0) skew(30deg);
      z-index: 1;
  }
  @media (max-width: 768px) {
    .testimonial-bubble::before {
      bottom: -22px;
      width: 30px;
      height: 24px;
    }
  
  }
  .testimonial-bubble-title{
    color: #333C66;
    line-height: 1.7;
    font-size: 18px;
    font-weight:bold;
    margin-bottom:10px
  }
  @media (max-width: 768px) {
    .testimonial-bubble-title{
      font-size: 16px;
      margin-bottom:8px
    }
  }
  
  .testimonial-bubble-text{
    line-height: 1.7;
  
  }
  @media (max-width: 768px) {
    .testimonial-bubble-text{
      font-size: 14px;
    }
  }

/* 画像モーダル用

====================================================*/

.column-body {
  width: 100%;
}
.column-body.ex-modal-img  .column-img img {
  cursor: pointer;
  width: auto;
}
  #graydisplay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    max-width: 100% !important;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    cursor: pointer;
  }

  #graydisplay.show {
    display: flex;
  }

  #graydisplay img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    max-width: 70vw;
    max-height: 70vh;
    width: auto !important;
    height: auto;
    object-fit: contain;
    cursor: pointer;
    background-color:#ffffff;
    padding:4px;
    border-radius:4px;
  }

/* 画像拡大、モーダル対応用 PCのみ */
@media screen and (min-width: 768px) {
  .js-ex-modal-img img {
    cursor: pointer;
    width: auto;
  }
}





