@charset "utf-8";


/*------------------------------------
font
--------------------------------------*/

.subtitle-size{
    font-size:2.8rem !important;
    margin: 0rem auto 1.5rem;
    /* padding: 1.5rem 0; */
    color:#0048EA;
}

.tv-sub-ttl{
    font-size: 1.5rem !important;
    /* padding: 1rem 0; */
    color:#333333;
}

.section-ttl{
    font-size:2.5rem !important;
    margin: 1rem auto 1rem;
    color:#0048EA;
    /* font-weight:bold; */
}

.section-sub-ttl{
    font-size:1.5rem !important;
    /* padding: 1rem 0; */
    color:#fff;
}


/*------------------------------------
header
--------------------------------------*/

/* 隠しテキスト用 */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    border: 0;
  }


/* .lp-header_top {
    background: url(../images/bg-top_v2.jpg) center left no-repeat #d4d9fe;
    background-size: cover;
    overflow: hidden;
    position: relative;
} */

/* .lp-header_top {
    background: url(../images/bg-top_B_v2.jpg) center center no-repeat #d4d9fe;
    background-size: cover;
    overflow: hidden;
    position: relative;
} */

.main-img {
    position: relative;
    z-index: 3;
}

@media (max-width: 767px) {
    /* スマホ対応（SP） */

    .lp-header_top {
        background: none !important;
    }

    }

@media(min-width: 992px) {


    /* .lp-header {
        background: url(../images/bg-top_B_v2.jpg) center left no-repeat #d4d9fe;
        background-size: cover;
        overflow: hidden;
        position: relative;
    } */

}

@media(min-width: 1200px) {

    /* .lp-header {
        background: url(../images/bg-top_B_v2.jpg) center left no-repeat #d4d9fe;
        background-size: cover;
        overflow: hidden;
        position: relative;
    } */

}

@media(min-width: 1400px) {

    /* .lp-header {
        background: url(../images/bg-top_B_v2.jpg) center left no-repeat #d4d9fe;
        background-size: cover;
        overflow: hidden;
        position: relative;
    } */

}

/* .tools-header{
    position: relative;
    margin: 0;
    color: #fff;
}

.bg-header{
    box-sizing: border-box;
    overflow: hidden;
} */

/* @media (min-width: 992px) {
    .bg-header {
        height: 280px;
    }
    }


@media (min-width: 1200px) {
    .tools-header {
        background: url(../fxdirectplus/tradetools/images/tradetool-title.png) no-repeat right 27% center, linear-gradient(90deg, rgba(3, 3, 3, 1) 0%, rgba(28, 34, 46, 1) 25%, rgba(57, 68, 86, 1) 45%, rgba(52, 62, 79, 1) 61%, rgba(28, 34, 46, 1) 83%, rgba(3, 3, 3, 1) 100%);
        background-size: 430px, 100%;
}
} */


/*------------------------------------
section1
--------------------------------------*/
.section01_BG{
    /* background: url(../images/section01_bg_v2.png) center left no-repeat ;
    background-size: contain;
    overflow: hidden;
    position: relative; */

}

/* @media (min-width:992px;){
    .section01_BG{
        margin-top: 80px;

    }
} */

.hero-section {
    /* background-image: url('../images/section01_bg.png'); */
    background-size: cover;
    background-position: center;
    height: 729px;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .content-wrapper {
    max-width: 1110px;
    width: 100%;
    position: relative;
    text-align: center;
  }

  h2 {
    font-size: 2.5rem;
    margin-bottom: 20px;
  }

  /* .woman-img {
    position: absolute;
    top: -8%;
    right: 0%;
    max-width: 350px;
    width: 100%;
    height: auto;
  } */

  .media-container {
    position: relative;
    display: inline-block;
  }

  .gif-img {
    max-width: 100%;
    width: 930px;
    height: auto;
    z-index: 2;
  }

  .overlay-img {
    position: absolute;
    bottom: 0;
    /* left: -60px; */
    width: 55%;
    height: auto;
    z-index: 3;
    right: -3%;
    top: 60%;
  }

@media (max-width: 767px) {
    /* スマホ対応（SP） */

    .section01_hight{
        max-height:700px;
    }

    .overflow_item{
        overflow: hidden;
    }

    /* フォント */

    .subtitle-size{
        font-size:3rem !important;
        margin: 0rem auto 0rem;
    }

    .custom-btn{
        font-size:1.5rem !important;
    }

    .content-wrapper {
        padding: 0rem 0.5rem 7rem;
    }

    .woman-img {
        position: absolute;
        /* display: block; */
        top: -2%;
        right: -10%;
        margin: 0 auto 16px;
        /* width: 230px; */
        height: auto;
        max-width:200px;
        height: auto;
    }

    .media-container{
        top: 9px;
        /* top: 70px; */
    }

    .gif-img {
      width: 100%;
    }

    .overlay-img {
        position: absolute;
        /* display: block; */
        margin: 0px auto 0;
        width: 75%;
        /* bottom: 0; */
        right: 4%;
        top: 65%;
    }


    h2 {
      font-size: 1.5rem;
    }

}

  @media (min-width: 768px) and (max-width: 991px) {
    .woman-img {
        position: absolute;
        /* display: block; */
        top: -4%;
        right: -2%;
        margin: 0 auto 16px;
        width: 290px;
        height: auto;
    }

    .content-wrapper {
        padding: 0rem 0.5rem 10rem;
    }

    .overlay-img {
        position: absolute;
        /* display: block; */
        margin: 0px auto 0;
        width: 75%;
        /* bottom: 0; */
        right: 4%;
        top: 73%;
    }


    .media-container{
        top: 0px;
    }

  }

@media (min-width:992px){

    .subtitle-size{
        font-size:3.5rem !important;
        margin: 0rem auto 0rem;
    }

    .custom-btn{
        font-size:1.5rem !important;
    }

    .content-wrapper {
        padding: 2rem 2rem 8rem;
      /* min-height:440px; */
    }

    .woman-img {
        position: absolute;
        /* display: block; */
        top: -6%;
        right: -5%;
        margin: 0 auto 16px;
        width: 400px;
        height: auto;
    }

    .media-container{
        top: 40px;
    }

    .gif-img {
      width: 100%;
    }

    .overlay-img {
        position: absolute;
        /* display: block; */
        margin: 0px auto 0;
        width: 45%;
        /* bottom: 0; */
        right: -1%;
        top: 74%;
    }

    h2 {
      font-size: 1.5rem;
    }

}

@media (min-width: 1200px) {
    .subtitle-size{
        font-size:4rem !important;
        margin: 0rem auto 0rem;
    }

    .custom-btn{
        font-size:1.5rem !important;
    }

    .content-wrapper {
        padding: 2rem 2rem 8rem;
      /* min-height:440px; */
    }

    .woman-img {
        position: absolute;
        /* display: block; */
        /* top: 35%; */
        right: -3%;
        margin: 0 auto 16px;
        width: 450px;
        height: auto;
    }

    .media-container{
        top: 0px;
    }

    .gif-img {
      width: 100%;
    }

    .overlay-img {
        position: absolute;
        /* display: block; */
        margin: 0px auto 0;
        width: 55%;
        /* bottom: 0; */
        right: -1%;
        top: 70%;
    }

    h2 {
      font-size: 1.5rem;
    }
}

/*------------------------------------
section2
--------------------------------------*/

/* .section02_BG{
    background: url(../images/section02_bg.png) center left no-repeat #fff;
    background-size: cover;
    overflow: hidden;
    position: relative;
} */

.section02_BG{
    /* position: absolute;
    width: 100vw;
    height:20vw; */
    background: url(../images/section02_bg.png) center center no-repeat #fff;
    background-size: cover;
    overflow: hidden;
}

/*------------------------------------
section3
--------------------------------------*/

.bg-circle_section_03 > h4{
    font-size:2.8rem;
}

@media (max-width: 767px) {
    .bg-circle_section_03{
        font-size: 1.5rem;
        line-height: 1.2;
        width: 180px;
        height: 100px;
        /* padding: 1rem; */
        position: absolute;
        left: 10px;
        bottom: -8%;
    }

    .bg-circle_section_03 > h4{
        font-size:1.5rem;
    }
}

@media(min-width: 768px) {
    .bg-circle_section_03{
        font-size:1.5rem;
        line-height: 1.2;
        width:350px;
        height:180px;
        /* padding: 2rem; */
        position: absolute;
        left: 30px;
        bottom: -3%;
    }
}

/*------------------------------------
section4
--------------------------------------*/

.section04_BG{
    /* position: absolute;
    width: 100vw;
    height:20vw; */
    background: url(../images/section04_bg.png) center center no-repeat #fff;
    background-size: cover;
    /* overflow: hidden; */
}

@media (max-width: 767px) {
    .bg-circle_section_04{
        line-height: 1.2;
        width: 283px;
        height: 103px;
        padding: 1rem 1rem 1rem 1.5rem;
        position: absolute;
        left: 5px;
        bottom: 31%;
    }

    .bg-circle_section_04 > h4{
        font-size:2rem !important;
    }

    .talent_04{
        position: absolute;
        left: -10%;
        bottom: 0%;
        /* z-index: 3; */
        width: 42%;

    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .talent_04{
        position: absolute;
        left: -15%;
        bottom: 0%;
        /* z-index: 3; */
        width: 38%;

    }

    .bg-circle_section_04{
        line-height: 1.2;
        width: 319px;
        height: 148px;
        padding: 1rem 1rem 1rem 1.5rem;
        position: absolute;
        left: -70px;
        bottom: 20%;
    }
}

@media(min-width: 992px) {
    .bg-circle_section_04{
        line-height: 1.2;
        width: 319px;
        height: 148px;
        padding: 2rem;
        position: absolute;
        left: -59px;
        bottom: 19%;
    }


    .talent_04{
        position: absolute;
        left: -15%;
        bottom: 0%;
        /* z-index: 3; */
        width: 38%;
    }
}

@media(min-width: 768px) {

    .bg-circle_section_04 > h4{
        font-size:2.8rem !important;
    }

    .talent_04{
        position: absolute;
        left: -8%;
        bottom: 0%;
        z-index: 3;
        width: 38%;
    }

}


/* .bg-circle_section_04{
    font-size:1.5rem;
    line-height: 1.2;
    width:540px;
    padding: 2rem;
    position: absolute;
    left: 30px;
    bottom: 0px;
}


@media (max-width: 767px) {
    .bg-circle_section_04{
        width:300px !important;
        height: 50% !important;
        padding: 1.2rem;
        position: absolute;
        left: 30px;
        bottom: 0px;
    }

    .bg-circle_section_04 > h4{
        font-size:1rem !important;

    }
} */


/*------------------------------------
section5
--------------------------------------*/

@media (max-width: 767px) {
    .bg-circle_section_05{
        line-height: 1.2;
        width: 250px;
        height: 120px;
        padding: 1rem;
        position: absolute;
        left: 10px;
        bottom: 32%;
    }

    .bg-circle_section_05 > h4{
        font-size:2rem !important;
    }
}


@media (min-width: 768px) and (max-width: 991px) {
    .bg-circle_section_05{
        line-height: 1.2;
        width: 337px;
        height: 168px;
        /* padding: 2rem; */
        position: absolute;
        left: -59px;
        bottom: 20%;
}
.bg-circle_section_05 > h4{
    font-size:3rem !important;
}
}

@media(min-width: 992px) {
    .bg-circle_section_05{
        line-height: 1.2;
        width: 337px;
        height: 168px;
        /* padding: 2rem; */
        position: absolute;
        left: -59px;
        bottom: 13%;
    }

    .bg-circle_section_05 > h4{
        font-size:3rem !important;
    }
}


/*------------------------------------
section6
--------------------------------------*/

.section06_BG{
    /* position: absolute;
    width: 100vw;
    height:20vw; */
    background: #333;
    background-size: cover;
    /* overflow: hidden; */
    /* border-top:4px solid #FF756A; */
}

.column-box-orange{
    border: 1px solid #FF756A;
    border-radius: 5px;
}

.column-box-orange > p,h4{
color:#FF756A;
}

/*------------------------------------
section7
--------------------------------------*/

@media(max-width: 767px) {
.talent_07{
    position: absolute;
    right: -12%;
    bottom: 0;
    z-index: 3;
    width: 43%;

}

}

@media (min-width: 768px){
    .talent_07{
        position: absolute;
        right: 4.5%;
        bottom: 0%;
        width: 25%;
        /* z-index: 3; */
}
}
/*------------------------------------
共通デザイン
--------------------------------------*/

.marker {
background: linear-gradient(transparent 60%, rgba(253, 252, 103, 0.75) 40%);
}
.text-orange {
    color: #e34f28 !important;
}
.text-xxl, .text-xxl-3x, .text-xxl-3xl, .text-xxl-4x {
    font-size: 2.55rem;
}
.font-weight-bolder {
    font-weight: bolder !important;
}

@media(max-width: 767px) {
    .section_margin{
        position: relative;
        overflow: hidden;
        padding: 3rem 0;
    }

    .section_margin07{
        position: relative;
        overflow: hidden;
        padding: 5rem 0 0rem;
    }
}

@media (min-width: 768px){
    .section_margin{
        padding: 5rem 0 5rem;
    }

    .section_margin07{
        padding: 6rem 0 0rem;
    }

}

.connection_box{
    border: 2px solid #4390e0 !important;
    background-color: #f2f9ff;
}

.checkbox-list h4{
    position: relative;
    line-height: 1.2;
    font-size: 1.8rem !important;
    font-weight: bold !important;
    padding: 0.5em 0em 0.5em 2rem;
    right: -2rem;

}

.checkbox-list > h4::before {
    content: '';
    position: absolute;
    left: -2rem;
    top: 50%;
    transform: translateY(-50%);
    width: 30px;
    height: 30px;
    background-image: url(../images/check_btn_01.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.checkbox-list-orange > h4::before{
    background-image: url(../images/check_btn_02.png);
}

.column-box{
    border: 1px solid #ababab;
    border-radius: 5px;

}

.custom-btn{
    background-color: #666666;
    border-radius: 50px;
    border: none;
    padding: 8px 20px;
    font-size: 1.5rem;
    margin: 0 1.5rem;
    vertical-align: middle;
}

.bg-circle{
    background-color: #0048EA;
    border-radius: 8rem 8rem 0rem 8rem;
}

.bg-circle-title{
    background-color: #0048EA;
    border-radius: 5rem 0rem 5rem 0rem;
}

.bg-circle-title-gray{
    background-color: #A1A1A1;
    border-radius: 5rem 0rem 5rem 0rem;
}

.bg-circle-title-purple{
    background-color: #5644AC;
    border-radius: 5rem 0rem 5rem 0rem;
}

.bg-circle-title-purple-sub{
    background-color: #fff;
    border:1px solid #5644AC;
    border-radius: 5rem 0rem 5rem 0rem;
}

.bg-circle > p,h4{
    color:#fff;
}

@media(min-width: 992px) {
    /* .bg-circle > h4 > span {
        font-size: 4rem;
    } */
    /* テキスト位置の微調整 */
    /* .bg-circle > h4{
        position: relative;
        top: -10%;
    } */
}

.grd-blue{
    /* background-image: linear-gradient( 135deg, #42b7ee 10%, #130CB7 100%); */
    background-image: linear-gradient( 135deg, #0048EA 10%, #0036AF 100%);
    /* background-image: linear-gradient( 135deg, #6B73FF 10%, #1721dd 100%); */
}

.grd-purple{
    background-image: linear-gradient( 135deg, #ec56e5 10%, #3813C2 100%);
}

/* テスト */

/* 外枠コンテナ */
    .my-box {
    position: relative;
    margin: 0px auto;
    width: 100%;
    max-width: 1110px;
    border-radius: 15px;
    padding: 2px; /* 実質的な枠線の厚み */
    background: linear-gradient(
      270deg,
      #ff756a,
      #ff9966,
      #ffc27a,
      #ff9966,
      #ff756a
    );
    background-size: 300% 300%;
    animation: borderGlow 4s linear infinite;
    box-shadow: 0 0 20px rgba(255, 117, 106, 0.4);
  }

  /* 実際のコンテンツエリア（黒背景） */
  .my-box .inner {
    background-color: #000;
    color: #fff;
    padding: 30px;
    border-radius: 13px; /* 枠の内側にフィット */
    position: relative;
    z-index: 2;
  }

  /* アニメーション：背景グラデーションが流れる */
  @keyframes borderGlow {
    0% {
      background-position: 0% 50%;
    }
    100% {
      background-position: 300% 50%;
    }
  }

  /* レスポンシブ対応 */
  @media (max-width: 690px) {
    .my-box {
      max-width: 690px;
    }
  }
