.d-body #heading {
    max-width: 1200px;
    margin: 0 auto;
    background-color: #fff;
    padding: 24px 0 32px;
}
.d-body #heading .heading-width {
    width: 100%;
    margin: auto;
    text-align: center;
    max-width: 912px;
}
.d-body .h2Normal {
    font-size: 40px;
}
.d-body #heading .h2Normal {
    margin-bottom: 16px;
    font-size: 24px;
    line-height: 1.2;
}
.d-body #heading .h2Normal-span {
    color: #666666;
    display: block;
    font-size: 20px;
}
.d-body #heading .heading-text a {
    text-decoration: underline;
}
.d-body .textNormal_16p a {
    text-decoration: underline;
    font-size: 1em;
}
.d-body .textNormal_16p b {
    font-size: 1em;
}

.d-body #sortListWrap {
    background-color: #EEF6FF;
    box-shadow: 0 0 0 100vmax #EEF6FF;
    clip-path: inset(0 -100vmax);
    padding: 48px 83px 16px;
    box-sizing: border-box;
    max-width: 1366px;
    margin: auto;
}
.modal-icon {
    background-image: url(/common/images/icon_modal.svg);
    background-repeat: no-repeat;
    background-position: center;
    display: inline-block;
    width: 1.5em;
    height: 1.2em;
}
.d-body .sortButtons {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-bottom: 24px;
}
.d-body .sortButton {
    box-sizing: border-box;
    padding: 16px 20px;
    background-color: #fff;
    border: 1px solid #E0E0E0;
    border-radius: 99px;
    text-align: center;
    font-family: Hiragino Kaku Gothic Pro;
    font-size: 20px;
    font-weight: 300;
    line-height: 18px;
    cursor: pointer;
}
.d-body .sortButton.active {
    background-color: #125BF5;
    color: #fff;
    font-weight: 600;
}

.d-body .sortList {
    padding-top: 48px;
}

.d-body .rankingWrap {
    margin-top: 40px;
}


/* tab切り替え　カテゴリ */
.d-body.categoryMenu {

}
.d-body .categoryMenu_item {

}
.d-body .categoryMenu_item.active {

}
.d-body.categoryContent {

}
.d-body .categoryContent_item {
    display: none;
}
.d-body .categoryContent_item.active {
    display: block;
}
.d-body .categoryTitle {

}
.d-body .categoryTitle .date {
    display: block;
    color: #666;
    font-size: 20px;
}
.d-body .categoryTitle .title {
    color: #125BF5;
    font-size: 40px;
    font-weight: bold;
}
.d-body .categoryComment {
    text-align: center;
}
.d-body .categoryComment[data-category="1"]::before {
    content: "ご契約数が多いメーカー順に、契約の多い保険会社をランキングにいたしました。";
}
.d-body .categoryComment[data-category="2"]::before{
    content: "ご契約数が多い車名順に、契約の多い保険会社をランキングにいたしました。";
}

/* tab切り替え　ランキング */
.d-body .rankingMenu {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 40px;
    border-bottom: solid 2px #125BF5;
}
.d-body .rankingMenu_Item {
    width: calc(100%/2);

    background-color: #FFFFFF;
    border-radius: 8px 8px 0 0;
    box-shadow: 0px -2px 10px 2px #dedede;
    color: #125BF5;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 12.5px 5px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
}
.d-body .rankingMenu_Item.active {
    background-color: #125BF5;
    color: #FFFFFF;
}
.d-body .categoryContent_item._maker .rankingMenu,
.d-body .categoryContent_item._car .rankingMenu {
    counter-reset: count 0;
}
.d-body .categoryContent_item._maker .rankingMenu_Item::before,
.d-body .categoryContent_item._car .rankingMenu_Item::before {
    counter-increment: count;
    content: counter(count)"位";
    margin-right: .5em;
}
.d-body .rankingContent {
    
}
.d-body .rankingContent_item {
    display: none;
}
.d-body .rankingContent_item.active {
    display: block;
}

/* 保険概要 */
.d-body .resultList {
    margin-bottom: 16px;
    padding: 32px 48px 32px;
    background-color: #fff;
}
.d-body .result_company {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    /*margin-bottom: 32px;*/
}
.d-body .result_company::before {
    content: "";
    background: url(/dmg-ins/car/ranking/images/icon_rank1.png)no-repeat ;
    background-size: contain;
    background-position: center;
    display: block;
    width: 60px;
    height: 60px;
    margin-right: 32px;
}
.d-body .resultList.ranking_01 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank1.png);
}
.d-body .resultList.ranking_02 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank2.png);
}
.d-body .resultList.ranking_03 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank3.png);
}
.d-body .resultList.ranking_04 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank4.png);
}
.d-body .resultList.ranking_05 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank5.png);
}
.d-body .resultList.ranking_06 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank6.png);
}
.d-body .resultList.ranking_07 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank7.png);
}
.d-body .resultList.ranking_08 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank8.png);
}
.d-body .resultList.ranking_09 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank9.png);
}
.d-body .resultList.ranking_10 .result_company::before {
    background-image: url(/dmg-ins/car/ranking/images/icon_rank10.png);
}
.d-body .result_companyLogo {
    margin-right: 16px;
    border: 1px solid #D9DEEA;
    width: 190px;
    height: 86px;
    box-sizing: border-box;
    text-align: center;
    display: flex;
    align-items: center;
    flex-flow: column;
}
.d-body .result_companyLogoImg {
    margin: auto;
    max-width: calc(100% - 20px);
    height: auto;
}
.d-body .result_companyName {
    display: flex;
    align-items: start;
    flex-flow: column;
    font-size: 30px;
    font-weight: bold;
}

.d-body .result_company .companyName_labelWrap {
    display: flex;
    gap: 10px;
}
.d-body .result_company .companyName_label{
    display: none;
    margin-top: 5px;
    padding: 5px;
    background-color: #DEE6F9;
    color: #333;
    font-size: 14px;
    font-weight: 600;
}
.d-body .rankingWrap._firsttime .companyName_label {
    display: block;
}
.d-body .rankingWrap._firsttime .result_company .companyName_label._pcUser {
    display: block;
}
.d-body .rankingWrap._firsttime .result_company .companyName_label._spUser {
    display: none;
}

.d-body .result_companyBtnWrap {
    margin-left: auto;
    display: flex;
    gap: 10px;
    align-items: center;
}
.d-body .result_companyBtnWrap .mainBtn02 {
    position: relative;
}
.d-body .result_companyBtnWrap .mainBtn02::after {
    content: "";
    -webkit-mask-image: url(/common/images/icon_modal.svg);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-image: url(/common/images/icon_modal.svg);
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
    background-color: #fff;
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
}
.d-body .result_companyBtnWrap .mainBtn02._notmodal::after {
    display: none;
}
.d-body .ranking_higher .result_companyBtnWrap {
    display: none;
}
.d-body .result_companyBtn {
    min-width: 160px;
}
.d-body .result-closer:after, 
.d-body .result-closer-sp:after {
    content: '';
    width: 30px;
    height: 30px;
    position: absolute;
    top: -4px;
    bottom: 0;
    right: 10px;
    margin: auto;
    background-image: url(/common/images/math-plus.svg);
    background-repeat: no-repeat;
    background-size: contain;
}
.d-body .result-closer._active:after, 
.d-body .result-closer-sp._active:after {
    background-image: url(/common/images/math-minus.svg);
}
.d-body .result_companyBtnWrap .result-closer {
    position: relative;
    cursor: pointer;
}
.d-body .result_companyBtnWrap .result-closer-text {
    position: absolute;
    left: 50%;
    transform: translateX(-60%);
    white-space: nowrap;
}
.d-body .result_companyAnnotationList {
    display: none;
    width: 100%;
    color: #666;
    font-size: 14px;
    padding-top: 16px;
}
.d-body .rankingWrap._firsttime .result_companyAnnotationList {
    display: block;
}
.d-body .result_companyAnnotationList li {
    position: relative;
    padding-left: 1em;
}
.d-body .result_companyAnnotationList li::before {
    content: '※';
    position: absolute;
    left: 0;
    top: 0;
}

/* modal */
.d-body .detail_applyWrap {
    display: none;
}
.d-body .detail_apply {
    padding: 50px;
}
.detail_apply .mainBtn02 {
    margin: 8px auto;
}

.d-body .detail_necessaryWrap {
    display: none;
}
.d-body .detail_necessary {
    padding: 50px;
}
.necessary_title {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: center;
}
.necessary_contentsWrap {
    max-width: 530px;
}
.necessary_contents {
    border-bottom: 1px solid #d9deea;
}
.necessary_contents:first-child {
    border-top: 1px solid #d9deea;
}
.d-body .necessary_head, 
.d-body .necessary_text {
    padding: 20px 24px;
    text-align: left;
    vertical-align: middle;
}
.d-body .necessary_head {
    background-color: transparent;
    border: none;
    float: none;
    box-sizing: border-box;
    background-color: #EEF6FF;
    font-size: 16px;
    font-weight: bold;
    width: 40%;

}
.d-body .necessary_text {
    border: none;
    margin: 0;
    padding: 20px 16px;
    font-size: 16px;
    font-weight: bold;
    font-weight: normal;
}
.d-body .necessary_text *:last-of-type{
    margin-bottom: 0;
}

.d-body .result-opener {
    margin-top: 32px;
}
.d-body .content-opener {
    height: 250px;
    position: relative;
    overflow: hidden;
}
.d-body .content-opener.active {
    height: auto !important;
    overflow: visible;
}
.d-body .content-opener::before {
    content: "";
    width: 100%;
    height: 50%;
    display: block;
    background: linear-gradient(rgba(255, 255, 255, 0) 0, #fff 50%);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}
.d-body .content-opener.active::before {
    background: unset!important;
    height: 0;
}
.d-body .content-closer {
    background-color: transparent;
    border-radius: 100px;
    box-sizing: border-box;
    /*box-shadow: 4px 4px 20px 0px #cccccc;*/
    text-align: left;
    width: fit-content;
    margin: auto;
    padding: 6px 28px;
    position: relative;
    cursor: pointer;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 30px;
    z-index: 1;
    color: #125BF5;
    font-size: 20px;
    font-weight: bold;
}
.d-body .content-closer::after {
    content: '';
    width: 7px;
    height: 7px;
    border-top: solid 2px #125BF5;
    border-right: solid 2px #125BF5;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%) rotate(135deg);
}
.d-body .content-opener.active .content-closer {
    bottom: -88px;
}
.d-body .content-opener.active .content-closer::after {
    transform: rotate(-45deg) translateY(-50%);
}

.d-body .ranking_lower .content-opener {
    height: auto;
    overflow: visible;
    position: unset;
}
.d-body .ranking_lower .content-opener::before {
    visibility: hidden;
}
.d-body .ranking_lower .content-closer {
    display: none;
}

.d-body .result_hyouka {
    margin-bottom: 32px;
}
.d-body .result_voice {
    margin-bottom: 85px;
}
.d-body .ranking_lower .result_voice {
    margin-bottom: 55px;
}
.d-body .result_point {
    margin-bottom: 32px;
}
.d-body .result_point.hidden_ikkatumitumori {
    margin-bottom: 48px;
}
.d-body .result_contentesTitle {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 24px;
    font-size: 24px;
    font-weight: bold;
}
.d-body .result_contentesTitle-img {
    display: block;
    max-width: 48px;
    margin-right: 12px;
}
.d-body .result_hyoukaBox {
    
}

.d-body .result_pointTitle {
    font-size: 20px;
    margin-bottom: 16px;
    font-weight: bold;
    color: #e8621c;
}
.d-body .result_pointTitle .point {
    font-size: 13px;
    background-color: #FFEEE3;
    padding: 5px 16px;
    border-radius: 30px;
    vertical-align: middle;
    /* line-height: 0; */
    display: inline-block;
}
.d-body .result_pointTitle .num {
    font-size: 16px;
    display: none;
}
.d-body .result_point .dotList{
    font-weight: normal;
}
.d-body .result_campImg {
    margin: 0 auto;
    display: block;
    height: auto;
}
.d-body .innerCaution {
    font-size: 10px;
    vertical-align: top;
}

.d-body .result_voice .hikaku-opener {
  max-width: unset;
}
.d-body .result_voiceItem {
    margin-bottom: 20px;
    padding: 24px;
    background-color: #F2F2F2; 
}
.d-body .voiceName-img {
    background-color: #fff;
}
.d-body .voice_recommend {
    display: inline-block;
    margin-bottom: 5px;
    padding: 3px 6px;
    background-color: #E8621C;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
}
.d-body .voiceName-text {
    color: #666;
}
.d-body .voiceMaintext {
    height: unset;
}

/* 上書き */
.d-body .result_pointCompanyName {
    display: none;
}

.d-body #hikaku .easyHikaku_wrap {
    display: flex;
    margin-bottom: 48px;
    justify-content: center;
    gap: 24px;
}
.d-body #hikaku .easyHikakuBtn_btntopText {
    color: #fff;
    font-size: 15px;
    font-weight: bold;
    text-align: center;
    position: relative;
    margin: 0;
}
.d-body #hikaku .easyHikakuBtn_btn {
    width: 100%;
    background-color: #ea0404;
    padding: 10px 0;
    margin: 25px auto 0;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 60px;
    border-radius: 10px;
    flex-direction: column;
    color: #125BF5;
    font-weight: bold;
    transition: 0.5s;

    background-color: #fff;
    border-radius: 4px;
    margin-top: 8px;
    padding: 0;
    position: relative;
    width: 368px;
    height: 62px;
    max-width: 100%;
}
.d-body .easyHikakuBtn_btn::before {
    content: '';
    width: 32px;
    height: 32px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 12px;
    margin: auto;
    background-size: contain;
    background-repeat: no-repeat;
}
.d-body .easyHikakuBtn_btn01::before {
    /*background-image: url(/common/images/icon_timer.svg);*/
    mask-image: url(/common/images/icon_timer.svg);
    -webkit-mask-image: url(/common/images/icon_timer.svg);
    mask-repeat: no-repeat;
    background-color: #125BF5;
}
.d-body .easyHikakuBtn_btn02::before {
    /*background-image: url(/common/images/icon_cheese.svg);*/
    mask-image: url(/common/images/icon_cheese.svg);
    -webkit-mask-image: url(/common/images/icon_cheese.svg);
    mask-repeat: no-repeat;
    background-color: #125BF5;
}
.d-body .easyHikakuBtn_startText {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
    margin: 0;
}
.d-body .easyHikakuBtn_startText .easyHikakuBtn_startTextVar {
    color: #333;
    display: block;
    font-size: 14px;
    line-height: 1.2;
}
.d-body .easyHikakuBtn_startTextVar01::after {
    content: '３秒でかんたん';
}
.d-body .easyHikakuBtn_startTextVar02::after {
    content: '5分でしっかり';
}

.d-body #hikaku .hikaku-opener .hikaku-closer {
    width: 160px;
}
.d-body #hikaku .hikaku-opener._active .hikaku-closer {
    width: 96px;
}
.d-body #hikaku .hikaku-opener::before {
    display: none;
}
.d-body .result-opener._active .hikaku-closer::after {
    top: 10px;
    transform: rotate(135deg);
}
.d-body .hikaku-closer {
    width: 200px;
    margin-bottom: 24px;
    bottom: 0;
}
.d-body ._active .hikaku-closer {
    width: 200px;
}
.d-body .resultList .hikaku-opener._active .hikaku-closer {
    position: relative;
    bottom: 0;
    width: 96px;
}
.d-body .resultList .hikaku-opener._active .hikaku-closer::after {
    transform: rotate(-45deg);
}
.d-body .resultList .hikaku-opener.voice {
    height: 500px;
    padding: 0;
}
.d-body .resultList .hikaku-opener::before {
    content: "";
    width: 100%;
    height: 85%;
    display: block;
    background: linear-gradient(rgba(255, 255, 255, 0) 0, #EEF6FF 80%);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}
.d-body .resultList .hikaku-opener.voice:before {
    height: 30%;
    background: linear-gradient(rgba(255, 255, 255, 0) 0, #fff 80%);
}
.d-body .resultList .hikaku-opener._active {
    height: auto !important;
    overflow: visible;
}
.d-body .resultList .hikaku-opener._active::before {
    background: none!important;
    height: 0;
}
.d-body .result_btnArea {
    margin: 0 -48px;
    padding: 48px 0 16px;
    position: relative;
    z-index: 1;
    border-top: 1px solid #D9DEEA;
}
.d-body .ranking_higher .active + .result_btnArea {
    margin-top: 136px;
}
.d-body .result_btnArea_inner {
    display: flex;
    justify-content: center;
    gap: 24px;
}
.d-body .result_btnArea_inner .mainBtn02 {
    position: relative;
}
.d-body .result_btnArea_inner .mainBtn02::after {
    content: "";
    -webkit-mask-image: url(/common/images/icon_modal.svg);
	-webkit-mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-image: url(/common/images/icon_modal.svg);
	mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center;
    background-color: #fff;
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
}
.d-body .result_btnArea_inner .mainBtn02._notmodal::after {
    display: none;
}
.d-body .mainBtn01, .d-body .mainBtn02 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    transition: 0.5s;
    background-color: #fff;
    border-radius: 4px;
    box-shadow: 0px 4px 15px 0px #dedede;
    padding: 0;
    position: relative;
    max-width: 368px;
    width: 100%;
    height: 62px;
    border: 1px solid #125BF5;
}
.d-body .result_voice .mainBtn01 {
    margin: 40px auto;
}
.d-body .mainBtn02 {
    background-color: #125BF5;
    color: #fff;
}
.d-body .mainBtn_startText {
    color: #125bf5;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
    margin: 0;
}
.d-body .mainBtn02 .mainBtn_startText {
    color: #FFFFFF;
}
.d-body .mainBtn02 .mainBtn_startText_small {
    font-weight: normal;
    font-size: 12px;
    margin-top: -3px;
    display: block;
}
.d-body .kiyaku_agreeText {
    margin-top: 48px;
}
.d-body .kiyaku_agreeText p, 
.d-body .kiyaku_agreeText .dotList-item {
    font-size: 16px;
}
.d-body .kiyaku_agreeText a {
    color: #125BF5;
}
.d-body .result_contentesTitle-img {
    max-width: 45px;
}
.d-body .result_pointTitle {
    margin-bottom: 12px;
}
.d-body .result_fp {
    margin-bottom: 48px;
}
.d-body .result_fp > * + *:not(.cautionList) {
    margin-top: 12px;
}
.d-body .result_fpLink {
    margin-top: 12px;
    text-align: right;
}
.d-body .result_fpLink a {
    color: #125BF5;
    font-size: 16px;
    text-decoration: underline;
}
.d-body .result_fpLink a:hover {
    text-decoration: none;
}


.d-body #hikaku {
    background-color: #EEF6FF;
}
.d-body .hikaku-inner {
    padding-top: 0;
}
.d-body .hikaku-opener {
    /*height: auto;*/
}
.d-body #hikaku .hikaku-opener {
    max-width: 1200px;
}
.d-body .hikaku-opener::before {
    /*display: none;*/
    background: none;
}
.d-body #hikaku .hikaku-opener::before {
    content: "";
    width: 100%;
    height: 85%;
    display: block;
    background: linear-gradient(rgba(255, 255, 255, 0) 0, #EEF6FF 80%);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}
.d-body #hikaku .hikaku-opener._active::before {
    background: none;
    height: 0;
}
.d-body .hikaku-opener_h3 {
    
}

.d-body #pastRanking {
    background-color: #fff;
    box-shadow: 0 0 0 100vmax #fff;
    clip-path: inset(0 -100vmax);
    padding: 80px 83px;
    box-sizing: border-box;
    max-width: 1366px;
    margin: auto;
}
.d-body #pastRanking._bgGray {
    background-color: #efefef;
    box-shadow: 0 0 0 100vmax #efefef;
}

.d-body .pastRanking-select {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}
.d-body .pastRanking-select_wrapper {
    width: 50%;
    max-width: 350px;
    position: relative;
    
}
.d-body .pastRanking-select_box {
    width: 100%;
    padding: 16px;
    border: 1px solid #E0E0E0;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none; /* デフォルトの矢印を非表示 */
    background-color: #fff;
    color: #333;
}
.d-body .pastRanking-select_box._month > span {
    display: none;
}
.d-body .pastRanking-select_wrapper::before {
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 7px solid #125BF5;
    content: "";
    position: absolute;
    right: 15px;
    top: 50%;
    width: 0;
    transform: translateY(-50%);
}
.d-body .pastRanking-submit {
    margin-top: 48px;
}
.d-body .pastRanking-submit_button {
    display: block;
    width: 50%;
    max-width: 368px;
    margin: 0 auto;
    padding: 20px 0;
    background-color: #fff;
    border: 1px solid #125BF5;
    border-radius: 8px;
    box-shadow: 0px 4px 15px 0px #0000001A;
    color: #125BF5;
    font-size: 20px;
    font-weight: 600;
    line-height: 1;
    text-align: center;
    cursor: pointer;
}

.d-body #variousRanking {
    background-color: #EEF6FF;
    box-shadow: 0 0 0 100vmax #EEF6FF;
    clip-path: inset(0 -100vmax);
    padding: 80px 83px;
    box-sizing: border-box;
    max-width: 1366px;
    margin: auto;
}
.d-body #variousRanking .rankingOtherList {
    margin-top: 40px;
}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(1) .rankingOtherList-link:before {

}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(2) .rankingOtherList-link:before {
    background-image: url(/common/images/icon_bland.svg);
}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(3) .rankingOtherList-link:before {
    background-image: url(/common/images/icon_car_kinds.svg);
}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(4) .rankingOtherList-link:before {
    background-image: url(/common/images/icon_location.svg);
}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(5) .rankingOtherList-link:before {

}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(6) .rankingOtherList-link:before {
    background-image: url(/common/images/icon_age.svg);
}
@media screen and (min-width: 501px) {
    .d-body #variousRanking .rankingOtherList-item:nth-of-type(n+4) {
        margin-bottom: 0;
    }
}


.d-body #knowledge {
    padding-top: 80px;
    padding-bottom: 80px;
}
.d-body #knowledge h2 {
    font-size: 40px;
    margin-bottom: 24px;
    font-weight: bold;
    letter-spacing: 0;
    text-align: center!important;
}

.d-body #privilege {
    padding-top: 80px;
    padding-bottom: 80px;
}

.d-body #banner {
    background-color: #F2F2F2;
    box-shadow: 0 0 0 100vmax #F2F2F2;
    clip-path: inset(0 -100vmax);
    padding: 80px 83px;
    box-sizing: border-box;
    max-width: 1366px;
    margin: auto;
} 
.d-body #banner .banner-inner{
    margin: 0 auto;
    margin-bottom: 24px;
    width: 100%;
    display: block;
    max-width: 672px;
}
.d-body #banner img {
    width: 100%;
    height: auto;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}

.cv-tech-fancybox-skin {
    display: none;
}

.d-body #bobunArea {
    max-width: 1200px;
    margin: 20px auto;
    padding: 0 4%;
}
.d-body #bobunArea p {
    font-size: 0.8em;
    text-align: right;
    height: 1em;
    padding-bottom: 1em;
}
.d-body #bobunArea p::after {
    margin: 0;
}

.d-body .result_footer_menu {
    display: none;
    position: fixed;
    bottom: 0;
    width: 1010px;
    transform: translateX(-50%);
    left: 50%;
    background-color: #fff;
    z-index: 99999;
    border-radius: 8px 8px 0px 0px;
    box-shadow: 8px -8px 24px 0px rgba(0, 0, 0, 0.10);
}
.d-body .result_footer_menu-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 16px;
    gap: 24px;
}
.d-body .result_footer_btn_inner {
    flex: 1;
    max-width: 368px;
    width: 100%;
}
.d-body .result_footer_btn_inner .linkBtn-text {
    color: #333;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    position: relative;
    margin: 0;
}
.d-body .linkBtn-text::before, 
.d-body .linkBtn-text::after {
    background-color: #333;
}
.d-body .linkBtn-text::before {
    left: 20px;
}
.d-body .linkBtn-text::after {
    right: 20px;
}
.d-body .result_footer_btn_inner .linkBtn {
    width: 100%;
    margin: 25px auto 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    color: #fff;
    transition: 0.5s;

    background-color: #125BF5;
    border-radius: 4px;
    box-shadow: 0px 4px 15px 0px #dedede;
    margin-top: 8px;
    padding: 0;
    position: relative;
    width: 100%;
    max-width: 368px;
    height: 62px;
}
.d-body .result_footer_btn_inner .linkBtn._01 {
    background-color: #fff;
}
.d-body .result_footer_btn_inner .linkBtn::before {
    content: '';
    width: 32px;
    height: 32px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 12px;
    margin: auto;
    background-image: url(/common/images/icon_timer.svg);
    background-size: contain;
    background-repeat: no-repeat;
}
.d-body .result_footer_btn_inner .linkBtn._01::before {
    background-image: url(/common/images/icon_timer_blue.svg);
}
.d-body .result_footer_btn_inner .linkBtn._02::before {
    background-image: url(/common/images/icon_cheese.svg);
}
.d-body .result_footer_btn_startText {
    color: #FFFFFF;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
    margin: 0;
}
.d-body .result_footer_btn_startText._01{
    color: #125BF5;
}
.d-body .result_footer_btn_startText span {
    color: #D9DEEA;
    display: block;
    font-size: 14px;
    line-height: 1.2;
}
.d-body .result_footer_btn_startText._01 span{
    color: #333;
}


@media screen and (max-width: 500px) {
    .d-body #heading {
        padding: 24px 4%;
    }
    .d-body .h2Normal {
        font-size: 28px;
    }
    .d-body #heading .h2Normal {
        font-size: 20px;
        margin-bottom: 12px;
    }
    .d-body #heading .h2Normal-span {
        font-size: 16px;
    }
    .d-body .h2Normal {
        margin-bottom: 24px;
    }
    .d-body #heading .heading-width {
        text-align: left;
    }
    .d-body #heading .heading-text {
        margin-bottom: 12px;
    }
    .d-body #heading .heading-text a {
        font-size: 1em;
    }
    
    .necessary_title {
        font-size: 18px;
    }
    .necessary_head {
        width: 40%;
    }

    .d-body #sortListWrap {
        padding: 32px 4% 16px;
    }
    .d-body .hikaku-inner {
        padding-bottom: 32px;
    }

    .d-body .sortButtons {
        overflow-x: scroll;
        white-space: nowrap;
        flex-wrap: nowrap;
        justify-content: start;
        gap: 6px;
        margin-bottom: 24px;

        width: calc(100vw - 5%);
    }
    .d-body .sortButton {
        padding: 10px 16px;
        font-size: 14px;
    }

    .d-body #pastRanking {
        padding: 64px 4%;
    }

    .d-body #variousRanking {
        padding: 64px 4%;
    }
    .d-body #variousRanking .rankingOtherList-item:nth-of-type(n+5){
        margin-bottom: 0;
    }

    .d-body #knowledge {
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .d-body #knowledge h2 {
        margin-bottom: 20px;
        font-size: 28px;
    }

    .d-body #privilege {
        padding-top: 64px;
        padding-bottom: 64px;
    }

    .d-body .mainBtn_startText {
        font-size: 20px;
    }

    .d-body #hikaku .easyHikaku_wrap {
        flex-flow: column;
    }
    .d-body #hikaku ._active .hikaku-closer {
        margin-bottom: 0;
    }

    .d-body .categoryTitle {
        line-height: 1;
    }
    .d-body .categoryTitle .date {
        font-size: 16px;
        margin-bottom: 8px;
    }
    .d-body .categoryTitle .title {
        font-size: 28px;
    }
    .d-body .categoryComment {
        text-align: left;
    }

    .d-body .rankingWrap {
        margin-top: 24px;
    }
    .d-body .rankingMenu {
        margin-top: -20px;
        margin-bottom: 24px;
        gap: 5px;
        overflow-x: scroll;
        white-space: nowrap;
    }
    .d-body .categoryContent_item._age .rankingMenu {
        width: calc(100vw - 5%);
    }
    .d-body .rankingMenu_Item {
        font-size: 14px;
        min-width: 100px;
        margin-top: 20px;
    }
    .d-body .categoryContent_item._maker .rankingMenu_Item,
    .d-body .categoryContent_item._car .rankingMenu_Item {
        flex-flow: column;
        padding: 3px 5px;
    }

    /* ranking */
    .d-body .resultList {
        padding: 16px 15px 40px;
        margin-bottom: 16px;
    }
    .d-body .result_company {
        flex-wrap: wrap;
    }
    .d-body .result_companyLogo {
        margin-right: 10px;
        min-height: 54px;
        height: auto;
        box-sizing: border-box;
        display: flex;
        align-items: center;
        width: 120px;
        height: 70px;
        padding: 3px;
    }
    .d-body .result_company::before {
        width: 100%;
        height: 45px;
        margin: 0 0 12px;
    }
    .d-body .result_companyLogoImg {
        margin: auto;
        max-width: 100%;
        height: auto;
    }
    .d-body .result_companyName {
        font-size: 18px;
        width: calc(100% - 130px);
    }
    .d-body .result_company .companyName_label {
        margin-top: 16px;
    }
    .d-body .rankingWrap._firsttime .result_company .companyName_label._pcUser {
        display: none;
    }
    .d-body .rankingWrap._firsttime .result_company .companyName_label._spUser {
        display: block;
    }
    .d-body .result_companyAnnotationList {
        padding-top: 12px;
    }

    .d-body .result_companyBtnWrap {
        margin: 32px 0 0;
        flex: inherit;
        gap: 12px;
        width: 100%;
    }
    .d-body .result_companyBtn {
        min-width: 0;
    }
    .d-body .result_companyBtnWrap .mainBtn01, 
    .d-body .result_companyBtnWrap .mainBtn02 {
        margin: 0;
    }
    .d-body .result_companyBtnWrap .mainBtn02 {
        height: 54px;
        width: 50%;
    }
    .d-body .result_companyBtnWrap .mainBtn_startText {
        font-size: 18px;
    }
    .d-body .result_companyBtnWrap .result-closer {
        width: 50%;
        box-sizing: border-box;
        height: 54px;
        box-shadow: none;
    }
    .d-body .result_companyBtnWrap .result-closer::after {
        right: 5px;
        top: 0;
    }
    .d-body .result_contentesTitle {
        font-size: 18px;
    }
    .d-body .result_hyoukaBox p {
        font-size: 16px;
    }
    .d-body .result_point p {
        font-size: 16px;
    }
    .d-body .result_point p a {
        font-size: 1em;
    }
    
    .d-body .hikaku-closer {
        margin-bottom: 16px;
    }
    
    .d-body .content-closer {
        font-size: 16px;
    }
    .d-body .content-closer .content-closerBtn {
        font-size: 16px;
    }
    .d-body .content-opener.active .content-closer {
        bottom: -60px;
    }

    .d-body .result_btnArea {
        margin: 0 -2%;
        padding: 40px 0 0;
    }
    .d-body .ranking_higher .active + .result_btnArea {
        margin-top: 85px;
    }
    .d-body .result_btnArea_inner {
        flex-wrap: wrap;
    }
    .d-body .kiyaku_agreeText {
        margin-top: 40px;
    }
    .d-body .kiyaku_agreeText .dotList {
        margin-bottom: 0;
    }

    .d-body .pastRanking-select {
        flex-flow: column;
        gap: 16px;
        margin: 24px 0;
    }
    .d-body .pastRanking-select_wrapper {
        width: 100%;
    }
    .d-body .pastRanking-select_box {
        width: 100%;
    }
    .d-body .pastRanking-submit {
        margin-top: 32px;
    }
    .d-body .pastRanking-submit_button {
        width: 90%;
        max-width: 315px;
    }

    .d-body .necessary {
        margin-bottom: 36px;
        position: static;
        width: auto;
        padding: 24px 4% 30px;
        margin: 0 auto;
    }
    .d-body .detail_necessary .necessary_head, 
    .d-body .detail_necessary .necessary_text {
        font-size: 14px;
        padding: 20px 15px;
    }
    .d-body .detail_necessary .necessary_text {
        padding: 16px 10px;
    }

    .d-body .result_footer_menu {
        width: 100%;
        border-radius: 0;
    }
    .d-body .result_footer_menu-inner {
        padding: 10px 15px;
        gap: 15px;
    }
    .d-body .result_footer_btn_inner {
        
    }
    .d-body .result_footer_btn_inner .linkBtn-text {
        font-size: 14px;
    }
    .d-body .linkBtn-text::before {
        left: 20px;
    }
    .d-body .linkBtn-text::after {
        right: 20px;
    }
    .d-body .result_footer_btn_inner .linkBtn::before {
        background: none!important;
    }
    .d-body .result_footer_btn_startText {
        font-size: 16px;
    }
    .d-body .result_footer_btn_startText span {
        font-size: 14px;
    }
    .d-body #banner {
        padding: 64px 15px;
    }
    .d-body #bobunArea p {
        margin: 0 auto 0.5em;
        padding: 0;
        font-size: 12.8px;
        line-height: 1.5;
    }
}


/* ===== heading add 202408 ===== */
.l-newRank.d-body #heading {
    padding: 24px 0 40px;
}
.l-newRank.d-body #heading .heading-width {
    text-align: left;
}
.l-newRank.d-body #heading._firsttime .heading-width {
    text-align: center;
}
.l-newRank.d-body #heading .heading-width > * + * {
    margin-top: 16px;
}
.l-newRank.d-body #heading._firsttime .heading-width > * + * {
    margin-top: 0;
}
.l-newRank.d-body #heading .heading-text a:hover {
    text-decoration: none;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body #heading {
        padding: 12px 4% 24px;
    }
    .l-newRank.d-body #heading._firsttime .heading-width {
        text-align: left;
    }
    .l-newRank.d-body #heading .heading-width > * + *,
    .l-newRank.d-body #heading._firsttime .heading-width > * + * {
        margin-top: 12px;
    }
    .l-newRank.d-body #heading .heading-text {
        margin-bottom: 0;
        font-size: 14px;
    }
    .l-newRank.d-body #heading .heading-text > strong {
        font-size: 14px;
    }
}

/* ===== agenda add 202408 ===== */
.l-newRank.d-body .agenda_toggleBtn {
    padding: 16px 24px;
}
.l-newRank.d-body .agenda_toggleBtn:after {
    right: 15px;
}
.l-newRank.d-body .agenda_title {
    font-size: 20px;
}
.l-newRank.d-body .agenda_toggleDetail {
    display: block;
    padding-bottom: 0;
}
.l-newRank.d-body .agenda_item a {
    padding: 6px 24px 4px 0;
}
.l-newRank.d-body .agenda_item a[class*="_indent"] {
    font-weight: normal;
}
.l-newRank.d-body .agenda_item a._indentH3 {
    padding-left: 24px;
}
.l-newRank.d-body .agenda_item a._indentH4 {
    padding-left: 48px;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .agenda_toggleBtn {
        padding: 12px 15px;
    }
    .l-newRank.d-body .agenda_toggleBtn:after {
        right: 6px;
    }
    .l-newRank.d-body .agenda_title {
        font-size: 18px;
    }
    .l-newRank.d-body .agenda_item a {
        padding: 5px 24px 5px 0;
    }
}

/* ===== title add 202408 ===== */
.l-newRank.d-body .h3Normal {
    margin-bottom: 16px;
    line-height: 1.5;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .categoryTitle .date {
        margin-bottom: 0;
    }
}

/* ===== resultList add 202408 ===== */
.l-newRank.d-body .resultList {
    padding-bottom: 0;
}
.l-newRank.d-body .ranking_higher .result_companyBtnWrap {
    display: flex;
}
.l-newRank.d-body .result_companyBtnWrap .result_companyBtn {
    min-width: 180px;
}
.l-newRank.d-body .result_companyBtnWrap .mainBtn_startText {
    margin-top: 2px;
    font-size: 17px;
}
.l-newRank.d-body .result_companyBtnWrap .mainBtn01::before {
    content: "";
    -webkit-mask-image: url(/common/images/icon_modal.svg);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-image: url(/common/images/icon_modal.svg);
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
    background-color: #125BF5;
    width: 16px;
    height: 16px;
    display: block;
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
}
.l-newRank.d-body .result_companyBtnWrap .mainBtn02::after {
    width: 16px;
    height: 16px;
    right: 8px;
}
.l-newRank.d-body .content-opener {
    height: 218px;
    padding-bottom: 32px;
}
.l-newRank.d-body .content-opener::before {
    height: 60%;
    background: linear-gradient(rgba(255, 255, 255, 0) 0, #fff 50%);
    bottom: 0;
}
.l-newRank.d-body .content-opener.active {
    padding-bottom: 112px;
}
.l-newRank.d-body .content-opener.active::before {
    height: 0;
}
.l-newRank.d-body .content-closer {
    bottom: 32px;
}
.l-newRank.d-body .content-closer::after {
    margin-top: -2px;
}
.l-newRank.d-body .content-opener.active .content-closer::after {
    margin-top: 2px;
}
.l-newRank.d-body .content-opener.active .content-closer {
    bottom: 32px;
}
.l-newRank.d-body .result_point a {
    color: #125BF5;
    text-decoration: underline;
}
.l-newRank.d-body .result_point a:hover {
    text-decoration: none;
}
.l-newRank.d-body .result_pointTitle .point {
    color: #333;
}
.l-newRank.d-body .result_hyouka {
    margin-top: 48px;
    margin-bottom: 48px;
}
.l-newRank.d-body .result_voice {
    margin-bottom: 40px;
}
.l-newRank.d-body .voice_recommend {
    box-sizing: border-box;
    border: 2px solid #E8621C;
    background: #fff;
    color: #333;
}
.l-newRank.d-body .hikaku-closer {
    margin-bottom: 34px;
}
.l-newRank.d-body .result_btnArea {
    padding: 40px 0 0;
}
.l-newRank.d-body .result_btnArea {
    z-index: 0;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .result_companyBtnWrap .result_companyBtn {
        min-width: initial;
    }
    .l-newRank.d-body .result_companyBtnWrap .mainBtn_startText {
        margin-top: -2px;
        font-size: 15px;
    }
    .l-newRank.d-body .result_companyBtnWrap .mainBtn01::before {
        width: 12px;
        height: 12px;
    }
    .l-newRank.d-body .result_companyBtnWrap .mainBtn02::after {
        width: 12px;
        height: 12px;
    }
    .l-newRank.d-body .result_company::before {
        height: 40px;
    }
    .l-newRank.d-body .result_companyName {
        width: calc(100% - 130px);
        font-size: 18px;
    }
    .l-newRank.d-body .result_companyBtnWrap {
        justify-content: center;
    }
    .l-newRank.d-body .result_companyBtnWrap .mainBtn01 {
        height: 54px;
        width: 50%;
    }
    .l-newRank.d-body .content-opener {
        height: 210px;
    }
    .l-newRank.d-body .content-opener.active {
        padding-bottom: 115px;
    }
    .l-newRank.d-body .content-opener::before {
        width: 100%;
        height: 54%;
    }
    .l-newRank.d-body .content-closer {
        min-height: 35px;
        bottom: 24px;
    }
    .l-newRank.d-body .content-closer::after {
        margin-top: -3px;
    }
    .l-newRank.d-body .content-opener.active .content-closer {
        bottom: 40px;
    }
    .l-newRank.d-body .result_pointTitle {
        margin-bottom: 12px;
    }
    .l-newRank.d-body .result_fpLink {
        margin-top: 12px;
    }
    .l-newRank.d-body .result_contentesTitle {
        margin-bottom: 24px;
        font-size: 18px;
    }
    .l-newRank.d-body .voice_recommend {
        margin-bottom: 5px;
        font-size: 12px;
    }
    .l-newRank.d-body .textNormal {
        font-size: 14px;
    }
    .l-newRank.d-body .hikaku-closer {
        margin-bottom: 10px;
    }
}

/* ===== hikaku add 202408 ===== */
.l-newRank.d-body #hikaku {
    margin-top: 32px;
}
.l-newRank.d-body #sortListWrap + #hikaku {
    margin-top: 0;
}
.l-newRank.d-body  #hikaku .hikaku-closer {
    margin-bottom: 24px;
}
.l-newRank.d-body .hikaku-opener {
    padding: 40px 48px;
}
.l-newRank.d-body .hikaku-opener_flow .hikaku-opener_flowIcon img {
    height: auto;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body  #hikaku .hikaku-closer {
        margin-bottom: 16px;
    }
    .l-newRank.d-body #hikaku ._active .hikaku-closer {
        margin-bottom: 0;
    }
    .l-newRank.d-body .hikaku-opener {
        padding: 4%;
    }
    .l-newRank.d-body .outerTextLink {
        margin-top: 16px;
    }
}

/* ===== sortButton add 202408 ===== */
.l-newRank.d-body .sortButtons {
    margin-bottom: 32px;
}
.l-newRank.d-body .sortButton {
    margin-bottom: 0;
    padding: 17px 20px 15px;
    font-family: /* Verdana,Helvetica,Arial, */ '繝偵Λ繧ｮ繝手ｧ偵ざ Pro W3', 'Hiragino Kaku Gothic Pro', '繝｡繧､繝ｪ繧ｪ', Meiryo, '�ｭ�ｳ �ｰ繧ｴ繧ｷ繝�け', sans-serif;
    letter-spacing: 0;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .sortButtons {
        margin-bottom: 24px;
    }
    .l-newRank.d-body .sortButton {
        min-width: 60px;
        padding: 10px 12px 10px 13px;
    }
}

/* ===== categoryContent add 202408 ===== */
.l-newRank.d-body .categoryContent_item.active {
    display: flex;
    justify-content: center;
}

/* ===== breadcrumbs add 202408 ===== */
@media screen and (max-width: 500px) {
    .l-newRank.d-body #breadcrumbs .container ol {
        line-height: 1.6;
        overflow-x: scroll;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
        margin: 0;
        padding-left: 10px;
        width: 100%;
        box-sizing: border-box;
    }
    .l-newRank.d-body #breadcrumbs .container ol::-webkit-scrollbar {
        display: none;
    }
}

/* ===== rankingOtherList-link add 202408 ===== */
.l-newRank.d-body .rankingOtherList-link {
    box-shadow: none;
}

/* ===== knowledge add 202408 ===== */
.l-newRank.d-body #pastRanking {
    background-color: #EEF6FF;
    box-shadow: 0 0 0 100vmax #EEF6FF;
}
.l-newRank.d-body #pastRanking._white {
    background-color: #fff;
    box-shadow: 0 0 0 100vmax #fff;
}
.l-newRank.d-body #pastRanking._bgGray {
    background-color: #f7f7f7;
    box-shadow: 0 0 0 100vmax #f7f7f7;
}

/* ===== knowledge add 202408 ===== */
.l-newRank.d-body .rankingWrap._firsttime .c-otherRank {
    display: none;
}

/* ===== result_companyAnnotationList add 202408 ===== */
.l-newRank.d-body .rankingWrap._firsttime .result_companyAnnotationList._spUser {
    display: none;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .rankingWrap._firsttime .result_companyAnnotationList._pcUser {
        display: none;
    }
    .l-newRank.d-body .rankingWrap._firsttime .result_companyAnnotationList._spUser {
        display: block;
    }
}

/* ===== header_news add 202408 ===== */
@media screen and (max-width: 500px) {
    .l-newRank.d-body .header_news_inner p a {
        padding: 5px;
    }
}

/* ===== result_footer_menu add 202411===== */
.l-newRank.d-body .result_footer_menu-inner {
    padding: 12px 16px;
}
.l-newRank.d-body .result_footer_btn_inner .linkBtn {
    height: 56px;
}
.l-newRank.d-body .result_footer_menu_btn {
    position: absolute;
    top: -34px;
    right: 0;
    padding: 7px 30px 6px 15px;
    border-radius: 8px 8px 0 0;
    background: #fff;
    font-weight: bold;
    color: #125BF5;
    box-shadow: 4px 4px 20px rgba(0,0,0,0.15);
    cursor: pointer;
}
.l-newRank.d-body .result_footer_menu_btn::before {
    content: "";
    display: block;
    position: absolute;
    bottom: -50px;
    right: 0;
    width: 150%;
    height: 50px;
    background: #fff;
    cursor: default;
}
.l-newRank.d-body .result_footer_menu_btn::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 15px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #125BF5;
    border-right: 2px solid #125BF5;
    transition: transform .5s;
}
.l-newRank.d-body .result_footer_menu_btn.is-close::after {
    margin-top: -1px;
    transform: rotate(-45deg);
}
.l-newRank.d-body .result_footer_menu_btn.is-open::after {
    margin-top: -5px;
    transform: rotate(135deg);
}
.l-newRank.d-body .result_footer_menu_btn_text {
    font-size: 14px;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .result_footer_menu-inner {
        padding: 10px 15px;
    }
    .l-newRank.d-body .result_footer_btn_inner .linkBtn {
        height: 48px;
    }
}

/* ===== cautionList add 202412 ===== */
.l-newRank.d-body .cautionList .cautionList-item {
    font-size: 14px;
}
.l-newRank.d-body .cautionList .cautionList-item a {
    font-size: 14px;
}

/* ===== innerCaution add 202412 ===== */
.l-newRank.d-body .innerCaution {
    font-size: 10px;
}

/* ===== scrolltop add 202412 ===== */
.l-newRank.d-body .scrolltop._fixed {
    bottom: 160px;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .scrolltop._fixed {
        bottom: 145px;
    }
}


/* ========================================
      layout add 202408
========================================= */

/* == l-newRank == */
.l-newRank * {
    font-size: 16px;
}

/* == l-section == */
.l-newRank .l-section--blue {
    background: #EEF6FF;
}
.l-newRank .l-section--gray {
    background: #f7f7f7;
}
.l-newRank .l-section__inner {
    max-width: 1366px;
    margin: 0 auto;
    padding: 80px 83px;
    box-sizing: border-box;
}
.l-newRank #heading + .l-section .l-section__inner {
    padding-top: 40px;
}
.l-newRank .l-section--w1078 .l-section__inner {
    max-width: 1078px;
}

/* == l-subSection == */
.l-newRank .l-subSection > *:not(:first-child) + * {
    margin-top: 40px;
}
.l-newRank .l-subSection > div > *:not(:first-child) + *:not(.cautionList),
.l-newRank .l-subSection > div > p + p {
    margin-top: 16px;
}
.l-newRank .l-subSection + .l-subSection {
    margin-top: 40px;
}

@media screen and (max-width: 500px) {
    
    /* == l-section == */
    .l-newRank .l-section p {
        width: auto;
        margin: 0;
        font-size: 16px;
    }
    .l-newRank .l-section strong {
        font-size: 16px;
    }
    .l-newRank .l-section__inner {
        padding: 64px 4%;
    } 
    .l-newRank #heading + .l-section .l-section__inner {
        padding-top: 24px;
    }
    
    /* == l-subSection == */
    .l-newRank .l-subSection > *:not(:first-child) + * {
        margin-top: 32px;
    }
    .l-newRank .l-subSection + .l-subSection {
        margin-top: 32px;
    }
}


/* ========================================
      Component add 202408
========================================= */

/* == c-textLink == */
.l-newRank .c-textLink {
    color: #125BF5;
    text-decoration: underline;
    font-size: 16px;
}
.l-newRank .c-textLink:hover {
    color: #125BF5;
    text-decoration: none;
}
.l-newRank .c-textLink[target="_blank"]::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 12px;
    margin: 0 4px;
    background: url(/common/images/icon_link_b.svg) no-repeat center/ cover;
}
.l-newRank .c-textLink--fz14 {
    font-size: 14px;
}

/* == c-categoryRank == */
.l-newRank .c-categoryRank {
    display: grid;
    grid-gap: 24px;
}
.l-newRank .c-categoryRank__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px;
    background: #EEF6FF;
    box-shadow: 5px 5px 10px 0px rgba(0,0,0,0.1);
}
.l-newRank .c-categoryRank__link:hover > * {
    opacity: 0.8;
}
.l-newRank .c-categoryRank__rank {
    display: flex;
    align-items: center;
}
.l-newRank .c-categoryRank__rank::before {
    content: "";
    display: block;
    width: 60px;
    height: 60px;
    margin-right: 16px;
}
.l-newRank .c-categoryRank--rank1 .c-categoryRank__rank::before {
    background: url(/dmg-ins/car/ranking/images/icon_rank1.png) no-repeat center / cover;
}
.l-newRank .c-categoryRank--rank2 .c-categoryRank__rank::before {
    background: url(/dmg-ins/car/ranking/images/icon_rank2.png) no-repeat center / cover;
}
.l-newRank .c-categoryRank--rank3 .c-categoryRank__rank::before {
    background: url(/dmg-ins/car/ranking/images/icon_rank3.png) no-repeat center / cover;
}
.l-newRank .c-categoryRank__logo {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 160px;
    height: 86px;
    border: 1px solid #D9DEEA;
    background: #fff;
    box-sizing: border-box;
}
.l-newRank .l-section .c-categoryRank__name {
    margin-top: 12px;
    font-size: 20px;
    font-weight: bold;
}

/* == c-numberList == */
.l-newRank .c-numberList > li + li {
    margin-top: 24px;
}
.l-newRank .c-numberList__title {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
}
.l-newRank .l-section .c-numberList__number {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    margin-right: 12px;
    padding: 2px 0 0 2px;
    border-radius: 50%;
    background: #E8621C;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    box-sizing: border-box;
}
.l-newRank .l-section .c-numberList__text {
    flex: 1;
    padding: 6px 0 0;
    font-size: 30px;
    font-weight: bold;
    line-height: 1.5;
}

/* == c-heading3 == */
.l-newRank .c-heading3 {
    margin-bottom: 8px;
    font-size: 30px;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0;
}

/* == c-heading4 == */
.l-newRank .c-heading4 {
    margin-bottom: 8px;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0;
}
.l-newRank .c-heading4--line {
    padding-left: 8px;
    border-left: 6px solid #E8621C;
}
.l-newRank .c-heading4--line > span {
    display: inline-block;
    padding-top: 6px;
    font-size: 24px;
}
.l-newRank .c-heading4--mb16 {
    margin-bottom: 16px;
}

/* == c-image == */
.l-newRank .c-image img {
    width: 100%;
    height: auto;
}

/* == c-table01 == */
.l-newRank .c-table01 {
    width: 100%;
    background: #fff;
}
.l-newRank .c-table01 th,
.l-newRank .c-table01 td {
    position: relative;
    height: 40px;
    padding: 8px 9px;
    border: 1px solid #949494;
    font-size: 18px;
    line-height: 1.2;
    text-align: center;
    vertical-align: middle;
    box-sizing: border-box;
    z-index: 0;
}
.l-newRank .c-table01 th {
    font-weight: bold;
}
.l-newRank .c-table01--w200 {
    width: 200px;
}
.l-newRank .c-table01--w176 {
    width: 176.5px;
}
.l-newRank .c-table01--w20p {
    width: 20%;
}
.l-newRank .c-table01--w25p {
    width: 25%;
}
.l-newRank .c-table01--w55p {
    width: 55%;
}
.l-newRank .c-table01 .c-table01--h122 {
    height: 122px;
}
.l-newRank .c-table01--bgBlue {
    background: #EEF6FF;
}
.l-newRank .c-table01--bgGray {
    background: #E0E0E0;
}
.l-newRank .c-table01--bgCircle {
    display: inline-block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 60px;
    height: 60px;
    margin: -35px 0 0 -35px;
    border: 5px solid #DEE6F9;
    border-radius: 50%;
    z-index: -1;
}
.l-newRank .c-table01--bgBad {
    display: inline-block;
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -40px 0 0 -2px;
    z-index: -1;
}
.l-newRank .c-table01--bgBad::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
    width: 5px;
    height: 80px;
    background: #DEE6F9;
    transform: rotate(135deg);
}
.l-newRank .c-table01--bgBad::after {
    content: "";
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
    width: 5px;
    height: 80px;
    background: #DEE6F9;
    transform: rotate(225deg);
}
.l-newRank .c-table01 .c-table01--fz14 {
    font-size: 14px;
    line-height: 1.665;
}

/* == c-table02 == */
.l-newRank .c-table02 {
    width: 100%;
    height: 100%;
}
.l-newRank .c-table02 th,
.l-newRank .c-table02 td {
    height: 40px;
    padding: 7px 9px 5px;
    border: 1px solid #949494;
    font-size: 18px;
    line-height: 1.2;
    box-sizing: border-box;
    vertical-align: middle;
}
.l-newRank .c-table02 th,
.l-newRank .c-table02 .c-textLink {
    font-weight: bold;
    font-size: 18px;
}
.l-newRank .c-table02 th {
    width: 33%;
    background: #EEF6FF;
}
.l-newRank .c-table02 td {
    background: #fff;
}

/* == c-table03 == */
.l-newRank .c-table03 {
    width: 100%;
    background: #fff;
}
.l-newRank .c-table03 th,
.l-newRank .c-table03 td {
    border: 1px solid #949494;
    text-align: center;
    vertical-align: middle;
    font-size: 16px;
    line-height: 1.2;
}
.l-newRank .c-table03 th {
    font-size: 18px;
    font-weight: bold;
}
.l-newRank .c-table03 td {
    padding: 24px 20px;
}
.l-newRank .c-table03 td > * + * {
    margin-top: 16px;
}
.l-newRank .c-table03--bgGray {
    height: 50px;
    background: #e0e0e0;
}
.l-newRank .c-table03--bgBlue {
    min-height: 200px;
    background: #DEE6F9;
}
.l-newRank .c-table03--bgBlue > span {
    font-size: 18px;
    writing-mode: vertical-rl;
}
.l-newRank .c-table03--w50 {
    width: 50px;
}
.l-newRank .c-table03 figure img {
    height: auto;
}

/* == c-linkList == */
.l-newRank .c-linkList {
    display: grid;
    grid-gap: 40px;
    grid-template-columns: repeat(2, 1fr);
}
.l-newRank .c-linkList > li {
    border-right: 2px solid #125BF5;
    border-bottom: 2px solid #125BF5;
    border-left: 2px solid #125BF5;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}
.l-newRank .c-linkList__title {
    margin-bottom: 0;
    padding: 9px 10px;
    background: #125BF5;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    line-height: 1.5;
}
.l-newRank .c-linkList__list {
    padding: 20px;
}
.l-newRank .c-linkList__list > li {
    display: flex;
    align-items: center;
    position: relative;
    font-size: 16px;
}
.l-newRank .c-linkList__list > li::before {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    margin: -3px 8px 0 0;
    border-radius: 50%;
    background: #125BF5;
}
.l-newRank .c-linkList__list > li + li {
    margin-top: 8px;
}

/* == c-pointList == */
.l-newRank .c-pointList li + li {
    margin-top: 24px;
}
.l-newRank .c-pointList__title {
    display: flex;
    align-items: center;
    letter-spacing: 0;
}
.l-newRank .result_pointTitle .c-pointList__point {
    margin-right: 8px;
    box-sizing: border-box;
}
.l-newRank .result_pointTitle .c-pointList__point .num {
    display: inline-block;
}
.l-newRank .c-pointList__text {
    display: block;
    flex: 1;
    padding-top: 4px;
    color: #333;
    font-size: 24px;
    line-height: 1.5;
}
.l-newRank .c-pointList li > p:not(:first-child) + p {
    margin-top: 12px;
}

/* == c-adjustHeader == */
.l-newRank .c-adjustHeader--active {
    margin-top: -115px;
    padding-top: 115px;
}

/* == c-meritList == */
.l-newRank .c-meritList > li {
    font-size: 16px;
}
.l-newRank .c-meritList > li > strong {
    display: inline-block;
    margin-bottom: 4px;
    font-size: 18px;
}
.l-newRank .c-meritList > li + li {
    margin-top: 16px;
}

/* == c-otherRank == */
.l-newRank .c-otherRank {
    margin-bottom: 32px;
}
.l-newRank .l-section .c-otherRank__title {
    margin-bottom: 8px;
    padding-left: 8px;
    border-left: 4px solid #125BF5;
    color: #125BF5;
    font-weight: bold;
}
.l-newRank .c-otherRank__title > span {
    display: inline-block;
    padding-top: 4px;
    font-size: 16px;
}
.l-newRank .c-otherRank__scroll {
    padding-bottom: 8px;
    overflow-x: auto;
    overflow-y: hidden;
}
.l-newRank .c-otherRank__scroll::-webkit-scrollbar {
    height: 8px;
    background: none;
}
.l-newRank .c-otherRank__scroll::-webkit-scrollbar-thumb {
    border-radius: 8px;
    background: #d9d5d1;
}
.l-newRank .c-otherRank__button {
    display: flex;
    align-items: center;
}
.l-newRank .c-otherRank__button > li,
.l-newRank .c-otherRank__button > li > a {
    display: flex;
    align-items: center;
    flex: none;
    min-height: 28px;
    padding: 4px 10px 3px;
    border-radius: 24px;
    background: #f2f2f2;
    color: #666;
    font-size: 14px;
    font-weight: bold;
    box-sizing: border-box;
}
.l-newRank .c-otherRank__button > li:has(> a) {
    padding: 0;
}
.l-newRank .c-otherRank__button > li > a {
    background: #125BF5;
    color: #fff;
}
.l-newRank .c-otherRank__button > li > a::before {
    display: none;
}
.l-newRank .c-otherRank__button > li + li {
    margin-left: 8px;
}

@media screen and (max-width: 500px) {
    
    /* == c-categoryRank == */
    .l-newRank .c-categoryRank__link {
        padding: 10px;
    }
    .l-newRank .c-categoryRank {
        grid-gap: 16px;
    }
    .l-newRank .c-categoryRank__rank::before {
        width: 32px;
        height: 32px;
        margin-right: 8px;
    }
    .l-newRank .c-categoryRank__logo {
        width: 125px;
        height: 65px;
    }
    .l-newRank .l-section .c-categoryRank__name {
        margin-top: 8px;
        font-size: 14px;
    }
    
    /* == c-numberList == */
    .l-newRank .l-section .c-numberList__number {
        width: 35px;
        height: 35px;
        margin-bottom: 0;
        padding: 0 0 0 1px;
        font-size: 18px;
    }
    .l-newRank .l-section .c-numberList__text {
        margin-bottom: 0;
        padding: 0;
        font-size: 24px;
    }
    
    /* == c-heading3 == */
    .l-newRank .c-heading3 {
        font-size: 24px;
    }
    
    /* == c-heading4 == */
    .l-newRank .c-heading4 {
        font-size: 20px;
    }
    .l-newRank .c-heading4--line > span {
        display: block;
        padding: 1px 0;
        font-size: 20px;
    }
    
    /* == c-image == */
    .l-newRank .c-image--spW560 img {
        width: 560px;
        max-width: initial;
        height: auto;
    }
    
    /* == c-table01 == */
    .l-newRank .c-table01 {
        width: 560px;
    }
    
    /* == c-table02 == */
    .l-newRank .c-table02 th,
    .l-newRank .c-table02 td {
        display: flex;
        align-items: center;
        width: 100%;
        height: auto;
        min-height: 40px;
    }
    .l-newRank .c-table02 th,
    .l-newRank .c-table02 td {
        padding: 6px 9px;
    }
    .l-newRank .c-table02 th {
        justify-content: center;
        border-bottom: 0;
        font-weight: bold;
    }
    .l-newRank .c-table02 tr + tr th {
        border-top: 0;
    }
    
    /* == c-table03 == */
    .l-newRank .c-table03 {
        width: 560px;
    }
    .l-newRank .c-table03 td {
        padding: 16px;
        vertical-align: top;
    }
    .l-newRank .l-section .c-table03 p {
        font-size: 14px;
    }
    
    /* == c-linkList == */
    .l-newRank .c-linkList {
        grid-gap: 16px;
        grid-template-columns: repeat(1, 1fr);
    }
    .l-newRank .c-linkList__list > li::before {
        margin: -1px 8px 0 0;
    }
    
    /* == c-pointList == */
    .l-newRank .c-pointList__title.result_pointTitle {
        display: block;
        margin-bottom: 8px;
    }
    .l-newRank .c-pointList__text {
        margin-top: 8px;
        padding-top: 0;
        font-size: 20px;
    }
    
    /* == c-adjustHeader == */
    .l-newRank .l-section .c-adjustHeader--active {
        margin-top: -60px;
        padding-top: 60px;
    }
    
    /* == c-otherRank == */
    .l-newRank .c-otherRank__scroll {
        padding-bottom: 0;
    }
    .l-newRank .c-otherRank__scroll::-webkit-scrollbar {
        display: none;
    }
    .l-newRank .c-otherRank__title > span {
        padding-top: 2px;
    }
    .l-newRank .c-otherRank__button > li,
    .l-newRank .c-otherRank__button > li > a {
        padding: 3px 10px;
        font-size: 12px;
    }
    .l-newRank .c-otherRank__button > li + li {
        margin-left: 4px;
    }
    
    /* == c-spScroll == */
    .l-newRank .c-spScroll {
        overflow-x: scroll;
        -webkit-overflow-scrolling:touch
    }
    .l-newRank .c-spScroll::-webkit-scrollbar {
        display: none;
    }
    .l-newRank .c-spScroll--wsNw {
        white-space: nowrap;
    }
}


/* ========================================
      Project add 202408
========================================= */

/* == p-mainVisual == */
.l-newRank .p-mainVisual {
    margin-bottom: 16px;
}
.l-newRank .p-mainVisual img {
    width: 100%;
    height: auto;
}

/* == p-contractRank == */
.l-newRank .p-contractRank {
    display: grid;
    grid-gap: 24px;
    grid-template-columns: repeat(3, 1fr);
}
.l-newRank .p-contractRank__item {
    display: flex;
    align-items: center;
    position: relative;
    padding: 10px 10px 25px 55px;
    border-radius: 4px;
    background: #fff;
    box-shadow: 5px 5px 10px 0px rgba(0,0,0,0.1);
    font-weight: bold;
}
.l-newRank .p-contractRank__item::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 15px;
    border-radius: 0 0 4px 4px;
    background: #125BF5;
}
.l-newRank .p-contractRank__item::after {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    bottom: 6px;
    width: 5px;
    height: 5px;
    margin-left: -3px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(135deg);
}
.l-newRank .p-contractRank__item:hover > * {
    opacity: 0.8;
}
.l-newRank .l-section .p-contractRank__number {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 10px;
    width: 30px;
    height: 40px;
    background: #F2F2F2;
}
.l-newRank .l-section .p-contractRank__number::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 15px solid transparent;
    border-left: 15px solid transparent;
    border-bottom: 8px solid #fff;
    border-top: 0;
}
.l-newRank .l-section .p-contractRank--rank1 .p-contractRank__number {
    background: #E2CA79;
}
.l-newRank .l-section .p-contractRank--rank2 .p-contractRank__number {
    background: #D4D4D4;
}
.l-newRank .l-section .p-contractRank--rank3 .p-contractRank__number {
    background: #E7B78A;
}
.l-newRank .p-contractRank__logo {
    display: flex;
    align-items: center;
    width: 80px;
    height: 48px;
    margin-right: 10px;
}
.l-newRank .p-contractRank__logo img {
    width: 100%;
    height: auto;
}
.l-newRank .p-contractRank__name {
    flex: 1;
}

/* == p-categoryRank == */
.l-newRank .p-categoryRank {
    display: flex;
    padding-bottom: 24px;
    overflow-x: auto;
}
.l-newRank .p-categoryRank::-webkit-scrollbar {
    height: 8px;
    background: none;
}
.l-newRank .p-categoryRank::-webkit-scrollbar-thumb {
    border-radius: 8px;
    background: #d9d5d1;
}
.l-newRank .p-categoryRank > li {
    min-width: 320px;
    padding: 0 24px;
}
.l-newRank .p-categoryRank > li:first-child {
    padding-left: 16px;
}
.l-newRank .p-categoryRank > li:last-child {
    padding-right: 16px;
}
.l-newRank .p-categoryRank > li + li {
    margin-left: -24px;
}
.l-newRank .p-categoryRank__title {
    margin-bottom: 16px;
    font-size: 24px;
    font-weight: bold;
    color: #125BF5;
    line-height: 1.5;
    text-align: center;
    letter-spacing: 0;
}

/* == p-relatedLink == */
.l-newRank .p-relatedLink {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
}
.l-newRank .p-relatedLink__list {
    display: flex;
    flex-wrap: wrap;
    margin-left: 24px;
}
.l-newRank .p-relatedLink__list > li:not(:last-child) {
    margin-right: 24px;
}

/* == p-fourCompensation == */
.l-newRank .p-fourCompensation {
    display: flex;
    gap: 16px;
    width: 100%;
    font-weight: bold;
    text-align: center;
}
.l-newRank .p-fourCompensation--blue {
    gap: 16px;
    width: 74%;
    padding: 24px 24px 18px;
    border-radius: 8px;
    background: #EEF6FF;
}
.l-newRank .p-fourCompensation--orange {
    width: 26%;
    padding: 24px 24px 18px;
    border-radius: 8px;
    background: #FFEEE3;
}
.l-newRank .p-fourCompensation__image {
    display: flex;
    gap: 16px;
}
.l-newRank .p-fourCompensation__image figure {
    width: 100%;
    padding: 16px 12px;
    border-radius: 8px;
    color: #fff;
}
.l-newRank .p-fourCompensation--blue .p-fourCompensation__image figure { 
    background: #125BF5;
}
.l-newRank .p-fourCompensation--orange .p-fourCompensation__image figure { 
    background: #E8621C;
}
.l-newRank .p-fourCompensation__image figure img {
    height: auto;
}
.l-newRank .p-fourCompensation__image figcaption {
    margin-top: 8px;
    font-size: 20px;
    line-height: 1.5;
}
.l-newRank .l-section .p-fourCompensation__text {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 60px;
    margin-top: 12px;
    font-size: 20px;
}

/* == p-compensationType == */
.l-newRank .p-compensationType col {
    width: 16.66666666666667%;
}
.l-newRank .p-compensationType th,
.l-newRank .p-compensationType td {
    border: 1px solid #949494;
}
.l-newRank .p-compensationType thead th {
    padding: 14px 10px;
    background: #e0e0e0;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
}
.l-newRank .p-compensationType tbody td {
    padding: 8px;
    background: #fff;
}
.l-newRank .p-compensationType__image {
    text-align: center;
}
.l-newRank .p-compensationType__text {
    margin-top: 8px;
}
.l-newRank .l-section .p-compensationType__title {
    min-height: 51px;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.4;
}
.l-newRank .l-section .p-compensationType__desc {
    margin-top: 4px;
}

/* == p-needDoc == */
.l-newRank .p-needDoc > li + li {
    margin-top: 24px;
}
.l-newRank .p-needDoc > li > *:not(:first-child) + * {
    margin-top: 12px;
}
.l-newRank .p-needDoc__title {
    margin-bottom: 8px;
    font-size: 20px;
    font-weight: bold;
}
.l-newRank .p-needDoc__col {
    display: flex;
}
.l-newRank .p-needDoc__col > div {
    width: 50%;
}
.l-newRank .p-needDoc__col > div > * + * {
    margin-top: 4px;
}
.l-newRank .p-needDoc__colTitle {
    font-weight: bold;
}
.l-newRank .p-needDoc__colList > li::before {
    content: "・";
}

/* == p-contractFlow == */
.l-newRank .l-section .p-contractFlow__title {
    margin-bottom: 12px;
    font-size: 20px;
    font-weight: bold;
}
.l-newRank .l-subSection > div .p-contractFlow__list {
    margin-top: 0;
}
.l-newRank .p-contractFlow__list > li {
    display: flex;
}
.l-newRank .l-section .p-contractFlow__number {
    position: relative;
    width: 28px;
    margin-right: 8px;
}
.l-newRank .p-contractFlow__list > li:not(:last-child) .p-contractFlow__number::before {
    content: "";
    display: inline-block;
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 2px;
    height: 100%;
    background: #E0E0E0;
    transform: translateX(-50%);
    z-index: -1;
}
.l-newRank .p-contractFlow__number span {
    width: 100%;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #E0E0E0;
    font-weight: bold;
}
.l-newRank .p-contractFlow__desc {
    flex: 1;
    margin-top: 3px;
}
.l-newRank .p-contractFlow__list > li:not(:last-child) .p-contractFlow__desc {
    padding-bottom: 16px;
}
.l-newRank .p-contractFlow__list .cautionList {
    margin-bottom: 0;
}

/* == p-headDetail == */
.l-newRank.d-body #heading .p-headDetail {
    margin-top: 0;
    font-weight: bold;
}
.l-newRank .p-headDetail__list {
    display: flex;
}
.l-newRank .p-headDetail__title {
    min-width: 80px;
}
.l-newRank .p-headDetail__desc {
    display: flex;
    flex: 1;
}
.l-newRank .p-headDetail__desc::before {
    content: "：";
    display: block;
}
.l-newRank .p-headDetail__desc a {
    font-weight: normal;
}

/* == p-rankRead == */
.l-newRank .l-section .p-rankRead {
    margin-top: 40px;
}
.l-newRank .l-section .p-rankRead > *:not(:first-child) + * {
    margin-top: 16px;
}
.l-newRank .l-section .p-rankRead__title {
    margin-bottom: 16px;
    font-size: 18px;
    font-weight: bold;
}

@media screen and (max-width: 500px) {
    
    /* == p-mainVisual == */
    .l-newRank .p-mainVisual {
        margin-bottom: 12px;
    }
    
    /* == p-contractRank == */
    .l-newRank .p-contractRank {
        grid-gap: 16px;
        grid-template-columns: repeat(1, 1fr);
    }
    
    /* == p-categoryRank == */
    .l-newRank .p-categoryRank {
        padding-bottom: 16px;
    }
    .l-newRank .p-categoryRank::-webkit-scrollbar {
        display: none;
    }
    .l-newRank .p-categoryRank > li {
        min-width: 200px;
        padding: 0 16px;
    }
    .l-newRank .p-categoryRank > li + li {
        margin-left: -16px;
    }
    .l-newRank .p-categoryRank__title {
        font-size: 20px;
    }
    
    /* == p-relatedLink == */
    .l-newRank .p-relatedLink {
        display: block;
        margin-top: 32px;
    }
    .l-newRank .p-relatedLink > p {
        width: 100%;
        margin: 0;
    }
    .l-newRank .p-relatedLink__list {
        display: block;
        margin-top: 8px;
        margin-left: 0;
    }
    .l-newRank .p-relatedLink__list > li:not(:last-child) {
        margin-right: 0;
        margin-bottom: 8px;
    }
    
    /* == p-fourCompensation == */
    .l-newRank .p-fourCompensation {
        flex-direction: column;
        gap: 12px;
    }
    .l-newRank .p-fourCompensation br {
        display: none;
    }
    .l-newRank .p-fourCompensation__image {
        gap: 12px;
    }
    .l-newRank .p-fourCompensation__image figure {
        padding: 8px;
    }
    .l-newRank .p-fourCompensation__image figcaption {
        font-size: 14px;
    }
    .l-newRank .p-fourCompensation--blue,
    .l-newRank .p-fourCompensation--orange {
        width: auto;
        padding: 16px 16px 12px;
    }
    .l-newRank .l-section .p-fourCompensation__text {
        min-height: auto;
        margin-top: 8px;
        font-size: 14px;
    }
    
    /* == p-compensationType == */
    .l-newRank .p-compensationType {
        border: 1px solid #949494;
    }
    .l-newRank .p-compensationType col {
        width: 100%;
    }
    .l-newRank .p-compensationType th,
    .l-newRank .p-compensationType td {
        border: none;
    }
    .l-newRank .p-compensationType thead th {
        padding: 9px 10px;
    }
    .l-newRank .p-compensationType tbody td {
        display: block;
        border-top: 1px solid #949494;
        padding: 12px;
    }
    .l-newRank .p-compensationType__box {
        display: flex;
    }
    .l-newRank .p-compensationType__image {
        width: 80px;
        margin-right: 12px;
    }
    .l-newRank .p-compensationType__text {
        margin-top: 0;
        flex: 1;
    }
    .l-newRank .l-section .p-compensationType__title {
        min-height: initial;
        text-align: left;
    }
    
    /* == p-needDoc == */
    .l-newRank .p-needDoc > li + li {
        margin-top: 16px;
    }
    .l-newRank .p-needDoc > li > *:not(:first-child) + * {
        margin-top: 8px;
    }
    .l-newRank .l-section .p-needDoc__title {
        margin-bottom: 4px;
        font-size: 18px;
    }
    .l-newRank .p-needDoc__col {
        display: block;
    }
    .l-newRank .p-needDoc__col > div {
        width: 100%;
    }
    .l-newRank .p-needDoc__col > div + div {
        margin-top: 8px;
    }
    
    /* == p-contractFlow == */
    .l-newRank .l-section .p-contractFlow__title {
        font-size: 18px;
    }
    
    /* == p-headDetail == */
    .l-newRank .p-headDetail__title,
    .l-newRank .p-headDetail__desc {
        font-size: 14px;
    }
    .l-newRank .p-headDetail__title {
        min-width: 70px;
    }
    
    /* == p-rankRead == */
    .l-newRank .l-section .p-rankRead {
        margin-top: 32px;
    }
}


/* ========================================
      Utility add 202408
========================================= */
.l-newRank .u-mt-12 {
    margin-top: 12px !important;
}
.l-newRank .u-mt-16 {
    margin-top: 16px !important;
}
.l-newRank .u-mt-40 {
    margin-top: 40px !important;
}
.l-newRank .u-mb-0 {
    margin-bottom: 0 !important;
}
.l-newRank .u-fz-16 {
    font-size: 16px !important;
}
.l-newRank .u-jc-c {
    justify-content: center !important;
}
.l-newRank .u-ta-r {
    text-align: right !important;
}
@media screen and (max-width: 500px) {
    .l-newRank .u-mt-sp-32 {
        margin-top: 32px !important;
    }
}