@charset "UTF-8";
div.sukima01{
margin-top: 5em;
margin-bottom: 5em;
}

p {
margin-top: 0.5em;
margin-bottom: 1.5em;
padding-right: 5px;
padding-left: 5px;
}

p.img{
text-align: center;
}

p.img img{
width: 80%;
}

p a img{
margin: auto;
display: block;
}

p.micro{
font-size: small;
text-align: center;
margin-top: -13px;
}

p.gachu{
font-size: small;
text-align: right;
margin-top: -25px;
}


.b_body p{
font-size: 1.1em;
color: #000099;
font-weight: bolder;
}

p.Q{
font-size: 1em;
color: #000000;
font-weight: bolder;
}

.huto{
font-weight: bold;
}

.deka{
font-size: x-large;
font-weight: bold;
line-height: 2em;
}

.aka{
color: #B71313;
font-weight: bold;
}

.ao{
color: #0066FF;
font-weight: bold;
text-decoration: underline;
}

.deaka{
font-size: x-large;
color: #B71313;
font-weight: bold;
line-height: 2em;
}

.kasen{
font-weight: bold;
background: linear-gradient(transparent 60%, #FFCCFF 60%);
}

.hukidasi{
font-size: large;
font-weight: bold;
line-height: 1.5em;
}

dl{
margin-bottom: 3em;
}

dd{
padding-left: 4em;
}

p.click {
padding-left: 55px;
position: relative;
}

p.click::before {
position: absolute;
display: inline-block;
top: -20px;
left: 0px;
content: url(<% imgDir %>icon-click-.png);
transform: scale(0.8);
}

p.pr{
font-size: smaller;
color: #FFFFFF;
text-align: right;
position: relative;
top: 210px;
}

.youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%; /* 16:9のアスペクト比 */
    height: 0;
}

.youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


/*
==================================================
ランキングをチェック
==================================================
*/

.backranking { 
position: fixed;
bottom: 0px;
right: 0px;
}

/*
==================================================
ランキング表修正（ChatGPT）
==================================================
*/

 .ranking-table {
            width: 100%;
            max-width: 800px;
            margin: 20px auto;
            border-collapse: collapse;
            background-color: #fff;
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
            border: 1px solid #ddd;
        }
        .ranking-table th,
        .ranking-table td {
            border: 1px solid #ddd;
            padding: 5px;
            text-align: center;
            vertical-align: middle;
        }
        .ranking-table .top-row .image-col {
            width: 20%; /* 2:8 ratio */
        }
        .ranking-table .top-row .title-col {
            width: 80%;
            font-size: 1.5em;
            text-align: center;
            font-weight: bold;
        }
        .ranking-table .top-row .title-col a {
            text-decoration: none;
            color: inherit;
        }
        .ranking-table .thumbnail-row img {
            max-width: 33%; /* Thumbnail takes up 1/3 of the row width */
            height: auto;
            display: block;
            margin: 0 auto;
        }
        .ranking-table .text-row p {
            text-align: left;
            font-size: 1em;
            padding: 10px;
        }
        .ranking-table .extra-row {
            text-align: left;
            font-size: 1.2em;
            padding: 10px;
        }
        .ranking-table img {
            max-width: 100%;
            height: auto;
        }

        @media (max-width: 600px) {
            .ranking-table {
                font-size: 0.9em;
            }
            .ranking-table .top-row .title-col {
                font-size: 1.2em;
            }
        }


/*
==================================================
ランキング表
==================================================
*/

@media screen and (max-width: 640px) {
    .rnk1item .ttitle, .rnk1item .timg, .rnk1item th, .rnk1item .timg p, .rnk1item th p {
        text-align: center !important;
    }
}
.rnk1item .timg {
    width: auto;
    padding-top: 10px;
    vertical-align: middle;
}
@media screen and (max-width: 640px) {
    .rnk1item th, .rnk1item td {
        width: 100%;
        display: block;
        border: none;
    }
}
.rnk1item th, .rnk1item td {
}
.rnk1item td {
    background-color: #FFFFFF;
    vertical-align: top;
    font-size:
    line-height: 130%;
    padding: 15px 10px;
}
.rnk1item td, .rnk1item th {
    border: none;
    border-bottom: dotted 1px #CCC;
}
td, th {
    word-break: break-all !important;
}
td {
}
@media screen and (max-width: 640px) {
    td, th, tr {
        -moz-box-sizing: border-box;
        box-sizing: border-box;
    }
}
table, td, th {
    border: solid 1px #CCC;
    word-wrap: break-word;
    overflow-wrap: break-word;
    text-align: left;
}
td {
    background-color: #FFFFFF;
    padding: 5px;
}
* {
    margin: 0;
    padding: 0;
}
user agent stylesheet
td {
    display: table-cell;
    vertical-align: inherit;
    unicode-bidi: isolate;
}

.rnk1item .ttitle {
    font-size: 1.5em;
    font-weight: bold;
    margin-bottom: 12px;
    line-height: 130%;
}