/* CSS Document */

/* ======================================== 共通 ======================================== */
:root {
	--col-black: #171717;
	--col-gray: #C9C9C9;
	--col-d-gray: #5B5B5B;
	--col-l-gray: #F1F1F1;
	
	--col-red: #E60012;
	--col-green: #006835;
	
	--header-height: 110px;
    --menu-transition-duration: 0.4s;
    --menu-transition-timing: cubic-bezier(0.4, 0, 0.2, 1); /* Material Design標準 */
}
 /* [ex] color: var(--col-black); */

body {
    color: var(--col-black);
    font-size: 1rem;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    line-height: 1.6;
	background-color: #FFF;
}

main {
	padding-top: 110px;
}

body:not(#top) h1 {
	font-family: 'Poppins', 'Noto Sans JP', sans-serif;
	font-weight: bold;
    font-size: 2.3rem;
	margin-bottom: 2rem;
    /* text-transform: uppercase; */
	text-align: center;
	letter-spacing: 3px;
}

h2 {
	font-family: 'Poppins', 'Noto Sans JP', sans-serif;
	font-weight: bold;
    font-size: 2.5rem;
	margin-bottom: 2rem;
    text-transform: uppercase;
	text-align: center;
	letter-spacing: 3px;
}

a {
    color: var(--col-red);
    transition: all .2s;
    border-bottom: 1px dotted;
}

a.buttonFill {
    -webkit-transition: all 200ms cubic-bezier(0.22, 0.61, 0.36, 1);
    -moz-transition: all 200ms cubic-bezier(0.22, 0.61, 0.36, 1);
    -ms-transition: all 200ms cubic-bezier(0.22, 0.61, 0.36, 1);
    -o-transition: all 200ms cubic-bezier(0.22, 0.61, 0.36, 1);
    transition: all 200ms cubic-bezier(0.22, 0.61, 0.36, 1);
    display: block;
    margin: 20px auto;
    width: fit-content;
    text-decoration: none;
    padding: 20px 30px;
    font-weight: bold;
    border: none;
}

a.buttonFill.redGreen {
    color: var(--col-red);
    box-shadow: var(--col-red) 0 0px 0px 2px inset;
}
a.buttonFill.redGreen:active {
    color: #FFF;
    box-shadow: var(--col-green) 0 0px 0px 80px inset;
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    a.buttonFill.redGreen:hover {
        color: #FFF;
        box-shadow: var(--col-green) 0 0px 0px 80px inset;
    }
}
a.buttonFill.blackRed {
    color: var(--col-black);
    box-shadow: var(--col-black) 0 0px 0px 2px inset;
}
a.buttonFill.blackRed:active {
    color: #FFF;
    box-shadow: var(--col-red) 0 0px 0px 80px inset;
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    a.buttonFill.blackRed:hover {
        color: #FFF;
        box-shadow: var(--col-red) 0 0px 0px 80px inset;
    }
}

.row a.btn {
    background: var(--col-red);
    color: #FFF;
    display: block;
    width: fit-content;
    margin: 5px auto 10px;
    padding: 10px 30px;
    letter-spacing: 1px;
    text-indent: 0;
    font-weight: bold;
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    .row a.btn:hover {
        opacity: 0.8;
        color: #FFF;
    }
}
.row a.btn.disable {
    opacity: 0.3;
    background-color: #FFF;
    color: var(--col-red);
    border-color: var(--col-red);
}

br.spCtrl { display: none; }/* スマホで改行 */
br.pcCtrl { display: block; }/* スマホ以外で改行 */

.fontL {
    font-size: 110%;
}
.fontLL {
    font-size: 132%;
    letter-spacing: 0.05rem;
    margin-bottom: 0.2rem;
}
.fontB {
    font-weight: bold;
}
.fontRed {
    color: var(--col-red);
}

ul.points {
    list-style: none;
    margin: 0.5rem 0;
    padding-left: 2rem;
    text-indent: -1rem;
}
ul.points > li {
    margin-bottom: 10px;
}
ul.points ul.points {
    list-style: none;
    margin: 0.5rem 0;
    padding-left: 2rem;
    text-indent: -1rem;
}

dl.labeledList {
}
dl.labeledList > dt {
    border: 1px solid var(--col-gray);
    display: inline-block;
    padding: 5px 15px;
    letter-spacing: 1px;
    margin-bottom: 10px;
}
dl.labeledList > dd {
    padding: 0 0 20px 0;
}

ul.points dl.labeledList {
    text-indent: 0;
    margin-top: 0.5rem;
}

/* --- テーブル --- */
.table {}
.table th {
    color: #FFF;
    background-color: var(--col-d-gray);
    border-color: var(--col-l-gray);
    vertical-align: middle;
    white-space: nowrap;
    text-align: center;
}
.table:not(.table-mini) > tbody > tr > th {
    width: 25%;
}
.table td {}
.table td > dl {
    padding: 1rem;
}
.table td > dl > dt {
    border: 1px solid var(--col-l-gray);
    display: inline-block;
    padding: 3px 10px;
    letter-spacing: 2px;
    margin-bottom: 1rem;
    background: var(--col-l-gray);
}
.table td > dl > dd {
    padding: 0 1rem;
}

.table td table th {
    color: var(--col-gray);
    background-color: var(--col-l-gray);
    border-color: var(--col-l-gray);
    vertical-align: middle;
    line-height: 1.2;
}
.table td table thead th {
    background-color: var(--col-l-gray);
    font-weight: bold;
    font-size: 120%;
}
.table td table td {
    vertical-align: middle;
}

.table td div.highlight {
    background: var(--col-gray);
    border: 10px solid var(--col-gray);
    padding: 20px 30px 0;
    color: var(--col-red);
    font-weight: bold;
    font-size: 120%;
}

/* --- タブ --- */
#tab_contents {
    padding-top: 30px;
}
#tab_contents .tab-area {
    display: flex;
    gap: 0 10px; /* アイテム間の隙間（任意） */
    justify-content: space-around;
    align-items: stretch;
    padding: 0 20px;
    margin: 0;
    text-indent: 0;
}
#tab_contents .tab-item {
    flex: 1; /* すべてのアイテムに均等な伸び率（1）を与える */
    font-size: 1.2rem;
    text-align: center;
    color: var(--col-gray);
    border: 1px solid var(--col-d-gray);
    background-color: #FFF;
    font-weight: bold;
    transition: color 0.2s ease, background-color 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 10px 0;
    padding: 20px 10px;
    /* min-width: 120px; */
    max-width: 100%;
    cursor: pointer;
    line-height: 1.2;
    min-height: 100px;
}
#tab_contents .tab-item.active {
    margin: 0;
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    #tab_contents .tab-item:hover {
        color: var(--col-d-gray);
        background-color: var(--col-gray);
    }
}
#tab_contents .tab-item.active {
    color: #FFF;
    background-color: var(--col-d-gray);
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    #tab_contents .tab-item.active:hover {
        color: #FFF;
        background-color: var(--col-d-gray);
    }
}

#tab_contents .panel-area .panel {
    background: var(--col-d-gray);
    display: none;
    text-align: center;
    transition: all 0.2s ease;
    padding: 20px 50px;
    border: 1px solid var(--col-d-gray);
}
#tab_contents .panel-area .panel.active {
    display: block;
    margin-top: -1px;
}

#tab_contents .panel-area .panel #attention {
    background: #FFF;
    text-align: center;
    padding: 30px 50px;
    margin: 0 auto 70px;
    line-height: 1;
    width: fit-content;
}

#tab_contents .panel-area h2 {
    border: none;
    color: #FFF;
    margin: 20px 0;
    padding: 0 0 20px 0;
}

/* dl */
#tab_contents .panel-area dl.outline {}
#tab_contents .panel-area dl.outline > dt {
    background: var(--col-black);
    color: #FFF;
    padding: 10px;
    font-size: 130%;
    letter-spacing: 0.5rem;
    border-bottom: 1px solid var(--col-d-gray);
}
#tab_contents .panel-area dl.outline > dd {
    padding: 40px;
    text-align: left;
    margin-bottom: 3rem;
    background: #FFF;
}
#tab_contents .panel-area dl.outline > dd > table {
    margin: 40px -40px;
    width: calc(100% + 80px);
    border-bottom: 1px solid var(--col-d-gray);
}

#tab_contents .panel-area table {
}
#tab_contents .panel-area table caption {
    caption-side: top;
    text-align: center;
    border-top: 1px solid var(--col-d-gray);
    background: var(--col-l-gray);
    color: var(--col-black);
    font-weight: bold;
    margin-top: 20px;
}

#tab_contents .panel-area table tr th {
    background: var(--col-l-gray);
    color: var(--col-d-gray);
    border-color: var(--col-d-gray);
}
#tab_contents .panel-area table tr td {
    background: #FFF;
    border-left: 1px solid;
    border-color: var(--col-d-gray);
}

/* 初期状態：パネル非表示 */
#tab_contents .panel-area-nest .panel-nest {
    display: none;
}
#tab_contents .panel-area-nest .panel-nest.active {
    display: block;
}
#tab_contents .panel-area-nest .panel-nest h3 {
    background: var(--col-black);
    color: #FFF;
    padding: 20px;
    margin-bottom: 50px;
}

#tab_contents .tab-area-nest {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    margin: 0.5rem 0 2rem;
    padding-left: 0;
    text-indent: 0;
    justify-content: center;
    align-items: center;
    min-height: 70px;
}
#tab_contents .tab-area-nest .tab-item-nest {
    margin: 5px;
    padding: 10px 20px;
    display: block;
    cursor: pointer;
    background-color: #fff;
    color: var(--col-d-gray);
    border: 1px solid #FFF;
    transition: all 0.2s ease;
}
#tab_contents .tab-area-nest .tab-item-nest.active {
    opacity: 1;
    border: 1px solid var(--col-red);
    color: var(--col-red);
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    #tab_contents .tab-area-nest .tab-item-nest:hover {
        opacity: 1;
        border: 1px solid var(--col-red);
        color: var(--col-red);
    }
}
#tab_contents .tab-area-nest .tab-item-nest.active {
    font-size: 130%;
    font-weight: bold;
    letter-spacing: 5px;
    border: 1px solid var(--col-red);
    color: var(--col-red);
    cursor: default;
}

/* --- タブ（ネスト） --- */
.tabs {
    overflow: hidden;
}

.tabs .main-tab,
.tabs .sub-tab {
    display: flex;
    flex-wrap: wrap;
	justify-content: center;
    background-color: var(--col-d-gray);
    border-bottom: 1px solid var(--col-l-gray);
    padding: 10px;
}

.tabs .sub-tab {
    background-color: var(--col-l-gray);
    padding: 10px;
}

.tabs .tab-btn {
    padding: 8px 15px;
    cursor: pointer;
    margin: 5px;
    border: 1px solid transparent;
    border-radius: 4px;
    transition: background-color 0.2s, border-color 0.2s;
    user-select: none;
    color: var(--col-black);
}
@media (hover: hover) {/* マウスが使えるデバイスのみ */
    .tabs .tab-btn:hover {
        background-color: #FFF;
        border-color: var(--col-gray);
    }
}
.tabs .tab-btn:focus {
    outline: none;
}
.tabs .tab-btn.active {
    background-color: #FFF;
    border-color: var(--col-l-gray);
    border-bottom-color: #FFF; 
    font-weight: bold;
    color: var(--col-red); 
}

.tabs .main-tab .tab-btn {
    font-size: 1.05rem;
}

.tabs .sub-tab .tab-btn {
    font-size: 0.9rem;
    padding: 5px 10px;
    margin: 5px;
    border-radius: 2px;
}

.tabs .sub-tab .tab-btn.active {
    background-color: #FFF; 
    border-color: var(--col-red);
    color: var(--col-red);
}

.tabs .sub-tab .tab-btn:empty {/* 小項目がない場合のタブボタンの表示を保証 */
    min-width: 50px;
    text-align: center;
}

.tabs .main-panel {
    padding: 0;
}

.tabs .sub-panel {
    padding: 20px;
    background-color: #fff;
    min-height: 100px;
}

/* --- 絞り込み --- */
.controls {
    display: flex;
    flex-wrap: wrap;
	justify-content: center;
    align-items: center;
    padding: 15px;
    background-color: var(--col-l-gray);
    border: 1px solid var(--col-d-gray);
}

.controls label {
    display: none;
}

.controls select {
    padding: 10px 20px;
    border: 1px solid var(--col-d-gray);
    border-radius: 4px;
    margin: 0 10px;
    font-size: 1.4rem;
    letter-spacing: 1px;
}

.controls #status {
    display: none;
}

/* --- ランキング --- */
#output {
    border: 1px solid var(--col-d-gray);
}
#output p.updatedAt {
	font-size: 1.2rem;
	letter-spacing: 1px;
    text-align: center;
    font-weight: bold;
}
#output h2.rankingTitle {
	font-size: 1.8rem;
	text-transform: none;
	letter-spacing: 1px;
    text-align: center;
    background: var(--col-black);
    color: #FFF;
    padding: 20px;
    margin: 0 auto;
    display: block;
	max-width: 700px;
	width: 100%;
}
#output ul.rankingList {
	max-width: 700px;
	width: 100%;
    border: 10px solid var(--col-gray);
    margin: 0 auto;
	padding: 0;
	list-style: none;
}
#output ul.rankingList li.rankingItem {
	display: flex;
	border-top: 1px solid var(--col-gray);
}
#output ul.rankingList li.rankingItem:first-child {
	border-top: none;
}
#output ul.rankingList li.rankingItem .rank {
	display: flex;
    justify-content: center;
    align-items: center;
    flex: 0 0 80px;/* 幅を XXpx で固定 */
	font-family: 'Teko', sans-serif;
	font-size: 1.7rem;
    padding: 0.3rem 0.5rem 0.1rem;
	margin: 0;
	overflow: hidden;
}
#output ul.rankingList li.rankingItem.rankTop3 .rank {
	font-size: 3rem;
    padding: 0.8rem 0.5rem;
}
#output ul.rankingList li.rankingItem.rankTop10 .rank {
	font-size: 2.5rem;
    padding: 0.5rem 0.5rem;
}

#output ul.rankingList li.rankingItem .rankData {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-grow: 1;
    padding: 0.3em 1.5rem;
    margin: 0;
}
#output ul.rankingList li.rankingItem.rankTop3 .rankData {
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 1em 1.5rem;
    margin: 0;
}
#output ul.rankingList li.rankingItem.rankTop10 .rankData {
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0.8em 1.5rem;
    margin: 0;
}
#output ul.rankingList li.rankingItem .rankData p.rankingName {
    flex: 0 0 215px;/* 幅を XXpx で固定 */
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: bold;
	font-size: 1rem;
    margin: 0;
    line-height: 1;
}
#output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
    flex: 0 0 420px;
	font-size: 2rem;
    padding-top: 15px;
    margin-bottom: 10px;
}
#output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingName {
    flex: 0 0 450px;
	font-size: 1.5rem;
    padding-top: 15px;
}
#output ul.rankingList li.rankingItem.rankTop3.rank1 .rankData p {
	color: #cb9e25;
}
#output ul.rankingList li.rankingItem.rankTop3.rank2 .rankData p {
	color: #8f9399;
}
#output ul.rankingList li.rankingItem.rankTop3.rank3 .rankData p,
#output ul.rankingList li.rankingItem.rankTop3.rankBest4 .rankData p {
	color: #80451d;
}
#output ul.rankingList li.rankingItem .rankData p.rankingPoints {
    flex: 0 0 80px;/* 幅を XXpx で固定 */
	font-family: 'Teko', sans-serif;
	font-size: 1.5rem;
    text-align: right;
	margin: 0;
    padding: 0 15px;
}
#output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingPoints {
    flex: 0 0 120px;/* 幅を XXpx で固定 */
	font-size: 3rem;
    padding: 0 0 0 15px;
}
#output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingPoints {
    flex: 0 0 100px;/* 幅を XXpx で固定 */
	font-size: 2.2rem;
    padding: 0 0 0 15px;
}
#output ul.rankingList li.rankingItem .rankData ul.rankingSponsor {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
	list-style: none;
    padding: 0;
    margin: 0 -3px 0 0;
    flex-grow: 1;
}
#output ul.rankingList li.rankingItem .rankData ul.rankingSponsor > li {
	color: #FFF;
	background-color: var(--col-d-gray);
    margin: 1px 2px 1px 0;
    padding: 3px 10px;
    font-size: 0.8rem;
}
#output ul.rankingList li.rankingItem.rankTop3 .rankData ul.rankingSponsor > li {
	font-size: 1.2rem;
    margin: 1px 3px 1px 0;
}
#output ul.rankingList li.rankingItem.rankTop10 .rankData ul.rankingSponsor > li {
    font-size: 1rem;
}

/* --- 金銀銅 --- */
.rankingItem.rankTop3 .rank {/* 背景共通スタイル */
    padding: 2rem;
	position: relative;
	color: var(--col-black);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	background-blend-mode: overlay;/* 少し光沢感を追加 */
}
.rankingItem:not(.rankTop3) .rank {
    background-color: var(--col-l-gray);
}

/* 金背景 */
.rankingItem.rankTop3.rank1 .rank {
	border-top: none;
	background-image:
		linear-gradient(135deg, #f7df88 0%, #f2c84b 45%, #c89a1f 100%),
		repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 2px, rgba(0,0,0,0.02) 2px 4px);
	background-size: cover;
	background-blend-mode: overlay;
}

/* 銀背景 */
.rankingItem.rankTop3.rank2 .rank {
	background-image:
		linear-gradient(90deg, #f5f7f9 0%, #d9dde3 45%, #bfc6ce 100%),
		repeating-linear-gradient(60deg, rgba(255,255,255,0.03) 0 2px, rgba(0,0,0,0.03) 2px 4px);
	color: #0f1720;
}

/* 銅背景 */
.rankingItem.rankTop3.rank3 .rank,
.rankingItem.rankTop3.rankBest4 .rank {
	background-image:
		linear-gradient(120deg, #d99b55 0%, #b96e2e 45%, #7a3f1a 100%),
		repeating-linear-gradient(30deg, rgba(255,255,255,0.03) 0 2px, rgba(0,0,0,0.04) 2px 4px);
	color: #1a0700;
}

.rankingItem.rankTop3 .rank::after {/* 微細なノイズテクスチャ（柔らかい金属感） */
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 6px 6px;
    opacity: 0.15;
    pointer-events: none;
    mix-blend-mode: soft-light;
}

/* 光エフェクト */
.rankingItem.rankTop3.rank1 .rank::before {
    content: "";
    position: absolute;
    top: -40%;
    left: -40%;
    width: 180%;
    height: 180%;
    z-index: 1;
    background: linear-gradient(90deg,
    rgba(255,255,200,0) 0%,
    rgba(255,255,240,0.6) 50%,
    rgba(255,255,200,0) 100%);
    filter: blur(12px);
    opacity: 0;
    pointer-events: none;
    mix-blend-mode: screen;
    transform: rotate(-25deg) translateX(-120%);
    will-change: transform, opacity;
    animation: softSparkle 10s ease-in-out infinite;
}

/* キラッアニメーション */
@keyframes softSparkle {
    0%, 85% {
        transform: rotate(-25deg) translateX(-120%);
        opacity: 0;
    }
    88% {
        transform: rotate(-25deg) translateX(0%);
        opacity: 0.6;
    }
    91% {
        transform: rotate(-25deg) translateX(60%);
        opacity: 0.3;
    }
    94%, 100% {
        transform: rotate(-25deg) translateX(120%);
        opacity: 0;
    }
}
@keyframes softSparkleWide {
    0% {
        transform: rotate(-7deg) translateX(-200px);
        opacity: 0;
    }
    5% {
        opacity: 0.5;
    }
    15% {
        /* 700px以上の距離を移動させる */
        transform: rotate(-7deg) translateX(850px);
        opacity: 0.2;
    }
    100% {
        transform: rotate(-7deg) translateX(850px);
        opacity: 0;
    }
}

/* --- aside共通 --- */
aside .layout_padding { padding: 100px 0; }
aside p.sectionTitle {
    text-align: center;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 50px;
}

/* --- SNS --- */
aside .sns_section ul.sns_list {
    list-style: none;
    display: flex;
    padding: 0;
    justify-content: center;
}
aside .sns_section ul.sns_list > li {
    padding: 20px 60px;
}
aside .sns_section ul.sns_list > li > a {
    display: block;
    border: none;
}

/* --- スポンサー --- */
aside .sponsorLink_section p,
.main_section .sponsorBox p {
    text-align: center;
    font-size: 1.5rem;
    margin-top: 70px;
    margin-bottom: -50px;
}
aside .sponsorLink_section p.sectionTitle,
.main_section .sponsorBox p.sectionTitle {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 50px;
}
aside .sponsorLink_section p.sectionTitle.sponsorOfficial,
.main_section .sponsorBox p.sectionTitle.sponsorOfficial { font-size: 2.3rem; }
aside .sponsorLink_section p.sectionTitle.sponsorCorporate,
.main_section .sponsorBox p.sectionTitle.sponsorCorporate { font-size: 2rem; }
aside .sponsorLink_section p.sectionTitle.sponsorShop,
.main_section .sponsorBox p.sectionTitle.sponsorShop { font-size: 1.8rem; }

aside .sponsorLink_section ul,
.main_section .sponsorBox ul {
    padding-left : 0;
    list-style   : none;
    text-align   : center;
    margin-top   : 60px;
    margin-bottom: 100px;
}
aside .sponsorLink_section ul>li,
.main_section .sponsorBox ul>li {
    display: inline-block;
    margin : 0 10px 20px;
}
aside .sponsorLink_section ul:not(.officialSponsor)>li img,
.main_section .sponsorBox ul:not(.officialSponsor)>li img  { border: 1px solid var(--col-black); }
aside .sponsorLink_section ul.officialSponsor>li img,
.main_section .sponsorBox ul.officialSponsor>li img {
    max-width: 100%;
    min-width: 180px;
    margin   : 30px 0;
}


/* ==================== @media (共通) ==================== */
@media (max-width: 1199px) {
}
@media (max-width: 992px) {
    body:not(#top) h1 {
        font-size: 2.2rem;
        margin-bottom: 1.8rem;
        letter-spacing: 2px;
    }
    
    .layout_padding {
        padding: 50px 0;
    }
    
    /* --- ランキング --- */
    #output ul.rankingList li.rankingItem .rank {
        flex: 0 0 60px;/* 幅を XXpx で固定 */
    }
    #output ul.rankingList li.rankingItem .rankData p.rankingName {
        flex: 0 0 160px;/* 幅を XXpx で固定 */
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
        flex: 0 0 400px;/* 幅を XXpx で固定 */
    }
    #output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingName {
        flex: 0 0 420px;/* 幅を XXpx で固定 */
    }
    #output ul.rankingList li.rankingItem .rankData p.rankingPoints {
        flex: 0 0 75px;/* 幅を XXpx で固定 */
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingPoints {
        flex: 0 0 110px;/* 幅を XXpx で固定 */
    }    
    #output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingPoints {
        flex: 0 0 95px;/* 幅を XXpx で固定 */
    }    
}
@media (max-width: 768px) {
    body {
        font-size: 0.9rem;
    }
    .mainText {
        font-size: 110%;
        margin-bottom: 0.1rem;
    }

    /* --- テーブル --- */
    .table {
        width: 100%;
        border: none;
        border-bottom: 1px solid var(--col-l-gray);
    }
    .table.spRow th,
    .table.spRow td{
        display: block;
        border-bottom: none;
    }
    .table.spRow > tbody > tr > th {
        width: auto;
        padding: 0.5rem;
        border: none;
    }
    .table.spRow > tbody > tr > td {
        width: auto;
        padding: 0.5rem;
    }
    .table.spRow > tbody > tr > td img {
        width: 100%;
    }

    /* --- タブ --- */
    /* タブエリア全体の設定 */
    #tab_contents .tab-area {
        overflow-x: auto;
        white-space: nowrap;/* タブ自体の折り返しを防止 */
        -webkit-overflow-scrolling: touch;/* iOSでの慣性スクロール（なめらかにする） */
        padding: 0;
    }
    #tab_contents .tab-item {
        /* flex: 0 0 auto;タブが画面幅に合わせて縮まないように */
        padding: 10px 15px;
        min-height: 80px;
    }
    /* スクロールバーを非表示 */
    #tab_contents .tab-area::-webkit-scrollbar {
        display: none; /* Chrome, Safari */
    }
    #tab_contents .tab-area {
        -ms-overflow-style: none; /* IE, Edge */
        scrollbar-width: none; /* Firefox */
    }
    
    #tab_contents .panel-area .panel {
        padding: 20px 20px;
    }
    #tab_contents .panel-area h2 {
        font-size: 2rem;
        margin: 10px 0;
    }
    #tab_contents .panel-area table tr th {
        border-top: 1px solid;
    }
    #tab_contents .panel-area table tr td {
        border-left: none;
    }
    
    /* --- タブ（ネスト） --- */
    .tabs .tab-btn {
        padding: 8px 12px;
    }

    .tabs .main-tab .tab-btn {
        font-size: 0.95rem;
        line-height: 1.2;
    }
    
    /* --- 絞り込み --- */
    .controls select {
        font-size: 1.2rem;
    }
    
    /* --- ランキング --- */
    #output h2.rankingTitle {
        font-size: 1.2rem;
        letter-spacing: 1px;
        padding: 15px;
    }    
    #output ul.rankingList li.rankingItem.rankTop3 .rank {
        font-size: 2.5rem;
    }
    #output ul.rankingList li.rankingItem.rankTop10 .rank {
        font-size: 2rem;
    }
    #output ul.rankingList li.rankingItem .rankData {
        align-items: flex-start;
        justify-content: space-between;
        flex-wrap: wrap;
        padding: 0.3em 1em 0.5rem;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData {
        padding: 0.3em 1em 0.5rem;
    }
    #output ul.rankingList li.rankingItem.rankTop10 .rankData {
        padding: 0.3em 1em 0.5rem;
    }
    #output ul.rankingList li.rankingItem .rankData p.rankingName {
        flex: 0 0 290px;/* 幅を XXpx で固定 */
        padding-top: 10px;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
        flex: 0 0 270px;/* 幅を XXpx で固定 */
    	font-size: 1.7rem;
        margin-bottom: 10px;
    }
    #output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingName {
        flex: 0 0 280px;/* 幅を XXpx で固定 */
    	font-size: 1.3rem;
        margin-bottom: 8px;
    }
    #output ul.rankingList li.rankingItem .rankData p.rankingPoints {
        flex: 0 0 60px;/* 幅を XXpx で固定 */
        padding: 0;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingPoints {
        flex: 0 0 80px;/* 幅を XXpx で固定 */
    	font-size: 2.4rem;
        padding: 0;
    }    
    #output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingPoints {
        flex: 0 0 70px;/* 幅を XXpx で固定 */
    	font-size: 1.8rem;
        padding: 0;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData ul.rankingSponsor > li {
        font-size: 1rem;
    }
    #output ul.rankingList li.rankingItem.rankTop10 .rankData ul.rankingSponsor > li {
        font-size: 0.9rem;
    }
    
    /* --- aside共通 --- */
    aside .layout_padding { padding: 70px 0; }
    aside p.sectionTitle { font-size: 1.5rem; }
    
    /* --- スポンサー --- */
    aside .sponsorLink_section p,
    .main_section .sponsorBox p {
        font-size: 1.2rem;
        margin-top: 30px;
        margin-bottom: -10px;
    }
    aside .sponsorLink_section p.sectionTitle,
    .main_section .sponsorBox p.sectionTitle {
        font-size: 1.5rem;
        margin-bottom: 30px;
    }
    aside .sponsorLink_section p.sectionTitle.sponsorOfficial,
    .main_section .sponsorBox p.sectionTitle.sponsorOfficial { font-size: 2rem; }
    aside .sponsorLink_section p.sectionTitle.sponsorCorporate,
    .main_section .sponsorBox p.sectionTitle.sponsorCorporate { font-size: 1.5rem; }
    aside .sponsorLink_section p.sectionTitle.sponsorShop,
    .main_section .sponsorBox p.sectionTitle.sponsorShop { font-size: 1.3rem; }
    
    aside .sponsorLink_section ul.supporterStandard>li img,
    .main_section .sponsorBox ul.supporterStandard>li img,
    aside .sponsorLink_section ul.shopSponsor>li img,
    .main_section .sponsorBox ul.shopSponsor>li img {
        width: 140px;
        margin: 0;
    }
    aside .sponsorLink_section ul,
    .main_section .sponsorBox ul {
        margin-top   : 30px;
        margin-bottom: 80px;
    }
}
@media (max-width: 576px) {
    body:not(#top) h1 {
        font-size: 2rem;
        margin-bottom: 1.6rem;
        letter-spacing: 1px;
    }
    
    h2 {
        font-size: 1.5rem;
        margin-bottom: 20px;
    }
    
    br.spCtrl { display: block; }/* スマホで改行 */
    br.pcCtrl { display: none; }/* スマホ以外で改行 */
    
    .fontL {
        font-size: 105%;
    }
    .fontLL {
        font-size: 120%;
        letter-spacing: 0rem;
    }
    
    ul.points {
        padding-left: 1rem;
    }
    ul.points ul.points {
        padding-left: 1rem;
    }

    /* --- テーブル --- */
    .table th,
    .table td {
        padding: 5px;
    }
    
    .table-responsive_sp{
        border: none;
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;    
    }
    .table td table th {
        padding: 2px;
    }
    
    .table td div.highlight {
        padding: 15px 15px 0;
    }
    
    /* --- タブ（ネスト） --- */
    .tabs .main-tab .tab-btn {
        font-size: 0.9rem;
    }
    .tabs .sub-tab .tab-btn {
        font-size: 0.85rem;
        padding: 5px 7px;
    }
    
    /* --- ランキング --- */
    #output h2.rankingTitle span {
        display: block;
    }    
    #output ul.rankingList li.rankingItem .rank {
        flex: 0 0 40px;/* 幅を XXpx で固定 */
        font-size: 1.4rem;
    }
    #output ul.rankingList li.rankingItem .rankData {
        align-items: center;
        padding: 0.3em 1em;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData,
    #output ul.rankingList li.rankingItem.rankTop10 .rankData {
        display: block;
        text-align: center;
    }
    #output ul.rankingList li.rankingItem .rankData p.rankingName {
        flex: none;
        width: 80%;
        padding-top: 0;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName,
    #output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingName {
        width: 100%;
        margin-bottom: 5px;
    }
    #output ul.rankingList li.rankingItem .rankData p.rankingPoints {
        flex: none;
        width: 15%;
        white-space: nowrap;
        margin-left: 5%;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingPoints,
    #output ul.rankingList li.rankingItem.rankTop10 .rankData p.rankingPoints {
        width: 100%;
        margin: 0;
        text-align: center;
        line-height: 1.2;
    }
    #output ul.rankingList li.rankingItem .rankData ul.rankingSponsor {
        width: 100%;
    }
    #output ul.rankingList li.rankingItem.rankTop3 .rankData ul.rankingSponsor,
    #output ul.rankingList li.rankingItem.rankTop10 .rankData ul.rankingSponsor {
        justify-content: center;
    }
    #output ul.rankingList li.rankingItem .rankData ul.rankingSponsor > li {
        padding: 2px 6px;
        font-size: 0.7rem;
    }
    
    /* --- aside共通 --- */
    aside .layout_padding { padding: 50px 0; }
    aside p.sectionTitle { font-size: 1.5rem; }
    
    /* --- SNS --- */
    aside .sns_section ul.sns_list > li {
        padding: 20px 40px;
    }
    
    aside .sns_section ul.sns_list > li > a img {
        width: 80px;
        height: auto;
    }

    /* --- スポンサー --- */
    aside .sponsorLink_section p.sectionTitle,
    .main_section .sponsorBox p.sectionTitle { font-size: 1.5rem; }
    aside .sponsorLink_section p.sectionTitle.sponsorOfficial,
    .main_section .sponsorBox p.sectionTitle.sponsorOfficial { font-size: 1.7rem; }
    aside .sponsorLink_section p.sectionTitle.sponsorCorporate,
    .main_section .sponsorBox p.sectionTitle.sponsorCorporate { font-size: 1.4rem; }
    aside .sponsorLink_section p.sectionTitle.sponsorShop,
    .main_section .sponsorBox p.sectionTitle.sponsorShop { font-size: 1.2rem; }

}

/* ======================================== ヘッダー ======================================== */
header {
	position: fixed;
	z-index: 100;
	width: 100%;
	top: 0;
	left: 0;
}

header .header_wrapper {
	width: 100%;
	top: 0;
	box-shadow: 0 6px 8px rgba(0, 0, 0, 0.1);
	background: url("../images/header-img.jpg") no-repeat;
	background-color: #FFF;
	background-size: cover;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}

header .header_wrapper .brand_box {
	position: static;
	width: auto;
	display: inline-block;
	justify-content: initial;
	padding: 10px 20px;
	flex-shrink: 0;
}

#top header .header_wrapper .brand_box h1,
header .header_wrapper .brand_box a.logo {
	display: block;
	margin: 0;
	padding: 0;
	position: relative;
    z-index: 10;
    border: none;
}

/* --- メニューボタン（スマホ表示） --- */
header .header_wrapper .header-toggler {
	display: none;
}

/* --- メインメニュー --- */
header nav.navbar {
	height: var(--header-height);
	flex-grow: 1;
	justify-content: flex-end;
	padding: 0 15px;
	margin-top: calc(-1 * var(--header-height));
	align-items: flex-end;
}

header nav.navbar .menu-content {
	justify-content: flex-end;
}

header nav.navbar .navbar-nav .nav-item a.nav-link {
	cursor: pointer;
	padding: 15px 20px;
	color: var(--col-black);
	font-size: 1.2rem;
	white-space: nowrap;
	font-family: 'BIZ UDPGothic', sans-serif;
	font-weight: 700;
	letter-spacing: 1px;
	border-bottom: 3px solid transparent;
}

header nav.navbar .navbar-nav .nav-item.active a.nav-link,
header nav.navbar .navbar-nav .nav-item a.nav-link:hover {
	color: var(--col-red);
	border-bottom: 3px solid var(--col-red);
}


/* ==================== @media (ヘッダー) ==================== */
@media (max-width: 1199px) {
	/* --- メインメニュー --- */
	header nav.navbar {
		padding-left: 0;
		padding-right: 0;
	}
	header nav.navbar .navbar-nav .nav-item a.nav-link {
		padding: 10px 15px;
		font-size: 1rem;
	}
}
@media (max-width: 992px) {
	header .header_wrapper {
		position: fixed;
		z-index: 10;
	}

	header .header_wrapper .container {
		position: relative;
	}

	/* --- メニューボタン（スマホ表示） --- */
	header .header_wrapper .header-toggler {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		gap: 10px;
		position: absolute;
		bottom: 0;
		right: 0;
		border: none;
		background-color: var(--col-d-gray);/* 初期状態: グレー */
		padding: 5px 8px;
		cursor: pointer;
		width: auto;
		min-width: 120px;
		height: 40px;
		z-index: 99;
		border-radius: 10px 10px 0 0;
		outline: 0;
        transition: background-color 0.3s ease;
	}

	header .header_wrapper .header-toggler::after {
		content: "MENU";
		color: #FFF;
		font-size: 1rem;
		font-weight: 700;
		letter-spacing: 1px;
		font-family: 'BIZ UDPGothic', sans-serif;
	}

    header .header_wrapper .header-toggler[aria-expanded="true"] {
		background-color: var(--col-black);
        transition: background-color 0.4s ease;
    }
	
	header .header_wrapper .header-toggler .menu-icon {
		background-image: none;
		position: relative;
		display: block;
		width: 30px;
		height: 30px;
		background-color: transparent;
		border-radius: 0;
		flex-shrink: 0;
	}

	header .header_wrapper .header-toggler .menu-icon::before {
		content: "";
		position: absolute;
		top: 45%; /* V字全体の垂直位置調整 */
		left: 50%;

		/* 線の長さ調整 */
		width: 10px;
		height: 10px;

		/* 右と下の線だけを表示 */
		border-right: 2px solid #FFF;
		border-bottom: 2px solid #FFF;

		/* 45度回転してV字（下向き）にする */
		transform: translate(-50%, -50%) rotate(45deg);
		transition: all 0.3s ease;
	}
    
	/* V字アイコンの回転アニメーション */
    header .header_wrapper .header-toggler[aria-expanded="true"] .menu-icon {
        transform: rotate(180deg);
        transition: transform 0.4s ease;
    }
	
	/* --- メインメニュー --- */
    header nav.navbar {
        position: fixed;
        top: var(--header-height); /* ヘッダーの高さの下に配置 */
        left: 0;
        width: 100%;
		height: auto;
        z-index: 9;
        background-color: var(--col-d-gray);/* 初期状態: グレー */
		margin-top: auto;
		padding: 0 10px;
		max-width: 100%;
		justify-content: center;
        transform: translateY(-100%);
        transition: transform 0.4s ease,background-color 0.4s ease;
        
        /* コンテンツが画面を超えた場合のスクロール対応 */
        max-height: calc(100vh - var(--header-height));
    }
    
    header nav.navbar.is-open {/* 展開時 */
        transform: translateY(0); /* 本来の位置に戻し、スライドイン */
		background-color: var(--col-black);
    }
	
	header nav.navbar .menu-content ul.navbar-nav {
		padding: 20px 0;
		margin: 0;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}

	header nav.navbar .menu-content ul.navbar-nav li.nav-item {
		text-align: center;
		padding: 10px 0;
		margin: 0;
	}

	header nav.navbar .menu-content ul.navbar-nav li.nav-item a.nav-link {
		color: #FFF;
        padding: 10px;
        display: block;
        border-bottom: 1px solid #FFF;
        transition: color 0.3s ease;
        margin: 10px 30px;
	}

	header nav.navbar .menu-content ul.navbar-nav li.nav-item a.nav-link:hover {
		color: var(--col-gray);
		border-bottom: 1px solid var(--col-gray);
	}
}
@media (max-width: 768px) {
	/* --- メインメニュー --- */
	header nav.navbar {
		padding: 0;
	}
	header nav.navbar .menu-content ul.navbar-nav {
		padding: 0;
	}
	header nav.navbar .menu-content ul.navbar-nav li.nav-item {
		width: 100%;
		padding: 0;
	}
	header nav.navbar .menu-content ul.navbar-nav li.nav-item a.nav-link {
		width: 100%;
		margin: 0;
		padding: 20px;
	}
}
@media (max-width: 576px) {
}

/* ======================================== フッター ======================================== */
footer .info_section { background-color: var(--col-d-gray); }

footer .info_section.layout_padding { padding: 80px 0; }

footer .info_section .info_logo img {
	display: block;
	width: auto;
	height: auto;
	margin: auto;
}

/* --- フッターリンク --- */
footer .info_section .info_menu { margin: 20px 0 0; }

footer .info_section .info_menu ul {
    padding-left: 0;
    margin: auto;
    list-style: none;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
footer .info_section .info_menu ul li {
    border: 1px solid #FFF;
    margin: 12px;
}
footer .info_section .info_menu ul li a {
    width: 250px;
    height: 60px;
    line-height: 1.1;
    display: flex;
    align-items: center;
    padding: 5px;
    text-align: center;
    justify-content: center;
    border: none;
}
footer .info_section .info_menu ul li a:hover,
footer .info_section .info_menu ul li.active a {
    background-color: #FFF;
    color: var(--col-d-gray);
}

/* --- 運営リンク --- */
footer .link_section {
    background: url("../images/footer-img.jpg") center;
    background-size: cover;
}

footer .link_section ul {
    padding: 20px 0;
    margin: 0;
    text-align: center;
}

footer .link_section ul li {
    display: inline-block;
    margin: 10px 20px;
}

footer .link_section ul li a,
footer .link_section ul li img {
    display: block;
    border: none;
}

/* --- コピーライト --- */
footer .footer_section { background-color: var(--col-black); }
footer .footer_section p a {
    color: #FFF;
    letter-spacing: 2px;
    border: none;
}


/* ==================== @media (フッター) ==================== */
@media (max-width: 1199px) {
    /* --- フッターリンク --- */
    footer .info_section .info_menu ul li a { width: 200px; }
}
@media (max-width: 992px) {
    /* --- フッターリンク --- */
    footer .info_section .info_menu ul li a {
        font-size: 0.83rem;
        width: 145px;
        height: 50px;
    }
}
@media (max-width: 768px) {
    /* --- フッターリンク --- */
    footer .info_section .info_menu ul li a {
        font-size: 0.8rem;
        width: 140px;
        height: 50px;
    }
    
    /* --- 運営リンク --- */
    footer .link_section ul li img { width: 140px; }
}
@media (max-width: 576px) {
}


/* ======================================== トップページ ======================================== */
#top h2 {
    font-family: 'Poppins', 'Noto Sans JP', sans-serif;
    font-weight: bold;
    font-size: 3rem;
    margin-bottom: 2rem;
    text-transform: uppercase;
    text-align: center;
    letter-spacing: 3px;
}

/* --- スライダー --- */
#top .slider_section {
	background-color: var(--col-l-gray);
	max-height: 641px;
	overflow: hidden;
}
#top .slider_section .carousel-cell img {
    max-height: 641px;
}

#top .slider_section .carousel-cell:not(.is-selected) { opacity: 0.4; }

#top .slider_section .flickity-button { background: transparent; }
#top .slider_section .flickity-button-icon { fill: var(--col-red); }
#top .slider_section .flickity-page-dots { bottom: 12px; }
#top .slider_section .flickity-page-dots .dot { background-color: var(--col-black); }

/* --- トピックス --- */
#top .topics_section ul {
    padding-left: 0;
    list-style: none;
    text-align: left;
}
#top .topics_section ul li {
    color: var(--col-black);
	margin-bottom: 15px;
	display: flex;
}

#top .topics_section ul li a {
    color: var(--col-black);
}
#top .topics_section ul li a:hover {
    color: var(--col-red);
}
#top .topics_section ul li time {
    padding-right: 10px;
	font-size: 80%;
    line-height: 1.7;
	white-space: nowrap;
}

/* --- ランキング --- */
#top .ranking_section { background-color: var(--col-l-gray); }

#top .ranking_section #output h3.rankingTitle {
	font-size: 1.3rem;
	font-weight: bold;
	letter-spacing: 2px;
    text-align: center;
    background: var(--col-black);
    color: #FFF;
    padding: 10px;
    margin: 0 auto;
    display: block;
	max-width: 700px;
	width: 100%;
}
#top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rank {
    font-size: 1.8rem;
    padding: 0.3rem 0.5rem 0.1rem;
}
#top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData {
    padding: 0.3em 1.5rem;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: nowrap;
}
#top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
    flex: 0 0 215px;
    font-size: 1.4rem;
    padding-top: unset;
    margin-bottom: unset;
}
#top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingPoints {
    flex: 0 0 80px;
    font-size: 1.7rem;
    padding: 3px 13px 0;
    line-height: 1;
}
#top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData ul.rankingSponsor > li {
	margin: 1px 2px 1px 0;
    font-size: 0.9rem;
}

/* ==================== @media (トップページ) ==================== */
@media (max-width: 1199px) {
    /* --- スライダー --- */
    #top .slider_section {
        max-height: 538px;
        width: auto;
    }
    #top .slider_section .carousel-cell { width: auto; }
    #top .slider_section .carousel-cell img {
        max-height: 538px;
        width: auto;
    }
    #top .slider_section .flickity-page-dots { bottom: 5px; }
}
@media (max-width: 992px) {
    #top h2 {
        font-size: 2.7rem;
        margin-bottom: 1.8rem;
        letter-spacing: 2px;
    }
    
    /* --- スライダー --- */
    #top .slider_section .carousel-cell img {
        width: 100%;
    }
    
    /* --- ランキング --- */
    #top .ranking_section #output ul.rankingList li.rankingItem .rank {
        flex: 0 0 50px;
    }
    #top .ranking_section #output ul.rankingList li.rankingItem .rankData p.rankingName,
    #top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
        flex: 0 0 180px;
    }
}
@media (max-width: 768px) {
    /* --- トピックス --- */
    #top .topics_section ul {
        max-width: 540px;
        width: 100%;
        padding: 0 30px;
    }
    
    /* --- ランキング --- */
    #top .ranking_section #output h3.rankingTitle {
        font-size: 1.2rem;
        letter-spacing: 1px;
    }
    #top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData {
        justify-content: space-between;
        flex-wrap: wrap;
        padding: 0.3em 1em 0.5rem;
    }
    #top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
        flex: 0 0 270px;
        margin-bottom: 10px;
        padding-top: 10px;
    }
    #top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingName {
        flex: 0 0 270px;
        margin-bottom: 10px;
        padding-top: 10px;
    }
    #top .ranking_section #output ul.rankingList li.rankingItem.rankTop3 .rankData p.rankingPoints {
        padding: 3px 0 0 13px;
    }
}
@media (max-width: 576px) {
    /* --- トピックス --- */
    #top .topics_section ul li {
        margin-bottom: 30px;
        flex-direction: column;
    }
    
    /* --- ランキング --- */
    #top .ranking_section #output ul.rankingList li.rankingItem .rank {
        flex: 0 0 40px;
    }
    #top .ranking_section #output ul.rankingList li.rankingItem .rankData p.rankingName {
        flex: 0 0 170px;
    }
}


/* ======================================== 大会概要 ======================================== */
#summary .about {
    position: relative;
    width: 820px;
    margin: 0 auto 50px;
    padding: 50px;
    font-size: 1.2rem;
    overflow: hidden;
    color: #FFF;
    background: linear-gradient(to right, #2a8f2e, var(--col-green));
}

#summary .about::after {
    position: absolute;
    content: "";
    background-image: url("../images/summary/logo_d.png");
    opacity: 0.05;
    display: block;
    width: 800px;
    height: 500px;
    bottom: -112px;
    right: -90px;
}

#summary .about .aboutDtour {
    color: #FFF;
    font-weight: bold;
    text-align: left;
    font-size: 1.8rem;
    border-bottom: 1px solid #FFF;
    letter-spacing: 6px;
    padding-bottom: 5px;
}

#summary h2#rules {
    background: var(--col-d-gray);
    color: #FFF;
    text-align: left;
    width: 820px;
    margin: 0 auto;
    padding: 20px 40px;
}

/*----- アコーディオン -----*/
#summary ol.accordion-area {
    width: 820px;
    margin: 0 auto 50px;
    padding: 40px 40px 10px 100px;
    background: var(--col-l-gray);
}
#summary ol.accordion-area > li {
    float: none;
    font-size: 1.5rem;
    font-weight: normal;
    line-height: 1;
    color: var(--col-black);
    text-shadow: none;
    opacity: 1;
    padding: 0 0 30px 0;
}
#summary ol.accordion-area > li::marker {
    font-size: 1.4rem;
    color: var(--col-d-gray);
    transition: all .2s ease;
}
#summary ol.accordion-area > li.close::marker {
    color: var(--col-black);
    font-weight: bold;
}
#summary ol.accordion-area > li h2.title {
    position: relative;
    cursor: pointer;
    padding: 0;
    transition: all .2s ease;
    text-align: left;
    font-size: 1.5rem;
    color: var(--col-d-gray);
    margin: 0 0 10px 0;
    line-height: 1;
    text-transform: none;
    font-weight: normal;
}
#summary ol.accordion-area > li.close h2.title {
    color: var(--col-black);
    font-weight: bold;
    float: none;
    opacity: 1;
    text-shadow: none;
    margin: 0 0 10px 0;
}
#summary ol.accordion-area h2.title::before,
#summary ol.accordion-area h2.title::after {
    position: absolute;
    content: '';
    width: 20px;
    height: 3px;
    background-color: var(--col-d-gray);
    /* 重心がずれないように、translateで中心配置を行ってから回転させます */
    top: 50%; 
    left: -60px;
    transition: transform .2s ease; /* transitionはtransformに対して効かせるとスムーズです */
}
#summary ol.accordion-area h2.title::before {
    /* 縦方向の真ん中に配置(-50%)しつつ、0度 */
    transform: translateY(-50%) rotate(0deg);
}
#summary ol.accordion-area h2.title::after {
    /* 縦方向の真ん中に配置(-50%)しつつ、90度 */
    transform: translateY(-50%) rotate(90deg);
}

#summary ol.accordion-area > li.close h2.title::before,
#summary ol.accordion-area > li.close h2.title::after  { background-color: var(--col-black); }
#summary ol.accordion-area > li.close h2.title::before { transform: translateY(-50%) rotate(135deg); }
#summary ol.accordion-area > li.close h2.title::after  { transform: translateY(-50%) rotate(225deg); }

#summary ol.accordion-area > li .box {
    font-size: 1.1rem;
    display: none;
    background: #FFF;
    margin: 0 0 0 -40px;
    padding: 30px;
    line-height: 1.3;
    transition: transform .2s ease;
}

#summary #tab_contents {
    width: 820px;
    margin: 0 auto 50px;
}

#summary #tab_contents h2 span.season {
    text-transform: none;
    background: var(--col-black);
    border-radius: 45px;
    padding: 8px 30px;
    font-size: 1.6rem;
    font-weight: normal;
    display: block;
    width: fit-content;
    margin: 0 auto 10px;
}


/* ==================== @media (大会概要) ==================== */
@media (max-width: 992px) {
    #summary .about {
        width: 100%;
    }
    
    #summary h2#rules {
        width: 100%;
    }
    
    /*----- アコーディオン -----*/
    #summary ol.accordion-area {
        width: 100%;
    }
    
    #summary #tab_contents {
        width: 100%;
    }
}
@media (max-width: 767px) {
    #summary .about {
        padding: 30px 40px;
        line-height: 1.3;
        font-size: 1rem;
    }

    #summary .about::after {
        width: 600px;
        height: 375px;
        bottom: 0;
    }

    #summary .about .aboutDtour {
        font-size: 1.6rem;
    }
    
    #summary h2#rules {
        font-size: 1.5rem;
    }
    
    /*----- アコーディオン -----*/
    #summary ol.accordion-area {
        padding: 20px 20px 10px 80px;
    }
    #summary ol.accordion-area > li::marker {
        font-size: 1.2rem;
    }
    #summary ol.accordion-area > li h2.title {
        font-size: 1.3rem;
        letter-spacing: 0;
    }
    #summary ol.accordion-area > li .box {
        padding: 20px;
        margin: 0 0 0 -60px;
    }
}
@media (max-width: 576px) {
    /*----- アコーディオン -----*/
    #summary ol.accordion-area > li::marker {
        font-size: 1.1rem;
    }
    #summary ol.accordion-area > li h2.title {
        font-size: 1.2rem;
    }
    
    #summary ol.accordion-area > li .box {
        font-size: 1rem;
    }
}


/* ======================================== 日程 ======================================== */
#schedule #tab_contents h2 span.season {
    text-transform: none;
    background: var(--col-black);
    border-radius: 45px;
    padding: 8px 30px;
    font-size: 1.6rem;
    font-weight: normal;
    display: block;
    width: fit-content;
    margin: 0 auto 10px;
}

/* 日程詳細 */
#schedule .scheduleBox {
    background-color: var(--col-l-gray);
    color: var(--col-black);
    padding: 50px;
    width: 100%;
    margin: 0 auto 50px;
    display: flex;
    align-items: flex-start; /* 上揃え */
}

#schedule .scheduleBox > div {
    flex-grow: 1; /* 残りの幅いっぱいに広げる */
    margin-right: 30px;
}

#schedule .scheduleBox p.roundName {
    background: var(--col-green);
    font-size: 1.2rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
    color: #FFF;
    text-align: center;
    padding: 30px 10px;
    width: 100%;
}
#schedule .scheduleBox p.roundName span {
    font-size: 2rem;
    font-weight: bold;
    letter-spacing: 0.3rem;
    display: block;
    margin-top: 10px;
}

#schedule .scheduleBox p.info {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.3;
}

#schedule .scheduleBox ul.btnList {
    display: flex;
    flex-direction: column;
    padding: 0;
    list-style: none;
    margin: 0;
}

#schedule .scheduleBox ul.btnList a.btn {
    font-size: 1.4rem;
    padding: 8px 44px;
    width: 100%;
    line-height: 1.1;
}
#schedule .scheduleBox ul.btnList a.btn > span {
    font-size: 0.9rem;
    display: block;
    margin-top: 3px;
    text-align: left;
    text-indent: -0.9rem;
    margin-left: 0.9rem;
    font-weight: normal;
}

#schedule .scheduleBox table.schedule {
    width: 640px;
    flex-shrink: 0; /* 縮まないようにする */
    background: #FFF;
    border: none;
    margin-bottom: 0;
}
#schedule .scheduleBox table.schedule th {
    vertical-align: middle;
    white-space: nowrap;
    background: var(--col-gray);
}
#schedule .scheduleBox table.schedule td {
    vertical-align: middle;
}
#schedule .scheduleBox table.schedule td a.btn {
    padding: 5px 7px;
    font-size: 1em;
    margin-bottom: 0;
}

/* ==================== @media (日程) ==================== */
@media (max-width: 1199px) {
    /* 日程詳細 */
    #schedule .scheduleBox {
        padding: 30px;
    }

    #schedule .scheduleBox ul.btnList a.btn {
        padding: 8px 29px;
    }
    
    #schedule .scheduleBox table.schedule {
        width: 500px;
    }
    #schedule .scheduleBox table.schedule th {
        font-size: 0.9rem;
    }
}
@media (max-width: 992px) {
    /* 日程詳細 */
    #schedule .scheduleBox {
        align-items: center;
        flex-direction: column;
    }
    #schedule .scheduleBox > div {
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
    }
    #schedule .scheduleBox p.roundName {
        width: 300px;
        padding: 20px 10px;
    }
    #schedule .scheduleBox p.info {
        width: 220px;
    }
    
    #schedule .scheduleBox ul.btnList {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 10px 0;
        width: 450px;
        gap: 20px;
        margin: 0 auto 1rem;
    }
    #schedule .scheduleBox ul.btnList a.btn {
        width: 200px;
    }
    #schedule .scheduleBox ul.btnList a.btn.qualProgress {
        width: 450px;
    }
    #schedule .scheduleBox ul.btnList a.btn > span {
        text-align: center;
        margin-left: 0;
        text-indent: 0;
    }
}
@media (max-width: 768px) {
    #schedule .scheduleBox p.roundName {
        width: 100%;
        padding: 10px;
    }
    #schedule .scheduleBox p.roundName span {
        margin-top: 0;
    }
    
    #schedule .scheduleBox p.info {
        width: 100%;
    }
    
    #schedule .scheduleBox ul.btnList {
        width: 400px;
    }
    #schedule .scheduleBox ul.btnList a.btn {
        padding: 10px;
        width: 400px;
    }
    #schedule .scheduleBox ul.btnList a.btn.qualProgress {
        width: 400px;
    }
    
    #schedule .scheduleBox table.schedule {
        width: 100%;
    }
    #schedule .scheduleBox table.schedule th,
    #schedule .scheduleBox table.schedule td {
        display: block;
        width: 100%;
        padding: 15px 5px;
        border: none;
    }
}
@media (max-width: 576px) {
    /* 日程詳細 */
    #schedule .scheduleBox {
        padding: 20px;
        margin: 10px auto 30px;
    }
    #schedule .scheduleBox ul.btnList {
        width: 100%;
        gap: 10px;
        flex-direction: column;
        justify-content: space-around;
    }
    #schedule .scheduleBox ul.btnList a.btn {
        font-size: 1.3rem;
        width: 100%;
    }
    #schedule .scheduleBox ul.btnList a.btn.qualProgress {
        width: 100%;
    }
}


/* ======================================== ランキング ======================================== */
#ranking .controls {
    border-bottom: none;
}

/* ==================== @media (ランキング) ==================== */
@media (max-width: 1199px) {
}
@media (max-width: 992px) {
}
@media (max-width: 768px) {
}
@media (max-width: 576px) {
}


/* ======================================== 結果 ======================================== */
/* --- 結果一覧 --- */
#result ul.resultList {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    padding: 40px 0;
	list-style: none;
}
#result ul.resultList > li {
    margin: 10px;
    text-indent: 0;
}
#result ul.resultList > li a {
    display: block;
    border: none;
}
#result ul.resultList > li a img {
    max-width: 360px;
}

/* --- 個別結果ページ --- */
#result h1 span {
    display: block;
    margin: 8px 0;
}
#result h1 span.season {
    background: var(--col-d-gray);
    border-radius: 45px;
    color: #FFF;
    padding: 10px 30px;
    font-size: 2rem;
    font-weight: normal;
    display: inline-block;
}
#result ul.subInfo {
    list-style: none;
    text-align: center;
    margin: 50px 0;
    padding: 0;
    text-indent: 0;
    display: flex;
    justify-content: center;
}

#result ul.subInfo > li {
    display: inline-block;
    margin: 10px;
}
#result ul.subInfo > li a {
    padding: 20px;
    min-width: 250px;
    display: block;
    background: var(--col-black);
    color: #FFF;
    border: none;
}
#result ul.subInfo > li a:hover {
    background: var(--col-red);
}

#result ul.result {
    margin: 30px 0;
    text-align: center;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#result ul.result > li {
    width: 100%;
    display: flex;
    margin-bottom: 100px;
    border: 1px solid var(--col-gray);
    padding: 10px;
}
#result ul.result > li.rankBest16,
#result ul.result > li.rankBest32 {
    flex-direction: column;
    width: 48%;
}
#result ul.result > li .rank {
    font-size: 2.2rem;
    padding: 10px;
    flex: 0 0 200px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
#result ul.result > li.rankBest16 .rank,
#result ul.result > li.rankBest32 .rank {
    flex: 0 0 60px;
    font-size: 1.8rem;
}
#result ul.result > li.rank1 .rank { color: #7b6116; }
#result ul.result > li.rank2 .rank { color: #727375; }
#result ul.result > li.rank3 .rank,
#result ul.result > li.rankBest4 .rank { color: #572605; }
#result ul.result > li.qualifier .rank {
    background: var(--col-black);
    color: var(--col-l-gray);
}
#result ul.result > li .rankData {
    flex-grow: 1;
    display: flex;
}
#result ul.result > li .rankData > img {
    max-width: 300px;
    max-height: 300px;
    width: 100%;
    height: 100%;
}
#result ul.result > li.rankBest16 .rankData > img,
#result ul.result > li.rankBest32 .rankData > img {
    max-width: 200px;
    max-height: 200px;
    width: 100%;
    height: 100%;
}
#result ul.result > li .rankData > div {
    flex-grow: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
}
#result ul.result > li .rankData > div p {
    margin: 0;
}
#result ul.result > li .rankData > div p.name {
    width: 100%;
    font-size: 2.2rem;
    letter-spacing: 1px;
    padding: 20px 0 15px;
    font-weight: bold;
    line-height: 1.3;
}
#result ul.result > li.rankBest16 .rankData > div p.name,
#result ul.result > li.rankBest32 .rankData > div p.name {
    font-size: 1.8rem;
    padding: 20px 0 10px;
    line-height: 1.2;
}
#result ul.result > li .rankData > div p.shop,
#result ul.result > li .rankData > div p.ppr {
    width: fit-content;
    text-align: center;
    border: 1px solid var(--col-gray);
    border-radius: 20px;
    margin: 5px 10px;
    padding: 0 20px;
}
#result ul.result > li .rankData > div p.ppr > span {
    margin: 0 10px 0 0;
}
#result ul.result > li .rankData > div p.comment {
    width: 80%;
    background: var(--col-l-gray);
    margin: 10px auto 0;
    padding: 10px 10px;
    font-size: 0.9rem;
    line-height: 1.4;
}

#result ul.result > li .rankData > div ul.mySponsor {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    list-style: none;
    padding: 0px;
    margin: 15px 10px;
}
#result ul.result > li .rankData > div ul.mySponsor > li {
	color: #FFF;
	background-color: var(--col-d-gray);
    margin: 1px 2px;
    padding: 3px 10px;
}
#result ul.result > li.rankBest16 .rankData > div ul.mySponsor > li,
#result ul.result > li.rankBest32 .rankData > div ul.mySponsor > li {
    font-size: 0.9rem;
    padding: 1px 6px;
}

#result .fixBottom {/* 結果一覧ページへ */
    position: sticky;
    bottom: 0;
    display: flex;
    justify-content: center;
    margin-top: -80px;
    margin-bottom: 80px;
    z-index: 10;
}
#result .fixBottom > a {
    background: var(--col-green);
    display: block;
    width: 100%;
    padding: 20px;
    text-align: center;
    color: #FFF;
    font-size: 1.1rem;
    letter-spacing: 2px;
    opacity: 0.8;
}
#result .fixBottom > a:hover {
    opacity: 1;
}

    
/* ==================== @media (結果) ==================== */
@media (max-width: 1199px) {
    #result ul.result > li .rankData > div {
        flex-direction: column;
    }
    #result ul.result > li .rankData > div p.shop {
        width: fit-content;
        padding: 0 15px;
    }
    #result ul.result > li .rankData > div p.ppr {
        width: fit-content;
        padding: 0 15px;
    }
}
@media (max-width: 992px) {
    #result .controls select {
        padding: 10px 5px;
        margin: 0 8px;
        font-size: 1.2rem;
        letter-spacing: 0;
    }
    
    #result ul.resultList > li a img {
        max-width: 320px;
    }
    
    #result ul.subInfo > li a {
        padding: 20px 10px;
        min-width: 200px;
    }
    
    #result ul.result > li {
        flex-direction: column;
    }
    #result ul.result > li .rank {
        flex: auto;
    }
    #result ul.result > li.rankBest16 .rankData,
    #result ul.result > li.rankBest32 .rankData {
        flex-direction: column;
        align-items: center;
    }
    #result ul.result > li .rankData > div p.name {
        font-size: 2rem;
        letter-spacing: 0;
    }
    #result ul.result > li .rankData > div ul.mySponsor {
        font-size: 0.9rem;
    }
    
    /* 光エフェクト */
    .rankingItem.rankTop3.rank1 .rank::before {
        top: -125%; 
        left: -20%;
        width: 150px; /* 光の筋自体の幅 */
        height: 350%;
        z-index: 1;
        background: linear-gradient(90deg,
            rgba(255, 255, 200, 0) 0%,
            rgba(255, 255, 240, 0.6) 50%,
            rgba(255, 255, 200, 0) 100%);
        filter: blur(15px);
        transform: rotate(-10deg) translateX(-200px);
        animation: softSparkleWide 6s ease-in-out infinite;
    }
}
@media (max-width: 768px) {
    #result .controls {
        flex-direction: column;
    }
    #result .controls select {
        margin: 5px;
        width: 50%;
    }
    #result ul.resultList {
        flex-direction: column;
        align-items: center;
    }
    #result ul.resultList > li a img {
        max-width: 360px;
        width: 100%;
    }
    
    #result ul.subInfo {
        flex-direction: column;
        margin: 30px 0;
    }

    #result ul.subInfo > li {
        display: inline-block;
        margin: 5px 20px;
    }
    #result ul.subInfo > li a {
        padding: 15px
    }
    
    #result ul.result > li .rankData {
        flex-direction: column;
        align-items: center;
    }
    #result ul.result > li .rankData > div p.comment {
        width: 100%;
    }
}
@media (max-width: 576px) {
    #result .controls select {
        width: 90%;
    }
    
    #result ul.result > li.rankBest16,
    #result ul.result > li.rankBest32 {
        width: 100%;
    }
}

/* ======================================== 動画 ======================================== */
#movie ul.movieList {
    list-style: none;
    padding: 0;
}
#movie ul.movieList > li {
    margin: 20px 0;
}
#movie ul.movieList > li a {
    display: block;
    width: fit-content;
    margin: 0 auto;
    border: 2px solid var(--col-l-gray);
}
#movie ul.movieList > li a:hover {
    border: 2px solid var(--col-red);
}
#movie ul.movieList > li a img {
    width: 100%;
    max-width: 820px;
    margin: 0;
}

/* ==================== @media (動画) ==================== */
@media (max-width: 1199px) {
}
@media (max-width: 992px) {
}
@media (max-width: 768px) {
}
@media (max-width: 576px) {
}


/* ======================================== GRAND SLAM ======================================== */
#grandslam #tab_contents {
    width: 820px;
    margin: 0 auto 50px;
    padding-top: 0;
}

#grandslam #tab_contents h2 span.season {
    text-transform: none;
    background: var(--col-black);
    border-radius: 45px;
    padding: 8px 30px;
    font-size: 1.6rem;
    font-weight: normal;
    display: block;
    width: fit-content;
    margin: 0 auto 10px;
}

#grandslam ul.resultList {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 1fr(比率)×3 で3等分 */
    gap: 20px;
}
#grandslam ul.resultList > li {
}
#grandslam ul.resultList > li a {
    width: 100%;
    text-align: center;
    font-size: 1.2rem;
    border: none;
}
#grandslam ul.resultList > li a span {
    display: block;
    font-size: 1.5rem;
    color: #FFF;
    background: var(--col-black);
    border-radius: 50px;
    margin-bottom: 5px;
}


/* ==================== @media (GRAND SLAM) ==================== */
@media (max-width: 1199px) {
}
@media (max-width: 992px) {
    #grandslam #tab_contents {
        width: 100%;
    }
    #grandslam ul.resultList {
        grid-template-columns: repeat(2, 1fr); /* 1fr(比率)×2 で2等分 */
    }
}
@media (max-width: 768px) {
}
@media (max-width: 576px) {
    #grandslam ul.resultList {
        display: block;
    }
}


/* ======================================== スポンサー ======================================== */
/*
body#sponsor section.sponsor_section .btn {
    display: block;
    width: fit-content;
    margin: 20px auto;
    background-color: #1c57a3;
    color: #fff;
    text-align: center;
    padding: 10px 40px;
    letter-spacing: 1px;
}
body#sponsor section.sponsor_section .btn:hover {
    background-color: #fff;
    color: #000;
    border-color: var(--col-d-gray);
}
*/
#sponsor section.sponsorLink_section.sponsor_contents {
    padding: 0;
    margin-top: -50px;
    margin-bottom: -50px;
}
#sponsor section.sponsor_section .row img {
    display: block;
    width: 100%;
    height: auto;
    margin: 50px auto;
}

/* ==================== @media (スポンサー) ==================== */
@media (max-width: 576px) {
    #sponsor section.sponsorLink_section.sponsor_contents {
        margin: 0 auto;
    }
}


/* ======================================== プライバシーポリシー・ご利用規約 ======================================== */
#policy .main_section p,
#terms .main_section p {
    text-indent: 1rem;
}

#policy .main_section a,
#terms .main_section a {
    color: var(--col-green);
    text-decoration: underline dotted;
    text-underline-offset: 5px;
}

#policy .main_section ol.rules,
#terms .main_section ol.rules {
    counter-reset: number;
    list-style-type: none;
    padding-left: 0;
}
#policy .main_section ol.rules > li,
#terms .main_section ol.rules > li {
    padding: 20px 0 30px;
}
#policy .main_section ol.rules > li:before,
#terms .main_section ol.rules > li:before {
    counter-increment: number;
    content: counter(number)'.';
    display: inline;
    color: var(--col-green);
    font-size: 1.3rem;
    font-weight: bold;
    margin: 0 3px 0 15px;
}

#policy .main_section ol.rules li h2,
#terms .main_section ol.rules li h2 {
    display: inline;
    text-align: left;
    color: var(--col-green);
    font-size: 1.5rem;
    font-weight: bold;
}

#policy .main_section ol.rules li > div,
#terms .main_section ol.rules li > div {
    border-top: 1px solid var(--col-green);
    padding: 20px 15px;
}

#policy .main_section ol.rules > li > ol,
#terms .main_section ol.rules > li > ol {
    list-style: upper-latin;
    margin-bottom: 20px;
}
#policy .main_section ol.rules > li > ol > li,
#terms .main_section ol.rules > li > ol > li {
    margin-bottom: 10px;
}
#policy .main_section ol.rules > li > ol > li > ol {
    list-style: lower-latin;
    margin-top: 20px;
}
#terms .main_section ol.rules > li dl {
    padding: 0 15px 15px 15px;
}
#terms .main_section ol.rules > li dl dt {
    border: 1px solid var(--col-d-gray);
    width: 120px;
    text-align: center;
    padding: 15px;
    margin-top: 25px;
    margin-bottom: 10px;
    line-height: 1;
}
#terms .main_section ol.rules > li dl dd {
    margin-left: 20px;
    margin-bottom: 10px;
}

/* ==================== @media (プライバシーポリシー・ご利用規約) ==================== */
@media (max-width: 992px) {
}
@media (max-width: 768px) {
}
@media (max-width: 576px) {
    #policy .main_section ol.rules li h2,
    #terms .main_section ol.rules li h2 {
        font-size: 1.3rem;
        letter-spacing: 0;
    }
    #policy .main_section ol.rules > li:before,
    #terms .main_section ol.rules > li:before {
        font-size: 1.2rem;
    }
}


/* ======================================== 予選結果 ======================================== */
#qualify h1 span {
    display: block;
    margin: 8px 0;
}
#qualify h1 span.season {
    background: var(--col-d-gray);
    border-radius: 45px;
    color: #FFF;
    padding: 10px 30px;
    font-size: 2rem;
    font-weight: normal;
    display: inline-block;
}

#qualify div.viewTbl {
    text-align: center;
    margin-bottom: 50px;
}
#qualify p.note {
    text-align: right;
    margin-bottom: 0;
}
#qualify p.note span {
    color: rgb(207 255 0 / 16%);
    display: inline-block;
    border: 1px solid var(--col-gray);
    line-height: 1;
}

#qualify p.caption {
    background-color: var(--col-green);
    color: #FFF;
    padding: 10px 0;
    margin-bottom: 0;
    font-size: 1.4rem;
    border-top: 1px solid var(--col-gray);
    border-left: 1px solid var(--col-gray);
    border-right: 1px solid var(--col-gray);
}
#qualify div.viewTbl table { width: 100%; }

#qualify div.viewTbl table tr.list {
    background-color: var(--col-gray);
    color: var(--col-d-gray);
}

#qualify div.viewTbl tr.checkok { background-color: rgb(207 255 0 / 16%); }

#qualify div.viewTbl tr.list th {
    padding: 7px 2px;
    border-color: var(--col-gray);
    background-color: var(--col-d-gray);
    color: var(--col-l-gray);
    font-weight: normal;
}

#qualify div.viewTbl tr:not(.list):hover { background-color: #ffed69; }

#qualify div.viewTbl tr td {
    padding: 7px 2px;
    border-color: var(--col-gray);
}

#qualify div.viewTbl tr.ladies td.name { color: #f563a0; }

/* ==================== @media (予選結果) ==================== */
@media (max-width: 992px) {
    body#qualify section.qualify_section p.caption { font-size: 17px; }
    
    body#qualify section.qualify_section table { font-size: 14px; }
}
@media (max-width: 768px) {
    body#qualify section.qualify_section p.note { font-size: 13px; }
    
    body#qualify section.qualify_section p.caption { font-size: 14px; }
    
    body#qualify section.qualify_section table { font-size: 13px; }
}
@media (max-width: 576px) {
    body#qualify section.qualify_section table { font-size: 11px; }
}
