@charset "UTF-8";

/* TAG --------------------------------------- */

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
h2 abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

html {
    box-sizing: border-box;
}

body {
    line-height: 1;
    font-family: 'Noto Sans Japanese', 'Lucida Grande', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif !important;
    color: #545454;
    font-size: 14px !important;
    line-height: 160% !important;
}

input[type="checkbox"],
input[type="radio"] {
    display: inline-block;
    margin: 0 2px;
    padding: 0;
    vertical-align: middle;
    position: relative;
    top: -2px;
    cursor: pointer;
}

img {
    vertical-align: bottom;
}

ul {
    list-style: none;
}


/* Common --------------------------------------- */

a {
    color: #545454;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
    color: #545454;
}

.hidden {
    display: none;
}

.clear {
    clear: both;
    font-size: 0px;
    line-height: 0px;
}

.alpha a:hover img {
    opacity: 0.8;
    filter: alpha(opacity=80);
    -ms-filter: "alpha(opacity=80)";
}

.mb00 {
    margin-bottom: 0px !important;
}

.mb10 {
    margin-bottom: 10px !important;
}

.mb20 {
    margin-bottom: 20px !important;
}

.mb30 {
    margin-bottom: 30px !important;
}

.mb40 {
    margin-bottom: 40px !important;
}

.mt10 {
    margin-top: 10px !important;
}

.mt20 {
    margin-top: 20px !important;
}

.mt30 {
    margin-top: 30px !important;
}

.mt40 {
    margin-top: 40px !important;
}

.pb10 {
    padding-bottom: 10px !important;
}

.pb20 {
    padding-bottom: 20px !important;
}

.pb30 {
    padding-bottom: 30px !important;
}

.pb40 {
    padding-bottom: 40px !important;
}

.pt10 {
    padding-top: 10px !important;
}

.pt20 {
    padding-top: 20px !important;
}

.pt30 {
    padding-top: 30px !important;
}

.pt40 {
    padding-top: 40px !important;
}

.backtotop {
    position: fixed;
    right: 10px;
    bottom: 10px;
    z-index: 9000;
    display: none;
}

.backtotop a {
    background: url(/common/img/page_top.png) no-repeat center center;
    width: 70px;
    height: 70px;
    display: block;
    background-size: contain;
    text-indent: -9999px;
    outline: none;
}

.backtotop a:hover {
    opacity: 0.8;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}

em {
    color: #eb1a1a;
    font-style: normal;
    background: linear-gradient(transparent 50%, #FFFF84 0%);
    font-weight: bold;
    display: inline;
}

a.btnType01 {
    background: #D1F0FD;
    border: 1px solid #D1F0FD;
    border-radius: 25px;
    color: #307FD8;
    display: inline-block;
    font-size: 14px;
    text-align: center;
    text-decoration: none;
    /*box-shadow:0 7px 0 rgba(25,136,169,1);*/
    padding: 16px 20px;
}

a.btnType02 {
    background: #fb532b;
    border: 1px solid #e80915;
    border-radius: 20px;
    color: #FFF;
    display: inline-block;
    font-size: 16px;
    text-align: center;
    text-decoration: none;
    padding: 10px 20px;
}

a.btnType02b {
    background: #fb532b;
    border: 1px solid #e80915;
    border-radius: 20px;
    color: #FFF;
    display: inline-block;
    font-size: 16px;
    text-align: center;
    text-decoration: none;
    padding: 10px 20px;
}

a.btnType03 {
    background: #fb532b;
    /*border:1px solid #e80915;*/
    border-radius: 25px;
    color: #FFF;
    display: inline-block;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 4px 0 #E80915;
    padding: 15px 5px;
}

a.btnType04 {
    background: linear-gradient(#fb532b, #e80915);
    border: 1px solid #e80915;
    border-radius: 25px;
    color: #FFF;
    display: inline-block;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 4px 0 #E80915;
    padding: 15px 5px;
}

a.btnType05 {
    background: linear-gradient(#fb532b, #e80915);
    border-radius: 5px;
    box-shadow: 0 3px 0 rgba(163, 44, 29, 1.00);
    color: #FFF;
    display: block;
    font-size: 21px;
    text-align: center;
    text-decoration: none;
    margin: 0px auto 60px auto;
    padding: 10px 10px;
    border-radius: 5px;
    width: 350px;
}

a.btnType05:hover {
    box-shadow: none;
    transform: translate3d(0, 3px, 0);
}

a.btnSubmit {
    background: #307FD8;
    border-radius: 15px;
    color: #FFF;
    display: inline-block;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    padding: 10px 0px;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

a.btnType01:hover,
a.btnType02:hover,
a.btnType02b:hover,
a.btnType03:hover,
a.btnType03b:hover,
a.btnType04:hover,
a.btnType04b:hover,
a.btnSubmit:hover {
    opacity: 0.8;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}

.pekopeko {
    animation: pekopeko 2s infinite;
    box-shadow: 0 3px 0 rgb(0, 0, 0, 0.3);
}

@keyframes pekopeko {
    0% {
        box-shadow: 0 3px 0 rgb(0, 0, 0, 0.3);
        top: 0px;
    }
    10% {
        box-shadow: 0 0 0 rgb(0, 0, 0, 0.3);
        top: 3px;
    }
    20% {
        box-shadow: 0 3px 0 rgb(0, 0, 0, 0.3);
        top: 0px;
    }
    30% {
        box-shadow: 0 0 0 rgb(0, 0, 0, 0.3);
        top: 3px;
    }
    40% {
        box-shadow: 0 3px 0 rgb(0, 0, 0, 0.3);
        top: 0px;
    }
}


/* ratingStar --------------------------------------- */

.rate {
    margin-right: 10px;
    position: relative;
    display: inline-block;
    width: 80px;
    height: 21px;
    font-size: 16px;
}

.rate:before,
.rate:after {
    position: absolute;
    top: 0px;
    left: 0px;
    content: '★★★★★';
    display: inline-block;
    height: 21px;
}

.rate:before {
    color: #999;
}

.rate:after {
    color: #D03730;
    overflow: hidden;
    white-space: nowrap;
}

.rate1:after {
    width: 16px;
}

.rate2:after {
    width: 32px;
}

.rate3:after {
    width: 48px;
}

.rate4:after {
    width: 64px;
}

.rate5:after {
    width: 80px;
}

.ratingNum {
    color: #194B82;
    font-size: 21px;
    margin-right: 10px;
}

.ratingBox {
    display: flex;
    align-items: center;
}


/* header ------------------------------------------------ */

#header {
    width: 100%;
    border-bottom: 5px solid #153B54;
}

#headerInner {
    width: 1000px;
    margin: 0px auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#headerInner h1 {
    padding: 20px 10px 15px 10px;
}

#headerInner ul#hMenu {
    display: flex;
    align-items: center;
}

#hMenu li {
    padding: 0px 40px 0px 0px;
    font-size: 18px;
    line-height: 32px;
}

#hMenu li:last-child {
    padding: 0px;
}

#hMenu li i {
    padding: 0px 5px 0px 0px;
}

#hMenu li a:hover {
    text-decoration: none;
    color: #307FD8;
}

#hMenu li a {
    color: #333;
    display: block;
}


/* mainImg --------------------------------------- */

#mainImg {
    width: 1000px;
    margin: 0px auto;
    height: 250px;
    position: relative;
}

#mainImg figure img {
    width: 1000px;
}

#mainImg #monthTextBox {
    font-size: 28px;
    line-height: 36px;
    font-weight: bold;
    position: absolute;
    top: 80px;
    left: 330px;
    width: 270px;
    text-align: center;
    padding: 5px;
    color: #000;
}

#mainImg #monthTextBox strong {
    font-size: 36px;
    line-height: 36px;
}


/* siteLogo --------------------------------------- */

#siteLogo {
    width: 1000px;
    margin: 0px auto;
}

#siteLogo figure img {
    width: 1000px;
}


/* multiplesites --------------------------------------- */

#multiplesites {
    width: 720px;
    margin: 0px auto;
}

#multiplesites figure img {
    width: 720px;
}


/* Layout --------------------------------------- */

#contents {
    display: flex;
    width: 1000px;
    margin: 10px auto 40px auto;
}

#contentsSingle {
    width: 1000px;
    margin: 0px;
}

#contents #contentsSide {
    width: 250px;
    padding: 0px 10px;
}

#contents #contentsMain {
    width: 750px;
    padding: 0px 25px 0px 0px;
}


/* Footer --------------------------------------- */

#fTextBox {
    background: #D8E0E9;
    color: #545454;
    padding: 20px;
    width: 100%;
    font-size: 12px;
    line-height: 15px;
}

#fTextBoxInner {
    width: 1000px;
    margin: 0px auto;
}

#fTextBox h5 {
    font-weight: normal;
    margin: 0px 0px 5px -5px;
}

#fTextBox ul {
    list-style: none;
    margin-top: 5px;
}

#fMemuWapper {
    background: #093A53;
    width: 100%;
}

#fMemuWapper .fMemu {
    padding: 5px 0px;
    width: 1000px;
    margin: 0px auto;
    list-style: none;
    text-align: center;
    font-size: 12px;
    line-height: 15px;
}

#fMemuWapper .fMemu li {
    color: #FFF;
    display: inline-block;
    padding: 0px 5px
}

#fMemuWapper .fMemu li a {
    color: #FFF;
    text-decoration: none;
}

#fMemuWapper .fMemu li a:hover {
    color: #FFF;
}

#faddressWapper {
    background: #5285BA;
    width: 100%;
}

#faddressWapper address {
    width: 1000px;
    padding: 5px 0px;
    text-align: center;
    color: #FFF;
    font-size: 12px;
    line-height: 15px;
    margin: 0px auto;
}


/* localMenu --------------------------------------- */

#localMenu h2.localMenuTit {
    background: #153B54;
    color: #FFF;
    font-size: 18px;
    line-height: 30px;
    display: flex;
    margin: 40px 0px 10px 0px;
    padding: 2px 0px;
}

#localMenu h2.localMenuTit i {
    padding: 0px 5px 0px 5px;
}

#localMenu .prefTable {
    margin: 20px 0px 40px 0px;
}

#localMenu .prefTable th {
    padding: 5px;
    font-weight: normal;
    width: 120px;
}

#localMenu .prefTable td {
    padding: 5px;
}

#localMenu .prefTable ul {
    display: flex;
    flex-wrap: wrap;
}

#localMenu .prefTable ul li {
    padding: 0px;
}

#localMenu .prefTable ul li:before {
    content: "|";
    padding: 0px 3px;
    display: inline-block;
}

#localMenu .prefTable ul li:first-child:before {
    content: none;
    padding: 0px 3px;
    display: inline-block;
}

#localMenu .localMenuList {
    display: flex;
    flex-wrap: wrap;
}

#localMenu .localMenuList li {
    padding: 5px 0px 5px 10px;
}

#localMenu .localMenuList li:nth-child(5n) {
    padding-right: 0px;
}

#localMenu .localMenuList li a {
    display: flex;
    border-radius: 15px;
    border: 1px solid #C6C6C6;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    padding: 5px;
    align-items: center;
    min-width: 135px;
}

#localMenu .localMenuList li a span {
    padding: 0px;
    line-height: 30px;
    font-size: 14px;
}

#localMenu .localMenuList li a i {
    width: 30px;
    margin-right: 2px;
}

#localMenu .localMenuList li a:hover {
    background: #307FD8;
    color: #FFF;
    text-decoration: none;
}


/* contentsSide --------------------------------------- */

#contentsSide .rankingListTit {
    font-size: 21px;
    line-height: 32px;
    display: flex;
    margin: 0px 0px 10px 0px;
    padding: 0px;
}

#contentsSide .rankingListTit i {
    padding: 0px 10px 0px 0px;
}

#contentsSide .rankingList {
    margin-bottom: 40px;
}

#contentsSide .rankingList li {
    padding: 5px 0px;
}

#contentsSide .rankingList li a {
    display: flex;
    border-radius: 15px;
    border: 1px solid #C6C6C6;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    padding: 5px;
    align-items: center;
    width: 100%;
}

#contentsSide .rankingList li a span {
    padding: 0px;
    line-height: 30px;
    font-size: 16px
}

#contentsSide .rankingList li a i {
    width: 30px;
    margin-right: 2px;
}

#contentsSide .rankingList li a:hover {
    background: #307FD8;
    color: #FFF;
    text-decoration: none;
}

#contentsSide .siteListTit {
    font-size: 21px;
    line-height: 32px;
    display: flex;
    margin: 0px;
    padding: 0px;
}

#contentsSide .siteListTit i {
    padding: 0px 10px 0px 0px;
}

#contentsSide .siteList {
    margin-bottom: 40px;
}

#contentsSide .siteList li a {
    display: block;
}

#contentsSide .siteList li {
    padding: 10px 0px;
    text-align: center;
    border-bottom: 1px dashed #CCC;
}

#contentsSide .siteList li:last-child {
    border-bottom: none;
}

#contentsSide ul.sFeature {
    list-style: none;
    margin: 0px 0px 20px;
}

#contentsSide ul.sFeature li {
    margin-bottom: 10px;
}


/* searchForm ------------------------------------------------ */

#searchForm {
    width: 100%;
    margin: 0px auto;
    padding: 0px;
}

#searchForm h2 {
    background: #153B54;
    color: #FFF;
    font-size: 18px;
    line-height: 30px;
    display: flex;
    margin: 0px 0px 20px 0px;
    padding: 2px 0px;
}

#searchForm h2 i {
    padding: 0px 5px 0px 5px;
}

#searchTable table {
    width: 100%;
    border-spacing: 0px;
    margin-top: 0px;
}

#searchTable table td {
    padding: 0px;
    text-align: left;
    vertical-align: middle;
    font-size: 16px;
    line-height: 24px;
}

#searchTable table th {
    text-align: left;
    color: #153B54;
    padding: 0px 20px;
    font-size: 18px;
    line-height: 24px;
    vertical-align: middle;
    white-space: nowrap;
    width: 150px;
}

#searchTable label {
    font-weight: normal;
}

.formParts {
    width: 100%;
    margin: 3px auto;
    padding: 0px;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
}

.formParts li {
    padding: 5px;
    margin: 0px;
    vertical-align: top;
    text-align: left;
}

.formParts label {
    width: 100%;
}

.formParts .w25p {
    width: 25%;
}

.formParts .w50p {
    width: 50%;
}

.checkboxInput {
    display: none !important;
}

.checkboxParts {
    cursor: pointer;
    position: relative;
    transition: .2s;
    color: #666;
    border-radius: 15px;
    display: inline-block;
    padding: 5px 15px;
    width: 100%;
    min-width: 80px;
    text-align: center;
    font-weight: bold;
    background: #E9E9E9;
    font-weight: normal;
    border: 1px solid #B5B5B5;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

.checkboxInput:checked+.checkboxParts {
    background: #63D7F9;
    color: #FFF;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

.radioInput {
    display: none !important;
}

.radioParts {
    cursor: pointer;
    position: relative;
    transition: .2s;
    color: #666;
    border-radius: 15px;
    display: inline-block;
    padding: 5px 15px;
    width: 100%;
    text-align: center;
    font-weight: bold;
    background: #FFF;
    font-weight: normal;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

.radioInput:checked+.radioParts {
    background: #63D7F9;
    color: #FFF;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

.selectParts {
    overflow: hidden;
    margin: 5px 0px;
    width: 49.5%;
}

.selectParts select {
    padding-right: 10px;
    cursor: pointer;
    text-overflow: ellipsis;
    border: none;
    outline: none;
    background: transparent;
    background-image: none;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
}

.selectParts select::-ms-expand {
    display: none;
}

.selectParts {
    position: relative;
    border-radius: 2px;
    border-radius: 25px;
    border: 1px solid #B5B5B5;
    background: #FFF;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

.selectParts::before {
    position: absolute;
    top: 15px;
    right: 10px;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid #307FD8;
    pointer-events: none;
}

.selectParts select {
    padding: 5px 20px 5px 10px;
    color: #333;
}

#searchForm .submit {
    width: 360px;
    margin: 20px auto 40px auto;
    padding: 0px;
    text-align: center;
}

#searchForm .submit a {
    display: flex;
    align-items: center;
    justify-content: center;
}

#searchForm .submit a i {
    margin-right: 10px;
}


/* feature ------------------------------------------------ */

#feature {
    padding: 0px;
    margin-top: 40px;
    margin-bottom: 40px;
}

#feature h2 {
    background: #153B54;
    color: #FFF;
    font-size: 18px;
    line-height: 30px;
    display: flex;
    margin: 0px 0px 10px 0px;
    padding: 2px 0px;
}

#feature h2 i {
    padding: 0px 5px 0px 5px;
}

#feature #featureInner .itemData h3 {
    font-size: 18px;
    line-height: 24px;
    font-weight: normal;
    text-align: center;
    padding: 0px 0px 10px 0px;
    border-bottom: 1px solid #307FD8;
    font-weight: bold;
}

#feature #featureInner .itemData h3 a {
    color: #307FD8;
    text-decoration: none;
}

#feature #featureInner {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
    width: 100%;
    padding: 10px 0px 0px 0px;
}

#feature #featureInner .itemData {
    padding: 20px;
    width: 352px;
    margin-right: 20px;
    background: #FFF;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    border-radius: 20px;
}

#feature #featureInner .itemData:nth-child(2n) {
    margin-right: 0px;
}

#feature #featureInner .itemData .imgBox {
    margin: 20px auto;
    text-align: center;
}

#feature #featureInner .itemData .textBox {
    margin: 20px auto;
    text-align: left;
}

#feature #featureInner .itemData .linkBox {
    width: 270px;
    margin: 0px auto;
}

#feature #featureInner .itemData .linkBox a {
    width: 100%;
}

#contentsSingle #feature #featureInner .itemData {
    margin-right: 20px;
    width: 320px;
}

#contentsSingle #feature #featureInner .itemData:nth-child(3n) {
    margin-right: 0px;
}

#contentsSingle #feature #featureInner .itemData:nth-child(2n) {
    margin-right: 20px;
}

#contentsSingle #feature #featureInner .itemData .imgBox img {
    width: 270px;
}


/* abc test 20201020 for feature2 ------------------------------------------------ */

#feature2 {
    padding: 0px;
    margin-top: 40px;
    margin-bottom: 40px;
}

#feature2 h2 {
    background: #153B54;
    color: #FFF;
    font-size: 18px;
    line-height: 30px;
    display: flex;
    margin: 0px 0px 10px 0px;
    padding: 2px 0px;
}

#feature2 h2 i {
    padding: 0px 5px 0px 5px;
}

#feature2 #featureInner2 .itemData h3 {
    font-size: 18px;
    line-height: 24px;
    font-weight: normal;
    text-align: center;
    padding: 0px 0px 10px 0px;
    border-bottom: 1px solid #307FD8;
    font-weight: bold;
}

#feature2 #featureInner2 .itemData h3 a {
    color: #307FD8;
    text-decoration: none;
}

#feature2 #featureInner2 {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
    width: 100%;
    padding: 10px 0px 0px 0px;
}

#feature2 #featureInner2 .itemData {
    padding: 20px;
    width: 330px;
    margin-right: 20px;
    background: #FFF;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    border-radius: 20px;
}

#feature2 #featureInner2 .itemData:nth-child(2n) {
    margin-right: 0px;
}

#feature2 #featureInner2 .itemData .imgBox {
    margin: 20px auto;
    text-align: center;
}

#feature2 #featureInner2 .itemData .textBox {
    margin: 20px auto;
    text-align: left;
}

#feature2 #featureInner2 .itemData .linkBox {
    width: 270px;
    margin: 0px auto;
}

#feature2 #featureInner2 .itemData .linkBox a {
    width: 100%;
}

#contentsSingle #feature2 #featureInner2 .itemData {
    margin-right: 20px;
    width: 320px;
}

#contentsSingle #feature2 #featureInner2 .itemData:nth-child(3n) {
    margin-right: 0px;
}

#contentsSingle #feature2 #featureInner2 .itemData:nth-child(2n) {
    margin-right: 20px;
}

#contentsSingle #feature2 #featureInner2 .itemData .imgBox img {
    width: 270px;
}


/* item ------------------------------------------------ */

.itemData {
    padding: 0px;
    margin-bottom: 20px;
    padding: 20px;
}

.itemDataHead {
    margin-bottom: 20px;
    display: flex;
    padding: 0px 0px 10px 0px;
}

.itemDataHead i {
    width: 50px;
    text-align: center;
}

.itemDataHead i img {
    width: 50px;
}

.itemName {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: space-between;
}

.itemName .ratingBox {
    width: 140px;
}

.itemName h3 {
    width: 500px;
    text-align: left;
    padding: 0px 10px;
    font-size: 21px;
    line-height: 24px;
    font-weight: bold;
}

.itemData h4.appealTit {
    font-size: 16px;
    line-height: 20px;
    font-weight: bold;
    padding: 5px 10px;
    ;
}

.itemDataInner {
    display: flex;
    margin-bottom: 20px;
}

.itemDataInner .imgBox {
    width: 240px;
}

.itemDataInner .imgBox img {
    width: 240px;
}

.itemDataInner .pointBox {
    width: 100%;
    padding-left: 20px;
}

.itemDataInner .pointBox ul {
    margin: 0px;
}

.itemDataInner .pointBox li {
    display: table;
    font-size: 17px;
    font-weight: normal;
    line-height: 22px;
    padding: 5px 0px 0px 0px;
}

.itemDataInner .pointBox li:before {
    display: table-cell;
    content: "\f00c";
    font-family: FontAwesome;
    font-size: 14px;
    line-height: 22px;
    padding: 0px 5px 0px 0px;
}

.specTable {
    margin: 10px 0px;
}

.specTable table {
    border-collapse: collapse;
    width: 100%;
    border-top: 1px solid #A3E5FB;
    border-bottom: 1px solid #A3E5FB;
}

.specTable th {
    white-space: nowrap;
    padding: 5px;
    background: #A3E5FB;
    text-align: center;
    border-right: 1px solid #FFF;
}

.specTable th:first-child {
    border-left: 1px solid #A3E5FB;
}

.specTable th:last-child {
    border-right: 1px solid #A3E5FB;
}

.specTable td {
    padding: 5px;
    background: #FFF;
    border-right: 1px solid #A3E5FB;
    text-align: center;
    vertical-align: middle;
}

.specTable td:first-child {
    border-left: 1px solid #A3E5FB;
}

.specialtyBox {
    display: flex;
    background: #A3E5FB;
    align-items: center;
    justify-content: start;
    padding: 5px;
    margin: 10px 0px 20px 0px;
}

.specialtyBox h4 {
    width: 100px;
    font-size: 15px;
    font-weight: bold;
    padding: 5px 10px;
    color: #1D50A2;
    text-align: center;
}

.specialtyBox ul {
    display: flex;
    flex-wrap: wrap;
}

.specialtyBox ul li {
    background: #CCC;
    color: #FFF;
    padding: 0px 10px;
    border-radius: 20px;
    margin: 5px 0px 5px 5px;
}

.specialtyBox ul li.on {
    background: #1D50A2;
    color: #FFF;
    padding: 0px 10px;
    border-radius: 20px;
    margin: 5px 0px 5px 5px;
}

.osusumePoint {
    border-radius: 20px;
    padding: 20px;
    background: #F5F982;
    margin: 20px 0px;
}

.osusumePoint h3.osusumeTit {
    margin-bottom: 10px;
    padding: 0px;
}

.osusumePointText em {
    color: #eb1a1a;
    font-weight: bold;
    font-style: normal;
}

.kuchikomiBox {
    display: flex;
    flex-wrap: wrap;
    align-items: start;
}

.kuchikomiData {
    display: flex;
    margin-bottom: 10px;
    margin-right: 20px;
}

.kuchikomiData:nth-child(2n) {
    margin-right: 0px;
}

.kuchikomiData figure {
    width: 60px;
    margin-right: 10px;
}

.kuchikomiData .kuchikomiDataInner {
    position: relative;
    border-radius: 5px;
    background: #A3E5FB;
    padding: 10px;
    width: 260px;
}

.kuchikomiData .kuchikomiDataInner:before {
    content: "";
    position: absolute;
    top: 21px;
    left: -14px;
    margin-top: -7px;
    border: 7px solid transparent;
    border-right: 7px solid #A3E5FB;
}

.kuchikomiData .kuchikomiText .text {
    padding-top: 5px;
}

.kuchikomiHead {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 5px;
}

.kuchikomiHead .rate {
    margin-right: 5px;
    position: relative;
    display: inline-block;
    width: 60px;
    height: 16px;
    font-size: 12px;
    line-height: 16px;
}

.kuchikomiHead .rate:before,
.kuchikomiHead .rate:after {
    position: absolute;
    top: 0px;
    left: 0px;
    content: '★★★★★';
    display: inline-block;
    height: 16px;
}

.kuchikomiHead .rate:before {
    color: #FFF;
    -webkit-text-stroke: 1px #999;
    text-stroke: 1px #999;
}

.kuchikomiHead .rate:after {
    color: #666;
    overflow: hidden;
    white-space: nowrap;
}

.kuchikomiHead .rate1:after {
    width: 12px;
}

.kuchikomiHead .rate2:after {
    width: 24px;
}

.kuchikomiHead .rate3:after {
    width: 36px;
}

.kuchikomiHead .rate4:after {
    width: 48px;
}

.kuchikomiHead .rate5:after {
    width: 60px;
}

.kuchikomiHead .ratingNum {
    color: #C04C44;
    font-size: 16px;
    line-height: 16px;
    margin-right: 0px;
    margin-right: 5px;
}

.kuchikomiHead .ratingBox {
    display: flex;
    align-items: center;
}

.kuchimomiMoreBtnWrap {
    width: 100%;
    text-align: center;
    font-size: 14px;
    line-height: 24px;
    font-weight: bold;
    padding-top: 10px;
    color: #153B54;
}

.kuchimomiMoreBtn:hover {
    cursor: pointer;
}

.kuchimomiMoreBtn i {
    font-size: 24px;
    color: #ABABAB;
    padding-right: 10px;
    vertical-align: -3px;
}

.osusumePointText strong {
    color: #eb1a1a;
    font-weight: bold;
    font-style: normal;
    background: linear-gradient(transparent 50%, #FFFF84 0%);
}

.osusumePointB {
    background: #FFFFFF;
    border-radius: 20px;
    padding: 20px;
    border: 1px solid #1F1F1F;
    margin: 20px 0px;
}

.osusumePointB h3.osusumeTit {
    margin-bottom: 10px;
    padding: 0px;
}

.osusumePointBText strong {
    color: #eb1a1a;
    font-weight: bold;
    font-style: normal;
}

.osusumePointBText em {
    background: #FFFF82;
    color: #000000;
    font-weight: bold;
    font-style: normal;
}

.kyujin img {
    width: 100%;
}


/* ranking ------------------------------------------------ */

#ranking {
    margin-bottom: 40px;
}

.rankingTit {
    margin-bottom: 20px;
}

#ranking00 {
    background: #FFFFFF;
    border: 1px solid #FFFFFF;
    border-radius: 20px;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

#ranking01 {
    background: #FFFEF5;
    border: 1px solid #FFFEF5;
    border-radius: 20px;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

#ranking02 {
    background: #F3FCFE;
    border: 1px solid #F3FCFE;
    border-radius: 20px;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

#ranking03 {
    background: #FEF8F9;
    border: 1px solid #FEF8F9;
    border-radius: 20px;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

#ranking .itemData .linkBox {
    padding: 10px 0px 0px 0px;
}

#ranking .itemData .linkBox ul {
    display: flex;
    width: 100%;
    margin: 0px auto;
}

#ranking .itemData .linkBox li:nth-child(1) {
    padding: 0px 5px 0px 0px;
    width: 20%;
}

#ranking .itemData .linkBox li:nth-child(2) {
    padding: 0px 0px 0px 5px;
    width: 80%;
}

#ranking .itemData .linkBox li a {
    width: 100%;
}

#ranking01 .itemDataInner .pointBox li:before {
    color: #C04C44;
}

#ranking02 .itemDataInner .pointBox li:before {
    color: #194B82;
}

#ranking03 .itemDataInner .pointBox li:before {
    color: #ED7C3D;
}

#ranking00 .itemDataInner .pointBox li:before {
    color: #194B82;
}

#ranking01 .itemDataHead {
    border-bottom: 2px solid #C04C44;
}

#ranking02 .itemDataHead {
    border-bottom: 2px solid #194B82;
}

#ranking03 .itemDataHead {
    border-bottom: 2px solid #ED7C3D;
}

#ranking00 .itemDataHead {
    border-bottom: 2px solid #194B82;
}

#ranking01 .itemName h3 a {
    color: #C04C44;
}

#ranking02 .itemName h3 a {
    color: #194B82;
}

#ranking03 .itemName h3 a {
    color: #ED7C3D;
}

#ranking00 .itemName h3 a {
    color: #194B82;
}

#ranking #monthTextBox {
    font-size: 18px;
    line-height: 36px;
    font-weight: bold;
    position: absolute;
    top: 300px;
    left: 670px;
    width: 270px;
    text-align: center;
    padding: 5px;
    color: #fff;
}

#ranking #monthTextBox strong {
    font-size: 24px;
    line-height: 20px;
}


/* details ------------------------------------------------ */

#details {
    background: #FFFFFF;
    border: 1px solid #FFFFFF;
    border-radius: 20px;
    box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
    -moz-box-shadow: 0px 0px 5px -3px rgba(0, 0, 0, 0.8);
}

#details .itemData .linkBox {
    padding: 10px 0px 0px 0px;
}

#details .itemData .linkBox ul {
    display: flex;
    width: 100%;
    margin: 0px auto;
}

#details .itemData .linkBox li a {
    width: 100%;
}

#details .itemData .linkBox li {
    width: 100%;
}


/* searchResult ------------------------------------------------ */

#searchResult {
    margin-bottom: 40px;
}

.searchConditionBox p {
    font-size: 21px;
    line-height: 36px;
    text-align: left;
    color: #194B82;
}

.searchConditionBox strong {
    font-size: 28px;
    padding: 0px 5px 0px 25px;
    display: inline-block;
    color: #D03730;
}

.serachResultTable {
    width: 100%;
    border-collapse: separate;
    margin: 10px 0px 0px 0px;
    border-spacing: 0px;
    border-top: 1px solid #194B82;
    border-right: 1px solid #194B82;
}

.serachResultTable tr {
    background: url(/common/img/line02.png)repeat-x center bottom;
}

.serachResultTable td {
    padding: 10px;
    vertical-align: middle;
    font-size: 14px;
    border-left: 1px solid #194B82;
    border-bottom: 1px solid #194B82;
}

.serachResultTable th {
    font-size: 16px;
    background: #194B82;
    color: #FFF;
    padding: 5px;
    text-align: center;
    border-left: 1px solid #FFF;
    border-bottom: 1px solid #194B82;
}

.serachResultTable th:first-child {
    border-left: 1px solid #194B82;
}

.serachResultTable th span {
    letter-spacing: 0.5em;
    padding-left: 0.5em;
}

.serachResultTable td.siteName .ratingBox {
    margin: 10px 0px;
    width: 240px;
    justify-content: center;
}

.serachResultTable td.siteName figcaption {
    margin-bottom: 5px;
    display: block;
    font-size: 18px;
    font-weight: bold;
}

.serachResultTable td.siteName figure img {
    width: 200px;
}

.serachResultTable td.siteName figure {
    width: 200px;
    margin: 0px auto;
}

.serachResultTable td.siteName a {
    color: #121212;
    text-decoration: none;
}

.arrowBox {
    display: inline-block;
}

.arrowBox li {
    margin: 2px 5px;
    font-size: 1px;
    line-height: 8px;
    padding: 0px;
}

.sort:hover {
    cursor: pointer;
}

.serachResultTable .upArrow .sort {
    text-indent: -9999px;
    background-image: url(/common/img/sort_up_arrow.png);
    background-repeat: no-repeat;
    background-position: bottom center;
    cursor: pointer;
    display: block;
    width: 12px;
    height: 8px;
}

.serachResultTable .upArrow .on {
    text-indent: -9999px;
    background-image: url(/common/img/sort_up_arrow_o.png);
    background-repeat:no-repeat;
    background-position: bottom center;
    cursor: pointer;
    display: block;
    width: 12px;
    height: 8px;
}

.serachResultTable .downArrow .sort {
    text-indent: -9999px;
    background-image: url(/common/img/sort_down_arrow.png);
    background-repeat: no-repeat;
    background-position: bottom center;
    cursor: pointer;
    display: block;
    width: 12px;
    height: 8px;
}

.serachResultTable .downArrow .on {
    text-indent: -9999px;
    background-image: url(/common/img/sort_down_arrow_o.png);
    background-repeat: no-repeat;
    background-position: bottom center;
    cursor: pointer;
    display: block;
    width: 12px;
    height: 8px;
}

.serachResultTable td .ratingBox strong {
    display: block;
}

.serachResultTable td ul.tags li {
    background: #ccc;
    color: #FFF;
    padding: 0px 5px;
    border-radius: 10px;
    text-align: center;
    margin: 0px 0px 5px 0px;
    letter-spacing: -0.05em;
}

.serachResultTable td ul.tags li.on {
    background: #194B82;
    color: #FFF;
    padding: 0px 5px;
    border-radius: 10px;
    text-align: center;
    margin: 0px 0px 5px 0px;
    letter-spacing: -0.05em;
}

.serachResultTable td ul.linkBox {
    width: 200px;
    margin: 0px auto;
}

.serachResultTable td ul.linkBox li {
    padding: 0px 0px 10px 0px;
    text-align: center;
}

.serachResultTable td ul.linkBox li a.btnType03 {
    width: 95%;
    border-radius: 25px;
    font-size: 18px;
    line-height: 28px;
    padding: 10px 5px;
}

.serachResultTable td ul.linkBox li a.btnType03b {
    width: 95%;
    border-radius: 25px;
    font-size: 18px;
    line-height: 28px;
    padding: 10px 5px;
}

.serachResultTable td ul.linkBox li a.btnType01 {
    width: 60%;
    padding: 10px 5px
}


/* column pankuzu --------------------------------------- */

nav#pankuzu ul {
    margin: 0px auto 10px auto;
    font-size: 10px;
    line-height: 15px;
    width: 725px;
    list-style: none;
    padding: 5px 0px;
}

nav#pankuzu ul li {
    display: inline-block;
}

nav#pankuzu ul li:before {
    content: ">";
    padding: 0px 5px;
}

nav#pankuzu ul li:first-child:before {
    content: "";
    padding: 0px;
}


/* column index----------------------------------------------- */

#columnMain h1 {
    font-size: 22px;
    line-height: 140%;
    color: #494949;
    display: block;
    margin-bottom: 10px;
    padding: 0.4em 0.5em;
    background: #f4f4f4;
    border-left: solid 5px #153b54;
    border-bottom: solid 3px #d7d7d7;
}

#columnMain ul {
    margin: 0px;
    padding: 0px;
    font-size: 12px;
    line-height: 15px;
    list-style: none;
}

.tagList li {
    display: inline-block;
    padding: 0px 5px 0px 0px;
}

.tagList li:first-child {
    padding: 0px 5px 0px 0px;
}

.tagList li a {
    color: #008FFF;
}

.timeStamp {
    text-align: right;
    width: 100%;
}

.timeStamp li {
    display: inline-block;
    padding: 5px;
    color: #174A7D;
}

.timeStamp li time {
    padding: 0px 5px;
    color: #666;
}

#columnMain {
    font-size: 16px;
    line-height: 32px;
}

#columnMain .entryIndex {
    padding: 0px;
}

#columnMain h2.h2Type01 {
    font-size: 20px;
    line-height: 40px;
    height: 40px;
    background: #D1F0Fd;
    color: #39393a;
    padding: 0px 10px;
}

#columnMain h3.h3Type01 {
    font-size: 18px;
    line-height: 40px;
    height: 40px;
    border-bottom: 1px solid #cccccc;
    border-left: 7px solid #FF5800;
    color: #545454;
    padding: 0px 10px;
    font-weight: normal;
}

#columnMain ul.listType01 li {
    color: #174A7D;
    font-size: 16px;
    line-height: 25px;
    font-weight: bold;
    padding: 5px 5px 0px 10px;
}

#columnMain ul.listType01 li:before {
    font-family: "Font Awesome 5 Free";
    content: "\f150";
    color: #addc30;
    font-weight: 900;
    margin-right: 10px
}

#columnMain figure {
    text-align: center;
    margin: 0 0 20px;
}

#columnMain figure img {
    vertical-align: bottom;
    max-width: 720px;
}

#columnMain blockquote {
    position: relative;
    padding: 10px 20px;
    box-sizing: border-box;
    font-style: normal;
    background: #EDF5F6 url(/common/img/bg_blockquote.png) no-repeat left top;
    border: 1px solid #87BEC5;
    border-radius: 3px;
}

#columnMain blockquote p {
    padding: 0px;
    margin: 10px 0px;
    line-height: 150%;
}

#columnMain blockquote cite {
    display: block;
    text-align: right;
    color: #999;
    font-size: 10px;
    font-style: normal;
}

#columnMain strong {
    color: #ff0000;
    background: linear-gradient(transparent 50%, #ff6 50%);
}

#columnMain b {
    color: #ff0000;
    background: linear-gradient(transparent 50%, #ff6 50%);
}

#columnMain cite {
    display: block;
    color: #999;
    font-size: 10px;
    font-style: normal;
}

#columnMain em {
    font-weight: 600;
    background: linear-gradient(transparent 50%, #ff0 50%);
    color: #ff0000;
    font-style: normal
}

#columnMain .matomeBox ul.point {
    padding: 10px;
    border: 1px solid #008FFF;
}

#columnMain .matomeBox ul.point li {
    color: #174A7D;
    font-size: 16px;
    line-height: 25px;
    font-weight: bold;
    padding: 5px 5px 0px 30px;
    background: url(/common/img/ico_point01.png) no-repeat left 5px;
}

#columnMain ul.point {
    padding: 10px;
    border: 1px solid #008FFF;
}

#columnMain ul.point li {
    color: #174A7D;
    font-size: 16px;
    line-height: 25px;
    font-weight: bold;
    padding: 5px 5px 0px 30px;
    background: url(/common/img/ico_point01.png) no-repeat left 5px;
}

#columnMain p {
    margin: 0 0 20px;
}

#columnMain ol {
    margin-bottom: 30px;
}

#columnMain ol li {
    list-style-type: decimal;
    margin-left: 40px;
}

#columnMain h3.pointBoxTit {
    background: #008FFF;
    margin: 0px;
    padding: 0px;
}

#columnMain h3.pointBoxTit img {
    vertical-align: bottom;
}

#columnMain .pointBox ul.point {
    padding: 10px;
    border: 1px solid #008FFF;
}

#columnMain .pointBox ul.point p {
    margin: 0
}

#columnMain .pointBox ul.point li {
    color: #174A7D;
    font-size: 16px;
    line-height: 25px;
    font-weight: bold;
    padding: 5px 5px 0px 30px;
    background: url(/common/img/ico_point01.png) no-repeat left 5px;
}

#columnMain .pointBox ul.point li em {
    font-style: normal;
    background: linear-gradient(transparent 30%, #FF0 30%);
}

#columnMain .pointBox ul.point li strong {
    color: #FF6B6B;
}

#columnMain .aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

#columnMain table.tbarticle {
    border-spacing: 1px;
    width: 100%;
    max-width: 840px;
    margin: 10px auto;
    text-align: center;
    border-collapse: collapse;
    border-spacing: 0px;
    font-size: 15px;
    line-height: 150%;
}

#columnMain table.tbarticle th {
    background-color: #174A7E;
    margin: 0px;
    padding: 5px;
    text-align: center;
    font-weight: bold;
    vertical-align: middle;
    color: #FFF;
}

#columnMain table.tbarticle td {
    padding: 15px;
    background-color: #FFF;
    vertical-align: middle;
    border: 1px solid #EFEFEF;
}

#columnMain table.tbarticle td.tbt {
    background: #EDF5F6;
}

#columnMain .columnList {
    font-size: 16px;
    color: #5e5854;
}


/* #columnMain .columnList .head_special{position: relative;padding: 15px;border-top: 3px solid #ffffff;background-repeat: no-repeat;background-color: #fff;-webkit-box-shadow: rgba(0, 0, 0, 0.18) 0 1px 2px 0;box-shadow: rgba(0, 0, 0, 0.18) 0 1px 2px 0;} */

#columnMain .columnList h2.title {
    font-size: 26px;
    font-weight: bold;
    color: #073E0D;
}

#columnMain .columnList h3.subTitle {
    font-size: 17px;
    padding: 0.25em 0.5em;
    margin: 30px 0 0;
    background: transparent;
    border-bottom: solid 1px #b5b5b5;
    border-left: solid 5px #153b54;
}

#columnMain .columnList ul.contentsList {
    padding: 0px 10px 10px 10px;
    font-size: 10px;
    line-height: 150%;
    list-style: none;
}

#columnMain .columnList ul.contentsList a {
    padding: 0px 5px 0px 0px;
    font-size: 16px;
    line-height: 150%;
}

#columnMain .columnList ul.contentsList li {
    background-repeat: no-repeat;
    background-position: left center;
    padding: 10px 0px 10px 5px;
}

#columnMain .columnList ul.contentsList li a {
    color: #3579d4;
    text-decoration: underline;
}

#columnMain .columnList ul.contentsList li {
    background: url("/common/img/ico_column.png") left/*top*/
    no-repeat;
    background-size: auto 20px;
    padding-left: 30px;
    margin-right: 5px;
}


/*#columnMain .columnList ul.contentsList li :before {font-family: "Font Awesome 5 Free";content: "\f0a4";color: #addc30;font-weight: 900;margin-right:5px}*/

#columnMain .columnList .contentsTextBox {
    padding: 10px 0;
    line-height: 140%;
}

#columnMain .columnList .contentsTextBox p {
    padding: 0 0 5px 0;
}

#columnMain .columnList .contentsTextBox img {
    padding: 10px;
}

#columnMain .RankingList {
    margin-bottom: 20px;
    padding: 10px 0;
    border: 1px solid #dfd8ef;
    border-radius: 0 0 6px 6px;
    background: #ffffdf;
}

#columnMain .marker {
    font-weight: 600;
    background: linear-gradient(transparent 50%, #ff6 50%);
}

#columnMain a.textlink {
    color: #4AA8DD;
}

#columnMain a.bold {
    font-size: 120%;
    font-weight: bold;
}


/* Footer pages --------------------------------------- */

.FooterContentsWrapper {
    margin: 0px;
}

.FooterContents {
    margin: 5px auto 20px auto;
    width: 1000px;
    display: table;
}

.FinfoBox h3 {
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 20px;
    padding: 10px 0px;
}

.FinfoBox .infoTextBox h4 {
    font-size: 16px;
    font-weight: bold;
    border-left: 5px solid #153b54;
    padding-left: 10px
}

.FinfoBox .infoTextBox p {
    padding-left: 10px;
    font-size: 14px;
    margin: 5px 0 40px;
}

.FinfoBox .companytable {
    vertical-align: middle;
    border: 1px solid #333;
    border-bottom: 0px solid #333;
    margin-bottom: 40px;
}

.FinfoBox .companytd {
    width: 150px;
    height: 40px;
    text-align: center;
    vertical-align: middle;
    background: #e9e9e9;
    border-right: 1px solid #333;
    border-bottom: 1px solid #333;
}

.FinfoBox .companytdright {
    width: 600px;
    vertical-align: middle;
    border-bottom: 1px solid #333;
}


/* ランキングタイトル追加分 --------------------------------------- */

.rankingTitBox {
    position: relative;
}

.rankingTitBox .rankingTit img {
    max-width: 725px;
    width: 100%;
}

.rankingTitBox .rankingMonthTextBox {
    width: 220px;
    text-align: center;
    position: absolute;
    right: 5px;
    bottom: 5px;
    color: #FFF;
    font-size: 18px;
    line-height: 24px;
}

.rankingTitBox .rankingMonthTextBox strong {
    font-size: 24px;
}


/* Job pages --------------------------------------- */

.htmlBox h2 {
    font-size: 24px;
    padding-left: 15px;
    font-weight: bold;
    color: #4c5f98;
    padding: 0.5em 0;
    border-top: solid 3px #364e96;
    border-bottom: solid 3px #364e96;
}

.htmlBox img {
    width: 100%;
}


/*-2021/10/26追加- */


/* pickupRanking --------------------------------------- */

#pickupRanking {
    border-top: 5px solid #D03730;
    padding-top: 3px;
    background: #FFFEF5;
    width: 1000px;
    margin: 0px auto;
}

#pickupRanking h2.rankingListTit {
    color: #D03730;
    font-size: 18px;
    display: flex;
    align-items: center;
    padding: 2px 0px;
    font-weight: bold;
}

#pickupRanking h2.rankingListTit i {
    padding: 0px 5px 0px 5px;
}

#pickupRanking .rankingPNG {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding-bottom: 20px;
}

#pickupRanking .rankingPNG li {
    padding: 3px;
    flex: 1;
    width: 330px;
}

#pickupRanking .rankingPNG img {
    width: 326px;
}


/* TOP3Ranking --------------------------------------- */

section.top-rank {
    width: 1000px;
    margin: 0px auto;
    margin-bottom: 2rem;
}

section.top-rank h3 img {
    width: 1000px;
    margin-top: 10px;
    margin-bottom: 5px;
}

section.top-rank ol {
    display: flex;
    justify-content: space-between;
    margin: 5px;
}

section.top-rank ol li {
    width: 33%;
    text-align: center;
    position: relative;
    list-style: none;
}

section.top-rank ol li a {
    font-weight: bold;
    font-size: 2.5vw;
    color: #000;
}

.topgroup {
    border-radius: 0.5rem;
    -webkit-box-shadow: 0 2px 8px 0 rgb(2 13 110 / 15%);
    box-shadow: 0 2px 8px 0 rgb(2 13 110 / 15%);
    margin-right: 7px;
    margin-left: 7px;
    padding: 8px;
    padding-bottom: 17px;
}

.topgroup p {
    font-size: 15px;
    font-weight: normal;
    color: #144160;
}

.top3_logo {
    height: 62px;
    padding: 4px 0 0;
    border-bottom: 1px solid #ccc;
    margin-bottom: 11px;
}

.btn_top3 {
    border-radius: 15px;
    color: #FFF;
    display: inline-block;
    text-align: center;
    text-decoration: none;
    padding: 4px 20px 3px;
    font-size: 14px;
    letter-spacing: 1px;
}

.word_top3 {
    height: 3.4rem;
}

.topmenu_link p {
    color: #3c62be;
}


/* button-animation --------------------------------------- */

a.btnType04 {
    position: relative;
    top: -4px;
    display: block;
    font-size: 15px;
    font-weight: bold;
    color: #fff;
    letter-spacing: 1px;
    text-align: center;
    text-decoration: none;
    background: #F96582;
    background: linear-gradient(60deg, #ff7855, #ff39a0);
    box-sizing: border-box;
    box-shadow: 0 4px 0 0 rgb(237 183 197 / 50%);
    animation: btn-action 1s ease 0s infinite;
}

@keyframes btn-action {
    0% {
        top: -4px;
        box-shadow: 0 4px 0 0 rgba(237, 183, 197, 0.5);
    }
    50% {
        top: 0;
        box-shadow: 0 0 0 0 rgba(237, 183, 197, 0.5);
    }
}

a.btnType04 span {
    display: block;
    width: 100%;
    height: 100%;
    background: url("/common/img/ico_arrow.png") right 5px center no-repeat;
    background-size: 9px 15px;
    padding-top: 0;
}

a.btnType01 {
    letter-spacing: 1px;
}

.btn_top3 {
    position: relative;
    top: -4px;
    background: linear-gradient(60deg, #ff7855, #ff39a0);
    box-shadow: 0 4px 0 0 rgb(237 183 197 / 50%);
    animation: btn-action 1s ease 0s infinite;
}

a.btnType02 {
    position: relative;
    top: -4px;
    display: block;
    font-size: 15px;
    font-weight: bold;
    color: #fff;
    letter-spacing: 1px;
    text-align: center;
    text-decoration: none;
    background: #F96582;
    background: linear-gradient(60deg, #ff7855, #ff39a0);
    border-radius: 20px;
    box-sizing: border-box;
    box-shadow: 0 4px 0 0 rgb(237 183 197 / 50%);
    animation: btn-action 1s ease 0s infinite;
    padding: 11px 5px 10px;
}

a.btnType02 span {
    display: block;
    width: 100%;
    height: 100%;
    background: url("/common/img/ico_arrow.png") right 5px center no-repeat;
    background-size: 9px 15px;
    padding-top: 0;
}

section.top-rank {
    width: 1000px;
    margin: 0px auto;
    margin-bottom: 2rem;
}


/*20220317追加*/

.jobBannerBox img {
    width: 100%;
}


/*20220331追加*/

.rankingTitBox .rankingMonthTextBox.high {
    right: 50%;
    bottom: 28px;
    transform: translateX(50%);
}


/*20220427追加*/

#searchForm.t-lp {
    width: 1000px;
    margin: 0px auto;
}

#searchForm.t-lp #searchTable02 table {
    width: 100%;
    font-size: 14px;
    line-height: 18px;
    border-collapse: separate;
    border-spacing: 5px;
}


/*20220620追加*/

.add-a-brackets .btn_top3:before,
.add-a-brackets .btnType04 span:before,
.add-a-brackets.btnType04 span:before,
.add-a-brackets .btnType02 span:before,
.add-a-brackets.btnType02 span:before {
    content: "【"
}

a.btnType04.add-a-brackets span,
a.btnType02.add-a-brackets span,
.add-a-brackets a.btnType02 span,
.add-a-brackets a.btnType04 span {
    background: none;
}

.add-a-brackets .btn_top3:after,
.add-a-brackets.btnType04 span:after,
.add-a-brackets .btnType04 span:after,
.add-a-brackets.btnType02 span:after,
.add-a-brackets .btnType02 span:after {
    content: "】"
}

.ttl-img img {
	width: 100%;
}

.rankingTitBox .rankingMonthTextBox.r-40s,
.rankingTitBox .rankingMonthTextBox.r-50s,
.rankingTitBox .rankingMonthTextBox.r-30s  {
    /*display:none;*/
}




.itemData .linkBox a.btnType04b{
    display: block;
    position: relative;
    background-color: #ff5722;
    box-shadow: 0 3px 0 0 rgba(217, 80, 80, 1);
    border-radius: 5px;
    font-weight: bold;
    font-size: 18px;
    color: #fff;
    text-align: center;
    text-decoration: none;
    overflow: hidden;
    padding: 15px 20px;
    margin: 0 auto;
}

.itemData .linkBox a.btnType04b:hover{
    text-decoration: none;
    color: #fff;
    box-shadow: none;
    transform: translateY(3px);
    background-color: #ff5722;
}


.itemData .linkBox a.btnType04b::before {
    position: absolute;
    content: '';
    display: inline-block;
    top: -180px;
    left: 0;
    width: 30px;
    height: 100%;
    background-color: #fff;
    transition: 0.2s;
    animation: official 6s ease-in-out infinite;
}


.itemData .linkBox a.btnType01b {
    background-color: #fff;
    border: none;
    outline: solid 1px #333;
    outline-offset: -1px;
    color: #333;
    display: block;
    font-size: 14px;
    text-align: center;
    text-decoration: none;
    padding: 16px 20px;
    border-radius: 5px;
}

.itemData .linkBox a.btnType01b:hover {
    border: none;
    outline: solid 1px #ff0057;
    outline-offset: -1px;
}

.itemData .linkBox a.btnType01b {
    font-size: 14px;
    padding: 16px 10px;
}


.btn_top3b {
background-color: #ff5722;
box-shadow: 0 3px 0 0 rgba(217, 80, 80, 1);
border-radius: 5px;
color: #FFF;
display: inline-block;
text-align: center;
text-decoration: none;
padding: 1px 10px 0;
font-size: 10px;
letter-spacing: 0.5px;
position: relative;
overflow: hidden;
}

.btn_top3b:before {
position: absolute;
content: '';
display: inline-block;
top: -180px;
left: 0;
width: 10px;
height: 100%;
background-color: #fff;
transition: 0.2s;
animation: official 6s ease-in-out infinite;
}

.btn_top3b:hover {
text-decoration: none;
color: #fff;
box-shadow: none;
transform: translateY(2px);
background-color: #ff5722;
}




.linkBox a.btnType03b{
    display: block;
    position: relative;
    background-color: #ff5722;
    box-shadow: 0 3px 0 0 rgba(217, 80, 80, 1);
    border-radius: 5px !important;
    font-weight: bold;
    font-size: 18px;
    color: #fff;
    text-align: center;
    text-decoration: none;
    overflow: hidden;
    padding: 15px 20px;
    margin: 0 auto;
}

.linkBox a.btnType03b:hover{
    text-decoration: none;
    color: #fff;
    box-shadow: none;
    transform: translateY(3px);
    background-color: #ff5722;
}


.linkBox a.btnType03b::before {
    position: absolute;
    content: '';
    display: inline-block;
    top: -180px;
    left: 0;
    width: 30px;
    height: 100%;
    background-color: #fff;
    transition: 0.2s;
    animation: official 6s ease-in-out infinite;
}
.serachResultTable .linkBox {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.serachResultTable .linkBox li{width:100%;}


.serachResultTable .linkBox a.btnType01b {
    text-align: center;
    margin: 0 auto;
    width: 60%;
    background-color: #fff;
    border: none;
    outline: solid 1px #333;
    outline-offset: -1px;
    color: #333;
    display: block;
    font-size: 14px;
    text-align: center;
    text-decoration: none;
    padding: 5px;
    border-radius: 5px;
}

.serachResultTable .linkBox a.btnType01b:hover {
    border: none;
    outline: solid 1px #ff0057;
    outline-offset: -1px;
}

.serachResultTable .linkBox a.btnType01b {
    font-size: 14px;
    padding: 16px 10px;
}


@keyframes btn-action {
    0% {
        top: -4px;
        box-shadow: 0 4px 0 0 rgba(237, 183, 197, 0.5);
    }

    50% {
        top: 0;
        box-shadow: 0 0 0 0 rgba(237, 183, 197, 0.5);
    }
}

@keyframes official {
    0% {
        transform: scale(0) rotate(45deg);
        opacity: 0;
    }

    80% {
        transform: scale(0) rotate(45deg);
        opacity: 0.5;
    }

    81% {
        transform: scale(4) rotate(45deg);
        opacity: 1;
    }

    100% {
        transform: scale(50) rotate(45deg);
        opacity: 0;
    }
}
