@charset "UTF-8";
/* .c-
 * ============================================================================== */
/*====== .c-box-1024(960px以下の指定がcommonにないため追加) =====*/
@media screen and (min-width: 601px) {
  .c-box-1024 {
    width: 96%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 0;
    padding-left: 0;
  }
}
@media screen and (max-width: 600px) {
  .c-box-1024 {
    width: 90%;
    margin-right: auto;
    margin-left: auto;
  }
}
/*====== デフォルト打消し =====*/
main table a:not(.c-btn01):not(.c-btn01-takufile):not(.c-btn02):not(.c-link02):not(.c-link01) {
  color: inherit;
  text-decoration: inherit;
}

main ul:not(.c-anchor01):not(.c-anchor02):not(.c-pager):not(.p-product-list):not(.c-btns-col):not(.c-pagelink):not(.c-btns-row) li a:not(.c-btn01):not(.c-btn01-takufile):not(.c-btn02):not(.c-link01):not(.c-link02):not(.p-pagelink-next):not(.p-pagelink-prev):not(.c-index-item):not(.c-btn-contact):not(.c-btn-acc) {
  color: inherit;
  text-decoration: inherit;
}

/*====== 引継ぎCSS =====*/
main ul,
main ol {
  margin: 1em 0;
}

main h1,
main h2,
main h3,
main h4,
main h5,
main h6 {
  line-height: inherit;
}

main h2 {
  margin: 0.83em 0;
}

main h3 {
  font-size: 1.17em;
  margin: 1em 0;
}

.l-main * {
  box-sizing: content-box;
}

@media screen and (min-width: 960px) {
  .u-pc-non {
    display: none;
  }
}
/*====== .u-marker =====*/
.u-marker {
  background: linear-gradient(transparent 50%, #F8FF97 50%);
}

/*====== .u-font-weight =====*/
.u-fw-bold {
  font-weight: bold;
}

/*====== .p-mv =====*/
.p-mv {
  background: #DEF6FF;
  display: flex;
  flex-direction: column;
  align-items: center;
  align-self: stretch;
  margin-bottom: 80px;
  position: relative;
}
.p-mv::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  background-color: #94D7F2;
  transform: translateX(512px);
  width: calc(50vw - 512px);
  height: 100%;
}

.p-mv-bg {
  max-width: 1024px;
  margin: 0 auto;
  padding: 30px 0;
  background: url(/product/dxsi/images/mv-dxsi.png) no-repeat right -60px center;
  background-size: auto 100%;
}

.p-mv-inner {
  display: flex;
  align-items: flex-start;
  gap: 40px;
  align-self: stretch;
}

.p-mv-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  align-self: stretch;
  position: relative;
  z-index: 2;
}

.p-mv-img {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  position: relative;
  z-index: 1;
}

.p-mv-ttl {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  font-weight: bold;
}

.p-mv-ttl .p-mv-ttl-lead {
  color: #0066B5;
  font-size: 2rem;
  line-height: 1.5;
  margin-bottom: 16px;
}

.p-mv-ttl .p-mv-ttl-main {
  font-size: 4rem;
  line-height: 1.25;
}

.p-mv-text {
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 400;
  line-height: 1.66;
}

.p-mv-links {
  display: flex;
  height: 70px;
  justify-content: center;
  align-items: center;
  gap: 96px;
  flex-shrink: 0;
  align-self: stretch;
}

@media screen and (min-width: 601px) {
  .p-mv-img {
    width: 55.078125%;
  }
  .p-mv-content {
    width: 41.015625%;
  }
  .p-mv-ttl .p-mv-ttl-lead {
    width: 600px;
  }
}
@media screen and (max-width: 600px) {
  .p-mv {
    padding: 30px 0;
  }
  .p-mv-bg {
    background: none;
    padding: 0px 20px;
    width: 90%;
    margin-right: auto;
    margin-left: auto;
  }
  .p-mv-inner {
    flex-direction: column;
    gap: 20px;
  }
  .p-mv-content {
    width: auto;
    padding-left: 0;
  }
  .p-mv-img {
    display: flex;
  }
  .p-mv-ttl .p-mv-ttl-main {
    font-size: 3rem;
  }
  .p-mv-text {
    margin-top: 8px;
    margin-bottom: 0;
  }
  .p-mv-links {
    flex-direction: column;
    height: auto;
    gap: 20px;
    margin-top: 20px;
  }
  .p-mv-links a {
    width: 100%;
  }
}
/*====== .c-bt =====*/
.c-btn-rounded-indigo {
  background: #4A43CB;
  border: 1px solid #4A43CB;
  color: #fff;
  border-radius: calc(infinity * 1px);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 380px;
  height: 70px;
  font-size: 2rem;
  transition: opacity 0.5s;
}

.c-btn-rounded-indigo:hover {
  background: #fff;
  color: #4A43CB;
  opacity: 1;
}

.c-btn-rounded-indigo img {
  margin-left: 1em;
  filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.c-btn-rounded-indigo:hover img {
  filter: invert(22%) sepia(64%) saturate(4340%) hue-rotate(241deg) brightness(84%) contrast(86%);
}

.c-btn-rounded-coral {
  background: #FA5462;
  border: 1px solid #FA5462;
  color: #fff;
  border-radius: calc(infinity * 1px);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 380px;
  height: 70px;
  font-size: 2rem;
  transition: opacity 0.5s;
}

.c-btn-rounded-coral:hover {
  background: #fff;
  color: #FA5462;
  opacity: 1;
}

.c-btn-rounded-coral img {
  margin-left: 1em;
  filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.c-btn-rounded-coral:hover img {
  filter: invert(43%) sepia(24%) saturate(3316%) hue-rotate(322deg) brightness(104%) contrast(96%);
}

.c-btn-rounded-blue {
  background: #0066B5;
  border: 1px solid #0066B5;
  color: #fff;
  border-radius: calc(infinity * 1px);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 380px;
  height: 70px;
  font-size: 2rem;
  transition: opacity 0.5s;
}

.c-btn-rounded-blue:hover {
  background: #fff;
  color: #0066B5;
  opacity: 1;
}

.c-btn-rounded-blue img {
  margin-left: 1em;
  filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.c-btn-rounded-blue:hover img {
  filter: invert(26%) sepia(58%) saturate(2924%) hue-rotate(189deg) brightness(90%) contrast(101%);
}

.c-btn-rounded-white {
  background: #fff;
  color: #4A43CB;
  border-radius: calc(infinity * 1px);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 380px;
  height: 70px;
  font-size: 2rem;
  transition: opacity 0.5s;
}

.c-btn-rounded-white:hover {
  opacity: 0.7;
  color: #4A43CB;
}

.c-btn-rounded-white img {
  margin-left: 1em;
}

[class^=c-btn-rounded-white-border-blue] {
  background: #fff;
  color: #0066B5;
  border: 1px solid #0066B5;
  border-radius: calc(infinity * 1px);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 380px;
  height: 70px;
  font-size: 2rem;
  transition: opacity 0.5s;
}

[class^=c-btn-rounded-white-border-blue]:hover {
  background: #0066B5;
  color: #fff;
}

[class^=c-btn-rounded-white-border-blue] span {
  background-image: url("/product/dxsi/images/icon-arrow-blue_re.svg");
  background-position: right center;
  padding-right: calc(1em + 16px);
}

[class^=c-btn-rounded-white-border-blue]:hover span {
  background-image: url("/product/dxsi/images/icon-arrow-white_re.svg");
}

.c-btn-rounded-white-border-blue-long {
  width: 504px;
}

@media screen and (max-width: 600px) {
  [class^=c-btn-rounded] {
    font-size: 1.8rem;
  }
}
/*====== .c-ttl =====*/
.c-ttl-underline-center {
  text-align: center;
  font-size: 3rem;
  line-height: 1.5;
  position: relative;
  background: none;
  padding: 0 0 40px;
  margin-top: 0;
  margin-bottom: 50px;
}

.c-ttl-underline-center::after {
  content: "";
  display: block;
  width: 100px;
  height: 5px;
  background: #0066B5;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.c-ttl-consulting-sub {
  color: #0066B5;
  font-size: 2.8rem;
  text-align: center;
  line-height: 1.5;
}
.c-ttl-consulting-sub.text-left {
  text-align: left;
}

@media screen and (min-width: 960px) {
  .c-ttl-underline-center {
    letter-spacing: 3.2px;
  }
}
@media screen and (min-width: 601px) and (max-width: 959px) {
  .c-ttl-consulting-sub {
    font-size: 2rem;
  }
}
@media screen and (max-width: 600px) {
  .c-ttl-underline-center {
    font-size: 2.2rem;
  }
  .c-ttl-consulting-sub {
    font-size: 2rem;
  }
}
/*====== .p-trouble =====*/
.p-trouble-list {
  font-size: 2rem;
  line-height: 1.5;
  display: table;
  margin-right: auto;
  margin-left: auto;
  padding-left: 0;
}

.p-trouble-item {
  padding-left: 42px;
  position: relative;
  margin-bottom: 14px;
}

.p-trouble-item::before {
  content: "";
  width: 27px;
  height: 22px;
  background: url("/product/dxsi/images/icon-check-blue_re.png") no-repeat;
  background-size: cover;
  position: absolute;
  top: 2px;
  left: 0;
}

.p-solve-summary {
  line-height: 1.5;
  font-size: 1.6rem;
  margin-top: 30px;
}

.p-solve-summary th,
.p-solve-summary td {
  border: 1px solid #EBF3F9;
}

.p-solve-summary th {
  width: 33%;
  padding: 20px 12px;
  background: #0066B5;
  color: #fff;
}

.p-solve-summary dl {
  border: 1px solid #EBF3F9;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: #EBF3F9;
}

.p-solve-summary-content {
  display: grid;
  grid-template-rows: auto 1fr;
}

.p-solve-summary dt {
  background: #0066B5;
  color: #fff;
  font-size: 1.6rem;
  text-align: center;
  padding: 10px;
  font-weight: bold;
}

.p-solve-summary dd {
  padding: 12px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #fff;
}

.p-solve-summary .c-btn-rounded-blue {
  width: calc(100% - 18px);
  margin-right: 9px;
  margin-left: 9px;
  font-size: 1.6rem;
}

.p-solve-summary .c-btn-rounded-blue span {
  margin-right: 5px;
}

@media screen and (min-width: 601px) and (max-width: 959px) {
  .p-solve-summary dt {
    font-size: 1.5rem;
    letter-spacing: -1px;
  }
  .p-solve-summary .c-btn-rounded-blue {
    width: 100%;
    margin-right: 0;
    margin-left: 0;
    font-size: 1.4rem;
    text-align: center;
  }
}
@media screen and (min-width: 601px) {
  .p-solve-summary .p-solve-summary-layout {
    border-top: none;
  }
  .p-solve-summary dt {
    padding: 20px 12px;
  }
  .p-solve-summary-layout dt {
    height: 0;
    border: none;
    padding: 0;
  }
}
@media screen and (max-width: 600px) {
  .p-solve-summary dl {
    margin-bottom: 40px;
    display: block;
  }
  .p-solve-summary dt {
    background: #EBF3F9;
    border-top: 3px solid #0066B5;
    color: #0066B5;
  }
  .p-trouble-list {
    font-size: 1.8rem;
    padding-left: 0;
  }
  .p-trouble-item::before {
    width: 21px;
    height: 17px;
    top: 4px;
  }
}
/*====== .p-faq =====*/
.p-faq-item {
  margin-bottom: 20px;
}

.p-faq-question {
  border: 1px solid #0066B5;
  background: #FFF;
  display: flex;
  padding: 10px 80px 10px 20px;
  align-items: center;
  gap: 20px;
  font-size: 1.8rem;
  line-height: 1.5;
  font-weight: bold;
  position: relative;
}

.p-faq-question::before,
.p-faq-question::after {
  content: "";
  display: block;
  width: 22px;
  height: 2px;
  background: #1F79BE;
  position: absolute;
  right: 30px;
}

.p-faq-question::after {
  transform: rotate(90deg);
  transition: transform 0.3s ease;
}

.p-faq-question.js-accordion-on:after {
  transform: rotate(180deg);
}

.p-faq-q {
  color: #0066B5;
  font-size: 3.4rem;
  font-weight: bold;
}

.p-faq-answer {
  display: flex;
  padding: 25px 20px;
  align-items: center;
  gap: 20px;
  font-size: 1.6rem;
  line-height: 1.5;
  border-right: 1px solid #0066B5;
  border-bottom: 1px solid #0066B5;
  border-left: 1px solid #0066B5;
  background: #EBF3F9;
}

.p-faq-answer li {
  margin-left: 1em;
  list-style-type: disc;
  margin-bottom: 0.4em;
}

.p-faq-a {
  color: #0066B5;
  font-size: 3.4rem;
  font-weight: bold;
}

/*====== .p-solution =====*/
[class^=p-solution-sec] {
  border-bottom: 3px solid #0066B5;
  padding-bottom: 50px;
  margin-bottom: 50px;
  font-size: 1.6rem;
  line-height: 1.5;
}

.p-solution-ttl {
  background: none;
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.p-solution-ttl .p-solution-ttl-en {
  font-size: 2rem;
  margin-bottom: 10px;
  font-weight: normal;
}

.p-solution-sec01 .p-solution-ttl-en {
  color: #7D005B;
}

.p-solution-sec02 .p-solution-ttl-en {
  color: #7D3400;
}

.p-solution-sec03 .p-solution-ttl-en {
  color: #767D00;
}

.p-solution-sec04 .p-solution-ttl-en {
  color: #007D1C;
}

.p-solution-ttl .p-solution-ttl-jp {
  font-size: 3rem;
  margin-bottom: 40px;
}

.p-solution-ttl::after {
  content: "";
  width: 100px;
  height: 5px;
}

.p-solution-sec01 .p-solution-ttl::after {
  background: #7D005B;
}

.p-solution-sec02 .p-solution-ttl::after {
  background: #7D3400;
}

.p-solution-sec03 .p-solution-ttl::after {
  background: #767D00;
}

.p-solution-sec04 .p-solution-ttl::after {
  background: #007D1C;
}

.p-solution-img {
  text-align: center;
  max-width: 400px;
  margin: 0 auto;
}

.p-solution-summary {
  text-align: center;
  font-size: 18px;
  margin-top: 30px;
  margin-bottom: 10px;
}

.p-solution-list {
  display: table;
  margin-right: auto;
  margin-left: auto;
  padding-left: 0;
}

.p-solution-list-item {
  padding-left: 35px;
  font-size: 1.8rem;
  align-items: center;
  margin-bottom: 10px;
  position: relative;
}

.p-solution-list-item::before {
  content: "";
  width: 20px;
  height: 17px;
  background: url("/product/dxsi/images/icon-check-red_re.png") no-repeat;
  position: absolute;
  top: 3px;
  left: 0;
}

.p-solution-btn-area01 {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 80px;
  margin-top: 50px;
  margin-bottom: 50px;
}

.p-solution-sec04 .p-solution-btn-area01 {
  margin-bottom: 0;
}

.p-solution-btn-area02 {
  display: flex;
  flex-direction: column;
  gap: 30px;
  justify-content: center;
  align-items: center;
}

.p-solution-btn-area02 .c-btn-rounded-white-border-blue {
  width: 98%;
  max-width: 400px;
}

.p-solution-btn-area02 [class^=c-btn-rounded] img {
  margin-left: 12px;
}

.p-solution-btn-area01 .p-solution-btn-long {
  width: 564px;
}

.p-consulting-reason {
  margin-bottom: 80px;
}

.p-consulting-reason ul {
  display: table;
  margin: 0 auto 30px;
}

.p-consulting-reason ul li {
  font-size: 1.8rem;
  position: relative;
  margin-bottom: 0.2em;
  list-style-type: disc;
}

@media screen and (max-width: 959px) {
  .p-solution-btn-area01 {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }
  .p-solution-btn-area01 .c-btn-rounded-indigo {
    width: 98%;
    max-width: 400px;
    text-align: center;
  }
  .p-consulting-reason ul {
    padding: 0 30px;
  }
}
@media screen and (min-width: 601px) and (max-width: 959px) {
  .p-solution-tab-wrap {
    gap: 10px;
  }
  .p-solution-tab {
    padding-left: 0;
    padding-right: 0;
  }
  .p-solution-tab-en {
    font-size: 1.4rem;
  }
  .p-solution-tab-jp {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 600px) {
  [class^=p-solution-sec] {
    padding-bottom: 60px;
    margin-bottom: 60px;
  }
  .p-solution-tab-wrap {
    padding-right: 0;
    padding-left: 0;
    gap: 20px;
    grid-template-columns: repeat(2, 1fr);
  }
  .p-solution-tab {
    padding-left: 0;
    padding-right: 0;
  }
  .p-solution-tab-en {
    font-size: 1.6rem;
  }
  .p-solution-tab-jp {
    font-size: 2rem;
  }
  .p-solution-ttl {
    text-align: center;
  }
  .p-solution-ttl .p-solution-ttl-en {
    font-size: 1.6rem;
  }
  .p-solution-ttl .p-solution-ttl-jp {
    font-size: 2rem;
  }
  .p-solution-img {
    width: 84%;
    margin-right: auto;
    margin-left: auto;
  }
  .p-solution-summary {
    text-align: left;
  }
  .p-solution-btn-area02 .c-btn-rounded-white-border-blue-long {
    padding-right: 30px;
    padding-left: 30px;
    width: calc(98% - 60px);
  }
}
/*====== .p-case =====*/
.p-case-item {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 40px;
  align-self: stretch;
  font-size: 1.6rem;
  line-height: 1.5;
}

.p-case-lists {
  padding-left: 0;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 5px;
  margin-top: 0;
  margin-bottom: 0;
}

.p-case-list {
  background: #80A6D3;
  padding-top: 2px;
  padding-right: 10px;
  padding-left: 10px;
  color: #fff;
}

.p-case-ttl {
  font-size: 2rem;
  margin-top: 0;
  margin-bottom: 20px;
}

.p-case-link {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.p-case-link .c-btn-rounded-blue {
  padding-right: 50px;
  padding-left: 70px;
  justify-content: center;
  align-items: center;
  width: 210px;
  height: 60px;
  font-size: 1.6rem;
  -moz-column-gap: 10px;
       column-gap: 10px;
}

@media screen and (max-width: 600px) {
  .p-case-item {
    flex-direction: column;
  }
  .p-case-thumb {
    margin-right: auto;
    margin-left: auto;
  }
  .p-case-link {
    align-items: center;
  }
}
/*====== .p-consulting-detail =====*/
.p-consulting-detail {
  margin-bottom: 50px;
}

.p-consulting-detail-media {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 30px;
  align-self: stretch;
}

.p-consulting-detail-text {
  font-size: 1.6rem;
  line-height: 1.5;
}

.p-consulting-phase-wrap {
  display: flex;
  align-items: flex-start;
  align-items: stretch;
  gap: 30px;
}

.p-consulting-phase {
  background: #EBF3F9;
  border-radius: 8px;
  padding: 20px;
  gap: 15px;
  font-size: 1.6rem;
  line-height: 1.5;
  flex: 1 0 0;
}

.p-consulting-phase-ttl {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #0066B5;
  font-size: 2rem;
}

.p-consulting-phase-list {
  padding-left: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  align-self: stretch;
}

.p-consulting-phase-item {
  padding-left: 35px;
  position: relative;
}

.p-consulting-phase-item::before {
  content: "";
  width: 20px;
  height: 17px;
  background: url(/product/visualization/images/visualization-icon-check-red_re.png) no-repeat;
  background-size: cover;
  position: absolute;
  top: 4px;
  left: 0;
}

@media screen and (min-width: 601px) {
  .p-consulting-detail-text {
    width: 52.7%;
    max-width: 540px;
  }
}
@media screen and (max-width: 600px) {
  .p-consulting-detail-media {
    flex-direction: column;
  }
  .p-consulting-detail-img {
    width: 296px;
    margin-right: auto;
    margin-left: auto;
  }
  .p-consulting-phase-wrap {
    flex-direction: column;
  }
  .p-consulting-phase-list {
    margin-bottom: 0;
  }
}
/*====== .p-contact =====*/
.p-contact {
  background: #dbf0ff;
  text-align: center;
  padding-top: 80px;
  padding-bottom: 80px;
  margin-bottom: 80px;
}

.p-contact-ttl {
  background: none;
  text-align: center;
  font-size: 3.2rem;
  padding: 0;
  margin: 0;
}

.p-contact-lead {
  margin-top: 36px;
  margin-bottom: 36px;
  font-size: 1.6rem;
}

.p-contact-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: auto;
  margin-left: auto;
  gap: 9.3%;
}

@media screen and (max-width: 600px) {
  .p-contact {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .p-contact-ttl {
    font-size: 2rem;
    margin-top: 0;
    margin-bottom: 0;
  }
  .p-contact-lead {
    margin-top: 25px;
    margin-bottom: 25px;
  }
  .p-contact-buttons {
    flex-direction: column;
    gap: 30px;
  }
  .p-contact-buttons a {
    width: 98%;
  }
}
/*====== ..p-column =====*/
.p-column-item {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 40px;
  align-self: stretch;
  font-size: 1.6rem;
  line-height: 1.5;
}

.p-column-lists {
  padding-left: 0;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 5px;
  margin-top: 0;
  margin-bottom: 0;
}

.p-column-list {
  background: #80A6D3;
  padding-top: 2px;
  padding-right: 10px;
  padding-left: 10px;
  color: #fff;
}

.p-column-ttl {
  font-size: 2rem;
  margin-top: 0;
  margin-bottom: 20px;
}

.p-column-thumb {
  width: 100%;
}

.p-column-link {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.p-column-link .c-btn-rounded-blue {
  padding-right: 50px;
  padding-left: 70px;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 60px;
  font-size: 1.6rem;
  -moz-column-gap: 10px;
       column-gap: 10px;
}

@media screen and (max-width: 600px) {
  .p-column-item {
    flex-direction: column;
  }
  .p-column-thumb {
    margin-right: auto;
    margin-left: auto;
  }
  .p-column-link {
    align-items: center;
  }
}
/*====== .p-column 3-column=====*/
.p-column3 {
  background: #EBF3F9;
  padding-top: 80px;
  padding-bottom: 80px;
}

.p-column3-wrap {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 50px;
  grid-template-rows: auto auto 1fr;
}

.p-column3-block {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 20px;
  border-radius: 8px;
  font-size: 1.6rem;
  line-height: 1.5;
}

.p-column3-block:hover {
  opacity: 0.8;
  color: inherit;
}

.p-column3-block:hover .p-column-ttl {
  text-decoration: underline;
}

.p-column-img {
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-column3-img img {
  display: block;
  max-width: 100%;
  height: auto;
  border: 1px solid #BAC8D3;
  border-radius: 8px;
}

.p-column3-ttl {
  grid-row: 2;
  font-size: 2.3rem;
}

.p-column3-ttl-name {
  display: block;
  font-size: 1.6rem;
}

.p-column3-text {
  grid-row: 3;
}

.p-column3-text p {
  margin-top: 0;
  margin-bottom: 0;
}

@media screen and (min-width: 601px) and (max-width: 959px) {
  .p-column3-wrap {
    gap: 50px 10px;
  }
  .p-column3-block {
    padding-right: 10px;
    padding-left: 10px;
  }
  .p-column3-img {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  .p-column3-wrap {
    grid-template-columns: repeat(1, 1fr);
  }
  .p-column3-list {
    margin-bottom: 0;
  }
}
/*====== .p-related =====*/
.p-related {
  margin-bottom: 140px;
}

.p-related-card-wrap {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 38px;
  grid-template-rows: auto auto 1fr;
}

.p-related-card {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 20px;
  font-size: 1.6rem;
  line-height: 1.5;
}

.p-related-card:hover {
  color: inherit;
  opacity: 0.8;
}

.p-related-card:hover .p-related-card-ttl {
  text-decoration: underline;
}

.p-related-card:hover .p-related-card-ttl::before {
  text-decoration: none;
}

.p-related-card-img {
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-related-card-img img {
  display: block;
  min-width: 100%;
  min-height: 100%;
  border-radius: 8px;
}

.p-related-card-ttl {
  grid-row: 2;
  font-size: 2.4rem;
  margin-top: 0;
  margin-bottom: 0;
  position: relative;
  padding-left: 1.3em;
}

.p-related-card-ttl::before {
  content: "→";
  position: absolute;
  top: 0;
  left: 0;
}

.p-related-card-txt {
  grid-row: 3;
  margin-top: 0;
  margin-bottom: 0;
}

@media screen and (min-width: 601px) and (max-width: 959px) {
  .p-related-card-wrap {
    gap: 10px;
  }
  .p-related-card {
    padding-right: 10px;
    padding-left: 10px;
  }
  .p-related-card-img {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  .p-related {
    margin-bottom: 84px;
  }
  .p-related-card-wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 0;
  }
  .p-related-card {
    margin-bottom: 50px;
  }
}/*# sourceMappingURL=dxsi.css.map */