@charset "utf-8";
/* usecase CSS Document */

/* 共通 
-------------------------------------------------------*/
body {
    font-feature-settings: "palt" 1;
    letter-spacing: .3px;
}
.pc {
    display: block;
}
.sp {
    display: none;
}
.l-inner {
    max-width: 1200px;
    margin: 0 auto 0;
}
@media screen and (max-width: 2024px) {
    .l-inner {
        padding: 0 5%;
    }
}
@media screen and (max-width: 767px) {
    .l-inner {
        padding: 0 5%;
    }
}
.l-inner__right {
    display: flex;
    flex-direction: row-reverse;
}
.w-600{
    width: 600px;
}
@media screen and (max-width: 1200px) {
    .w-600 {
        width: 100%;
    }
    .client-interviewer__text {
        margin-top: 1rem;
    }
}
.section-separator{
    height: 10rem;
    background: url("../images/case/bg_key-points.svg")  center / cover;
}

/*--- パディング 上下 --*/
.py-10 {
    padding: 100px 0 !important;
}
.py-5 {
    padding: 50px 0 !important;
}
/*--- パディング 上 --*/
.pt-6{
    padding-top: 6rem;
}
.pt-3{
    padding-top: 3rem;
}

/*--- パディング 下 --*/
.pb-10 {
    padding-bottom: 100px !important;
}
.pb-5 {
    padding-bottom: 50px !important;
}

.w-mt-1 {
    margin-top: 1rem;
}



@media screen and (max-width: 1200px) {
    .case-container {
        padding: 0 3%;
    }
}
@media screen and (max-width: 767px) {
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
}

.img_left img {
    border-top-right-radius: 50px;
    border-bottom-right-radius: 50px;
}
.img_right img {
    border-top-left-radius: 50px;
    border-bottom-left-radius: 50px;
}

/* 2. ヒーローセクション 
-------------------------------------------------------*/
.hero-section {
    overflow: hidden;
    background-color: #E1F1F9;
}
.hero-section__decoration {
    background: #fff;
    border-top-left-radius: 50%;
    border-top-right-radius: 50%;
    /*  height: 200px;*/
    margin-left: -200px;
    margin-right: -200px;
    padding-left: 200px;
    padding-right: 200px;
    padding-bottom: 1rem;
} 

.hero-img {
    border-radius: 50px;
    margin: 2rem auto;
    border-radius: 20px;
}

.page-title {
    /* 最小1.8rem | SP:2rem | TB:2.5rem | PC:3rem | 最大3.2rem */
    font-size: clamp(1.8rem, calc(1.25vw + 1.5rem), 3.2rem);
    color: #003090;
    display: flex;
    text-align: left;
    margin: 1rem auto;
}
@media screen and (max-width: 1200px) {
    .page-title {
        padding: 0;
    }
}
.page-title__hd {
    margin: 0 2rem 0 0;
    white-space: nowrap;
}
.page-title .sase-studies {
    font-size: 1.2rem;
    color: #707070;
}
.page-title .client-name {
    font-size: 1.5rem;
    font-weight: bold;
    color: #000;
    
}
.page-title .page-title__text {
    border-left: 4px solid #003090;
    padding: 0 0 0 2rem;
    font-weight: bold;
}

.case-container {
    max-width: 1200px;
}

.h-260 {
/*    height: 260px;
    overflow: hidden;*/
    border-bottom: 3px solid #003090;
    padding-bottom: 1rem;
}
.client-interviewer {
    margin: 0 auto;
    padding: 0 0 0 200px;
    max-width: 1200px;
    position: relative;
}

.case-container__two-star {
    position: absolute;
    bottom: 0;
    left: 30px;
}
.client-interviewer__block{
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
}

.client-interviewer__img {
    margin-right: 30px;
    width: 180px;
    border-radius: 150px;
}

.client-interviewer__text {
    font-size: 1.25rem;
    line-height: 2;
    text-align: justify;

}
.client-interviewer__info {
/*    padding: 1rem 2rem;*/
    margin-right: 30px;
    white-space: nowrap;
}
.client-interviewer__company-name {
    
}
.client-interviewer__contact-person {
    margin-top: 1rem;
    font-weight: bold;
    font-size: 1.5rem;
}

@media screen and (max-width: 767px) {

    .page-title {
        display: block;
    }
    .page-title__hd {
        margin: 0 0 1rem;
    }
    .page-title .page-title__text {
        border-top: 4px solid #003090;
        border-left: none;
        padding: 0 1rem 0 0;
    }

    .client-interviewer__img {
        margin-right: 30px;
        width: 40%;
        border-radius: 150px;
        margin: 0;
    }
    .h-260 {
        height: auto;
        border-bottom: 5px solid #003090;
    }
    .client-interviewer {
        padding: 0;
    }
    .case-container__two-star {
        top: -50px;
        left: 0;
        width: 20%;
    }
    .client-interviewer__block{
/*        display: block;*/
        flex-wrap: wrap;
    }
    .client-interviewer__text {
        font-size: 1.2rem;
        padding: 1rem 0;
    }
    .client-interviewer__info {
        padding: 0;
    }
}



/* 3. Wisora活用のポイント
-------------------------------------------------------*/
.key-points {
    background: url("../images/case/bg_key-points.svg") center / cover;
    position: relative;
    min-height: 800px;
}
.key-points::before {
    position: absolute;
    top: -1px;
    content: "";
    display: block;
    width: 100%;
    aspect-ratio: 1366 / 180;
    background-image: url('../images/case/claude.svg');
/*    background-position: top;*/
    background-size: contain;
    background-repeat: no-repeat;
}
.key-points::after {
    position: absolute;
    bottom: -1px;
    content: "";
    display: block;
    width: 100%;
    aspect-ratio: 1366 / 180;
    background-image: url('../images/case/claude.svg');
/*    background-position: bottom;*/
    background-size: contain;
    background-repeat: no-repeat;
    transform: scaleY(-1);
}

.key-points__block {
    display: grid;
    gap: 20px;
    grid-template-columns: 1fr 1fr;
    /*    grid-template-columns: repeat(
        auto-fill,
        minmax(49%, 1fr)
    );
    column-gap: 10px;
    row-gap: 10px;
*/
    padding: 30% 0;
}
@media screen and (max-width: 767px) {
    .key-points__block {
        display: block;
        padding: 8rem 0;
    }
}
.key-points-title {
    padding: 0 0 1rem 0;
    color: #fff;
    font-weight: bold;
/*    font-size: 3rem;*/

    /* 最小1.8rem | SP:2rem | TB:2.5rem | PC:3rem | 最大3rem */
    font-size: clamp(1.8rem, calc(1.25vw + 1.5rem), 2.6rem);

}
.key-points-title span {
    border-bottom: 6px solid #fff;
}
.speechBubble-01 {
    order: 2; /*2番目*/
}
.speechBubble-02 {
    order: 1; /*1番目*/
}
.speechBubble-03 {
    text-align: right;
    margin-top: 2rem;
    order: 3; /*3番目*/
}

.speechBubble-01 .star-circle,
.speechBubble-02 .star-circle,
.speechBubble-03 .star-circle {
    position: absolute;
    top: -30px;
    left: -30px;
}


.speechBubble-01__text {
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  padding: 20px 20px 20px 40px;
  border: 3px solid #cccccc;
  border-radius: 20px;
  background-color: #ffffff;
  text-align: left;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}

.speechBubble-01__text::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 20px 0 0 20px;
  border-color: #cccccc transparent transparent;
  translate: -50% 100%;
}

.speechBubble-01__text::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 12.8px 0 0 12.8px;
  border-color: #ffffff transparent transparent;
  translate: calc(-50% + 0.6px) 100%;
}


.speechBubble-02__text {
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  padding: 20px 20px 20px 40px;
  border: 3px solid #cccccc;
  border-radius: 20px;
  background-color: #ffffff;
  text-align: left;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}

.speechBubble-02__text::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 20px 10px 0 10px;
  border-color: #cccccc transparent transparent;
  translate: -50% 100%;
}

.speechBubble-02__text::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 13.3px 6.6px 0 6.6px;
  border-color: #ffffff transparent transparent;
  translate: -50% 100%;
}


.speechBubble-03__text {
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  padding: 20px 20px 20px 40px;
  border: 3px solid #cccccc;
  border-radius: 20px;
  background-color: #ffffff;
  text-align: left;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}

.speechBubble-03__text::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 20px 20px 0 0;
  border-color: #cccccc transparent transparent;
  translate: -50% 100%;
}

.speechBubble-03__text::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 12.8px 12.8px 0 0;
  border-color: #ffffff transparent transparent;
  translate: calc(-50% - 0.6px) 100%;
}

@media screen and (max-width: 767px) {
    .key-points-title{
        margin-bottom: 2rem
    }
    .speechBubble-01,
    .speechBubble-02,
    .speechBubble-03 {
        padding: 3vh 0 0 6%;
    }
    .speechBubble-01 .star-circle,
    .speechBubble-02 .star-circle,
    .speechBubble-03 .star-circle {
        width:60px;
    }
    .speechBubble-01 {
        order: 1; /*1番目*/
    }
    .speechBubble-02 {
        order: 2; /*2番目*/
    }
    .speechBubble-01__text,
    .speechBubble-02__text,
    .speechBubble-03__text{
        font-size: 1rem;
        padding: 1rem 1rem 1rem 2rem;
    }
    .speechBubble-03{
        margin-top: 0;
    }
}


/*  5. 導入の背景　今後の展開
-------------------------------------------------------*/
.case-background {
    padding: 5rem 0;
}
.uc-contents {
    display: flex;
}
.uc-contents__title {
    writing-mode: vertical-rl;
    font-size: 6rem;
    font-weight: bold;
    margin: 0 40px 0 0;
    width: 164px;

}
.uc-contents__title span{
    display: block;
    font-size: 1.5rem;
}
.uc-contents__block {
    position: relative;
    padding-left: 40px;
    border-left: 10px solid #003090;
}
.uc-contents__blocktitle {
    margin: 0 0 5rem;
/*    font-size: 3rem;*/
    font-weight: bold;
    color: #003090;

    /* 最小1.8rem | SP:2rem | TB:2.5rem | PC:3rem | 最大3.2rem */
    font-size: clamp(1.8rem, calc(1.25vw + 1.5rem), 3.2rem);
}
.uc-contents__blocktext {
    line-height: 2;
    margin-top: 2rem;
    text-align: justify;
}
.uc-contents__blocktext a {
    text-decoration: underline;
    color: #003090;
}
.end-star {
    position: absolute;
    bottom: 0;
    left: -20px;
}





/*  6. 導入の結果
-------------------------------------------------------*/
/* 6. 導入結果（反転）　*/
.-reverse {
    flex-direction: row-reverse;
}
.-reverse .uc-contents__title {
    margin: 0 0 0 40px;
}
.-reverse .uc-contents__block {
    padding-right: 40px;
    padding-left: 0;
    border-right: 10px solid #003090;
    border-left:none;
}

.result {
    overflow: hidden;
    position: relative;
    
}
.result::after {
    content: url("../images/android-chrome-192x192.png");
    position: absolute;
    top: 20px;
    left: 5%;
    opacity: .1;
}
.result__2nd {
    display: flex;
    flex-direction: row-reverse;
    margin: 0 -10% 0 10%;
}
.result__2nd__img{
    margin: 0 0 0 40px;
    min-width: 50%;
}
.result__2nd__img img {
    max-height: 80vh;
}

@media screen and (max-width: 767px) {

    .uc-contents {
        flex-direction: column;
    }
    .uc-contents__title {
        border-left: 10px solid #003090;
        padding-left: 20px;
        padding-bottom: 10vh;
        line-height: 1.5
    }
    .uc-contents__title span {
        line-height: 1;
    }
    .uc-contents__block {
        padding-left: 20px;
    }

/* 反転*/
    .-reverse {
        flex-direction: column;
    }
    .-reverse .uc-contents__title {
        width: auto;
        border-left: none;
        border-right: 10px solid #003090;
        padding-right: 20px;
    }
    .-reverse .uc-contents__block {
        padding-right: 20px;
    }
    .result__2nd {
        display: block;
        margin: 0;
        padding: 0 5%;
    }
    .result__2nd .w-600 {
        border-right: 10px solid #003090;
        padding: 1rem 20px 1rem 0;
        
    }
    .result__2nd__img{
        margin: 0 -50px 0 0;
    }

}




/*  8. クライアントプロフィール
-------------------------------------------------------*/
.client-profile__block {
    position: relative;
    padding: 0 0 0 10%;
    min-height: 800px;
    color: #707070;
}
.client-profile__img {
    position: absolute;
    right: 0;
    width: 70%;
    z-index: 41;
}
.client-profile__img img {
    border-radius: 50px;
}
.client-profile__box {
    position: absolute;
    top: 15%;
    right: 80px;
    width: 80%;
    background-color: #eee;
    border-radius: 50px;
    padding: 33% 2rem 3rem 17%;
    z-index: 40;
    display: flex;
    line-height: 2;
    font-weight: bold;
}
.client-profile__box::after {
    content: url("../images/case/star_02.svg") ;
    position: absolute;
    bottom: 20px;
    right: -55px;
}
.client-profile__box a {
    text-decoration: underline;
}
.client-profile__box a:hover {
    color: #003090;
}
.client-profile__box .client-name {
    font-size: 2rem;
    font-weight: bold;
    margin-right: 10%;
    color: #000;
}
.client-profile__box .client-name span {
    display: block;
    font-size: 1.5rem;
    font-weight: normal;
    color: #707070;
}

.client-profile__box h3 {

}

@media screen and (max-width: 767px) {

    .client-profile__img {
        width: 85%;
    }
    .client-profile__box {
        right: 5%;
        width: 90%;
        display: block;
        padding: 30% 2rem 3rem;
    }
    .client-name {
        line-height: 1.5;
        margin-bottom: 2rem;
    }
    .client-profile__box::after{
        bottom: -80px;
        right: 0;
        
    }
}




