@media screen and (min-width: 768px) {

    html, body, div, span, applet, object, iframe,
    h1, h2, h3, h4, h5, h6, p, blockquote, pre,
    a, abbr, acronym, address, big, cite, code,
    del, dfn, em, img, ins, kbd, q, s, samp,
    small, strike, strong, sub, sup, tt, var,
    b, u, i, center,
    dl, dt, dd, ol, ul, li,
    fieldset, form, label, legend,
    table, caption, tbody, tfoot, thead, tr, th, td,
    article, aside, canvas, details, embed,
    figure, figcaption, footer, header, hgroup,
    menu, nav, output, ruby, section, summary,
    time, mark, audio, video {
        border: 0;
        font-family: inherit;
        font-size: 100%;
        font-style: inherit;
        font-weight: inherit;
        margin: 0;
        outline: 0;
        padding: 0;
        vertical-align: baseline;
    }

    * {
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
        box-sizing: border-box;
    }

    html {
        font-size: 62.5%;
    }

    body {
        height: 100%;
        background-color: #f3f3f3;
        color: #545454;
        font-size: 12px;
        font-size: 1.2rem;
        font-family: 'Lato', 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
        animation: fadeIn 3s ease 0s 1 normal;
        -webkit-animation: fadeIn 3s ease 0s 1 normal;
        -moz-animation: fadeIn 3s ease 0s 1 normal;
        -o-animation: fadeIn 3s ease 0s 1 normal;
    }

    @keyframes fadeIn {
        0% {
            opacity: 0
        }
        100% {
            opacity: 1
        }
    }
    @-webkit-keyframes fadeIn {
        0% {
            opacity: 0
        }
        100% {
            opacity: 1
        }
    }
    @-moz-keyframes fadeIn {
        0% {
            opacity: 0
        }
        100% {
            opacity: 1
        }
    }
    @-o-keyframes fadeIn {
        0% {
            opacity: 0
        }
        100% {
            opacity: 1
        }
    }
    html, body {
        height: 100%;
    }

    ol, ul {
        list-style: none;
        letter-spacing: 0.1em;
    }

    p {
        line-height: 1.8;
        letter-spacing: 0.1em;
    }

    dl {
        line-height: 1.8;
        letter-spacing: 0.1em;
    }

    caption, th, td {
        font-weight: normal;
        text-align: left;
        vertical-align: top;
    }

    img {
        max-width: 100%;
        height: auto;
        width /***/: auto;
        border: 0;
        vertical-align: bottom;
    }

    a, a:link a:visited {
        color: #cc0000;
        transition: all .3s;
        text-decoration: none;
    }


    a:hover {
        color: #111111;
        text-decoration: none;
    }

    .clearfix:after {
        content: "."; /* 新しい要素を作る */
        display: block; /* ブロックレベル要素に */
        clear: both;
        height: 0;
        visibility: hidden;
    }

    .clearfix {
        min-height: 1px;
    }

    * html .clearfix {
        height: 1px;
        /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
    }

    a.imghover:link img {
        transition: all .3s;
    }

    a.imghover:hover img {
        filter: alpha(opacity=70);
        opacity: 0.7;
    }

    .imghover {
        transition: all .3s;
    }

    .imghover:hover {
        filter: alpha(opacity=70);
        opacity: 0.7;
    }

    div.pagebox {
        min-height: 100%;
        box-sizing: border-box;
    }

    .wrapper {
        width: 100%;
    }


    #spotaka_top {
        position: fixed;
        bottom: 15px;
        right: 15px;
        z-index: 1000;
    }

    #spotaka_top a, a:link a:visited {
        display: block;
        font-size: 1.0rem;
        text-align: center;
        background-color: #cc0000;
        color: #fff;
        width: 56px;
        line-height: 1.0;
        height: 56px;
        border-radius: 28px;
        -webkit-border-radius: 28px;
        -moz-border-radius: 28px;
        padding: 15px 16px;
        box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
    }

    #spotaka_top a:hover {
        background-color: #111;
    }


    /* ############################# header ############################# */
    .header_bar {
        width: 100%;
        height: 60px;
        background-color: #cc0000;
    }

    @media screen and (min-width: 1024px) {
        .header_bar01 {
            position: relative;
            width: 94%;
            margin: 0 auto;
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .header_bar01 {
            position: relative;
            width: 100%;
        }
    }

    a.nav_menu {
        position: absolute;
        top: 0;
        left: 0;
        display: block;
        width: 60px;
        height: 60px;
        text-align: center;
        text-decoration: none;
        z-index: 2000;
        cursor: pointer;
    }

    a.nav_menu:hover {
        background-color: #aa0000;
    }

    .menu__line {
        display: block;
        height: 2px;
        position: absolute;
        transition: transform .3s;
        width: 22px;
    }

    .menu__line--top {
        top: 21px;
        left: 19px;
        background-color: #fff;
    }

    .menu__line--center {
        top: 29px;
        left: 19px;
        background-color: #fff;
    }

    .menu__line--bottom {
        bottom: 21px;
        left: 19px;
        background-color: #fff;
    }

    .menu__line--top.active {
        top: 29px;
        background-color: #fff;
        transform: rotate(45deg);
    }

    .menu__line--center.active {
        transform: scaleX(0);
    }

    .menu__line--bottom.active {
        bottom: 29px;
        background-color: #fff;
        transform: rotate(135deg);
    }

    /* ###### gnav ##### */
    @media screen and (min-width: 1024px) {
        .gnav {
            background: rgba(0, 0, 0, 0.7);
            display: none;
            height: 100%;
            position: fixed;
            width: 30%;
            z-index: 1000;
        }

        .gnav__wrap {
            position: relative;
            height: 100%;
        }

        .gnav__wrap01 {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            width: 80%;
            border-top: 1px dotted #999;
        }

        ul.gnav__menu01 {
        }

        .gnav__menu__item {
            text-align: center;
            border-bottom: 1px dotted #999;
        }

        .gnav__menu__item a {
            width: 100%;
            display: block;
            color: #fff;
            font-size: 1.2em;
            line-height: 1.0;
            letter-spacing: 0.1em;
            padding: 20px 0;
            text-decoration: none;
            transition: .5s;
            background: url(../images/list_mk002.svg) no-repeat right 10px center;
            background-size: 14px;
        }

        .gnav__menu__item a:hover {
            color: #cc0000;
            background: url(../images/list_mk002.svg) no-repeat right 5px center;
            background-size: 14px;
        }

        .gnav__wrap02 {
            display: none;
        }

        .ac_sp a {
            text-align: center;
            width: 100%;
            display: block;
            color: #fff;
            font-size: 1.2em;
            line-height: 1.0;
            letter-spacing: 0.1em;
            padding: 20px 0;
            text-decoration: none;
            transition: .5s;
            border-bottom: 1px dotted #999;
            cursor: pointer;
        }

        .ac_sp a:hover {
            color: #cc0000;
        }

        .ac_sp a:after {
            content: "";
            position: absolute;
            right: 0;
            background: url(../images/list_mk006.svg) no-repeat right 10px center;
            background-size: 14px;
            padding: 8px 15px;
        }

        .ac_sp a:after {
            content: "";
            position: absolute;
            right: 0;
            background: url(../images/list_mk004.svg) no-repeat right 10px center;
            background-size: 14px;
            padding: 8px 15px;
        }

        .gnav__wrap02 {
            display: none;
        }

        .menu-top-menu-container ul li a {
            padding: 0;
            font-size: 100%;
            font-weight: 500;
        }

        .menu-top-menu-container ul li {
            border: 0;
        }

    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .gnav {
            background: rgba(0, 0, 0, 0.7);
            display: none;
            height: 100%;
            position: fixed;
            width: 45%;
            z-index: 1000;
        }

        .gnav__wrap {
            position: relative;
            height: 100%;
        }

        .gnav__wrap02 {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            width: 80%;
            border-top: 1px dotted #999;
        }

        ul.gnav__menu01 {
        }

        .gnav__menu__item {
            text-align: center;
            border-bottom: 1px dotted #999;
        }

        .gnav__menu__item a {
            width: 100%;
            display: block;
            color: #fff;
            font-size: 1.2em;
            line-height: 1.0;
            letter-spacing: 0.1em;
            padding: 18px 0;
            text-decoration: none;
            transition: .5s;
            background: url(../images/list_mk002.svg) no-repeat right 10px center;
            background-size: 14px;
        }

        .gnav__menu__item a:hover {
            color: #cc0000;
            background: url(../images/list_mk002.svg) no-repeat right 5px center;
            background-size: 14px;
        }

        .ac_sp h3.ac_title {
            text-align: center;
            width: 100%;
            display: block;
            color: #fff;
            font-size: 1.2em;
            line-height: 1.0;
            letter-spacing: 0.1em;
            padding: 18px 0;
            text-decoration: none;
            transition: .5s;
            border-bottom: 1px dotted #999;
            cursor: pointer;
        }

        .ac_sp h3.ac_title:hover {
            color: #cc0000;
        }

        .ac_sp h3.ac_title:after {
            content: "";
            position: absolute;
            right: 0;
            background: url(../images/list_mk006.svg) no-repeat right 10px center;
            background-size: 14px;
            padding: 8px 15px;
        }

        .ac_sp h3.ac_title.ac:after {
            content: "";
            position: absolute;
            right: 0;
            background: url(../images/list_mk004.svg) no-repeat right 10px center;
            background-size: 14px;
            padding: 8px 15px;
        }

        .gnav__wrap01 {
            display: none;
        }
    }

    /* ###### gnav ##### */
    /* ###### header_search ##### */
    .header_search {
        width: 55%;
        height: 40px;
        padding-top: 11px;
        margin: 0 0 0 10%;
    }

    .header_search .search-btn:hover {
        filter: alpha(opacity=80);
        opacity: 0.8;
    }

    .header_search02 {
        position: relative;
        border-radius: 4px;
        -webkit-border-radius: 4px;
        -moz-border-radius: 4px;
        background-color: #fff;
    }

    .input_sp {
        width: 100%;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .input_sp01 {
        position: relative;
        width: 30%;
        display: inline-block;
        border-right: 1px solid #cc0000;
        overflow: hidden;
    }

    .input_sp01 select {
        color: #222;
        font-size: 1.4rem;
        display: inline;
        width: 100%;
        height: 40px;
        padding: 0 15px;
        border: none;
        background-color: #fff;
        cursor: pointer;
        font-family: 'Lato', 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    }

    .input_sp01::after {
        content: '';
        width: 6px;
        height: 6px;
        border: 0px;
        border-bottom: solid 2px #ccc;
        border-right: solid 2px #ccc;
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        position: absolute;
        top: 48%;
        right: 10px;
        margin-top: -4px;
        z-index: 20;
    }

    .select {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        width: 100%;
        height: 40px;
        background: transparent;
        position: relative;
        z-index: 1;
        padding: 0 40px 0 10px;
        border: 1px solid #ccc;
        border-radius: 2px;
    }

    select::-ms-expand {
        display: none;
    }

    .input_sp02 {
        width: 60%;
    }

    .search_input {
        color: #545454;
        font-size: 1.4rem;
        display: inline;
        width: 100%;
        height: 40px;
        padding: 2px 10px;
        border: none;
        font-family: 'Lato', 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    }

    .input_sp03 {
        position: relative;
        width: 10%;
    }

    .search_btn {
        position: absolute;
        top: 0;
        right: 0;
        width: 40px;
        padding: 11px;
    }

    /* ###### header_search ##### */
    @media screen and (min-width: 1024px) {
        /* ###### top_header ##### */
        .top_header {
            width: 100%;
            z-index: 100;
            background-color: #fff;
        }

        .top_header_sp01 {
            position: relative;
            width: 94%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        .top_header_sp01 .logo_sp {
            width: 120px;
            padding-top: 26px;
            z-index: 200;
        }

        .top_header_sp01 .logo_sp h1 {
            width: 120px;
        }

        .top_header_sp01 .global_nav {
            flex: 1;
            width: 100%;
        }

        .top_header_sp01 .global_nav ul {
            font-size: 1.4rem;
            line-height: 1.0;
            font-weight: 500;
            letter-spacing: 0.1em;
            padding: 40px 0;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            justify-content: flex-end;
        }

        .top_header_sp01 .global_nav ul li {
            margin-left: 35px;
        }

        .top_header_sp01 .global_nav ul li:last-child {
            margin-bottom: 0 !important;
        }

        .top_header_sp01 .global_nav ul li a, a:link a:visited {
            color: #111;
            position: relative;
            display: inline-block;
        }

        .top_header_sp01 .global_nav ul li a:before {
            content: "";
            position: absolute;
            display: block;
            background-color: #111;
            width: 0;
            height: 2px;
            bottom: -7px;
            left: 0;
            -webkit-transition: .3s ease 0s;
            transition: .3s ease 0s;
        }

        .top_header_sp01 .global_nav ul li a:hover {
            color: #111;
            text-decoration: none;
        }

        .top_header_sp01 .global_nav ul li a:hover:before {
            width: 100%;
        }

        .page_logo_sp {
            display: none;
        }

        /* ###### top_header ##### */
    }


    @media screen and (min-width: 768px) and (max-width: 1023px) {
        /* ###### top_header ##### */
        .top_header {
            display: none;
        }

        .top_header_sp01 {
            display: none;
        }

        .top_header_sp01 .logo_sp {
            display: none;
        }

        .page_logo_sp {
            position: absolute;
            z-index: 200;
            top: 35px;
            left: 50%;
            transform: translateX(-50%);
            -webkit-transform: translateX(-50%);
            width: 94%;
        }

        .page_logo_sp h1 {
            width: 100px;
        }

        /* ###### top_header ##### */
    }


    .sp_header {
        display: none;
    }

    .sp_header h1 {
        display: none;
    }

    .sp_page_header_sp {
        display: none;
    }

    .sp_page_header_sp h1 {
        display: none;
    }

    .fixed {
        position: fixed;
        top: 0;
        width: 100%;
        z-index: 10000;
    }

    /* ############################# header ############################# */
    /* ############################# top_contents ############################# */
    .top_contents_sp {
        width: 100%;
    }


    /* ###### top_info_sp ###### */
    @media screen and (min-width: 1024px) {
        .top_info_sp {
            position: relative;
            width: 100%;
        }

        .top_info_sp01 {
            position: relative;
            width: 97%;
            min-width: 1100px;
        }

        .sp_top_info_sports_list_sp {
            display: none;
        }

        .sp_top_info_sports_list_sp ul {
            display: none;
        }

        .pc_top_info_sp01_left {
            width: 210px;
            float: left;
            background-color: #222;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul {
            font-size: 1.4rem;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul li {
            border-bottom: 1px dotted #444;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul li:last-child {
            border: none;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul li a, a:link a:visited {
            display: block;
            width: 100%;
            color: #fff;
            text-decoration: none;
            padding: 16px 22px;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul li a:hover {
            background-color: #000;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul li a img {
            width: 26px;
            padding-right: 7px;
            padding-bottom: 1px;
        }

        .top_info_sp01_right {
            width: 100%;
            float: right;
            margin-top: -15px;
            margin-left: -210px;
        }

        .top_info_sp01_right01 {
            position: relative;
            background-color: #fff;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            margin-left: 210px;
        }

        .top_info_sp01_right01 .pc_slide_inner {
            width: 70%;
        }

        .top_info_sp01_right01 .pc_slide_inner div {
            width: 100%;
            height: 488px;
            overflow: hidden;
        }

        .top_info_sp01_right01 .pc_slide_inner div a {
            display: block;
            position: relative;
        }

        .top_info_sp01_right01 .pc_slide_inner div a dl.pc_slide_catch {
            position: absolute;
            width: 100%;
            left: 0;
            bottom: 0;
            color: #fff;
            background-color: rgba(0, 0, 0, 0.4);
            padding: 35px 40px 60px;
            z-index: 50;
        }

        .top_info_sp01_right01 .pc_slide_inner div a dl.pc_slide_catch dt {
            font-size: 1.1rem;
            font-family: 'Oswald', sans-serif;
            letter-spacing: 0.1em;
            float: left;
            display: block;
            border: 1px dotted #ddd;
            padding: 10px;
        }

        .top_info_sp01_right01 .pc_slide_inner div a dl.pc_slide_catch dd {
            font-size: 1.8rem;
            font-weight: 500;
            letter-spacing: 0.1em;
            padding-left: 100px;
        }

        .top_info_sp01_right01 .pc_slide_inner div img {
            width: 100%;
            height: 488px;
            object-fit: cover;
            -webkit-transition: .3s ease-in-out;
            transition: .3s ease-in-out;
        }

        .top_info_sp01_right01 .pc_slide_inner div a:hover img {
            transform: scale(1.1);
            z-index: 10;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots {
            position: absolute;
            bottom: 25px;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots li {
            position: relative;
            display: inline-block;
            width: 16px;
            height: 16px;
            margin: 0 10px;
            padding: 0;
            background-color: #fff;
            cursor: pointer;
            border-radius: 8px;
            -webkit-border-radius: 8px;
            -moz-border-radius: 8px;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots li button:before {
            width: 16px;
            height: 16px;
            border-radius: 8px;
            -webkit-border-radius: 8px;
            -moz-border-radius: 8px;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots li.slick-active button:before {
            opacity: .75;
            background-color: #cc0000;
        }

        .top_info_sp01_right01 .top_info_add_sp {
            width: 30%;
            padding: 40px 40px 30px;
        }

        .top_info_sp01_right01 .top_info_add_sp p a img {
            max-width: 100%;
            height: auto;
            width: auto;
            border: 0;
            max-height: 415px;
            margin: 0 auto;
            display: block;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom {
            width: 100%;
            border-top: 1px dotted #ddd;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp {
            width: 100%;
            padding: 40px;
            background-color: #f3f3f3;
            border-right: 1px dotted #ddd;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp h3 {
            width: 20%;
            font-family: 'Oswald', sans-serif;
            color: #111;
            font-weight: 500;
            font-size: 4.2rem;
            line-height: 1.0;
            letter-spacing: 0.075em;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp dl {
            width: 80%;
            letter-spacing: 0.075em;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp dl dt {
            font-size: 1.1rem;
            float: left;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp dl dd {
            font-size: 1.3rem;
            padding: 0 0 0 85px;
            margin-bottom: 10px;
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .top_info_sp {
            position: relative;
            width: 100%;
            margin-top: 100px;
        }

        .top_info_sp01 {
            position: relative;
            width: 94%;
            margin: 0 auto;
        }

        .sp_top_info_sports_list_sp {
            display: none;
        }

        .sp_top_info_sports_list_sp ul {
            display: none;
        }

        .pc_top_info_sp01_left {
            display: none;
        }

        .pc_top_info_sp01_left .pc_top_info_sports_list_sp ul {
            display: none;
        }

        .top_info_sp01_right {
            width: 100%;
        }

        .top_info_sp01_right01 {
            background-color: #fff;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            position: relative;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: center;
        }

        .top_info_sp01_right01 .pc_slide_inner {
            width: 70%;
        }

        .top_info_sp01_right01 .pc_slide_inner div {
            width: 100%;
            height: 400px;
            overflow: hidden;
        }

        .top_info_sp01_right01 .pc_slide_inner div a {
            display: block;
            position: relative;
        }

        .top_info_sp01_right01 .pc_slide_inner div a dl.pc_slide_catch {
            position: absolute;
            width: 100%;
            left: 0;
            bottom: 0;
            color: #fff;
            background-color: rgba(0, 0, 0, 0.4);
            padding: 30px 30px 60px;
            z-index: 50;
        }

        .top_info_sp01_right01 .pc_slide_inner div a dl.pc_slide_catch dt {
            font-size: 1.1rem;
            font-family: 'Oswald', sans-serif;
            letter-spacing: 0.1em;
            float: left;
            display: block;
            border: 1px dotted #ddd;
            padding: 10px;
        }

        .top_info_sp01_right01 .pc_slide_inner div a dl.pc_slide_catch dd {
            font-size: 1.6rem;
            font-weight: 500;
            letter-spacing: 0.1em;
            padding-left: 100px;
        }

        .top_info_sp01_right01 .pc_slide_inner div img {
            width: 100%;
            height: 400px;
            object-fit: cover;
            -webkit-transition: .3s ease-in-out;
            transition: .3s ease-in-out;
        }

        .top_info_sp01_right01 .pc_slide_inner div a:hover img {
            transform: scale(1.1);
            z-index: 10;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots {
            position: absolute;
            bottom: 25px;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots li {
            position: relative;
            display: inline-block;
            width: 16px;
            height: 16px;
            margin: 0 10px;
            padding: 0;
            background-color: #fff;
            cursor: pointer;
            border-radius: 8px;
            -webkit-border-radius: 8px;
            -moz-border-radius: 8px;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots li button:before {
            width: 16px;
            height: 16px;
            border-radius: 8px;
            -webkit-border-radius: 8px;
            -moz-border-radius: 8px;
        }

        .top_info_sp01_right01 .pc_slide_inner .slick-dots li.slick-active button:before {
            opacity: .75;
            background-color: #cc0000;
        }

        .top_info_sp01_right01 .top_info_add_sp {
            width: 30%;
            padding: 30px;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom {
            width: 100%;
            border-top: 1px dotted #ddd;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: center;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp {
            width: 70%;
            padding: 40px 35px;
            background-color: #f3f3f3;
            border-right: 1px dotted #ddd;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp h3 {
            text-align: center;
            font-family: 'Oswald', sans-serif;
            color: #111;
            font-weight: 500;
            font-size: 3.6rem;
            line-height: 1.0;
            letter-spacing: 0.075em;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp dl {
            letter-spacing: 0.075em;
            margin-top: 20px;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp dl dt {
            font-size: 1.0rem;
            float: left;
        }

        .top_info_sp01_right01 .top_info_sp01_right01_bottom .top_info_news_sp dl dd {
            font-size: 1.3rem;
            padding: 0 0 0 80px;
            margin-bottom: 10px;
        }
    }
    /* ###### top_info_sp ###### */
    /* ###### top_sports_genre_sp ###### */
    @media screen and (min-width: 1024px) {
        .top_sports_genre_sp {
            position: relative;
            background: url(../images/genre_backimg.svg) no-repeat right 0;
            background-size: 120px;
            width: 100%;
        }

        .top_sports_genre_sp .main_top_sports_genre_sp {
            position: relative;
            width: 86%;
            z-index: 100;
            margin: 0 auto;
            padding: 80px 0 60px;
        }

        .top_sports_genre_sp .main_top_sports_genre_img {
            position: relative;
            width: 60%;
        }

        .top_sports_genre_sp .main_top_sports_genre_img a {
            position: relative;
            display: block;
            width: 100%;
            overflow: hidden;
            background-color: #ccc;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp .main_top_sports_genre_img a img {
            width: 100%;
            -webkit-transition: .3s ease-in-out;
            transition: .3s ease-in-out;
        }

        .top_sports_genre_sp .main_top_sports_genre_img a:hover img {
            transform: scale(1.1);
        }

        .top_sports_genre_sp .main_top_sports_genre_img .main_top_sports_genre_title_sp {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            z-index: 20;
        }

        .top_sports_genre_sp .main_top_sports_genre_img .main_top_sports_genre_title_sp h2 {
            text-align: center;
            font-family: 'Oswald', sans-serif;
            color: #fff;
            font-weight: 500;
            font-size: 6.0rem;
            line-height: 1.0;
            letter-spacing: 0.05em;
            text-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp .main_top_sports_genre_text {
            position: absolute;
            width: 45%;
            top: 50%;
            right: 0;
            transform: translateY(-50%);
            -webkit-transform: translateY(-50%);
            z-index: 20;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 {
            position: relative;
            width: 100%;
            background-color: #111;
            padding: 80px 60px;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 p {
            color: #f3f3f3;
            font-size: 1.4rem;
            letter-spacing: 0.1em;
            line-height: 2.0;
            margin-bottom: 40px;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 h3 {
            padding-top: 20px;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 h3 a, a:link a:visited {
            display: block;
            text-align: center;
            width: 100%;
            color: #f3f3f3;
            font-size: 1.8rem;
            letter-spacing: 0.1em;
            background: url(../images/list_mk002.svg) no-repeat right 10px center;
            background-size: 14px;
            background-color: #c00;
            padding: 22px 0;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 h3 a:hover {
            background: url(../images/list_mk002.svg) no-repeat right 5px center;
            background-size: 14px;
            background-color: #a00;
            color: #fff;
        }

        /* ###### top_sports_genre_sp01 ###### */
        .top_sports_genre_sp01 {
            width: 92%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            justify-content: space-between;
            margin: 0 auto;
            padding-bottom: 40px;
        }

        .top_sports_genre_sp01 .top_sports_genre_list {
            width: 31.5%;
            margin-bottom: 40px;
        }

        .top_sports_genre_sp01 .top_sports_genre_img {
            position: relative;
            width: 100%;
        }

        .top_sports_genre_sp01 .top_sports_genre_list a {
            position: relative;
            display: block;
            width: 100%;
            overflow: hidden;
            background-color: #ccc;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
        }

        .top_sports_genre_sp01 .top_sports_genre_list a img {
            width: 100%;
            -webkit-filter: grayscale(100%);
            filter: grayscale(100%);
            -webkit-transition: .3s ease-in-out;
            transition: .3s ease-in-out;
        }

        .top_sports_genre_sp01 .top_sports_genre_list a:hover img {
            -webkit-filter: grayscale(0);
            filter: grayscale(0);
            transform: scale(1.1);
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_title_sp {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            z-index: 20;
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_title_sp h2 {
            text-align: center;
            font-family: 'Oswald', sans-serif;
            color: #fff;
            font-weight: 500;
            font-size: 3.6rem;
            line-height: 1.0;
            letter-spacing: 0.05em;
            text-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_text {
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_text p {
            font-size: 1.4rem;
            letter-spacing: 0.1em;
        }

        /* ###### top_sports_genre_sp01 ###### */
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .top_sports_genre_sp {
            position: relative;
            background: url(../images/genre_backimg.svg) no-repeat right 0;
            background-size: 100px;
            width: 100%;
        }

        .top_sports_genre_sp .main_top_sports_genre_sp {
            position: relative;
            width: 88%;
            z-index: 100;
            margin: 0 auto;
            padding: 60px 0 60px;
        }

        .top_sports_genre_sp .main_top_sports_genre_img {
            position: relative;
            width: 70%;
        }

        .top_sports_genre_sp .main_top_sports_genre_img a {
            position: relative;
            display: block;
            width: 100%;
            overflow: hidden;
            background-color: #ccc;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp .main_top_sports_genre_img a img {
            width: 100%;
            -webkit-transition: .3s ease-in-out;
            transition: .3s ease-in-out;
        }

        .top_sports_genre_sp .main_top_sports_genre_img a:hover img {
            transform: scale(1.1);
        }

        .top_sports_genre_sp .main_top_sports_genre_img .main_top_sports_genre_title_sp {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            z-index: 20;
        }

        .top_sports_genre_sp .main_top_sports_genre_img .main_top_sports_genre_title_sp h2 {
            text-align: center;
            font-family: 'Oswald', sans-serif;
            color: #fff;
            font-weight: 500;
            font-size: 5.0rem;
            line-height: 1.0;
            letter-spacing: 0.05em;
            text-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp .main_top_sports_genre_text {
            width: 80%;
            z-index: 20;
            margin: -10% 0 0 20%;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 {
            position: relative;
            width: 100%;
            background-color: #111;
            padding: 60px 40px;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 p {
            color: #f3f3f3;
            font-size: 1.3rem;
            letter-spacing: 0.1em;
            line-height: 2.0;
            margin-bottom: 40px;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 h3 a, a:link a:visited {
            display: block;
            text-align: center;
            width: 100%;
            color: #f3f3f3;
            font-size: 1.6rem;
            letter-spacing: 0.1em;
            background: url(../images/list_mk002.svg) no-repeat right 10px center;
            background-size: 14px;
            background-color: #c00;
            padding: 22px 0;
        }

        .top_sports_genre_sp .main_top_sports_genre_text01 h3 a:hover {
            background: url(../images/list_mk002.svg) no-repeat right 5px center;
            background-size: 14px;
            background-color: #a00;
            color: #fff;
        }

        /* ###### top_sports_genre_sp01 ###### */
        .top_sports_genre_sp01 {
            width: 92%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            justify-content: space-between;
            margin: 0 auto;
            padding-bottom: 60px;
        }

        .top_sports_genre_sp01 .top_sports_genre_list {
            width: 32%;
            margin-bottom: 20px;
        }

        .top_sports_genre_sp01 .top_sports_genre_img {
            position: relative;
            width: 100%;
        }

        .top_sports_genre_sp01 .top_sports_genre_list a {
            position: relative;
            display: block;
            width: 100%;
            overflow: hidden;
            background-color: #ccc;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
        }

        .top_sports_genre_sp01 .top_sports_genre_list a img {
            width: 100%;
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_title_sp {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            z-index: 20;
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_title_sp h2 {
            text-align: center;
            font-family: 'Oswald', sans-serif;
            color: #fff;
            font-weight: 500;
            font-size: 2.6rem;
            line-height: 1.0;
            letter-spacing: 0.05em;
            text-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_text {
        }

        .top_sports_genre_sp01 .top_sports_genre_list .top_sports_genre_text p {
            font-size: 1.4rem;
            letter-spacing: 0.1em;
        }

        /* ###### top_sports_genre_sp01 ###### */
    }
    /* ###### top_sports_genre_sp ###### */
    /* ###### top_slogan_sp ###### */
    @media screen and (min-width: 1024px) {
        .top_slogan_sp {
            width: 100%;
            background: url(../images/slogan_backimg.svg) no-repeat -3px -5px;
            background-size: 120px;
            background-color: #fff;
            padding: 100px 0;
        }

        .top_slogan_sp01 {
            position: relative;
            width: 84%;
            background-color: #fff;
            margin: 0 auto;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
            padding: 100px 40px;
        }

        .top_slogan_sp h3 {
            text-align: center;
            color: #cc0000;
            font-weight: 600;
            font-size: 3.6rem;
            line-height: 1.0;
            letter-spacing: 0.075em;
        }

        .top_slogan_sp p {
            font-size: 1.8rem;
            font-weight: 600;
            text-align: center;
            letter-spacing: 0.1em;
            line-height: 2.0;
            margin-top: 40px;
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .top_slogan_sp {
            width: 100%;
            background: url(../images/slogan_backimg.svg) no-repeat -3px -5px;
            background-size: 100px;
            background-color: #fff;
            padding: 80px 0 100px;
        }

        .top_slogan_sp01 {
            position: relative;
            width: 86%;
            background-color: #fff;
            margin: 0 auto;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
            padding: 80px 40px;
        }

        .top_slogan_sp h3 {
            text-align: center;
            color: #cc0000;
            font-weight: 600;
            font-size: 3.2rem;
            line-height: 1.0;
            letter-spacing: 0.075em;
        }

        .top_slogan_sp p {
            font-size: 1.6rem;
            font-weight: 600;
            text-align: center;
            letter-spacing: 0.1em;
            line-height: 2.0;
            margin-top: 40px;
        }
    }
    /* ###### top_slogan_sp ###### */
    /* ###### top_newest_post_sp ##### */
    @media screen and (min-width: 1024px) {
        .top_newest_post_sp {
            width: 100%;
            background: url(../images/newest_backimg.svg) no-repeat right 0;
            background-size: 120px;
            padding: 100px 0 50px;
            background-color: #f3f3f3;
        }

        .top_newest_post_sp01 {
            width: 92%;
            margin: 0 auto;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        }

        .top_newest_post_title_sp {
            width: 25%;
            padding: 60px 50px 0 0;
        }

        .top_newest_post_title_sp h2 {
            font-family: 'Oswald', sans-serif;
            color: #111;
            font-weight: 500;
            font-size: 4.6rem;
            letter-spacing: 0.075em;
            line-height: 1.3;
        }

        .top_newest_post_title_sp p {
            font-size: 1.4rem;
            letter-spacing: 0.1em;
            margin-top: 30px;
        }

        .top_newest_post_sp02 {
            width: 75%;
        }

        .top_newest_post_list {
            position: relative;
            width: 100%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: center;
            background-color: #fff;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
            padding-top: 60px;
            margin-bottom: 50px;
        }

        .top_newest_post_list .top_newest_post_thumb {
            position: relative;
            width: 50%;
            padding: 0 40px 0 60px;
        }

        .top_newest_post_list .top_newest_post_thumb01 {
            position: relative;
            width: 100%;
            overflow: hidden;
        }

        .top_newest_post_list .top_newest_post_thumb01 img {
            width: 100%;
            object-fit: cover;
        }

        .top_newest_post_list .top_newest_post_thumb .caption {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            font-size: 1.4rem;
            color: #fff;
            letter-spacing: 0.1em;
            font-family: 'Oswald', sans-serif;
            font-weight: 400;
        }

        .top_newest_post_list .top_newest_post_thumb .mask {
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
            left: 0;
            opacity: 0;
            background-color: rgba(0, 0, 0, 0.4);
            -webkit-transition: all 0.6s ease;
            -moz-transition: all 0.6s ease;
            -o-transition: all 0.6s ease;
            transition: all 0.6s ease;
        }

        .top_newest_post_list .top_newest_post_thumb:hover .mask {
            opacity: 1; /* マスクを表示する */
        }

        .top_newest_post_list .top_newest_post_text {
            position: relative;
            width: 50%;
            padding-right: 60px;
        }

        .top_newest_post_list .top_newest_post_text h3 {
            font-size: 2.4rem;
            line-height: 1.6;
            font-weight: bold;
            letter-spacing: 0.1em;
        }

        .top_newest_post_list .top_newest_post_text p.top_newest_post_desc {
            font-size: 1.4rem;
            letter-spacing: 0.1em;
            margin-top: 20px;
        }

        p.blog_icon {
            height: 80px;
            top: -35px;
            left: -35px;
            width: 80px;
            font-family: 'Oswald', sans-serif;
            text-align: center;
            color: #fff;
            font-weight: 400;
            font-size: 1.2rem;
            line-height: 80px;
            letter-spacing: 0.1em;
            background-color: #111;
            z-index: 50;
            border-radius: 40px;
            -webkit-border-radius: 40px;
            -moz-border-radius: 40px;
            position: absolute;
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
        }

        p.event_icon {
            position: absolute;
            top: -35px;
            left: -35px;
            width: 80px;
            height: 80px;
            font-family: 'Oswald', sans-serif;
            text-align: center;
            color: #fff;
            font-weight: 400;
            font-size: 1.2rem;
            line-height: 80px;
            letter-spacing: 0.1em;
            background-color: #a00;
            z-index: 50;
            border-radius: 40px;
            -webkit-border-radius: 40px;
            -moz-border-radius: 40px;
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .top_newest_post_sp {
            width: 100%;
            background: url(../images/newest_backimg.svg) no-repeat right 0;
            background-size: 100px;
            padding: 80px 0 100px;
        }

        .top_newest_post_sp01 {
            width: 90%;
            margin: 0 auto;
        }

        .top_newest_post_title_sp {
            width: 100%;
            margin-bottom: 40px;
        }

        .top_newest_post_title_sp h2 {
            text-align: center;
            font-family: 'Oswald', sans-serif;
            color: #111;
            font-weight: 500;
            font-size: 4.6rem;
            letter-spacing: 0.075em;
            line-height: 1.3;
        }

        .top_newest_post_title_sp h2 br {
            display: none;
        }

        .top_newest_post_title_sp p {
            width: 80%;
            font-size: 1.4rem;
            letter-spacing: 0.1em;
            margin: 30px auto 0;
        }

        .top_newest_post_sp02 {
            width: 100%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: stretch;
            justify-content: space-between;
        }

        .top_newest_post_list {
            position: relative;
            width: 48%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            flex-direction: column;
            background-color: #fff;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
        }

        .top_newest_post_list .top_newest_post_thumb {
            position: relative;
            width: 100%;
            margin-bottom: 30px;
        }

        .top_newest_post_list .top_newest_post_thumb01 {
            position: relative;
            width: 100%;
            overflow: hidden;
        }

        .top_newest_post_list .top_newest_post_thumb01 img {
            width: 100%;
            object-fit: cover;
        }

        .top_newest_post_list .top_newest_post_thumb .caption {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translateY(-50%) translateX(-50%);
            -webkit-transform: translateY(-50%) translateX(-50%);
            font-size: 1.4rem;
            color: #fff;
            letter-spacing: 0.1em;
            font-family: 'Oswald', sans-serif;
            font-weight: 400;
        }

        .top_newest_post_list .top_newest_post_thumb .mask {
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
            left: 0;
            opacity: 0;
            background-color: rgba(0, 0, 0, 0.4);
            -webkit-transition: all 0.6s ease;
            -moz-transition: all 0.6s ease;
            -o-transition: all 0.6s ease;
            transition: all 0.6s ease;
        }

        .top_newest_post_list .top_newest_post_thumb:hover .mask {
            opacity: 1; /* マスクを表示する */
        }

        .top_newest_post_list .top_newest_post_text {
            position: relative;
            width: 100%;
            padding: 0 30px;
        }

        .top_newest_post_list .top_newest_post_text h3 {
            font-size: 1.8rem;
            line-height: 1.6;
            font-weight: bold;
            letter-spacing: 0.1em;
        }

        .top_newest_post_list .top_newest_post_text p.top_newest_post_desc {
            font-size: 1.3rem;
            letter-spacing: 0.1em;
            margin-top: 20px;
            padding-bottom: 30px;
        }

        p.blog_icon {
            border-radius: 30px;
            left: -20px;
            top: -20px;
            width: 60px;
            height: 60px;
            font-family: 'Oswald', sans-serif;
            text-align: center;
            color: #fff;
            font-weight: 400;
            font-size: 1.0rem;
            line-height: 60px;
            position: absolute;
            letter-spacing: 0.1em;
            background-color: #111;
            z-index: 50;
            -webkit-border-radius: 30px;
            -moz-border-radius: 30px;
            box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
        }

        p.event_icon {
            position: absolute;
            top: -20px;
            left: -20px;
            text-align: center;
            height: 60px;
            font-family: 'Oswald', sans-serif;
            -moz-border-radius: 30px;
            color: #fff;
            font-weight: 400;
            font-size: 1.0rem;
            line-height: 60px;
            letter-spacing: 0.1em;
            background-color: #a00;
            z-index: 50;
            border-radius: 30px;
            -webkit-border-radius: 30px;
            width: 60px;
            box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
        }
    }
    /* ###### top_newest_post_sp ##### */
    /* ###### list_option_sp ###### */
    @media screen and (min-width: 1024px) {
        .list_option_sp {
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            padding: 30px 63px 30px;
            border-top: 1px dotted #ddd;
            width: 100%;
            margin-top: 40px;
        }

        .list_option_list {
            width: 50%;
        }

        .list_option_list p.option_date {
            color: #545454;
            font-size: 1.1rem;
            letter-spacing: 0.1em;
        }

        .list_option_list ul {
            color: #cc0000;
            font-size: 1.1rem;
            letter-spacing: 0.1em;
            text-align: right;
        }

        .list_option_list ul li {
            display: inline;
            margin-left: 6px;
        }

        .list_option_list ul li img {
            width: 18px;
            padding-right: 3px;
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .list_option_sp {
            width: 100%;
            margin-top: auto;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            border-top: 1px dotted #ddd;
            padding: 30px;
        }

        .list_option_list {
            width: 50%;
        }

        .list_option_list p.option_date {
            color: #545454;
            font-size: 1.1rem;
            letter-spacing: 0.1em;
        }

        .list_option_list ul {
            color: #cc0000;
            font-size: 1.1rem;
            letter-spacing: 0.1em;
            text-align: right;
        }

        .list_option_list ul li {
            display: inline;
            margin-left: 6px;
        }

        .list_option_list ul li img {
            width: 18px;
            padding-right: 3px;
        }
    }

    /* ###### top_bottom_sp ###### */
    @media screen and (min-width: 1024px) {
        .top_bottom_sp {
            width: 100%;
            height: 400px;
            background: url(../images/top_bottom_backimg.jpg) no-repeat 50% 50%;
            background-attachment: fixed;
            background-size: cover;
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .top_bottom_sp {
            width: 100%;
            height: 280px;
            background: url(../images/top_bottom_backimg.jpg) no-repeat 50% 50%;
            background-attachment: fixed;
            background-size: cover;
        }
    }

    .sp_top_bottom_sp {
        display: none;
    }

    /* ###### top_bottom_sp ###### */
    /* ###### list_option_sp ###### */
    @media screen and (min-width: 1024px) {
        .top_cliant_logo_sp {
            width: 100%;
            background: url(../images/top_cliant_logo_backimg.png) no-repeat 50% 50%;
            background-size: cover;
            padding: 100px 0 50px;
        }

        .top_cliant_logo_sp01 {
            width: 90%;
            margin: 0 auto;
        }

        .top_cliant_logo_sp01 ul {
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: center;
            justify-content: center;
        }

        .top_cliant_logo_sp01 ul li {
            height: 58px;
            margin: 0 40px 50px;
        }

        .top_cliant_logo_sp01 ul li img {
            height: 58px;
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1023px) {
        .top_cliant_logo_sp {
            width: 100%;
            background: url(../images/top_cliant_logo_backimg.png) no-repeat 50% 50%;
            background-size: cover;
            padding: 80px 0 40px;
        }

        .top_cliant_logo_sp01 {
            width: 80%;
            margin: 0 auto;
        }

        .top_cliant_logo_sp01 ul {
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: center;
            justify-content: center;
        }

        .top_cliant_logo_sp01 ul li {
            height: 50px;
            margin: 0 30px 40px;
        }

        .top_cliant_logo_sp01 ul li img {
            height: 50px;
        }
    }
    /* ###### list_option_sp ###### */
    /* ############################# top_contents ############################# */
    /* ############################# title ############################# */
    .title_sp01 {
        width: 100%;
        padding-top: 80px;
    }

    .title_sp01 h3 {
        text-align: center;
        font-family: 'Oswald', sans-serif;
        color: #111;
        font-weight: 500;
        font-size: 4.6rem;
        line-height: 1.0;
        letter-spacing: 0.075em;
    }

    .title_sp02 {
        width: 100%;
        padding-top: 80px;
    }

    .title_sp02 h3 {
        text-align: center;
        font-family: 'Oswald', sans-serif;
        color: #111;
        font-weight: 500;
        font-size: 3.6rem;
        line-height: 1.0;
        letter-spacing: 0.075em;
    }

    .title_sp02 p {
        text-align: center;
        color: #111;
        font-weight: 500;
        font-size: 1.2rem;
        line-height: 1.0;
        letter-spacing: 0.1em;
        margin-top: 12px;
    }

    .title_sp03 {
        width: 100%;
    }

    .title_sp03 h3 {
        text-align: center;
        font-family: 'Oswald', sans-serif;
        color: #111;
        font-weight: 500;
        font-size: 3.6rem;
        line-height: 1.0;
        letter-spacing: 0.075em;
    }

    .title_sp03 p {
        text-align: center;
        color: #111;
        font-weight: 500;
        font-size: 1.2rem;
        line-height: 1.0;
        letter-spacing: 0.1em;
        margin-top: 12px;
    }

    /* ############################# title ############################# */
    @media screen and (min-width: 1024px) {

        /* ############################# footer_sp ############################# */
        .footer_sp {
            width: 100%;
            margin: 0 auto;
            background-color: #111;
            padding: 0 0 25px;
        }

        .footer_access_sp {
            width: 100%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            background-color: #fff;
        }

        .footer_access_left {
            width: 50%;
        }

        .footer_access_right {
            width: 50%;
            background: url(../images/footer_storeinfo_backimg.svg) no-repeat right 0;
            background-size: 120px;
            background-color: #c00;
            padding: 60px 40px 60px 60px;
        }

        .footer_access_right h3 {
            font-family: 'Oswald', sans-serif;
            color: #fff;
            font-weight: 500;
            font-size: 4.6rem;
            letter-spacing: 0.075em;
            line-height: 1.3;
        }

        .footer_access_right dl {
            color: #fff;
            font-size: 1.4rem;
            letter-spacing: 0.1em;
            margin-top: 20px;
        }

        .footer_access_right dl dt {
            float: left;
            padding: 15px 0 0 2px;
        }

        .footer_access_right dl dd {
            padding: 15px 0 0 100px;
        }

        .footer_sp01 {
            width: 92%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            margin: 0 auto;
            padding-top: 60px;
        }

        .footer_sp01_left {
            width: 23%;
            padding-top: 10px;
        }

        .footer_sp01_left h4 {
            width: 150px;
        }

        .footer_sp01_right {
            width: 77%;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        .footer_list {
            width: 25%;
            padding-right: 25px;
        }

        .footer_list ul {
            font-size: 1.2rem;
            border-top: 1px dotted #333;
        }

        .footer_list ul li {
            border-bottom: 1px dotted #333;
            text-align: left;
        }

        .footer_list ul li a, a:link a:visited {
            display: block;
            color: #fff;
            background: url(../images/list_mk002.svg) no-repeat 5px center;
            background-size: 14px;
            padding: 9px 10px 9px 23px;
            font-size: 1.3rem;
            font-weight: 400;
            line-height: 1.7;
        }

        .footer_list ul li a:hover {
            background: url(../images/list_mk002.svg) no-repeat 8px center;
            background-size: 14px;
            background-color: #222;
        }

        .footer_list ul li img {
            width: 14px;
            margin-left: 7px;
            vertical-align: middle;
            padding-bottom: 2px;
        }

        .footer_sp02 {
            width: 92%;
            margin: 0 auto;
            padding-top: 60px;
        }

        .footer_sp02 p {
            width: 150px;
            margin: 0 auto;
        }

        p.copy {
            text-align: center;
            padding-top: 40px;
            font-size: 1.0rem;
            color: #fff;
            line-height: 1.0;
            letter-spacing: 0.1em;
        }

        /* ############################# footer_sp ############################# */

    }


    @media screen and (min-width: 768px) and (max-width: 1023px) {

        /* ############################# footer_sp ############################# */
        .footer_sp {
            width: 100%;
            margin: 0 auto;
            background-color: #111;
            padding: 0 0 25px;
        }

        .footer_access_sp {
            width: 100%;
            background-color: #fff;
        }

        .footer_access_left {
            width: 100%;
            height: 300px;
        }

        .footer_access_right {
            width: 100%;
            background: url(../images/footer_storeinfo_backimg.svg) no-repeat right 0;
            background-size: 80px;
            background-color: #c00;
            padding: 40px 7% 60px;
        }

        .footer_access_right h3 {
            font-family: 'Oswald', sans-serif;
            color: #fff;
            font-weight: 500;
            font-size: 3.6rem;
            letter-spacing: 0.075em;
            line-height: 1.3;
        }

        .footer_access_right dl {
            color: #fff;
            font-size: 1.3rem;
            letter-spacing: 0.1em;
            margin-top: 20px;
        }

        .footer_access_right dl dt {
            float: left;
            padding: 15px 0 0 2px;
        }

        .footer_access_right dl dd {
            padding: 15px 0 0 85px;
        }

        .footer_access_right dl dd a {
            color: #fff;
        }

        .footer_sp01 {
            width: 88%;
            margin: 0 auto;
            padding-top: 60px;
        }

        .footer_sp01_left {
            width: 100%;
        }

        .footer_sp01_left h4 {
            width: 120px;
            margin: 0 auto;
        }

        .footer_sp01_right {
            width: 100%;
        }

        .footer_list {
            width: 100%;
            margin-top: 40px;
        }

        .footer_list ul {
            font-size: 1.2rem;
            border-top: 1px dotted #333;
        }

        .footer_list ul li {
            border-bottom: 1px dotted #333;
        }

        .footer_list ul li a, a:link a:visited {
            display: block;
            color: #fff;
            background: url(../images/list_mk002.svg) no-repeat 5px center;
            background-size: 14px;
            padding: 14px 10px 14px 21px;
        }

        .footer_list ul li a:hover {
            background-color: #222;
        }

        .footer_list ul li a img {
            width: 14px;
            margin-left: 7px;
            vertical-align: middle;
            padding-bottom: 2px;
        }

        .f_nav001 {
            display: none !important;
        }

        .footer_sp02 {
            width: 92%;
            margin: 0 auto;
            padding-top: 40px;
        }

        .footer_sp02 p {
            width: 100px;
            margin: 0 auto;
        }

        p.copy {
            text-align: center;
            padding-top: 40px;
            font-size: 1.0rem;
            color: #fff;
            line-height: 1.0;
            letter-spacing: 0.1em;
        }

        /* ############################# footer_sp ############################# */

    }


    .mb_20px {
        margin-bottom: 20px;
    }

    .mb_30px {
        margin-bottom: 30px;
    }

    .mb_40px {
        margin-bottom: 40px;
    }

    .b_none {
        border: none !important;
    }

    .right {
        text-align: right;
    }

    .center {
        text-align: center;
    }

    .c_black01 {
        color: #111;
    }

    .c_black02 {
        color: #111;
        font-weight: bold;
    }

}

/* ############################# btn_style ############################# */


.sp {
    display: none;
}