/* ==========================================================================
   Author's custom styles
   ========================================================================== */

html {
    font-size: 62.5%;
}

body {
    font-size: 1.6rem;
    /* 16px*/
    line-height: 2;
}

a:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
    -moz-opacity: 0.8;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
}

#main-topic {
    margin-top: 200px!important;
}

#main-topic h2 {
    font-size: 2.6rem;
    margin-top: 20px;
    text-align: left;
    color: #212529;
}


/*altタグ内の改行 &#13;&#10; を有効にする*/

img {
    white-space: pre;
}


/* h1 {
  font-size: 36px;
  font-size: calc(2.4rem + ((1vw - 0.64rem) * 2.1429));
  line-height: 1.3;
} */

h2 {
    font-size: 24px;
    /* IE8以下とAndroid4.3以下用フォールバック */
    font-size: calc(2rem + ((1vw - 0.64rem) * 0.7143));
    /* 20px~24pxで可変*/
    line-height: 1.3;
    color: #1f4c97;
    font-weight: bold;
    text-align: center;
}


/* a:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -moz-opacity: 0.8;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
} */

@media (min-width: 1200px) {
    /* 1200px以上*/
    h1 {
        font-size: 2.6rem;
        /* 36px*/
    }
    h2 {
        font-size: 2.6rem;
        /* 24px*/
    }
    h3 {
        font-weight: bold;
        font-size: 2.2rem;
    }
}

@media screen and (max-width: 640px) {
    /* 640px以下*/
    body {
        line-height: 2;
    }
    h1 {
        font-size: 2.4rem;
        /* 24px*/
    }
    h2 {
        font-size: 2rem;
        /* 20px*/
    }
    h3 {
        font-weight: bold!important;
    }
}

body {
    padding-top: 0;
}

body {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", sans-serif;
}

li {
    list-style-type: none;
}


/* hr {
    border-color: #f00;
    border-width: 5px;
    width: 90%;
} */


/* 汎用クラス */

.b {
    font-weight: bold;
}

.bg_white {
    background: #fff;
}

.bg_blue {
    background: #def4ff;
    padding: 50px 0;
    margin-bottom: 30px;
    /* margin: 50px 0; */
}

.bg_darkblue {
    background: #5888bf;
    padding: 50px 0;
    margin-bottom: 30px;
    /* margin: 50px 0; */
}

.bg_grey {
    background: rgb(245, 245, 245);
    padding: 50px 0;
    margin: 30px 0;
}

.bg_lightgrey {
    background: #f7f8f8;
    padding: 50px 0;
    margin: 50px 0;
}

.orange {
    color: #f60;
}

.red {
    color: #f45434;
}

.blue {
    color: #1c9cc4;
}

.light-blue {
    color: #00abe1;
}

.light-purple {
    color: #5d99ff;
}

.btn_blue {
    background: #87b2c2;
    border: solid 1px #87b2c2;
    border-radius: 30px;
    color: #fff;
    display: inline-block;
    font-weight: bold;
    padding: 15px 50px;
}

.circle {
    background: #fff;
    border: solid 1px #ccc;
    border-radius: 10px;
}

.gray_circle {
    background: #ebf0f2;
    border: solid 1px #eee;
    border-radius: 10px;
}

.fs_large {
    font-size: 3.5rem;
    font-weight: bold;
}

.fs_xlarge {
    font-size: 5rem;
    font-weight: bold;
}

.mb50 {
    margin-bottom: 50px;
}

.mb100 {
    margin-bottom: 100px;
}

.pb50 {
    padding-bottom: 50px;
}

.analyze_show_pc {
    display: block;
}

.analyze_show_sp {
    display: none;
}

@media screen and (max-width: 640px) {
    /* 640px以下*/
    .analyze_show_pc {
        display: none;
    }
    .analyze_show_sp {
        display: block;
    }
}


/* 汎用クラス ここまで */


/* グローバルメニュー ここから */


/* ロゴ */

#logo {
    max-width: 40px;
}

@media (min-width: 992px) {
    /* 992px以上*/
    #logo {
        max-width: 220px;
    }
}

.navbar-light .navbar-nav .nav-link {
    color: #fff;
    padding: 1rem;
}

.navbar-light .navbar-toggler-icon {
    height: 30px;
    width: 30px;
}

.img-box {
    position: relative;
}


/* 電話問い合わせ */

#icon_tel {
    max-width: 290px;
}


/* フォーム問い合わせ */

#icon_form {
    max-width: 111px;
}


/* ボタンのホバー設定 */

.img-box .active {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    transition: 0.5s;
}

.img-box:hover .active {
    opacity: 1;
}

.navbar-inverse {
    background-color: rgba(28, 156, 196, 0.6) !important;
    padding: 0;
}

nav .container {
    padding-top: 10px;
    padding-bottom: 10px;
    width: 100%;
}

ul.navbar-nav li a {
    color: #fff;
    display: inline-block;
    padding: 10px;
}

ul.navbar-nav li:last-child a {
    margin-right: 0;
}

#nav-item a:hover {
    opacity: 1;
}


/* #navbarSupportedContent{
  background-color: rgba(28, 156, 196, 0.6);
} */


/* 問い合わせメニュー */

ul#contact {
    display: flex;
    max-width: 335px;
    padding-left: 0;
}

@media screen and (min-width: 768px) {
    ul#contact {
        display: flex;
        margin-bottom: 0;
        max-width: 100%;
    }
}


/* グローバルメニュー ここまで */


/* パンくずりすと */

.breadcrumb {
    position: absolute !important;
    width: auto !important;
    top: 16% !important;
    left: 30px;
    /* right: 15px !important; */
    margin: 0 !important;
    background-color: transparent !important;
    padding: 0 !important;
    font-size: 90%;
    transform: translateY(-50%);
}

.breadcrumb li {
    display: inline;
    list-style: none;
}

.breadcrumb li:after {
    content: '>';
    padding: 0 0.2em;
}

.breadcrumb li:last-child:after {
    content: '';
}

.breadcrumb li a {
    text-decoration: none;
}

.link_top:before {
    /*家アイコン*/
    font-family: "Font Awesome 5 Free";
    content: '\f015';
    font-weight: 900;
    text-decoration: none;
}

.breadcrumb li a:hover {
    text-decoration: none;
    opacity: .6;
}


/* パンくずりすと */


/* メインビジュアル ここから */

#doctortrust_for_stress_checks_sp {
    /* margin-bottom: 20px; */
    width: 90%;
    display: block;
    margin: 45px auto 0 auto;
}

#doctortrust_for_stress_checks {
    display: none;
    width: 100%;
}

@media screen and (min-width: 600px) {
    #doctortrust_for_stress_checks_sp {
        display: none;
        margin: 45px auto 0 auto;
    }
    #doctortrust_for_stress_checks {
        display: block;
    }
}


/* メインビジュアル ここまで */


/* 資料請求フォームへリンク ここから */

a.to_form_btn {
    background: #f45434;
    border: solid 1px #f45434;
    border-radius: 50px;
    color: #fff;
    display: block;
    font-size: 3rem;
    margin: 0px auto 50px auto;
    max-width: 500px;
    padding: 20px 0;
    text-align: center;
}

a.to_form_btn_blue {
    background: #87b2c2;
    border: solid 1px #87b2c2;
    border-radius: 50px;
    color: #fff;
    display: block;
    font-size: 2rem;
    margin: 0px auto 50px auto;
    max-width: 500px;
    padding: 20px 0;
    text-align: center;
    line-height: 1.3;
    font-weight: bold;
}

img.img_one_minute {
    display: block;
    margin: 0 auto 20px;
    width: 200px;
}

img#point_for_select {
    display: block;
    margin: 20px auto 0;
    width: 90%;
}


/* 資料請求フォームへリンク ここまで */

.analyze_service_top {
    position: relative;
}


/* .analyze_service_top p {
    position: absolute;
    bottom: 114px;
    left: 120px;
} */


/* ここから集団分析サービスページ */

.fa-square-full {
    color: #56a2e1;
    display: inline-block;
    margin-right: 10px;
    font-size: 0.8em;
}


/* トップ画像 */

.top-wrapper {
    display: flex;
    align-items: center;
}

.top_title {
    text-align: left;
    font-size: 3rem;
    letter-spacing: 4px;
    padding-bottom: 10px;
}

@media screen and (max-width: 768px) {
    .top-wrapper {
        flex-wrap: wrap;
    }
    .top-left {
        padding-top: 30px;
    }
}


/* ドクタートラストのストレスチェック実施サービス */

#service p {
    text-align: center;
}

@media screen and (max-width: 640px) {
    #service p {
        text-align: left;
    }
    .service_box_img img {
        width: 100%;
    }
    .service_box_img {
        padding-right: 0px;
        padding-left: 0px;
    }
}


/* 職場環境改善支援サービス */

a.to_law_btn {
    background: #175595;
    border: solid 2px #175595;
    border-radius: 3px;
    color: #fff;
    display: block;
    max-width: 208px;
    padding: 5px;
    margin-top: 20px;
    font-size: 1.5rem;
    text-align: center;
    transition: 0.3s ease-in-out;
    line-height: 1.4;
}


/* .to_law_btn a:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
    -moz-opacity: 0.8;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
} */

a.to_law_btn:hover {
    background: #fff;
    text-decoration: none;
    border: solid 2px #175595;
    color: #175595;
    font-weight: bold;
}


/* .service_txt {
    width: 100px!important;
} */

.service_txt img {
    width: 100%;
}

.service_box {
    padding: 0 60px;
}

.img100 img {
    width: 100%;
}


/* 職場環境改善支援サービス */

.analyze_service_contents {
    /* width: 80%; */
}

.analyze_service_txt_pl-6 {
    padding-left: 6rem;
}

@media screen and (max-width: 640px) {
    .analyze_service_txt_pl-6 {
        padding-left: 0;
    }
    .analyze_service_contents {
        width: 100%;
    }
}


/* サービス内容の紹介 */

.SC_service_item img {
    max-width: 100%;
}


/* 吹き出し */

.balloon1-left {
    position: relative;
    display: inline-block;
    margin: 10px 20px;
    padding: 50px;
    min-width: 120px;
    max-width: 100%;
    /* color: #555; */
    font-size: 16px;
    background: #fff;
    border-radius: 7px;
}

.balloon1-left:before {
    content: "";
    position: absolute;
    top: 85%;
    left: -30px;
    margin-top: -15px;
    border: 9px solid transparent;
    border-right: 31px solid #fff;
    -webkit-transform: rotate(35deg);
    transform: rotate(-24deg);
}

@media screen and (max-width: 640px) {
    .balloon1-left {
        margin: 10px 0px;
        padding: 30px;
    }
    .balloon1-left:before {
        content: "";
        position: absolute;
        top: -2%;
        left: 55px;
        margin-top: -15px;
        border: 9px solid transparent;
        border-right: 31px solid #fff;
        -webkit-transform: rotate(35deg);
        transform: rotate(118deg);
    }
}

.balloon1-left p {
    margin: 0;
    padding: 0;
}


/* 集団分析結果報告サービスを利用した企業さまの声 */

.sc_customer_voice {
    width: 95%;
    margin: 0px auto 80px auto;
}

.customer_service {
    padding: 30px 0;
    width: 34%;
    margin: 0 auto;
}

@media screen and (max-width: 640px) {
    /* 640px以下*/
    .sc_customer_voice {
        width: 100%;
    }
    .customer_service {
        width: 63%;
        justify-content: center;
    }
}

.customer_wrapper {
    width: 90%;
    margin: 0 auto;
}

.customer_service h3 {
    text-align: center;
    position: relative;
    display: inline-block;
    margin-bottom: 1em;
    padding-left: 30px;
    color: rgb(31, 31, 31);
}

.customer_service h3:before {
    content: '';
    position: absolute;
    bottom: -9px;
    display: inline-block;
    width: 103px;
    height: 3px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #268da7;
    border-radius: 2px;
}

.customer_service ul {
    padding-left: 134px;
}

@media screen and (max-width: 640px) {
    /* 640px以下*/
    .customer_service ul {
        padding-left: 0;
    }
}

.customer_service li {
    list-style-type: disc;
}


/* 担当者のコメント */

.dt_comment {
    width: 85%;
    margin: 10px auto;
    padding: 40px;
    border-radius: 7px;
}

.balloon1-left span {
    background: linear-gradient(transparent 60%, #ffff66 60%);
}


/* 集団分析結果報告サービスを利用した企業さまの声 */


/* アフターフォローサービス */

.afterfollow_service h2 {
    text-align: center;
    position: relative;
    display: inline-block;
    padding-left: 30px;
    color: rgb(31, 31, 31);
}

.afterfollow_service h2:before {
    content: '';
    position: absolute;
    bottom: -13px;
    display: inline-block;
    width: 103px;
    height: 5px;
    left: 53%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #e65335;
    border-radius: 2px;
}

.afterfollow_service h3 {
    position: relative;
    display: inline-block;
    padding: 20px 45px 20px 45px;
    text-align: center;
}

.afterfollow_service h3:before {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 30px;
    height: 2px;
    background-color: #e65335;
    -webkit-transform: rotate(60deg);
    transform: rotate(60deg);
}

.afterfollow_service h3:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 30px;
    height: 2px;
    background-color: #e65335;
    -webkit-transform: rotate(-60deg);
    transform: rotate(-60deg);
}

.afterfollow_service h3:before {
    left: 0;
}

.afterfollow_service h3:after {
    right: 0;
}

.afterfollow_service img {
    width: 100%;
}

.service_items {
    width: 60%;
}

@media screen and (max-width: 640px) {
    .service_items {
        width: 100%;
    }
    .sp-100 img {
        max-width: 300px;
        width: 100%;
        height: auto;
    }
}


/* ボタン */

.btn-primary {
    background-color: #00a7c4;
}

.btn-primary:hover {
    background-color: #0098b3;
}

.btn-primary:focus {
    background-color: #0098b3;
    color: white;
}

.btn-primary:active {
    background-color: #467370 !important;
}


/* 集団分析 */


/* トータルサポートサービス ここまで */


/* フッター */

.3marks_DT {
    display: flex;
    flex-direction: row;
}

footer {
    background: #e0f5ff;
    color: #333;
    margin-top: 0px;
    padding: 0;
}

@media screen and (min-width: 992px) {
    .d-flex {
        padding-left: 55px;
    }
}

#copy {
    background: #87b2c2;
    color: #fff;
    padding: 20px 0 10px;
    text-align: center;
}


/* フッター ここまで */


/* 青背景のスペーサー */

#spacer {
    margin-bottom: 70px;
    padding: 30px;
}


/* 青背景のスペーサー ここまで */

ul.anchor a {
    font-size: 2.2rem;
}

@media (min-width: 1200px) {
    .anchors {
        display: none;
    }
}


/* Page Top ボタン */

#page-top {
    width: 90px;
    height: 90px;
    position: fixed;
    right: 0;
    bottom: 60 !important;
    background: rgba(28, 156, 196);
    opacity: 0.7;
    border-radius: 50%;
}

#page-top a {
    position: relative;
    display: block;
    width: 90px;
    height: 90px;
    text-decoration: none;
}

#page-top a::before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f102';
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -40px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
    transition: all 0.5s;
}

#page-top a::after {
    content: 'PAGE TOP';
    font-size: 13px;
    color: #fff;
    position: absolute;
    top: 45px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

#page-top a:hover::before {
    bottom: 1rem;
}


/* スマホの問い合わせフォーム*/

#sp-contact {
    display: none !important;
}

@media screen and (max-width: 768px) {
    ul#contact {
        display: flex;
        margin-bottom: 0;
        max-width: 100%;
    }
    #sp-icon_tel {
        max-width: 290px;
        position: relative;
        bottom: 0px;
        left: 0px;
        width: 100%;
    }
    #sp-icon_mail {
        max-width: 290px;
        position: relative;
        bottom: 0px;
        left: 0px;
        width: 100%;
    }
    #sp_mail,
    sp_tel {
        padding: 0;
    }
    #sp-contact {
        position: fixed;
        bottom: 0px;
        font-size: 77%;
        width: 100%;
        display: block !important;
        /* background-color: rgba(28, 156, 196, 0.6); */
        margin-left: 0px !important;
    }
    #sp-contact a {
        text-decoration: none;
        color: #fff;
        padding: 8px 0 1px 0;
        text-align: center;
        display: block;
        transition: all 0.5s;
    }
    #sp-contact a:hover {
        text-decoration: none;
        /* opacity: 0.4; */
        filter: brightness(110%);
        /* background-color: rgba(28, 156, 196, 0.6); */
    }
    #sp_tel,
    #sp-tel {
        margin: 0 auto;
        padding: 0 !important;
        /* padding-right: 24px; */
    }
    #sp-contact-row {
        margin: 0;
    }
}