/******************************************************************
*******************************************************************

最高知！ショート動画コンテスト

*******************************************************************
******************************************************************/

/******************************************************************

共通

******************************************************************/
*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}
html {
    font-size: 16px;
    color: #595757; /* 変更 */
    line-height: 1.6;
}
body {
    font-family: 'Noto Sans JP', sans-serif;
    word-wrap: break-word;
}
.f-go {
    font-family: "Noto Sans JP", sans-serif;
}
.f-min {
    font-family: "Noto Serif JP", serif;
}
a:hover, a:focus, a:active {
    color: #158900;
}
:focus {
    outline-color: #777777;
}
img {
    -webkit-backface-visibility: hidden;
    width: 100%;
}
h1, h2, h3, h4, h5, h6 {
    line-height: 1.4;
    font-weight: bold;
}
.marginbh {
    margin-bottom: 0.5rem;
}
.marginb {
    margin-bottom: 1rem;
}
.marginbwh {
    margin-bottom: 1.5rem;
}
.marginbw {
    margin-bottom: 2rem;
}
.center-align {
    text-align: center !important;
}
.left-align {
    text-align: left !important;
}
.right-align {
    text-align: right !important;
}
.text-indent {
    padding-left: 1.13rem;
    text-indent: -1.13rem;
}

.base_width {
    max-width: 1240px !important;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}
.inner_width {
    max-width: 1040px !important;
    width: 100% !important;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0 auto !important;
}
.color-red {
    color: #ff0000;
}

br.br-pc {
}
br.br-sp {
    display: none;
}


/*
横並びレイアウト
*/
.flexbox {
    display: flex;
    flex-flow: row;
    align-content: flex-start;
}
.flexbox-wrap {
    flex-flow: row wrap;
}
.flexbox-center {
    align-items: center;
}

/*-------------------------------------------
YouTube枠レスポンシブ
-------------------------------------------*/
.video-frame {
    position: relative;
    width: 100%;
}
.video-frame:before {
    content: "";
    display: block;
    padding-top: 56.25%;
    position: relative;
}
.video-frame-inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/******************************************************************

body

******************************************************************/
.pc-only {
    display: block !important;
}
.sp-only {
    display: none !important;
}
#tokuteikenshin img {
    max-width: 100%;
}
#tokuteikenshin {
    /* background-image: url('/lp/tokuteikenshin/assets/img/bg_01.jpg');
    background-size: contain;
    padding: 3.8% 2.4%;
    position: relative; */
}
#tokuteikenshin #wrapper {
    background-color: #ffffff;
}


/******************************************************************

header

******************************************************************/
.overlay {
    display: none;
}
/*-------------------------------------------
main-image
-------------------------------------------*/
#header #main-image-wrapper {
    position: relative;
}
#header #main-image-wrapper:before {
    content: "";
    display: block;
    padding-top: 62.5%;
}
#header #wrap-main-slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}

.slick-dots {
    bottom: 1vw;
}

.slick-dots li {
    margin: 0 1vw;
    background: #717071;
    border-radius: 50%;
    border: 1px solid #ffffff;
}

.slick-dots li:hover,
.slick-dots li.slick-active {
    background: #d74c3f;
}
.slick-dots li button {
    display: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    padding: 0;
    border: none;
    background-color: transparent;
}


/******************************************************************

main

******************************************************************/
#tokuteikenshin-main {
    width: 100%;
    padding-top: 2rem;
    padding-bottom: 2rem;
}
#tokuteikenshin-main .entry-content {
    margin-bottom: 8.5rem;
}
#tokuteikenshin-main .article-header,
#tokuteikenshin-main section {
    margin-bottom: 6rem;
}

/*-------------------------------------------
overview
-------------------------------------------*/
#tokuteikenshin-main #overview .overview_title_wrapper {
    margin-bottom: 5rem;
}
#tokuteikenshin-main #overview .overview_title_wrapper .overview_title {
    text-align: center;
    font-weight: 400;
}
#tokuteikenshin-main #overview .overview_title_wrapper .overview_title .large {
    font-size: 13rem;
}
#tokuteikenshin-main #overview .overview_title_wrapper .overview_title .small {
    font-size: 5rem;
}
#tokuteikenshin-main #overview .overview_desc {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem 2%;
}
#tokuteikenshin-main #overview .cost {
    width: 29%;
}
#tokuteikenshin-main #overview .eligible-persons {
    width: 69%;
}
#tokuteikenshin-main #overview .about {
    width: 100%;
}
#tokuteikenshin-main #overview .cost,
#tokuteikenshin-main #overview .eligible-persons {
    display: flex;
    align-items: center;
    gap: 1rem 2%;
}
#tokuteikenshin-main #overview .cost-title,
#tokuteikenshin-main #overview .eligible-persons-title,
#tokuteikenshin-main #overview .about {
    padding: 0.5rem;
    border: 3px solid #595757;
}
#tokuteikenshin-main #overview .cost .cost-title,
#tokuteikenshin-main #overview .cost .cost-text,
#tokuteikenshin-main #overview .eligible-persons .eligible-persons-title,
#tokuteikenshin-main #overview .eligible-persons .eligible-persons-text {
    font-weight: 500;
}
#tokuteikenshin-main #overview .cost .cost-title {
    font-size: 2.8rem;
}
#tokuteikenshin-main #overview .cost .cost-text {
    font-size: 4.3rem;
    line-height: 1.2;
}
#tokuteikenshin-main #overview .eligible-persons .eligible-persons-title {
    font-size: 1.7rem;
    text-align: center;
}
#tokuteikenshin-main #overview .eligible-persons .eligible-persons-text.large {
    font-size: 1.6rem;
    line-height: 1.2;
    margin-bottom: 0.3rem;
}
#tokuteikenshin-main #overview .eligible-persons .eligible-persons-text.small {
    font-size: 1.3rem;
    line-height: 1.2;
}
#tokuteikenshin-main #overview .about {
    font-size: 1.4rem;
    line-height: 1.3;
    padding: 0.5rem 2%;
}
#tokuteikenshin-main #overview .about .about-title {
    font-weight: 800;
}
#tokuteikenshin-main #overview .about .about-text {
    font-weight: 500;
}


/*-------------------------------------------
risk
-------------------------------------------*/
/* チェックリストのスタイル */
#tokuteikenshin-main #risk .checklist {
    margin-bottom: 6rem;
}
#tokuteikenshin-main #risk .checklist li {
    font-size: 2.7rem;
    font-weight: 500;
    display: flex;
    align-items: flex-start;
    gap: 0 1rem;
    margin-bottom: 2rem;
}
#tokuteikenshin-main #risk .checklist li:last-child {
    margin-bottom: 0;
}
#tokuteikenshin-main #risk .checklist li img {
    width: 50px;
}
#tokuteikenshin-main #risk .checklist li span {
    flex: 1;
    line-height: 1.2;
}

#tokuteikenshin-main #risk .possibility {
    color: #d74c3f;
    margin-bottom: 10rem;
}
#tokuteikenshin-main #risk .possibility .possibility-but {
    text-align: center;
    font-size: 3.8rem;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: 5rem;
}
#tokuteikenshin-main #risk .possibility .possibility-text {
    text-align: center;
    font-size: 3.7rem;
    font-weight: 700;
    line-height: 1.3;
}

#tokuteikenshin-main #risk .ratio {
    text-align: center;
}
#tokuteikenshin-main #risk .ratio .ratio_title_wrapper {
    margin-bottom: 5rem;
}
#tokuteikenshin-main #risk .ratio .ratio_title,
#tokuteikenshin-main #risk .ratio .ratio_title_sub {
    font-weight: 500;
}
#tokuteikenshin-main #risk .ratio .ratio_title .large {
    font-size: 3.6rem;
}
#tokuteikenshin-main #risk .ratio .ratio_title .small {
    font-size: 2.7rem;
}
#tokuteikenshin-main #risk .ratio .ratiolist {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem 5%;
    margin-bottom: 5rem;
}
#tokuteikenshin-main #risk .ratio .ratiolist li {
    width: 30%;
}

#tokuteikenshin-main #risk .dangerous {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-bottom: 5rem;
}
#tokuteikenshin-main #risk .dangerous .dangerous_text {
    font-size: 3.0rem;
    font-weight: 500;
    line-height: 1.2;
    text-align: center;
}
#tokuteikenshin-main #risk .dangerous .dangerous_text span {
    color: #d74c3f;
}
#tokuteikenshin-main #risk .dangerous .dangerous_img img {
    width: 43px;
}
#tokuteikenshin-main #risk .dangerous .dangerous_examples {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem 10%;
}
#tokuteikenshin-main #risk .dangerous .dangerous_examples li {
    padding: 0.1rem;
    color: #fff;
    background-color: #d74c3f;
    border-radius: 3px;
    font-size: 3.0rem;
    font-weight: 500;
    line-height: 1.3;
    padding: 0.1rem 0.8rem;
}

#tokuteikenshin-main #risk .prompt .prompt_inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
}
#tokuteikenshin-main #risk .prompt .prompt_inner .image {
    width: 28%;
    display: flex;
}
#tokuteikenshin-main #risk .prompt .prompt_inner .text {
    width: 70%;
    font-size: 2.7rem;
    font-weight: 500;
    line-height: 1.5;
}
#tokuteikenshin-main #risk .prompt .prompt_inner .text span {
    color: #d74c3f;
    font-weight: 700;
}
#tokuteikenshin-main #risk .prompt .inquiry_desk_link {
    display: block;
    background-color: #e79d87;
    border-radius: 25px;
    color: #fff;
    font-size: 2.0rem;
    text-align: center;
    margin: 0 auto 4rem;
    text-decoration: none;
}
#tokuteikenshin-main #risk .prompt .inquiry_desk_link:hover {
    opacity: 0.5;
}
#tokuteikenshin-main #risk .prompt .prompt_text {
    color: #d74c3f;
    text-align: center;
    font-size: 3.0rem;
    font-weight: 700;
    line-height: 1.5;
}


/*-------------------------------------------
details
-------------------------------------------*/
#tokuteikenshin-main #details {
    margin-bottom: 5rem;
}
#tokuteikenshin-main #details .section_header .section_title_wrapper {
    border: 3px solid #595757;
    border-radius: 40px;
    width: 100%;
    max-width: 750px;
    text-align: center;
    margin: 0 auto 3rem;
}
#tokuteikenshin-main #details .section_header .section_title {
    font-weight: 500;
    font-size: 3.4rem;
}
#tokuteikenshin-main #details .section_main .steplist_wrapper {
    margin-bottom: 5rem;
}
#tokuteikenshin-main #details .section_main .steplist {
    display: flex;
    margin-bottom: 1rem;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_item_main {
    width: calc((100% - 14%) / 3);
}
#tokuteikenshin-main #details .section_main .steplist .steplist_item_sub {
    width: 7%;
    text-align: center;
    padding-top: 10%;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_item_sub .steplist_arrow_image img {
    width: 20px;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_item_sub .text p {
    color: #d74c3f;
    font-size: 0.85rem;
    font-weight: 500;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_title_wrapper {
    text-align: center;
    border-bottom: 1px solid #aec8c2;
    padding-bottom: 0.5rem;
    margin-bottom: 0.5rem;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_item_title_number {
    color: #fff;
    background-color: #aec8c2;
    border-radius: 40px;
    font-size: 1.9rem;
    font-weight: 500;
    width: 100%;
    max-width: 140px;
    padding-bottom: 0.2rem;
    margin: 0 auto 0.5rem;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_item_title {
    font-weight: 500;
    font-size: 1.9rem;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_content {
    padding: 0.5rem 0.2rem;
    text-align: center;
}
#tokuteikenshin-main #details .section_main .steplist .steplist_content p {
    font-weight: 500;
    font-size: 1.4rem;
}
#tokuteikenshin-main #details .section_main .steplist_wrapper .target {
    font-size: 1.4rem;
    font-weight: 500;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 3rem;
}
#tokuteikenshin-main #details .section_main .steplist_wrapper .kaizen {
    color: #d74c3f;
    font-size: 2.4rem;
    font-weight: 500;
}
#tokuteikenshin-main #details .section_main .steplist_wrapper .kaizen p {
    max-width: 900px;
    margin: 0 auto;
}

#tokuteikenshin-main #details .section_main .first_step {
    display: flex;
    align-items: center;
    gap: 0 5%;
}
#tokuteikenshin-main #details .section_main .first_step .image {
    width: 35%;
}
#tokuteikenshin-main #details .section_main .first_step .image img {
    width: 100%;
}
#tokuteikenshin-main #details .section_main .first_step .text {
    width: 60%;
    color: #5c392a;
    font-size: 3.0rem;
    font-weight: 300;
}


/*-------------------------------------------
movie
-------------------------------------------*/
#tokuteikenshin-main #movie .section_header {
    margin-bottom: 4rem;
}
#tokuteikenshin-main #movie .section_header .section_title_wrapper {
    text-align: center;
}
#tokuteikenshin-main #movie .section_header .section_title_wrapper .section_title {
    font-size: 3.4rem;
    font-weight: 500;
}
#tokuteikenshin-main #movie .section_main .health_checkup_movie {
    margin-bottom: 5rem;
}
#tokuteikenshin-main #movie .section_main .envelop {
    display: flex;
    align-items: center;
    gap: 1rem 5%;
}
#tokuteikenshin-main #movie .section_main .envelop .image {
    width: 40%;
}
#tokuteikenshin-main #movie .section_main .envelop .image img {
    width: 100%;
}
#tokuteikenshin-main #movie .section_main .envelop .text {
    width: 55%;
    font-size: 1.4rem;
    font-weight: 500;
}
#tokuteikenshin-main #movie .section_main .envelop .text .internal-link {
    color: #d74c3f;
    text-decoration: none;
}
#tokuteikenshin-main #movie .section_main .envelop .text .internal-link:hover {
    text-decoration: underline;
}

/*-------------------------------------------
procedure
-------------------------------------------*/
#tokuteikenshin-main #procedure {
    background-color: #bfdee7;
    padding: 5rem 0;
}
#tokuteikenshin-main #procedure .caution {
    color: #b28146;
}
#tokuteikenshin-main #procedure .white-box {
    background-color: #ffffff;
}

#tokuteikenshin-main #procedure .section_header {
    margin-bottom: 4rem;
}
#tokuteikenshin-main #procedure .section_header .section_title_wrapper {
    text-align: center;
    padding: 0.3rem 1rem;
    border: 3px solid #595757;
}
#tokuteikenshin-main #procedure .section_header .section_title_wrapper .section_title {
    font-size: 3.0rem;
    font-weight: 700;
}

#tokuteikenshin-main #procedure .section_main .method_box {
    margin-bottom: 5rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper {
    display: flex;
    align-items: flex-start;
    gap: 1rem 3%;
    margin-bottom: 2.5rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper:first-child {
    /* margin-bottom: 0.5rem; */
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper:last-child {
    margin-bottom: 0;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .title {
    width: 22%;
    text-align: center;
    padding: 0.5rem 0.2rem;
    border: 3px solid #595757;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .title h3 {
    font-size: 1.8rem;
    font-weight: 700;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc {
    width: 75%;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .text {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.4;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .text.large {
    font-size: 2.4rem;
    font-weight: 700;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist li {
    margin-bottom: 2rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist li:last-child {
    margin-bottom: 0;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem 1%;
    margin-bottom: 0.5rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_number {
    width: 56px;
    height: 56px;
    border: 2px solid #595757;
    border-radius: 50%;
    font-size: 2.4rem;
    font-weight: 700;
    text-align: center;
    line-height: 1.2;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_title {
    font-size: 2.4rem;
    font-weight: 700;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_title_sub {
    width: 100%;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1;
    padding-left: 4rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_box {
    font-size: 1.5rem;
    font-weight: 500;
    padding: 0.2rem 3%;
    border-radius: 5px;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .normal {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.5;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .steplist_content_flex {
    display: flex;
    align-items: center;
    gap: 0.5rem 1%;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .steplist_content_flex .label {
    font-weight: 700;
    text-align: center;
    border: 1px solid #595757;
    padding: 0.3rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 6%;
    border-radius: 5px;
    padding: 1rem 4%;
    font-weight: 500;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box img {
    width: 100%;
    max-width: 80px;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .good {
    display: flex;
    gap: 0 10%;
    width: 35%;
    font-size: 1.2rem;
    line-height: 1.4;
    align-items: center;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .good .image {
    text-align: center;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .bad {
    width: 70%;
    font-size: 1.6rem;
}
#tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .bad img {
    vertical-align: middle;
}
#tokuteikenshin-main #procedure .section_main .procedure_prompt {
    text-align: center;
}
#tokuteikenshin-main #procedure .section_main .procedure_prompt .procedure_prompt_text {
    font-size: 3.0rem;
    font-weight: 900;
    line-height: 1.5;
}
#tokuteikenshin-main #procedure .section_main .procedure_prompt .procedure_prompt_text span {
    color: #d74c3f;
}

/*-------------------------------------------
 inquiry desk
-------------------------------------------*/
#tokuteikenshin-main #inquiry_desk .section_header {
    margin-bottom: 2rem;
}
#tokuteikenshin-main #inquiry_desk .section_title {
    color: #231815;
    text-align: center;
    font-size: 2rem;
}
#tokuteikenshin-main #inquiry_desk .tables_wrapper {
    display: flex;
    justify-content: space-between;
    gap: 2rem 2rem;
}

#tokuteikenshin-main #inquiry_desk .tables_wrapper .table {
    flex: 1;
}


table {
    width: 100%;
    border-collapse: collapse;
    text-align: center;
    color: #231815;
}
/* ヘッダー */
th {
    padding: 10px;
    font-size: 1.2rem;
    font-weight: 700;
    border-top: 1px solid #231815;
    border-bottom: 1px solid #231815;
}
thead th {
    border-top: none;
}
/* データセル */
td {
    padding: 8px 10px;
    border-bottom: 1px solid #231815;
    font-weight: 700;
}
td:first-child {
    background-color: #a9c5e7;
}
/* リンク全般 */
td a {
    color: #231815;
    text-decoration: none;
}
td a:hover {
    text-decoration: underline;
}
/* 外部リンクアイコン */
.link-icon {
    margin-left: 4px;
    font-size: 0.8em;
    vertical-align: text-bottom;
}
/* 電話番号リンク */
.tel {
    white-space: nowrap;
    background-color: #fbe2c5;
}

/*-------------------------------------------
スティッキーリンク
-------------------------------------------*/
.sticky-nav_wrapper {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 99;
}

.sticky-nav {
    margin-bottom: 2rem;
}

.sticky-nav:last-child {
    margin-bottom: 0;
}

.sticky-nav a {
    display: block;
    width: 145px;
    height: 145px;
    background-color: #d74c3f;
    border-radius: 50%;
    text-align: center;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    text-decoration: none;
    line-height: 1.2;
    -webkit-transition: 0.4s;
    transition: 0.4s;
    border: 1px solid #ffffff;
    display: flex;
    justify-content: center;
    padding-top: 45px;
}

.sticky-nav a:hover {
    background-color: #717071;
}

/*-------------------------------------------
footer
-------------------------------------------*/
#footer {
    background-color: #bfdee7;
    padding-top: 2rem;
    padding-bottom: 2rem;
    text-align: center;
}
#footer .footer-title {
    font-size: 1.5rem;
    font-weight: 700;
}
#footer .footer-text {
    font-size: 2.3rem;
    font-weight: 700;
}


/******************************************************************
*******************************************************************

メディアクエリー

*******************************************************************
******************************************************************/
/* 1281px ~ : PC Large screens -> Default */

/* ~ 1280px : PC screens */
@media only screen and (max-width: 80em) {

    /*-------------------------------------------
    スティッキーリンク
    -------------------------------------------*/
    .sticky-nav_wrapper {
        bottom: 20px;
        right: 10px;
    }

    .sticky-nav {
        margin-bottom: 1rem;
    }

    .sticky-nav a {
        width: 110px;
        height: 110px;
        font-size: 16px;
        padding-top: 35px;
    }

    /*-------------------------------------------
    overview
    -------------------------------------------*/
    #tokuteikenshin-main #overview .overview_title_wrapper .overview_title .large {
        font-size: 8rem;
    }
    #tokuteikenshin-main #overview .overview_title_wrapper .overview_title .small {
        font-size: 3rem;
    }
    #tokuteikenshin-main #overview .cost {
        width: 100%;
    }
    #tokuteikenshin-main #overview .eligible-persons {
        width: 100%;
    }
    #tokuteikenshin-main #overview .cost-title,
    #tokuteikenshin-main #overview .eligible-persons .eligible-persons-title {
        text-align: center;
        width: 100%;
        max-width: 150px;
    }
    #tokuteikenshin-main #overview .cost .cost-title {
        font-size: 2.2rem;
    }
    #tokuteikenshin-main #overview .cost .cost-text {
        font-size: 2.5rem;
    }

   
    /*-------------------------------------------
    risk
    -------------------------------------------*/
    #tokuteikenshin-main #risk .checklist li {
        font-size: 2.0rem;
        margin-bottom: 1rem;
    }
    #tokuteikenshin-main #risk .checklist li img {
        width: 40px;
    }
    #tokuteikenshin-main #risk .possibility .possibility-but {
        font-size: 2.0rem;
        margin-bottom: 3rem;
    }
    #tokuteikenshin-main #risk .possibility .possibility-text {
        font-size: 2.0rem;
    }
    
    #tokuteikenshin-main #risk .ratio .ratio_title_wrapper {
        margin-bottom: 4rem;
    }
    #tokuteikenshin-main #risk .ratio .ratio_title .large {
        font-size: 2.9rem;
    }
    #tokuteikenshin-main #risk .ratio .ratio_title .small {
        font-size: 2.2rem;
    }
    #tokuteikenshin-main #risk .ratio .ratiolist {
        margin-bottom: 4rem;
    }
    #tokuteikenshin-main #risk .ratio .ratiolist li {
        width: 25%;
    }
    #tokuteikenshin-main #risk .dangerous .dangerous_text {
        font-size: 2.4rem;
    }
    #tokuteikenshin-main #risk .dangerous .dangerous_img img {
        width: 34px;
    }
    #tokuteikenshin-main #risk .dangerous .dangerous_examples li {
        font-size: 2.4rem;
    }
    #tokuteikenshin-main #risk .prompt .prompt_inner {
        justify-content: center;
        gap: 1rem 1%;
    }
    #tokuteikenshin-main #risk .prompt .prompt_inner .text {
        font-size: 1.8rem;
        max-width: 470px;
    }
    #tokuteikenshin-main #risk .prompt .inquiry_desk_link {
        font-size: 1.4rem;
    }
    #tokuteikenshin-main #risk .prompt .prompt_text {
        font-size: 2.0rem;
    }

    
    /*-------------------------------------------
    details
    -------------------------------------------*/
    #tokuteikenshin-main #details .section_header .section_title {
        font-size: 2.0rem;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_title_number,
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_title {
        font-size: 2.3vw;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_content p,
    #tokuteikenshin-main #details .section_main .steplist_wrapper .target {
        font-size: 2vw;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_sub {
        padding-top: 7%;
    }
    #tokuteikenshin-main #details .section_main .steplist_wrapper .kaizen {
        font-size: 1.9rem;
    }
    #tokuteikenshin-main #details .section_main .steplist_wrapper .kaizen p br {
        display: none;
    }
    

    /*-------------------------------------------
    details
    -------------------------------------------*/
    #tokuteikenshin-main #details .section_main .first_step {
        justify-content: center;
        gap: 2rem 5%;
    }
    #tokuteikenshin-main #details .section_main .first_step .image {
        width: 28%;
    }
    #tokuteikenshin-main #details .section_main .first_step .text {
        width: 70%;
        max-width: 320px;
        font-size: 1.8rem;
    }
    
    /*-------------------------------------------
    movie
    -------------------------------------------*/
    #tokuteikenshin-main #movie .section_header .section_title_wrapper .section_title {
        font-size: 2.9rem;
    }
    #tokuteikenshin-main #movie .section_main .health_checkup_movie {
        margin-bottom: 5rem;
    }
    #tokuteikenshin-main #movie .section_main .envelop {
        display: flex;
        align-items: center;
    }
    #tokuteikenshin-main #movie .section_main .envelop .image {
        width: 40%;
    }
    #tokuteikenshin-main #movie .section_main .envelop .image img {
        width: 100%;
    }
    #tokuteikenshin-main #movie .section_main .envelop .text {
        width: 55%;
        font-size: 1.4rem;
        font-weight: 500;
    }
    #tokuteikenshin-main #movie .section_main .envelop .text .internal-link {
        color: #d74c3f;
        text-decoration: none;
    }
    #tokuteikenshin-main #movie .section_main .envelop .text .internal-link:hover {
        text-decoration: underline;
    }

    /*-------------------------------------------
    procedure
    -------------------------------------------*/
    /* #tokuteikenshin-main #procedure .section_main .flex-wrapper {
        flex-wrap: wrap;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .title {
        width: 100%;
        max-width: 300px;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc {
        width: 100%;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_title_sub {
        padding-left: 0;
    } */
    
    #tokuteikenshin-main #procedure .section_header .section_title_wrapper .section_title {
        font-size: 2.4rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .title h3 {
        font-size: 1.4rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .text.large {
        font-size: 1.9rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_number {
        width: 48px;
        height: 48px;
        font-size: 2rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_title {
        font-size: 2rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_title_sub {
        font-size: 1.2rem;
        padding-left: 0;
        margin-bottom: 0.5rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_box {
        font-size: 1.2rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .normal {
        margin-bottom: 0.5rem;
        font-size: 1.2rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .steplist_content_flex {
        flex-direction: column;
        align-items: flex-start;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .steplist_content_flex .label br {
        display: none;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box {
        flex-wrap: wrap;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .good,
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .bad {
        width: 100%;
        font-size: 1.2rem;
    }
    #tokuteikenshin-main #procedure .section_main .procedure_prompt .procedure_prompt_text {
        font-size: 2.0rem;
    }

}

/* ~ 1180px : PC screens */
@media only screen and (max-width: 73.75em) {

}

/* ~ 1024px : Medium screens */
@media only screen and (max-width: 64em) {

    #tokuteikenshin-main #inquiry_desk .tables_wrapper {
        flex-direction: column;
        align-items: center;
        gap: 2rem 2rem;
    }
    
    #tokuteikenshin-main #inquiry_desk .tables_wrapper .table {
        flex: 1;
        width: 100%;
        max-width: 600px;
    }
    
}

/* ~ 960px : Tablet screens */
@media only screen and (max-width: 60em) {
}

/* ~ 896px : スマホ横 */
@media only screen and (max-width: 56em) {
}

/* ~ 812px : iphone X screens */
@media only screen and (max-width: 50.750em) {
    #tokuteikenshin-main #risk .ratio .ratio_title_sub,
    #tokuteikenshin-main #risk .dangerous .dangerous_text,
    #tokuteikenshin-main #risk .prompt .prompt_inner .text {
        text-align: left;
    }
    #tokuteikenshin-main #risk .dangerous .dangerous_text,
    #tokuteikenshin-main #risk .dangerous .dangerous_examples li {
        font-size: 2.0rem;
    }

}

/* ~ 767px : Tablet screens */
@media only screen and (max-width: 47.938em) {
}

/* 641px ~ 1024px : Medium only */
@media only screen and (min-width: 40.0625em) and (max-width: 64em) {
}

/* 640px以下:Small screens */
@media only screen and (max-width: 40em) {


    /******************************************************************

    共通

    ******************************************************************/
    html {
        /* font-size: 1rem; */
       font-size: 15px;
    }
    h1, h2, h3, h4, h5, h6 {
        font-size: 1.2rem;
        line-height: 1.4;
    }
    img {
        width: 100%;
    }


    /******************************************************************

    構造調整タグ

    ******************************************************************/
    .base_width {
        padding-left: 1.3rem !important;
        padding-right: 1.3rem !important;
    }
    .base_width.base_width_sp {
        width: 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    .inner_width {
        width: 100% !important;
        margin: 0 auto !important;
        padding-left: 1.2rem;
        padding-right: 1.2rem;
    }
    .inner_width.inner_width_sp {
        width: 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    #tokuteikenshin-main #application-requirements .section_main .base_width {
        /* padding-left: 0.8rem !important;
        padding-right: 0.8rem !important; */
        padding-left: 1.2rem !important;
        padding-right: 1.2rem !important;
    }

    .pc-only {
        display: none !important;
    }
    .sp-only {
        display: block !important;
    }

    br.br-pc {
        display: none;
    }
    br.br-sp {
        display: block;
    }

    /*
    横並びレイアウト
    */
    .flexbox {
        flex-flow: row wrap;
    }
    .flexbox-wrap {
    }
    .flexbox-center {
    }

    body#tokuteikenshin .pc {
        display: none;
    }
    body#tokuteikenshin .sp {
        display: block;
    }

    #tokuteikenshin-main {
    }


    /*
    スマホメニューボタン
    */
    .menu-btn-wrapper {
        text-align: center;
        position: absolute;
        top: -48px;
        left: 0;
        right: 0;
        z-index: 2;
    }
    .menu-btn {
        display: inline-block;
        background-color: #e5002d;
        padding: 1rem;
        border-radius: 50px;
        border: 1px solid #ffffff;
    }
    .menu-btn a,
    .menu-btn a span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
    }
    .menu-btn a {
        position: relative;
        width: 55px;
        height: 50px;
    }
    /* .menu-btn a:after {
        content: "MENU";
        display: inline-block;
        text-align: center;
        font-size: 10px;
        position: absolute;
        bottom: -16px;
        left: 0px;
        right: 0px;
        color: #0b2775;
    }
    .menu-btn a.btn-close:after {
        content: "CLOSE";
        left: 0px;
    } */
    .menu-btn a span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 4px;
        background-color: #ffffff;
        border-radius: 4px;
    }
    .menu-btn a span:nth-of-type(1) {
        top: 16px;
    }
    .menu-btn a span:nth-of-type(2) {
        top: 28px;
    }
    .menu-btn a span:nth-of-type(3) {
        bottom: 6px;
    }

    .menu-btn a.btn-close span:nth-of-type(1) {
        transform: translateY(11px) rotate(-45deg);
    }
    .menu-btn a.btn-close span:nth-of-type(2) {
        opacity: 0;
    }
    .menu-btn a.btn-close span:nth-of-type(3) {
        transform: translateY(-13px) rotate(45deg);
    }

    /*
    スマホメニュー
    */
    .overlay {
        /* position: fixed; */
        z-index: 50;
        /* background-color: #f1f1f1; */
        /* border-top: 1px solid #6f6067;
        border-bottom: 1px solid #6f6067; */
        width: 100%;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        padding: 3.5rem 1.0rem 2.5rem;
        /* height: calc(100% - 75px); */
    }
    /* スクロールバーのカスタマイズ */
    .overlay::-webkit-scrollbar{
        /*    width: 10px;*/
        width: 5px;
    }
    .overlay::-webkit-scrollbar-track{
        background: #ffffff;
        border-left: solid 1px #ececec;
    }
    .overlay::-webkit-scrollbar-thumb{
        background: #bbbbbb;
        border-radius: 10px;
        box-shadow: inset 0 0 0 2px #ffffff;
    }
    .overlay_inner {
        /*        overflow-y: scroll;*/
    }


    /*-------------------------------------------
    main-image
    -------------------------------------------*/
    #header #main-image-wrapper:before {
        padding-top: 166.2%;
    }
    .slick-dots {
        bottom: 0vw;
    }
  
    /******************************************************************

    main

    ******************************************************************/  
    #tokuteikenshin-main .entry-content {
        margin-bottom: 4rem;
    }
    #tokuteikenshin-main .article-header,
    #tokuteikenshin-main section {
        margin-bottom: 3rem;
    }

    #tokuteikenshin-main #overview .overview_title_wrapper {
        margin-bottom: 2.5rem;
    }
    #tokuteikenshin-main #overview .overview_title_wrapper .overview_title .large {
        font-size: 5rem;
    }
    #tokuteikenshin-main #overview .overview_title_wrapper .overview_title .small {
        font-size: 2rem;
    }
    #tokuteikenshin-main #overview .cost,
    #tokuteikenshin-main #overview .eligible-persons {
        flex-direction: column;
        align-items: flex-start;
    }
    #tokuteikenshin-main #overview .cost-title,
    #tokuteikenshin-main #overview .eligible-persons .eligible-persons-title {
        max-width: 200px;
    }
    #tokuteikenshin-main #overview .cost .cost-title,
    #tokuteikenshin-main #overview .eligible-persons .eligible-persons-title {
        font-size: 1.5rem;
    }
    #tokuteikenshin-main #overview .cost .cost-text {
        font-size: 1.8rem;
    }
    #tokuteikenshin-main #overview .eligible-persons .eligible-persons-text.large {
        font-size: 1.3rem;
    }
    #tokuteikenshin-main #overview .eligible-persons .eligible-persons-text.small {
        font-size: 1.1rem;
    }
    #tokuteikenshin-main #overview .about {
        font-size: 1.1rem;
    }

    #tokuteikenshin-main #risk .checklist {
        margin-bottom: 3rem;
    }
    #tokuteikenshin-main #risk .checklist li {
        font-size: 1.4rem;
    }
    #tokuteikenshin-main #risk .checklist li img {
        max-width: 27px;
    }
    #tokuteikenshin-main #risk .possibility {
        margin-bottom: 5rem;
    }
    #tokuteikenshin-main #risk .possibility .possibility-but {
        font-size: 1.6rem;
        margin-bottom: 1.5rem;
    }
    #tokuteikenshin-main #risk .possibility .possibility-text {
        font-size: 1.6rem;
        text-align: left;
    }
    #tokuteikenshin-main #risk .ratio .ratio_title_wrapper {
        margin-bottom: 2rem;
    }
    #tokuteikenshin-main #risk .ratio .ratio_title .large {
        font-size: 2.0rem;
    }
    #tokuteikenshin-main #risk .ratio .ratio_title .small {
        font-size: 1.6rem;
    }
    #tokuteikenshin-main #risk .ratio .ratiolist {
        flex-wrap: wrap;
        margin-bottom: 2.5rem;
    }
    #tokuteikenshin-main #risk .ratio .ratiolist li {
        width: 100%;
        max-width: 180px;
    }
    #tokuteikenshin-main #risk .dangerous {
        margin-bottom: 2.5rem;
    }
    #tokuteikenshin-main #risk .dangerous .dangerous_text,
    #tokuteikenshin-main #risk .dangerous .dangerous_examples li {
        font-size: 1.6rem;
    }
    #tokuteikenshin-main #risk .dangerous .dangerous_img img {
        width: 20px;
    }
    #tokuteikenshin-main #risk .prompt .prompt_inner {
        flex-wrap: wrap;
    }
    #tokuteikenshin-main #risk .prompt .prompt_inner .image {
        width: 100%;
        justify-content: center;
    }
    #tokuteikenshin-main #risk .prompt .prompt_inner .image img {
        max-width: 200px;
    }
    #tokuteikenshin-main #risk .prompt .prompt_inner .text {
        width: 100%;
        font-size: 1.5rem;
    }
    #tokuteikenshin-main #risk .prompt .inquiry_desk_link {
        font-size: 1.2rem;
        margin: 0 auto 2rem;
    }
    #tokuteikenshin-main #risk .prompt .prompt_text {
        font-size: 1.6rem;
        text-align: left;
    }

    #tokuteikenshin-main #details .section_main .steplist {
        flex-wrap: wrap;
        justify-content: center;
        margin-bottom: 3rem;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_main {
        width: 100%;
        max-width: 300px;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_sub {
        width: 100%;
        padding-top: 0;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_title_number,
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_title {
        font-size: 1.9rem;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_content p,
    #tokuteikenshin-main #details .section_main .steplist_wrapper .target {
        font-size: 1.4rem;
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_sub .steplist_arrow_image img {
        transform: rotate(90deg);
    }
    #tokuteikenshin-main #details .section_main .steplist .steplist_item_sub .text p {
        margin-bottom: 2rem;
    }
    #tokuteikenshin-main #details .section_main .steplist_wrapper .kaizen {
        font-size: 1.6rem;
    }
    #tokuteikenshin-main #details .section_main .first_step {
        flex-wrap: wrap;
    }
    #tokuteikenshin-main #details .section_main .first_step .image {
        width: 100%;
        text-align: center;
    }
    #tokuteikenshin-main #details .section_main .first_step .image img {
        max-width: 300px;
    }
    #tokuteikenshin-main #details .section_main .first_step .text {
        width: 100%;
    }

    #tokuteikenshin-main #movie .section_header {
        margin-bottom: 2rem;
    }
    #tokuteikenshin-main #movie .section_header .section_title_wrapper .section_title {
        font-size: 1.7rem;
    }
    #tokuteikenshin-main #movie .section_main .envelop {
        flex-wrap: wrap;
    }
    #tokuteikenshin-main #movie .section_main .envelop .image {
        width: 100%;
        text-align: center;
    }
    #tokuteikenshin-main #movie .section_main .envelop .image img {
        max-width: 300px;
    }
    #tokuteikenshin-main #movie .section_main .envelop .text {
        width: 100%;
        font-size: 1.1rem;
    }

    #tokuteikenshin-main #procedure {
        padding: 2.5rem 0;
    }
    #tokuteikenshin-main #procedure .section_header {
        margin-bottom: 2rem;
    }
    #tokuteikenshin-main #procedure .section_header .section_title_wrapper .section_title {
        font-size: 1.9rem;
    }
    #tokuteikenshin-main #procedure .section_main .method_box {
        margin-bottom: 2.5rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper {
        flex-wrap: wrap;
        margin-bottom: 1.2rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .title {
        width: 100%;
        max-width: 300px;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc {
        width: 100%;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .text {
        font-size: 1.4rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .text.large {
        font-size: 1.5rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_number {
        width: 40px;
        height: 40px;
        font-size: 1.8rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_title_wrapper .steplist_item_title {
        font-size: 1.6rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .normal {
        font-size: 1.0rem;
    }
    #tokuteikenshin-main #procedure .section_main .procedure_prompt .procedure_prompt_text {
        font-size: 1.6rem;
    }
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .good,
    #tokuteikenshin-main #procedure .section_main .flex-wrapper .desc .steplist .steplist_content .result_box .bad {
        font-size: 1.0rem;
    }

    #tokuteikenshin-main #inquiry_desk .section_title {
        font-size: 1.6rem;
    }
   
    /*-------------------------------------------
    footer
    -------------------------------------------*/
    #footer .footer-title {
        font-size: 1.0rem;
    }
    #footer .footer-text {
        font-size: 1.4rem;
    }

    /*-------------------------------------------
    スティッキーリンク
    -------------------------------------------*/
    .sticky-nav_wrapper {
        bottom: 5px;
        right: 2px;
    }

    .sticky-nav {
        margin-bottom: 0.5rem;
    }

    .sticky-nav a {
        width: 80px;
        height: 80px;
        font-size: 12px;
        padding-top: 12px;
    }

} /* 641以下end */

/* 479px以下: SP screens */
@media only screen and (max-width: 29.938em) {

}
