/*
Theme Name: template_2310001
Theme URL: https://mightyace.co.jp/
Author: 株式会社マイティーエース
Version: 23.10.001
*/

@charset "utf-8";
/* html5のブラウザ互換用
----------------------------------------------------------- */
@import url("css/reset.css");
@import url("css/common.css");


/* ページ設定
----------------------------------------------------------- */
@charset "utf-8";

sup{
    font-size: 0.65em;
    vertical-align: top;
}
/*#fv
------------------------------*/
#fv{
    background: url(images/fv_bg.jpg) no-repeat center;
    background-size: cover;
}
#fv .inner{
    position: relative;
}
#fv .fv_btn{
    position: absolute;
    bottom: 30px;
    right: 0;
    margin: auto;
    max-width: 250px;
}
#fv .fv_btn a{
    padding: 0.5em;
    position: relative;
    display: block;
}

/*検索
------------------------------*/
#search {
    margin: 0 auto;
}
#search h2 {
    width: 100%;
    background: var(--purple01);
    text-align: center;
    color: #fff;
    padding: 9px 0;
    font-size: var(--f32);
    font-weight: normal;
    margin: 0 0 var(--size_ss);
}
#search table tr th,#search table tr td{
    border: 1px solid gray;
    padding: 0.5em;
    background-color: #fff;
}
#search table tr th{
    font-weight: bold;
    width: 20%;
    background: rgb(0, 0, 0, 0.1);
    text-align: center;
}
#search label {
    margin: 0 10px 0 0;
}
.search_btn_box {
    text-align: center;
    margin-top: var(--size_ss);
}
.search_btn {
    width: 300px;
    background: rgb(0, 0, 0, 0.3);
    padding: 10px 0;
    color: #fff;
    border: none;
    border-radius: 9999px;
    font-size: var(--f28);
    cursor: pointer;
}

.search_btn:hover{
    background-color: var(--purple01);
}

/*検索結果
------------------------------*/
#wrapper {
    width: 1000px;
    background: #f2f2f2;
    padding: 50px 30px;
    box-sizing: border-box;
    margin: 0 auto;
}
#search_page_title {
    width: 100%;
    background: #000;
    text-align: center;
    color: #fff;
    padding: 10px 0;
    font-size: 25px;
    margin: 0 0 30px;
    font-weight: normal;
}
.search_box_top {
    border: solid 3px #ccc;
    padding: 3%;
    margin: 0 0 5%;
        background: #fff;
}
.search_box_top p {
    display: inline-block;
    margin: 0 2% 0 0;
}
.sort {
    border: solid 1px #ccc;
    border-radius: 5px;
    font-size: 18px;
    padding: 1%;
    margin: 0 0 3% 0;
}
#search_table {
    width: 100%;
}
#search_table th {
    border: solid 1px #ccc;
    background: var(--purple03);
    padding:1%;
    text-align: center;
    vertical-align: middle;
    box-sizing: border-box;
    font-size:12px;
}
#search_table td {
    border: solid 1px #ccc;
    background: #fff;
    padding:1%;
    text-align: center;
    vertical-align: middle;
    box-sizing: border-box;
    font-size:12px;
    width: 12.5%;
}
#search_table td img {
    width: auto;

}
#search_table td a {
    background:#ff8400;
    padding: 2% 0;
    text-align: center;
    color: #fff;
    border:none;
    border-radius: 5px;
    border-bottom: solid 4px #cb6e0a;
    text-decoration: none;
    display: block;
    box-sizing: border-box;
    font-size:14px;
}

/* #sec02
------------------------------*/
#sec02{
    background-color: #fff;
    padding: var(--size_ss);
}
#sec02 .sec02_box:nth-child(even){
    flex-direction: row-reverse;
}
#sec02 .sec02_box_txt,#sec02 .sec02_box figure{
    width: 50%;
}
#sec02 .sec02_box_txt{
    padding-right: var(--size_ss);
}
#sec02 .sec02_box:nth-child(even) .sec02_box_txt{
    padding: 0 0 0 var(--size_ss);
}
#sec02 .sec02_box_txt h3{
    color: var(--purple01);
    font-size: var(--f36);
    border-left: 5px solid #c6b372;
    padding-left: 3%;
    margin: var(--size_sss) 0;
    position: relative;
    z-index: 2;
}
#sec02 .sec02_box_txt h3 span{
    color: #f2f2f2;
    font-size: var(--size_l);
    font-weight: 700;
    position: absolute;
    top: -45%;
    right: 0;
    z-index: -1;
}

/* #sec03
------------------------------*/
#sec03{
    background: #fff;
    border: 2px solid var(--purple01);
    padding-bottom: var(--size_ms);
}
#sec03 h3{
    font-size: var(--f32);
    margin-bottom: var(--size_ss);
}
#sec03 h3 span{
    background-color: var(--purple01);
    color: #fff;
    padding: 0 var(--size_sss);
}
#sec03 .sec03_box ul{
    width: 69%;
}
#sec03 .sec03_box figure{
    width: 31%;
}
#sec03 .sec03_box ul li{
    margin-bottom: var(--size_sss);
}
#sec03 label span {
    width: 94%;
    text-align: center;
    display: block;
    font-size: var(--f20);
    border-radius: 100px;
    line-height: 1.2;
    padding: 3% 0;
    border: 1px solid #2c2b2b;
    margin: 0 auto 0 0;
    font-weight: bold;
    cursor: pointer;
}
#sec03 label input:checked+span {
    color: #FFF;
    background: var(--purple01);
}
#sec03 .result_box_wrap{
    display: none;
}
#sec03 .result_box{
    display: flex;
}
#sec03 .result_box_txt{
    width: 65%;
    font-size: var(--f24);
}
#sec03 .result_box_txt .result_chair {
    padding-top: 2%;
}
#sec03 .result_box_txt .result_chair span{
    background-color: var(--purple03);
    color: var(--purple02);
    font-size: var(--f36);
    font-weight: 700;
    padding: 0 var(--size_s);
}
#sec03 .result_box_img{
    width: 20%;
    padding-left: var(--size_sss);
}

/* #best
------------------------------*/
#best{
    padding: var(--size_s) var(--size_ss);
    position: relative;
    background: url(images/table_bg.jpg) no-repeat;
    background-size: cover;
}
#best h2{
    margin-bottom: var(--size_sss);
}
#best .sticky{
    position: sticky;
    top: 87px;
}
#best table td:first-child{
    width: 14%;
}
#best .btn_cv td{
    padding-top: 10px;
}
.btn a {
    background: linear-gradient(-50deg,#fe748d,#ff4564);
    border-radius: 9999px;
    display: block;
    font-size: 3.2rem;
    color: #fff;
    width: 100%;
    position: relative;
    box-shadow: 5px 5px 10px rgba(0,0,0,0.22);
    font-weight: 400;
}
.btn a::after{
    content: "";
    background: url(images/arrow_01.png) no-repeat;
    background-size: contain;
    display: block;
    width: 9%;
    max-width: 36px;
    padding-top: 3%;
    position: absolute;
    top: 50%;
    right: 30px;
}

/* #rank
------------------------------*/
#rank >section{
    background-color: #fff;
    margin: var(--size_s) 0 var(--size_m);
}
#rank h2{
    margin-bottom: var(--size_s);
}
#rank .box_rank:not(:first-of-type){
    margin-top: var(--size_l);
}
#rank .box_rank >div:not(.title){
    margin-left: var(--size_ss);
    margin-right: var(--size_ss);
}
#rank .box_rank .title{
    margin-bottom: var(--size_s);
    padding: 20px 0 15px 165px;
    color: #fff;
    background-color: var(--purple01);
    position: relative;
}
#rank .box_rank .title::before{
    content: "";
    width: 17%;
    padding-top: 17%;
    display: block;
    position: absolute;
    top: 15px;
    left: 15px;
    background-repeat: no-repeat;
    background-size: contain;
}
#rank .box_rank#no01 .title::before{
    background-image: url(images/rank01_medal.webp);
}
#rank .box_rank#no02 .title::before{
    background-image: url(images/rank02_medal.webp);
}
#rank .box_rank#no03 .title::before{
    background-image: url(images/rank03_medal.webp);
}
#rank .box_rank#no04 .title::before{
    background-image: url(images/rank04_medal.webp);
}
#rank .box_rank#no05 .title::before{
    background-image: url(images/rank05_medal.webp);
}
#rank .box_rank .title h3{
    font-size: var(--f50);
    font-weight: normal;
}
#rank .box_rank .title .caption{
    margin:0;
}

/* .box_top */
#rank .box_rank .box_top > div {
    width: 36.2%;
}
#rank .box_rank .box_top .box_top_txt{
    width: calc((100% - 36.2%) - 30px);
}
#rank .box_rank .box_top .box_top_txt h4 {
    font-size: var(--f24);
    margin-bottom: var(--size_sss);
    color: var(--purple02);
    position: relative;
}
#rank .box_rank .box_top .box_comm{
    margin-top: 20px;
}

/* .best_point */
#rank .box_rank .box_point{
    margin-top: var(--size_l);
    padding: var(--size_s) var(--size_sss) var(--size_sss);
    border: 3px solid var(--purple01);
    border-radius: 20px;
    font-size: var(--f20);
    position: relative;
}
#rank .box_rank .box_point h4{
    position: absolute;
    bottom: 93%;
    background-color: var(--purple01);
    font-size: var(--f24);
    color: #fff;
    padding: 8px 15px;
}
#rank .box_rank .box_point li{
    padding: 8px 0 8px 40px;
    font-size: var(--f20);
    position: relative;
}
#rank .box_rank .box_point li::before{
    content: "";
    display: block;
    background: url(images/rank_check.webp) no-repeat;
    background-size: contain;
    width: 5%;
    padding-top: 5%;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0,-50%);
}

/* .best_date */
#rank .box_rank .best_date tr:nth-child(even){
    border-bottom: 7px solid #fff;
}
#rank .box_rank .best_date th{
    background-color: #414141;
    color: #fff;
    padding: 5px 0;
    text-align: center;
    border-bottom: none;
    font-weight: bold;
    width: calc(100% / 3);
}
#rank .box_rank .best_date td{
    background-color: #f2f2f2;
    text-align: center;
    vertical-align: middle;
    border-top: none;
}
#rank .box_rank .best_date td:not(:nth-child(3n)),
#rank .box_rank .best_date th:not(:nth-child(3n)){
    border-right: 7px solid #fff;
}
#rank .box_rank .cv_area_col2{
    justify-content: space-between;
    align-items: self-end;
}
/* .voice */
#rank .box_rank .voice h4,
#rank .box_rank .reason h4,
#rank .box_rank .case h4,
.support h4{
    font-size: var(--f42);
    text-align: center;
    padding: 0.6em;
    line-height: 1em;
    background: #f8f8f8;
    margin-bottom: var(--size_ss);
}
#rank .box_rank .voice .scroll{
    overflow-y: scroll;
    height: 400px;
}
#rank #no01 .box_rank .voice .scroll{
    margin-top: 2.25em;
}
#rank .box_rank .voice section{
    padding: var(--size_sss);
}
#rank .box_rank .voice section h5{
    color: var(--purple02);
    border-bottom: 2px solid #fff;
    padding-bottom: 10px;
}
#rank .box_rank .voice section h5 span{
    margin-right: var(--size_ss);
}
#rank .box_rank .voice section .comment{
    margin-top: var(--size_sss);
}
#rank .box_rank .voice section .voice_box{
    background-color: var(--purple03);
    display: flex;
    align-items: flex-start;
    padding: var(--size_sss);
}
#rank .box_rank .voice section .voice_box figure{
    flex: 0 0 140px;
    padding-right: var(--size_sss);
}
#rank .box_rank .voice section .voice_box .voice_box_txt{
    flex: 1;
}

/* .reason */
.reason figure{margin: var(--size_ss) 0;}

/* .case */
#rank .box_rank .case_box{
    margin-bottom: var(--size_m);
}
#rank .box_rank .case_box figure{
    flex: 0 0 283px;
}

#rank .box_rank .case_txt {
    flex: 1;
    padding-left: var(--size_ss);
}

#rank .box_rank .case_txt h5{
    color: var(--purple01);
    font-size: var(--f24);
    margin-bottom: var(--size_sss);
    line-height: 1;
}
#rank .box_rank .case_voice h5{
    font-size: var(--f36);
}

#rank .box_rank .case_voice .case_voice_box{
    margin-top: var(--size_ss);
    width: 48%;
    border: 2px solid #cdbb84;
}

#rank .box_rank .case_voice .case_voice_box:first-child{
    width: 100%;
}

.cv_area{
    padding: var(--size_ms) 0;
}

/*スマホ
------------------------------*/
@media screen and (max-width: 800px) {
main, footer div, .inner{
    width: 100%;
}
/*#fv
------------------------------*/
#fv img,
#best img,
#rank img {
    width: 100%;
    height: auto;
}
#fv .fv_btn {
    bottom: 2%;
    right: 50%;
    transform: translate(50%,0);
    width: 90%;
    max-width: 370px;
}

/*検索
------------------------------*/
#search {
    width: 100%;
    margin: 0 auto;
}
#search h2 {
    width: 100%;
    padding: 2% 0;
    font-size: 18px;
    margin: 0 0 3%;
    font-weight: normal;
}
#search table *:not(label){
    display: block;
}
#search table tr th,
#search table tr td {
    width: 100%;
}
#search table tr td {
    border-top: none;
}
#search table tr:not(:last-of-type) td {
    border-bottom: none;
}
.search_btn {
    width: 80%;
    min-width: 180px;
    font-size: 2rem;
}

/*検索結果
------------------------------*/
#wrapper {
    width: 100%;
    background: #f2f2f2;
    padding: 5% 3%;
    box-sizing: border-box;
    margin: 0 auto;
}
#search_page_title {
    width: 100%;
    text-align: center;
    color: #fff;
    padding: 3% 0;
    font-size: 18px;
    margin: 0 0 3%;
    font-weight: normal;
}
.search_box_top {
    border: solid 3px #ccc;
    padding: 3%;
    margin: 0 0 5%;
    background: #fff;
}
.search_box_top p {
    display: block;
    margin: 0 2% 0 0;
}
.sort {
    border: solid 1px #ccc;
    border-radius: 3px;
    font-size: 12px;
    padding: 1%;
    margin: 0 0 3% 0;
}
.sort_box {
    width: 100%;
    overflow-x: scroll;
}
#search_table {
    width: 640px;
}
#search_table th {
    border: solid 1px #ccc;
    background: #f2f2f2;
    padding: 1%;
    text-align: center;
    vertical-align: middle;
    box-sizing: border-box;
    font-size: 8px;
}
#search_table td {
    border: solid 1px #ccc;
    padding: 1%;
    text-align: center;
    vertical-align: middle;
    box-sizing: border-box;
    font-size: 8px;
    width: 12.5%;
    background: #fff;
}
#search_table td img {
    width: auto;

}
#search_table td a {
    border-radius: 3px;
    border-bottom: solid 2px #cb6e0a;
    font-size: 9px;
}

/* #sec02 #sec03
------------------------------*/
#sec02 .sec02_box_txt,#sec02 .sec02_box:nth-child(even) .sec02_box_txt,#sec03 .sec03_box ul{
    width: 100%;
    padding: 0;
}
#sec02 .sec02_box_txt h3 span{
    top: -65%;
}
#sec02 .sec02_box figure{
    margin: 0 0 0 auto;
}
#sec03{
    margin: var(--size_ss) 3.5% 0;
}
#sec03 h3{
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}
#sec03 h3 figure{
    width: 45%;
    margin-left: 5%;
}
#sec03 label span{
    width: 100%;
}
#sec03 .result_box_txt{
    width: 75%;
}
#sec03 .result_box_txt .result_chair span{
    font-size: var(--f32);
    padding: 0 3%;
}
#sec03 .result_arrow img{
    width: 20%;
}
#sec03 .result_box_img{
    width: 23%;
}
#sec03 .result_btn{
    margin-top: var(--size_ss);
}

/* #best
------------------------------*/
#best {
    padding: 3.5%;
}
#best .sticky{
    top: 50px;
}
#best a{
    width: 100%;
}
#best table th{
    width: calc((100% - 48.89%) / 2);
}
#best table th:nth-of-type(1),#best table td:first-child{
    width: 21.16%;
}
#best table th:nth-of-type(2){
    width: 27.73%;
}
#best .btn_cv td{
    width: 25%;
    padding: 10px 1.5% 0;
}

/* #rank
------------------------------*/
#rank h2 {
    margin-bottom: var(--size_s);
}
#rank .box_rank .title {
    padding: 3.5% 3% 0 23%;
    background-size: 20% auto;
}
#rank .box_rank .title::before{
    left: 3%;
}
#rank .box_rank .title h3 .font_s{font-size:0.5em;}

/* .box_top */
#rank .box_rank .box_top div,
#rank .box_rank .box_top .box_top_txt {
    width: 100%;
}
#rank .box_rank .box_top div table {
    margin: 3.5% auto;
}
#rank .box_rank .box_top div figure{
    width: 80%;
    margin: 0 auto 5%;
}
#rank .best_date img{
    width: 50%;
}
/* .best_point */
#rank .box_rank .box_point h4{
    padding: 5px 10px 5px 20px;
}
#rank .box_rank .box_point h4::after{
    border-right: 30px solid transparent;
    border-bottom: 47px solid var(--purple03);
}
#rank .box_rank .box_point li{
    padding: 2% 0 2% 10%;
}
#rank .box_rank .box_point li::before{
    width: 7%;
    padding-top: 7%;
    transform: none;
    top: 12%;
}

/* .voice */
#rank .box_rank .voice section {
    padding: 3.5%;
}
#rank .box_rank .voice section .voice_box{
    flex-direction:column;
    align-items: center;
}
#rank .box_rank .voice section .voice_box figure{
    padding: 0 0 var(--size_sss);
}

/* #fix_bnr */
#fix_bnr {
    position: fixed;
    z-index: 9000;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    text-align: center;
}
    /* //End @media screen and (max-width: 800px) */
}