.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 #sortListWrap .h2Normal {
    margin: 0;
}
.d-body #heading .h2Normal,
.d-body #sortListWrap .h2Normal span {
    margin-bottom: 16px;
    font-size: 24px;
    line-height: 1.2;
}
.d-body #sortListWrap .h2Normal span.title {
    font-size: 40px;
}
.d-body #heading .h2Normal-span {
    color: #666666;
    display: block;
    font-size: 20px;
    margin-bottom: 4px;
}
.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: 24px;
}


/* 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 .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: 24px;
    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;
}
.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 .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 {
    background-image: url(/common/images/icon_dog.svg);
}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(2) .rankingOtherList-link:before {
    background-image: url(/common/images/icon_cat.svg);
}
.d-body #variousRanking .rankingOtherList-item:nth-of-type(3) .rankingOtherList-link:before {
    background-image: url(/common/images/icon_pet-all.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;
}

/* ピックアップの幅調整 */
.d-body .knowledgeMenu-item {
    width: 100%;
    cursor: unset;
}
/* ピックアップのボバー時の状態 */
.d-body .knowledgeMenu-item:hover {
    opacity: 1;
}


@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;
    }
    #heading .cautionList-item,
    #sortListWrap li {
        display: list-item;
    }
    
    .necessary_title {
        font-size: 18px;
    }
    .necessary_head {
        width: 40%;
    }

    .d-body #sortListWrap {
        padding: 32px 4% 16px;
    }
    .d-body .active {
        background-image: unset;
        background-repeat: unset;
        background-position: unset;
        background-color: unset;
        background-size: unset;
    }
    .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: 16px;
    }

    .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;
    }
}


/* ===== breadcrumbs add 202504 ===== */
@media screen and (max-width: 500px) {
    .l-newRank.d-body #breadcrumbs {
        padding: 4px 0;
    }
    .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;
    }
    .l-newRank.d-body #breadcrumbs .container ol li:not(:last-child):after {
        vertical-align: baseline;
    }
    .l-newRank.d-body #breadcrumbs .container ol li span {
        font-size: 1.35rem;
    }
}

/* ===== heading add 202504 ===== */
.l-newRank.d-body #heading {
    padding: 24px 0 40px;
}
.l-newRank.d-body #heading .heading-width {
    text-align: left;
}
.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 .heading-text {
        margin-bottom: 0;
        font-size: 14px;
    }
    .l-newRank.d-body #heading .heading-text > strong {
        font-size: 14px;
    }
}

/* ===== cautionList add 202504 ===== */
@media screen and (max-width: 500px) {
    .l-newRank.d-body .cautionList .cautionList-item {
        display: block;
    }
}

/* ===== rankingOtherList add 202504 ===== */
.l-newRank.d-body .rankingOtherList {
    gap: 24px;
    justify-content: center;
    align-items: stretch;
}
.l-newRank.d-body .rankingOtherList-item {
    margin-bottom: 0;
}
.l-newRank.d-body .rankingOtherList-all .rankingOtherList-link::before {
    background-image: url(/common/images/icon_pet-all.svg);
}
.l-newRank.d-body .rankingOtherList-dog .rankingOtherList-link::before {
    background-image: url(/common/images/icon_dog.svg);
}
.l-newRank.d-body .rankingOtherList-cat .rankingOtherList-link::before {
    background-image: url(/common/images/icon_cat.svg);
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .rankingOtherList {
        gap: 16px;
        margin-top: 32px;
    }
    .l-newRank.d-body .rankingOtherList-item {
        width: calc(50% - 8px);
    }
}

/* ===== categoryTitle add 202504 ===== */
.l-newRank.d-body .categoryTitle [class*="titlePet-"] {
    position: relative;
    padding-left: 64px;
}
.l-newRank.d-body .categoryTitle [class*="titlePet-"]::before {
    content: '';
    width: 48px;
    height: 48px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    background-size: contain;
    background-repeat: no-repeat;
}
.l-newRank.d-body .categoryTitle .titlePet-all::before {
    background-image: url(/common/images/icon_pet-all.svg);
}
.l-newRank.d-body .categoryTitle .titlePet-dog::before {
    background-image: url(/common/images/icon_dog.svg);
}
.l-newRank.d-body .categoryTitle .titlePet-cat::before {
    background-image: url(/common/images/icon_cat.svg);
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body .categoryTitle [class*="titlePet-"] {
        padding-left: 48px;
    }
    .l-newRank.d-body .categoryTitle [class*="titlePet-"]::before {
        width: 32px;
        height: 32px;
    }    
}

/* ===== agenda add 202504 ===== */
.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;
    }
}

/* ===== resultList add 202504 ===== */
.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 .mainBtn01._notmodal::before {
    display: none;
}
.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;
    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 .result-opener .content-opener li {
        display: block;
    }
    .l-newRank.d-body .result-opener .content-opener .dotList-item {
        font-size: 16px;
    }
    .l-newRank.d-body .content-opener .innerCaution
    .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_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;
    }
    .l-newRank.d-body .result_fpLink {
        margin-top: 12px;
    }
    .l-newRank.d-body .result_compensation_col {
        display: block;
    }
    .l-newRank.d-body .result_compensation_title {
        margin: 32px 0 8px;
    }
    .l-newRank.d-body .result_compensation_table + .result_compensation_table tbody tr:first-child {
        border-top: none;
    }
    .l-newRank.d-body .result_compensation_table td {
        padding: 4px 8px;
    }
    .l-newRank.d-body .result_compensation_table strong {
        font-size: 14px;
    }
    .l-newRank.d-body .result_compensation_table-help::before {
        padding-top: 0;
    }
}

/* ===== hikaku add 202504 ===== */
.l-newRank.d-body #hikaku {
    margin-top: 40px;
}
.l-newRank.d-body #hikaku .hikaku-inner {
    padding: 0;
}
@media screen and (max-width: 500px) {
    .l-newRank.d-body #hikaku {
        margin-top: 32px;
    }
}

/* ===== title add 202504 ===== */
.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;
    }
}

/* ===== pastRanking add 202504 ===== */
.l-newRank.d-body #pastRanking {
    background-color: #f7f7f7;
    box-shadow: 0 0 0 100vmax #f7f7f7;
}

/* ===== result_footer_menu add 202504 ===== */
.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;
    }
}

/* ===== scrolltop add 202504 ===== */
@media screen and (max-width: 500px) {
    .scrolltop._fixed {
        bottom: 37vw;
    }
}


/* ========================================
      layout add 202504
========================================= */

/* == 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 202504
========================================= */

/* == 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-spScroll == */
@media screen and (max-width: 500px) {
    .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;
    }
}

/* == c-linkList == */
.l-newRank .c-linkList {
    display: grid;
    grid-gap: 24px;
    grid-template-columns: repeat(3, 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: 16px;
    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;
}
.l-newRank .c-linkList__list > li > a {
    flex: 1;
}
@media screen and (max-width: 500px) {
    .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-numberList == */
.l-newRank .c-numberList {
    list-style: none;
}
.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;
}
@media screen and (max-width: 500px) {
    .l-newRank .l-section .c-numberList__number {
        width: 35px;
        height: 35px;
        margin-bottom: 0;
        padding: 0 0 0 1px;
        font-size: 18px !important;
    }
    .l-newRank .l-section .c-numberList__text {
        margin-bottom: 0;
        padding: 0;
        font-size: 24px !important;
    }
}

/* == c-heading4 == */
.l-newRank .c-heading4 {
    margin-bottom: 8px;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0;
}
@media screen and (max-width: 500px) {
    .l-newRank .c-heading4 {
        font-size: 20px;
    }
}

/* == c-table01 == */
.l-newRank .c-table01 {
    width: 100%;
    height: 100%;
}
.l-newRank .c-table01 th,
.l-newRank .c-table01 td {
    padding: 16px;
    border: 1px solid #949494;
    font-size: 16px;
    line-height: 1.2;
    box-sizing: border-box;
    vertical-align: middle;
}
.l-newRank .c-table01 th,
.l-newRank .c-table01 .c-textLink {
    font-weight: bold;
    font-size: 16px;
}
.l-newRank .c-table01 thead th {
    background: #f2f2f2;
}
.l-newRank .c-table01 tbody th {
    background: #EEF6FF;
}
.l-newRank .c-table01 td {
    background: #fff;
}
.l-newRank .c-table01 .cautionList {
    margin-bottom: 0;
}
.l-newRank .c-table01--w30p {
    width: 30%;
}
.l-newRank .c-table01--w35p {
    width: 35%;
}
.l-newRank .c-table01--w70p {
    width: 70%;
}
@media screen and (max-width: 500px) {
    .l-newRank .c-table01 th,
    .l-newRank .c-table01 td {
        padding: 8px;
    }
}


/* ========================================
      Project add 202504
========================================= */

/* == p-mainVisual == */
.l-newRank .p-mainVisual {
    margin-bottom: 16px;
}
.l-newRank .p-mainVisual img {
    width: 100%;
    height: auto;
}

/* == 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;
}
@media screen and (max-width: 500px) {
    .l-newRank .p-headDetail__title,
    .l-newRank .p-headDetail__desc {
        font-size: 14px;
    }
    .l-newRank .p-headDetail__title {
        min-width: 70px;
    }
}

/* == p-contractRank == */
.l-newRank .p-contractRank {
    display: grid;
    grid-gap: 24px;
    grid-template-columns: repeat(3, 1fr);
    list-style: none;
}
.l-newRank .p-contractRank--all {
    margin-top: 24px;
}
.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;
}
@media screen and (max-width: 500px) {
    .l-newRank .p-contractRank {
        grid-gap: 16px;
        grid-template-columns: repeat(1, 1fr);
    }
}

/* == p-rankRead == */
.l-newRank .l-section .p-rankRead {
    margin-top: 48px;
}
.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) {
    .l-newRank .l-section .p-rankRead {
        margin-top: 32px;
    }
}

/* == 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;
}
@media screen and (max-width: 500px) {
    .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-relatedLink == */
.l-newRank .p-aboutRanking {
    margin-top: 40px;
}
@media screen and (max-width: 500px) {
    .l-newRank .p-aboutRanking {
        margin-top: 32px;
    }
}

/* == p-resultRanking == */
.l-newRank .p-resultRanking {
    margin-top: 48px;
}
@media screen and (max-width: 500px) {
    .l-newRank .p-resultRanking {
        margin-top: 32px;
    }
}


/* ========================================
      Utility add 202408
========================================= */
.l-newRank .u-fw-nm {
    font-weight: normal !important;
}
.l-newRank .u-ta-r {
    text-align: right !important;
}
.l-newRank .u-pt-0 {
    padding-top: 0 !important;
}