@charset "UTF-8";
@keyframes zoomUp {
    0% {
        transform: scale(1)
    }
    100% {
        transform: scale(1.15)
    }
}
.swiper-slide-prev .slide-img {
    animation: zoomUp 10s linear 0s 1 normal both
}
.box {
    opacity: 0
}
.fadeUp {
    animation-name: fadeUpAnime;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0
}
@keyframes fadeUpAnime {
    from {
        opacity: 0;
        transform: translateY(100px)
    }
    to {
        opacity: 1;
        transform: translateY(0)
    }
}
@keyframes fadeInAnime {
    from {
        opacity: 0
    }
    to {
        opacity: 1
    }
}
@media all and (min-width:751px) {
    a[href^="tel:"] {
        pointer-events: none
    }
    .wrapper {
        padding: 12rem 0 0 0;
        background: #fefaef
    }
    .headerfix {
        position: fixed;
        top: 0;
        z-index: 100;
        width: 100%
    }
    header {
        width: 100%;
        display: flex;
        align-items: center;
        background: #fff;
        height: 12rem
    }
    .header1 {
        width: 800px;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: center
    }
    .header2 {
        width: 100%
    }
    .header2 h1 {
        width: 100%;
        text-align: center
    }
    .header2 h1 a img {
        width: auto;
        height: 7rem
    }
    .header3 {
        width: 260px;
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start
    }
    .header4 {
        width: 100%;
        text-align: center;
        margin: 0 0 15px 0
    }
    .header4 a {
        width: 100%;
        display: block;
        font-size: 4rem;
        color: #0050a3;
        font-weight: 900;
        line-height: 1
    }
    .header4 a span::before {
        content: "";
        background: url(../images/ic_tel.svg);
        display: inline-block;
        width: 3rem;
        height: 3rem;
        margin: 0 8px 0 0;
        vertical-align: bottom
    }
    .header5 {
        width: 100%;
        text-align: center;
        font-size: 1.4rem;
        font-weight: 500;
        color: #0050a3
    }
    .header6 {
        width: 21.5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between
    }
    .header7 {
        display: inline-block;
        font-size: 4rem;
        font-weight: 900;
        margin: 0 3px;
        color: #ff8e1a
    }
    .header8 {
        width: 8rem;
        text-align: center
    }
    .header8 span {
        display: inline-block;
        text-align: center;
        background: #f5f5f5;
        padding: 5px 5px 5px;
        line-height: 1;
        width: 100%;
        color: #464646
    }
    .header9 {
        width: calc(100% - 9rem);
        font-weight: 700
    }
    .header10 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: center
    }
    .header11 {
        width: 8rem;
        text-align: center
    }
    .header11 span {
        display: inline-block;
        text-align: center;
        background: #fff2f2;
        padding: 5px 5px 5px;
        line-height: 1;
        width: 100%;
        color: #f36666
    }
    .header12 {
        width: calc(100% - 9rem);
        color: #f36666;
        font-weight: 700
    }
    .header13 {
        width: 100%;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin: 0 0 7px 0
    }
    .header14 {
        width: 6rem
    }
    .header14 span {
        display: inline-block;
        text-align: center;
        font-size: 1.5rem;
        letter-spacing: 0;
        font-weight: 500
    }
    .header15 {
        text-align: center
    }
    .header15 a {
        width: 100%;
        display: block;
        font-size: 2.5rem;
        color: #000;
        font-weight: 900;
        line-height: 1
    }
    .header15 a span::before {
        content: "";
        background: url(../images/ic_tel.svg);
        display: inline-block;
        width: 1.8rem;
        height: 1.8rem;
        margin: 0 3px 0 0;
        vertical-align: middle
    }
    .header16 {
        text-align: center
    }
    .header16 a {
        width: 100%;
        display: block;
        font-size: 2.5rem;
        color: #e9618d;
        font-weight: 900;
        line-height: 1
    }
    .header16 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 1.8rem;
        height: 1.8rem;
        margin: 0 3px 0 0;
        vertical-align: middle
    }
    .header17 {
        color: #e9618d
    }
    .header18 {
        width: 10rem
    }
    .header18 span {
        display: inline-block;
        text-align: center;
        font-size: 2.2rem;
        letter-spacing: .3rem;
        font-weight: 500;
        width: 100%;
        color: #fff;
        background: #f1af2d;
        padding: 3px 0;
        font-family: YakuHanJP_Narrow, 'Zen Maru Gothic', sans-serif;
        line-height: 1.6;
        border-radius: 9px 2px 9px 2px
    }
    .header19 {
        width: 10rem
    }
    .header19 span {
        display: inline-block;
        text-align: center;
        font-size: 2.2rem;
        letter-spacing: .2rem;
        font-weight: 500;
        width: 100%;
        color: #fff;
        background: #4099d5;
        padding: 3px 0;
        font-family: YakuHanJP_Narrow, 'Zen Maru Gothic', sans-serif;
        line-height: 1.6;
        border-radius: 9px 2px 9px 2px
    }
    nav {
        text-align: center;
        width: 100%;
        padding: 1.5rem 0;
        background: #fff
    }
    nav ul {
        position: relative;
        list-style: none;
        display: flex;
        justify-content: center;
        margin: 0 auto;
        border-radius: 6px;
        flex-wrap: wrap
    }
    nav ul li {
        display: inline-block;
        border-left: 2px solid #00347c;
        border-right: 2px solid #00347c
    }
    nav ul li+li {
        border-left: 0;
        border-right: 2px solid #00347c
    }
    nav ul ul {
        display: block
    }
    nav ul li a {
        position: relative;
        display: block;
        text-decoration: none;
        color: #00347c;
        padding: .1rem 1.5rem;
        transition: all .5s;
        font-size: 1.6rem;
        letter-spacing: .02rem;
        font-weight: 700;
        border-radius: 3px;
        margin: .8rem .7rem
    }
    nav ul li li a {
        padding: 10px
    }
	
	/* ▼ メニュー文字を常に縦横センターにする ▼ */
	nav ul li {
  		display: flex;          /* <li> 自体をフレックスアイテムに */
  		align-items: center;    /* 子要素（<a>）を縦中央に */
	}
	nav ul li a {
  		display: flex;          /* <a> もフレックスにしておくと安心 */
  		flex-direction: column; /* <br> 改行をそのまま活かす */
  		justify-content: center;/* 文字を縦中央に */
  		align-items: center;    /* （お好み）横も中央に */
  		padding: 0 1.2rem;      /* 上下の余白は Flex 化で不要になるので左右だけ */
  		margin: .8rem .7rem;    /* 既存の余白はそのままでも OK */
	}
	
    .mainimg_w {
        position: relative;
        width: 100%
    }
    .slick_box {
        background: rgb(255 255 255 / 80%);
        width: 580px;
        position: absolute;
        right: 100px;
        padding: 20px 30px 30px;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        z-index: 10;
        top: 100px
    }
    .slick_box1 {
        width: 100%;
        text-align: center;
        padding: 0 0 10px 0;
        letter-spacing: .3rem;
        font-size: 1.8rem;
        font-weight: 500
    }
    .slick_box2 {
        padding: 0 0 10px 0;
        width: 100%
    }
    .slick_box2 img {
        width: 100%
    }
    .slick_box3 {
        width: 100%;
        font-size: 1.5rem;
        text-align: center
    }
    .slick_box3 span {
        color: #f55656
    }
    .slick_box4 {
        width: 100%;
        text-align: center;
        padding: 0;
        letter-spacing: .1rem;
        font-size: 1.6rem;
        color: #191e5f
    }
    .slick_box5 {
        width: 100%;
        text-align: center;
        margin: 0 0 20px 0
    }
    .slick_box5 a {
        color: #363a5b;
        display: inline-block;
        border-radius: 100px;
        font-weight: 700;
        line-height: 1;
        font-size: 4rem;
        font-family: YakuHanJP_Narrow, 'Zen Maru Gothic', sans-serif
    }
    .slick_box5 span::before {
        content: "";
        background: url(../images/ic_tel.svg) no-repeat;
        width: 2.8rem;
        height: 2.8rem;
        display: inline-block;
        background-size: contain;
        vertical-align: middle;
        margin: 0 10px 0 0
    }
    .slick_box6 {
        width: 100%;
        text-align: center;
        margin: 0 0 15px 0;
        font-size: 1.5rem;
        color: #222
    }
    .slick_box6 a {
        display: inline-block;
        border-radius: 5px;
        background: #fff;
        color: #5fc6d0;
        text-align: center;
        padding: 15px 30px;
        transition: .6s;
        position: relative;
        font-size: 1.6rem;
        width: 250px;
        box-shadow: 0 0 10px 0 #bfe4e4;
        font-weight: 700
    }
    .slick_box6 a:active, .slick_box6 a:hover {
        transform: translate(0, -3px);
        opacity: .9
    }
    .slick_box6 span::before {
        content: "";
        position: absolute;
        left: 20px;
        font-size: 1rem !important;
        top: 50%;
        transform: translateY(-50%) translateX(-50%);
        margin: auto;
        color: #aedce0
    }
    .slick_box7 {
        width: 25%
    }
    .slick_box7 a {
        display: block;
        background: #00479b;
        background: linear-gradient(120deg, #1ab1f5 0, #0076c5 100%);
        color: #fff;
        text-align: center;
        border-radius: 3px;
        padding: 3px 0;
        font-size: 1.4rem;
        transition: .3s;
        box-shadow: 3px 3px 10px #a5c2e7
    }
    .slick_box7 a:active, .slick_box7 a:hover {
        opacity: .8
    }
    .slick_box8 {
        width: 100%;
        text-align: center;
        margin: 0 0 20px 0;
        font-size: 1.5rem;
        line-height: 1.6
    }
    .slick_box9__w {
        width: 40rem;
        margin: 0 auto 0;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        align-items: center;
        background: #fff;
        padding: 1.5rem 2.5rem;
        border: 1px solid #595757;
        border-radius: 100px
    }
    .slick_box9 {
        width: 100%;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin: 0 0 15px 0;
        align-items: center
    }
    .slick_box9:last-child {
        margin: 0
    }
    .slick_box10 {
        width: 10rem
    }
    .slick_box10 span {
        display: inline-block;
        text-align: center;
        font-size: 1.6rem;
        letter-spacing: 0;
        font-weight: 500;
        color: #000
    }
    .slick_box11 {
        text-align: center
    }
    .slick_box11 a {
        width: 100%;
        display: block;
        font-size: 3rem;
        color: #000;
        font-weight: 900;
        line-height: 1
    }
    .slick_box11 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 2.2rem;
        height: 2.2rem;
        margin: 0 .5rem 0 0;
        vertical-align: bottom
    }
    .slick_box12 {
        text-align: center
    }
    .slick_box12 a {
        width: 100%;
        display: block;
        font-size: 3rem;
        color: #e9618d;
        font-weight: 900;
        line-height: 1
    }
    .slick_box12 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 2.2rem;
        height: 2.2rem;
        margin: 0 7px 0 0;
        vertical-align: middle
    }
    .slick_box13 {
        color: #e9618d
    }
    .about__w {
        width: 100%
    }
    .about1 {
        width: 1000px;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 8rem 0 10rem
    }
    .about2 {
        width: 100%;
        text-align: center;
        margin-bottom: 5rem;
        background: url(../images/line4.png) center bottom no-repeat;
        padding-bottom: 3rem
    }
    .about2 h2 {
        font-size: 3.5rem;
        font-weight: 800;
        letter-spacing: .3rem;
        color: #000
    }
    .about3 {
        width: 100%
    }
    .about4, .about4-2 {
        width: 800px;
        border-radius: 10px;
        margin: 0 auto 5rem;
        font-size: 1.7rem;
        line-height: 2.5;
        padding: 0 3rem
    }
    .about4 a {
        width: 800px;
        color: #ed6a02;
        border-bottom: 1px solid #ed6a02
    }
    .about5 {
        width: 100%;
        text-align: center;
        margin-top: 4rem
    }
    .about5 a {
        display: inline-block;
        color: #fff;
        border-radius: 10px;
        text-align: center;
        font-size: 1.8rem;
        background: #00347c;
        width: 380px;
        position: relative
    }
    .about5 a span {
        width: 100%;
        height: 100%;
        display: block;
        position: relative;
        padding: 3rem 2rem
    }
    .about5-1 a span {
        padding: 1.55rem 0 1.55rem 0 !important
    }
    .about5 a span::after {
        position: absolute;
        top: 50%;
        right: 13px;
        width: 8px;
        height: 8px;
        margin-top: -4px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        content: "";
        display: inline-block;
        vertical-align: middle
    }
    .about6 {
        width: 800px;
        margin: 0 auto 5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between
    }
    .about7 {
        width: 48%
    }
    .about7 a {
        position: relative;
        text-align: center;
        width: 100%;
        display: inline-block;
        border-radius: 10px;
        padding: 3rem 0 3rem 0;
        color: #00347c;
        background: #fff9b5;
        border: 2px solid #00347c;
        font-size: 1.6rem;
        margin-right: 2.5%;
        margin-bottom: 2rem;
        letter-spacing: 0
    }
    .about7-1 a {
        padding: 1.7rem 0 1.7rem 0 !important
    }
    .about7 a span::after {
        position: absolute;
        top: 50%;
        right: 13px;
        width: 8px;
        height: 8px;
        margin-top: -4px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        border-top: 2px solid #00347c;
        border-right: 2px solid #00347c;
        content: "";
        display: inline-block;
        vertical-align: middle
    }
    .about7:nth-child(2n) {
        margin-right: 0
    }
    .about8 {
        width: 100%;
        text-align: center;
        margin-top: 2rem
    }
    .about8 a {
        color: #ed6a02;
        border-bottom: 1px solid #ed6a02
    }
    .about9 {
        width: 100%;
        margin-top: 5rem
    }
    .about9 table {
        width: 740px;
        margin: 0 auto;
        border: 1px solid #eee
    }
    .about9 table th {
        width: 12rem;
        border: 1px solid #eee;
        padding: 2rem;
        text-align: center;
        background: #f0f0f0;
        vertical-align: middle
    }
    .about9 table td {
        border: 1px solid #eee;
        padding: 2rem;
        background: #fff
    }
    .about9 table td a {
        color: #ed6a02;
        border-bottom: 1px solid #ed6a02
    }
    .about10 {
        width: 100%
    }
    .about10::before {
        content: "令和５年度 投票 受付中";
        display: block;
        text-align: center;
        padding: .3rem 2rem;
        background: #ed6a02;
        color: #fff;
        width: 22rem;
        margin: 0 auto;
        font-size: 1.7rem;
        border-radius: 100px
    }
    .about11 {
        width: 1000px;
        margin: 0 auto 7rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 6rem 0;
        background: #fff;
        border: 2px solid #00a6d8;
        border-radius: 10px
    }
    .about12 {
        width: 100%;
        text-align: center;
        margin-bottom: 4rem;
        background: url(../images/line2.png) center bottom no-repeat;
        padding-bottom: 5rem;
        font-size: 3rem;
        font-weight: 700
    }
    .about12 a {
        text-decoration: underline !important
    }
    .about12 a:hover {
        color: #09c !important
    }
    .about13 {
        width: 100%;
        margin: 0 auto 5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        padding: 0 50px
    }
    .about14 a {
        width: 760px;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        font-size: 2.2rem;
        border: 1px solid #eee;
        border-radius: 10px;
        box-shadow: inset 0 0 20px #ccc;
        font-weight: 700;
        padding: 4rem 0;
        margin: 0 auto 3rem
    }
    .about14 a:hover {
        width: 760px;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        font-size: 2.2rem;
        border: 1px solid #eee;
        border-radius: 10px;
        box-shadow: inset 0 0 20px #09c;
        font-weight: 700;
        padding: 4rem 0;
        margin: 0 auto 3rem
    }
    .about15 {
        width: 100%;
        text-align: center
    }
    .about15 img {
        width: 500px;
        text-align: center
    }
    .about16 {
        width: 100%;
        margin: 0 auto 5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 0 50px
    }
    .about17 {
        position: relative;
        width: 100%;
        font-size: 1.7rem;
        font-weight: 700;
        padding-left: 1.5rem;
        margin-bottom: 2rem;
        z-index: 1
    }
    .about17::before {
        content: '';
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 40px;
        height: 100%;
        background: linear-gradient(to right, #00a0e9, #fff);
        border-left: 5px solid #000;
        z-index: -1
    }
    .about18 {
        width: 100%;
        line-height: 2;
        padding: 0 2rem;
		text-align: justify;
    }
    .about18-2 {
        width: 100%;
        font-size: 110%;
        line-height: 2;
        padding: 0 7rem;
		text-align: justify;
    }
    .about19 {
        width: 100%;
        margin: 0 auto 5.5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        padding: 0 50px
    }
    .about20 {
        width: 400px;
        margin-right: 50px
    }
    .about20:last-child {
        width: 400px;
        margin-right: 0
    }
    .about20 figcaption {
        padding-top: .5rem;
        font-size: 90%
    }
    .about20 p {
        width: 100%;
        display: inline-block;
        text-align: center;
        font-size: 1.4rem
    }
    .about21 {
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 0 50px
    }
    .about22 {
        width: 100%;
        font-size: 1.7rem;
        font-weight: 700;
        padding-left: 1.5rem;
        border-left: 5px solid #000;
        margin-bottom: 2rem
    }
    .about23 {
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start
    }
    .about24 {
        width: 180px;
        margin-right: 2rem
    }
    .about25 {
        width: 48%;
        display: inline-block;
        border-radius: 10px;
        padding: 1rem 0 1rem 3rem;
        background: #fff;
        font-size: 1.6rem;
        margin-right: 2.5%;
        margin-bottom: 2rem;
        letter-spacing: 0
    }
    .about25:nth-child(2n) {
        margin-right: 0
    }
    .about26 {
        width: 100%
    }
    .about26 span {
        display: inline-block;
        text-align: center;
        background: #000;
        color: #fff;
        padding: .1rem 2rem;
        border-radius: 100px;
        margin-top: 1rem;
        font-size: 1.3rem
    }
    footer {
        width: 100%
    }
    .footer1 {
        width: 1200px;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: center
    }
    .footer1 img {
        width: 100%
    }
    .footer2 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        color: #fff;
        text-align: center
    }
    .footer3 {
        width: 100%;
        font-size: 1.8rem;
        margin-bottom: 2rem;
        font-weight: 400
    }
    .footer4 {
        width: 100%;
        margin-bottom: 1.5rem;
        letter-spacing: .2rem
    }
    .footer5 a {
        font-size: 3rem;
        color: #fff;
        font-weight: 500;
        font-family: YakuHanJP, Asap, sans-serif
    }
    .footer__w {
        width: 100%;
        background: #3e3a39;
        position: relative
    }
    .footer__w p {
        font-size: 1.2rem;
        text-align: center;
        color: #fff;
        padding: 0 0 50px 0
    }
    .footer_logo {
        width: 280px;
        margin: 0 auto;
        padding: 80px 0 70px
    }
    .footer_logo img {
        width: 100%
    }
    .btn_pagetop {
        position: fixed;
        bottom: 1rem;
        right: 20px;
        z-index: 99
    }
    .btn_pagetop a {
        width: 100px;
        display: block;
        opacity: .9;
        transition: all .3s ease
    }
    .btn_pagetop a:hover {
        text-decoration: none;
        opacity: .5
    }
    .btn_pagetop a img {
        width: 100%;
        display: block
    }
    .h_about {
        background: url(../images/subtitle_bg3.jpg) no-repeat;
        background-size: cover;
        width: 100%
    }
    .h_about h1 span::after {
        content: "about";
        display: block;
        font-size: 1.3rem;
        letter-spacing: .2rem;
        line-height: 1
    }
    .img100 {
        width: 600px;
        margin: 0 auto
    }
    .img100 img {
        width: 100%
    }
    .swiper__w {
        width: 100%;
        position: relative;
        overflow: hidden;
        height: 600px;
        background: #e8dcc1
    }
    .swiper {
        width: 100%;
        height: 600px;
        position: relative
    }
    .swiper-slide {
        text-align: center;
        font-size: 18px;
        background: #fff;
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: cente
    }
    .swiper-slide img {
        display: block;
        width: 100vw;
        height: 100%;
        object-fit: cove
    }
    .swiper_txt {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        z-index: 10
    }
    .swiper_txt1 {
        width: 100%
    }
    .swiper_txt2 {
        width: 100%;
        text-align: center
    }
    .swiper_txt2 img {
        width: 669px
    }
    .swiper_txt3 {
        width: 100%;
        text-align: center
    }
    .swiper_txt3 a {
        display: inline-block;
        text-align: center;
        justify-content: center;
        align-items: center;
        transition: .5s;
        font-weight: 400;
        color: #fff;
        font-size: 1.8rem;
        line-height: 1.4;
        letter-spacing: .1rem;
        background: #e94919;
        border-radius: 3px;
        padding: 1.8rem 6rem
    }
    .swiper_txt3 a span::before {
        content: "";
        background: url(../images/ic_arrow.svg);
        display: inline-block;
        width: 1rem;
        height: 1rem;
        margin-right: .8rem
    }
    .swiper_txt4 {
        width: 100%;
        margin-bottom: 2rem
    }
    .swiper_txt4 img {
        display: block;
        width: 70%;
        padding: 2rem 3rem;
        border: 2px solid #009d95;
        margin: 0 auto;
        border-radius: 5px;
        box-shadow: 0 5px 0 #009d95
    }
    .swiper_txt4 a span::before {
        content: "＼ 同日開催 ／";
        display: block;
        font-size: 2rem;
        color: #009d95;
        text-align: center;
        letter-spacing: .2rem;
        font-weight: 700;
        margin-bottom: 1rem
    }
    .swiper-button-prev {
        display: none !important
    }
    .swiper_txt5 {
        font-size: 1.5rem;
        margin-top: 1rem;
        margin-bottom: .5rem;
        width: 100%;
        text-align: center;
        line-height: 1.2;
        color: #e94919
    }
    .swiper_txt6 {
        font-size: 1.8rem;
        width: 100%;
        text-align: center
    }
    .oubo-btn {
        margin-top: 10px
    }
    .hyosho-container {
        display: flex;
        justify-content: space-between;
        padding-top: 45px;
        padding-bottom: 20px
    }
    .hyosho-box {
        position: relative;
        width: 48%;
        margin: 0 auto;
        background-color: #fefaef;
        border: 1px solid #000;
        box-shadow: 2px 2px 10px rgba(0, 0, 0, .1)
    }
    .hyosho-box ol {
        list-style: none;
        padding-left: 1em;
        text-indent: -1em;
        margin: 40px 20px 10px 20px
    }
    .hyosho-header {
        position: absolute;
        top: -30px;
        left: 14px;
        background-color: #fefaef;
        border: 1px solid #000;
        color: #000;
        padding: 18px 20px;
        text-align: center;
        display: inline-block;
        border-radius: 30px;
        line-height: 1.2em;
        width: 92%;
        height: 60px
    }
/*
	.hyosho-container .hyosho-box:first-of-type .hyosho-header {
        padding-top: 18px
    }
    .hyosho-container .hyosho-box .hyosho-header {
        padding-top: 18px
    }
*/
    .hyosho-header li {
        margin-bottom: 20px
    }
    #g-nav ul li a {
        font-size: 1.35rem;
        height: 5rem
    }
    #g-nav ul li:nth-child(3) a span {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 100%
    }
}
@media all and (max-width:1250px) {
    .header_txt {
        color: #116cba;
        position: absolute;
        left: 20px;
        width: calc(100% - 820px)
    }
}
@media all and (max-width:750px) {
    header {
        display: flex;
        justify-content: space-between;
        width: 100%
    }
    .header__w {
        display: flex;
        justify-content: center;
        width: 100%
    }
    .header_logo {
        text-align: center;
        width: calc(100% - 100px);
        margin: 0 auto
    }
    .header_logo h1 {
        width: calc(60%);
        margin: 0 aut
    }
    .header_logo img {
        display: inline-block;
        width: 100%
    }
    .header_txt {
        width: 40vw;
        margin: 0 0 0 22vw
    }
    .header_txt img {
        width: 100%
    }
    .mainimg_w {
        position: relative;
        height: 90vh;
        background-position: top center !important;
        background-size: contain !important;
        text-align: center;
        background-repeat: no-repeat !important
    }
    .slick_box {
        background: #fff;
        width: 100%;
        padding: 2vw 5vw 4vw;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        margin: 5vw auto 0
    }
    .slick_box0 {
        width: 100%;
        text-align: center;
        padding: 0 0 2vw 0;
        letter-spacing: .1rem;
        font-size: 1.3rem;
        color: #484542
    }
    .slick_box0 span {
        font-size: 1.5rem;
        color: #ffa37c;
        font-weight: 700
    }
    .slick_box1 {
        width: 100%;
        text-align: center;
        padding: 0 0 2vw 0;
        letter-spacing: .1rem;
        font-size: 1.5rem;
        color: #104c9e;
        font-weight: 700
    }
    .slick_box2 {
        padding: 0 0 2vw 0;
        width: 100%
    }
    .slick_box2 img {
        width: 100%
    }
    .slick_box3 {
        width: 100%;
        padding: 0;
        font-size: 1.2rem;
        text-align: center
    }
    .slick_box3 span {
        color: #f55656
    }
    .slick_box4 {
        width: 100%;
        text-align: center;
        padding: 0 0 1vw 0;
        letter-spacing: .1rem;
        font-size: 1.3rem;
        color: #191e5f
    }
    .slick_box5 {
        width: 100%;
        text-align: center;
        padding: 0 0 2vw 0
    }
    .slick_box5 a {
        color: #363a5b;
        display: inline-block;
        border-radius: 100px;
        font-weight: 700;
        font-family: YakuHanJP_Narrow, 'Zen Maru Gothic', sans-serif;
        line-height: 1;
        letter-spacing: .2rem;
        font-size: 2rem
    }
    .slick_box5 span::before {
        content: "";
        background: url(../images/ic_tel.svg) no-repeat;
        width: 1.7rem;
        height: 1.7rem;
        display: inline-block;
        background-size: contain;
        margin: 0 1.5vw 0 0;
        vertical-align: botto
    }
    .slick_box6 {
        margin: 0 0 3vw 0
    }
    .slick_box7 {
        width: 100%;
        margin: 0 0 2vw 0
    }
    .slick_box7 a {
        display: block;
        background: #00479b;
        background: linear-gradient(120deg, #1ab1f5 0, #0076c5 100%);
        color: #fff;
        text-align: center;
        border-radius: 3px;
        padding: 1vw 1vw;
        font-size: 1.2rem;
        transition: .3s;
        box-shadow: 3px 3px 10px #a5c2e7;
        width: 30vw;
        margin: 0 auto
    }
    .slick_box7 a:active, .slick_box7 a:hover {
        opacity: .7
    }
    .slick_box8 {
        margin: 0 0 2vw 0
    }
    .slick_box9__w {
        width: 100%;
        margin: 3vw auto;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        align-items: center;
        background: #f5f5f5;
        padding: 3vw 3vw
    }
    .slick_box9 {
        width: 100%;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        margin: 0 0 3vw 0;
        align-items: center
    }
    .slick_box9:last-child {
        margin: 0
    }
    .slick_box10 {
        width: 10rem
    }
    .slick_box10 span {
        display: inline-block;
        text-align: center;
        font-size: 1.3rem;
        letter-spacing: 0;
        font-weight: 500
    }
    .slick_box11 {
        text-align: center
    }
    .slick_box11 a {
        width: 100%;
        display: block;
        font-size: 2rem;
        color: #000;
        font-weight: 900;
        line-height: 1
    }
    .slick_box11 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 1.7rem;
        height: 1.7rem;
        margin: 0 1vw 0 0;
        vertical-align: middle
    }
    .slick_box12 {
        text-align: center
    }
    .slick_box12 a {
        width: 100%;
        display: block;
        font-size: 1.8rem;
        color: #e9618d;
        font-weight: 900;
        line-height: 1
    }
    .slick_box12 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 1.5rem;
        height: 1.5rem;
        margin: 0 7px 0 0;
        vertical-align: middle
    }
    .slick_box13 {
        color: #e9618d
    }
    .about__w {
        width: 100%
    }
    .about1 {
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 6rem 0 4rem
    }
    .about2 {
        width: 100%;
        text-align: center;
        margin-bottom: 3rem;
        background: url(../images/line4.png) center bottom no-repeat;
        background-size: 90%;
        padding: 0 2rem 2.5rem
    }
    .about2 h2 {
        font-size: 2rem;
        font-weight: 800;
        letter-spacing: .15rem;
        color: #000
    }
    .about3 {
        width: 100%
    }
    .about4, .about4-2 {
        width: 100%;
        border-radius: 10px;
        margin: 0 auto 3rem;
        line-height: 2.5;
        padding: 0 3rem
    }
    .about4 a {
        width: 100%;
        color: #ed6a02;
        border-bottom: 1px solid #ed6a02
    }
    .about5 {
        width: 100%;
        text-align: center;
        margin-top: 3rem
    }
    .about5 a {
        display: inline-block;
        color: #fff;
        border-radius: 10px;
        background: #00347c;
        text-align: center;
        font-size: 1.5rem;
        width: 100%;
        position: relative
    }
    .about5 a span {
        width: 100%;
        height: 100%;
        display: block;
        position: relative;
        padding: 3rem 2rem
    }
    .about5-1 a span {
        padding: 1.8rem 0 1.8rem 0 !important
    }
    .about5 a span::after {
        position: absolute;
        top: 50%;
        right: 13px;
        width: 8px;
        height: 8px;
        margin-top: -4px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        content: "";
        display: inline-block;
        vertical-align: middle
    }
    .about5a a span::after {
        content: "";
        background: url(../images/arrow1.svg);
        width: 1.7rem;
        height: 1.7rem;
        display: inline-block;
        position: absolute;
        top: 3.5rem;
        right: 2rem
    }
    .about6 {
        width: 95%;
        margin: 0 auto 5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between
    }
    .about7 {
        width: 100%
    }
    .about7 a {
        position: relative;
        color: #00347c;
        width: 100%;
        display: inline-block;
        border-radius: 10px;
        padding: 2rem;
        background: #fff9b5;
        font-size: 1.5rem;
        margin-bottom: 2rem;
        letter-spacing: 0;
        border: 2px solid #00347c
    }
    .about7 a span::after {
        position: absolute;
        top: 50%;
        right: 13px;
        width: 8px;
        height: 8px;
        margin-top: -4px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        border-top: 2px solid #00347c;
        border-right: 2px solid #00347c;
        content: "";
        display: inline-block;
        vertical-align: middle
    }
    .sp_no {
        display: none
    }
    .about7:nth-child(2n) {
        margin-right: 0
    }
    .about8 {
        width: 100%;
        text-align: center;
        margin-top: 1rem;
        padding: 0 2rem;
        font-size: 1.3rem
    }
    .about8 a {
        color: #ed6a02;
        border-bottom: 1px solid #ed6a02
    }
    .about9 {
        width: 100%;
        margin-top: 5rem
    }
    .about9 table {
        width: 90%;
        margin: 0 auto;
        border: 1px solid #eee
    }
    .about9 table th {
        width: 10rem;
        border: 1px solid #eee;
        padding: 2rem 1rem;
        text-align: center;
        background: #f0f0f0;
        vertical-align: middle
    }
    .about9 table td {
        border: 1px solid #eee;
        padding: 2rem;
        background: #fff
    }
    .about9 table td a {
        color: #ed6a02;
        border-bottom: 1px solid #ed6a02
    }
    .about10 {
        width: 100%
    }
    .about10::before {
        content: "令和５年度 投票 受付中";
        display: block;
        text-align: center;
        padding: .3rem 2rem;
        background: #ed6a02;
        color: #fff;
        width: 18rem;
        margin: 0 auto .7rem;
        font-size: 1.4rem;
        border-radius: 100px
    }
    .about11 {
        width: 95%;
        margin: 0 auto 7rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 3rem 0;
        background: #fff;
        border: 2px solid #00a6d8;
        border-radius: 10px
    }
    .about11:last-child {
        width: 95%;
        margin: 0 auto 0;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 3rem 0;
        background: #fff;
        border: 2px solid #00a6d8;
        border-radius: 10px
    }
    .about12 {
        width: 100%;
        text-align: center;
        margin-bottom: 4rem;
        background: url(../images/line2.png) center bottom no-repeat;
        padding: 2rem 2rem 7rem 2rem;
        font-size: 2rem;
        font-weight: 700
    }
    .about12 a {
        text-decoration: underline !important
    }
    .about12 a:hover {
        color: #09c !important
    }
    .about13 {
        width: 100%;
        margin: 0 auto 5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 0 2rem
    }
    .about14 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        font-size: 1.6rem;
        border: 1px solid #eee;
        border-radius: 10px;
        box-shadow: inset 0 0 20px #ccc;
        font-weight: 700;
        padding: 4rem 1rem;
        margin: 0 auto 3rem
    }
    .about15 {
        width: 100%;
        text-align: center
    }
    .about15 img {
        width: 100%;
        text-align: center
    }
    .about16 {
        width: 100%;
        margin: 0 auto 5rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 0 2rem
    }
    .about17 {
        position: relative;
        width: 100%;
        font-size: 1.7rem;
        font-weight: 700;
        padding-left: 1.5rem;
        margin-bottom: 2rem;
        z-index: 1
    }
    .about17::before {
        content: '';
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 40px;
        height: 100%;
        background: linear-gradient(to right, #00a0e9, #fff);
        border-left: 5px solid #000;
        z-index: -1
    }
    .about18 {
        width: 100%;
        line-height: 2;
        padding: 0 2rem;
		text-align: justify;
    }
    .about19 {
        width: 100%;
        margin: 0 auto 7rem;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        padding: 0 50px
    }
    .about20 {
        width: 100%;
        margin-bottom: 3rem
    }
    .about20 figcaption {
        padding-top: .5rem;
        font-size: 90%
    }
    .about20 img {
        width: 100%;
        text-align: center
    }
    .about20:last-child {
        width: 100%;
        margin-bottom: 0
    }
    .about20 p {
        width: 100%;
        display: inline-block;
        text-align: center
    }
    .about21 {
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 0 50px
    }
    .about22 {
        width: 100%;
        font-size: 1.7rem;
        font-weight: 700;
        padding-left: 1.5rem;
        border-left: 5px solid #000;
        margin-bottom: 2rem
    }
    .about23 {
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start
    }
    .about24 {
        width: 30%;
        margin-right: 5%
    }
    .about24:last-child {
        width: 30%;
        margin-right: 0
    }
    .about25 {
        width: 100%;
        display: inline-block;
        border-radius: 10px;
        padding: 1rem;
        background: #fff;
        font-size: 1.5rem;
        margin-bottom: 2rem;
        letter-spacing: 0
    }
    .about25:nth-child(2n) {
        margin-right: 0
    }
    .about26 {
        width: 100%
    }
    .about26 span {
        display: inline-block;
        text-align: center;
        background: #000;
        color: #fff;
        padding: .1rem 2rem;
        border-radius: 100px;
        margin-top: .5rem;
        font-size: 1.2rem
    }
    footer {
        width: 100%
    }
    .footer1 {
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: center
    }
    .footer1 img {
        width: 100%
    }
    .footer2 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        color: #fff;
        text-align: center
    }
    .footer3 {
        width: 100%;
        font-size: 1.4rem;
        margin-bottom: 2rem;
        font-weight: 400
    }
    .footer4 {
        width: 100%;
        margin-bottom: 1.5rem;
        letter-spacing: .05rem
    }
    .footer5 a {
        font-size: 2rem;
        color: #fff;
        font-weight: 500;
        font-family: YakuHanJP, Asap, sans-serif
    }
    .footer__w {
        width: 100%;
        background: #3e3a39;
        position: relative
    }
    .footer__w p {
        font-size: 1rem;
        text-align: center;
        color: #fff;
        padding: 0 0 2vw 0
    }
    .headerfix {
        background: #fff;
        position: fixed;
        top: 0;
        z-index: 19;
        width: 100%
    }
    header {
        width: 100%;
        height: 7rem
    }
    .header1 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center
    }
    .header2 {
        width: 100%
    }
    .header2 h1 {
        width: 100%;
        text-align: center
    }
    .header2 h1 a {
        height: 3.2rem;
        align-items: center
    }
    .header2 h1 a img {
        height: 5rem
    }
    .header3 {
        width: 26rem;
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        align-items: center;
        margin: 0 auto 0
    }
    .header4 {
        width: 100%;
        text-align: center;
        margin: 0 0 2vw 0
    }
    .header4 a {
        width: 100%;
        display: block;
        font-size: 3rem;
        color: #fff;
        font-weight: 900;
        line-height: 1
    }
    .header4 a span::before {
        content: "";
        background: url(../images/ic_tel.svg);
        display: inline-block;
        width: 2.1rem;
        height: 2.1rem;
        margin: 0 1.5vw 0 0;
        vertical-align: bottom
    }
    .header5 {
        width: 100%;
        text-align: center;
        font-size: 1.3rem;
        font-weight: 400;
        letter-spacing: 0;
        color: #fff
    }
    .header6 {
        width: 95%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        font-size: 1.4rem;
        font-weight: 500;
        line-height: 1.4;
        margin: 0 auto
    }
    .header7 {
        display: inline-block;
        font-size: 1.5rem;
        font-weight: 900;
        margin: 0 .1rem;
        color: #ff8e1a
    }
    .header8 {
        width: 7.5rem;
        text-align: center
    }
    .header8 span {
        display: inline-block;
        border-radius: 100px;
        text-align: center;
        background: #4dbbed;
        padding: 3px 5px 3px;
        line-height: 1;
        width: 100%;
        color: #fff;
        font-size: 1.3rem
    }
    .header9 {
        width: calc(100% - 9rem);
        color: #fff;
        font-size: 1.3rem
    }
    .header10 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: center
    }
    .header11 {
        width: 7.5rem;
        text-align: center
    }
    .header11 span {
        display: inline-block;
        border-radius: 100px;
        text-align: center;
        background: #f38aa3;
        padding: 3px 5px 3px;
        line-height: 1;
        width: 100%;
        color: #fff;
        font-size: 1.3rem
    }
    .header12 {
        width: calc(100% - 9rem);
        color: #f3a0bf;
        font-size: 1.3rem
    }
    .header13 {
        width: 100%;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        align-items: center
    }
    .header13 :last-child {
        margin: 0
    }
    .header14 {
        width: 100%;
        text-align: center;
        margin: 0 0 1vw 0
    }
    .header14 span {
        display: inline-block;
        text-align: center;
        font-size: 1.5rem;
        letter-spacing: 0;
        font-weight: 500;
        color: #fff
    }
    .header15 {
        text-align: center;
        width: 100%
    }
    .header15 a {
        width: 100%;
        display: block;
        font-size: 2.5rem;
        color: #fff;
        font-weight: 900;
        line-height: 1
    }
    .header15 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 1.8rem;
        height: 1.8rem;
        margin: 0 1vw 0 0;
        vertical-align: middle
    }
    .header16 {
        text-align: center
    }
    .header16 a {
        width: 100%;
        display: block;
        font-size: 2.5rem;
        color: #fff;
        font-weight: 900;
        line-height: 1
    }
    .header16 a span::before {
        content: "";
        background: url(../images/ic_tel2.svg);
        display: inline-block;
        width: 1.8rem;
        height: 1.8rem;
        margin: 0 1vw 0 0;
        vertical-align: middle
    }
    .header17 {
        color: #4099d5
    }
    .header18 {
        width: 3.4rem
    }
    .header18 span {
        display: inline-block;
        text-align: center;
        font-size: 1.2rem;
        letter-spacing: .005rem;
        font-weight: 500;
        width: 100%;
        color: #fff;
        background: #f1af2d;
        padding: 3px 0;
        font-family: YakuHanJP_Narrow, 'Zen Maru Gothic', sans-serif;
        line-height: 1.6;
        border-radius: 9px 2px 9px 2px
    }
    .header19 {
        width: 4.6rem
    }
    .header19 span {
        display: inline-block;
        text-align: center;
        font-size: 1.2rem;
        letter-spacing: .005rem;
        font-weight: 500;
        width: 100%;
        color: #fff;
        background: #4099d5;
        padding: 3px 0;
        font-family: YakuHanJP_Narrow, 'Zen Maru Gothic', sans-serif;
        line-height: 1.6;
        border-radius: 9px 2px 9px 2px
    }
    #g-nav {
        position: fixed;
        z-index: -1;
        display: none;
        top: 0;
        width: 100%;
        height: 100vh;
        background: rgb(54 154 219 / 95%);
        transition: all .3s
    }
    #g-nav ul {
        display: none;
        z-index: 999
    }
    #g-nav li {
        list-style: none;
        text-align: center;
        width: 95%;
        margin: 0 auto 2rem
    }
    #g-nav li a {
        color: #000;
        text-decoration: none;
        padding: 1.2rem 1rem;
        display: flex;
        text-transform: uppercase;
        letter-spacing: 0;
        font-weight: 500;
        font-size: 1.5rem;
        background: #fff;
        border-radius: 3px;
        width: 100%;
        margin: 0 auto;
        height: 7rem;
        justify-content: center;
        align-items: center;
        line-height: 1.3
    }
    .openbtn {
        position: fixed;
        z-index: 9999;
        top: 0;
        right: 0;
        cursor: pointer;
        width: 50px;
        height: 50px;
        border-radius: 0 0 0 3px
    }
    .openbtn span {
        display: inline-block;
        transition: all .4s;
        position: absolute;
        right: 1.5rem;
        height: 3px;
        border-radius: 2px;
        background-color: #2b71b0;
        width: 3rem
    }
    .openbtn span:nth-of-type(1) {
        top: 2.2rem
    }
    .openbtn span:nth-of-type(2) {
        top: 3.2rem
    }
    .openbtn span:nth-of-type(3) {
        top: 4.2rem
    }
    .h_about {
        background: url(../images/subtitle_bg5.jpg) no-repeat right center;
        background-size: cover
    }
    .h_about h1 span::after {
        content: "about";
        display: block;
        font-size: 1.3rem;
        letter-spacing: .2rem;
        line-height: 1
    }
    .s_01 {
        padding: 0 0 10vw 0
    }
    .footer_logo {
        width: 100%;
        margin: 0 auto;
        padding: 10vw 0 5vw;
        text-align: center
    }
    .footer_logo img {
        width: 60%
    }
    .btn_pagetop {
        position: fixed;
        bottom: 1rem;
        right: 1rem;
        z-index: 3;
        opacity: .9
    }
    .btn_pagetop a {
        width: 12vw;
        display: block;
        opacity: .9;
        transition: all .3s ease
    }
    .btn_pagetop a:hover {
        text-decoration: none;
        opacity: .5
    }
    .btn_pagetop a img {
        width: 100%;
        display: block
    }
    .img100 {
        width: 90%;
        margin: 0 auto
    }
    .img100 img {
        width: 100%
    }
    .wrapper {
        background: #fefaef;
        padding: 7rem 0 0 0
    }
    .swiper__w {
        width: 100%;
        position: relative;
        overflow: hidden
    }
    .swiper {
        width: 100%;
        position: relative
    }
    .swiper-slide {
        text-align: center;
        font-size: 18px;
        background: #fff;
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center
    }
    .swiper-slide img {
        display: block;
        width: 100vw;
        height: 100%;
        object-fit: cover
    }
    .swiper_txt {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        z-index: 10;
        width: 100%
    }
    .swiper_txt0 {
        padding: 7rem 3rem;
        width: 75%;
        margin: 0 auto
    }
    .swiper_txt1 {
        width: 100%
    }
    .swiper_txt2 {
        width: 100%;
        text-align: center
    }
    .swiper_txt2 img {
        width: 100%
    }
    .swiper_txt3 {
        width: 100%;
        text-align: center
    }
    .swiper_txt3 a {
        display: inline-block;
        text-align: center;
        justify-content: center;
        align-items: center;
        transition: .5s;
        font-weight: 400;
        color: #fff;
        font-size: 1.8rem;
        line-height: 1.4;
        letter-spacing: .1rem;
        background: #e94919;
        border-radius: 3px;
        padding: 1.8rem 6rem
    }
    .swiper_txt3 a span::before {
        content: "";
        background: url(../images/ic_arrow.svg);
        display: inline-block;
        width: 1rem;
        height: 1rem;
        margin-right: .8rem
    }
    .swiper_txt4 {
        width: 100%;
        margin-bottom: 2rem
    }
    .swiper_txt4 img {
        display: block;
        width: 70%;
        padding: 2rem 3rem;
        border: 2px solid #009d95;
        margin: 0 auto;
        border-radius: 5px;
        box-shadow: 0 5px 0 #009d95
    }
    .swiper_txt4 a span::before {
        content: "＼ 同日開催 ／";
        display: block;
        font-size: 2rem;
        color: #009d95;
        text-align: center;
        letter-spacing: .2rem;
        font-weight: 700;
        margin-bottom: 1rem
    }
    .swiper-button-prev {
        display: none !important
    }
    .swiper_txt5 {
        font-size: 1.5rem;
        margin-top: 1rem;
        margin-bottom: .5rem;
        width: 100%;
        text-align: center;
        line-height: 1.2;
        color: #e94919
    }
    .swiper_txt6 {
        font-size: 1.8rem;
        width: 100%;
        text-align: center
    }
    .oubo-btn {
        margin-top: 10px
    }
    .hyosho-box ol {
        list-style: none;
        padding-left: 1em;
        text-indent: -1em;
        margin: 40px 20px 10px 20px
    }
    .hyosho-container {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding-top: 45px
    }
    .hyosho-box {
        width: 100%;
        margin-bottom: 20px;
        position: relative;
        background-color: #fefaef;
        border: 1px solid #000;
        box-shadow: 2px 2px 10px rgba(0, 0, 0, .1)
    }
    .hyosho-header {
        position: absolute;
        top: -30px;
        left: 50%;
        transform: translateX(-50%);
        width: 100%;
        max-width: 95%;
        height: 60px;
        padding: 10px 20px;
        text-align: center;
        border-radius: 30px;
        background-color: #fefaef;
        border: 1px solid #000;
        color: #000
    }
    .hyosho-container .hyosho-box:first-of-type {
        margin-bottom: 50px
    }
    .hyosho-header li {
        margin-bottom: 20px
    }
}
.readmore {
    position: relative;
    margin: 3em auto;
    padding-bottom: 17rem;
    display: block;
    color: #666;
    border: none;
    outline: 0;
    cursor: pointer;
    background: 0 0;
    letter-spacing: .1em
}
.readmore:before {
    content: "";
    width: 50px;
    height: 50px;
    text-align: center;
    border-radius: 50%;
    display: block;
    margin: 0 auto .5em;
    background: url(../images/arrow.png) no-repeat center/20px #fff;
    transition: .3s
}
.readmore.on-click:before {
    transform: rotate(180deg)
}
.readmore .open {
    display: block
}
.readmore.on-click .open {
    display: none
}
.readmore .close {
    display: none
}
.readmore.on-click .close {
    display: block
}
.readmore05 {
    position: relative;
    margin: 3em auto;
    padding-bottom: 17rem;
    display: block;
    color: #666;
    border: none;
    outline: 0;
    cursor: pointer;
    background: 0 0;
    letter-spacing: .1em
}
.readmore05:before {
    content: "";
    width: 50px;
    height: 50px;
    text-align: center;
    border-radius: 50%;
    display: block;
    margin: 0 auto .5em;
    background: url(../images/arrow.png) no-repeat center/20px #fff;
    transition: .3s
}
.readmore05.on-click:before {
    transform: rotate(180deg)
}
.readmore05 .open {
    display: block
}
.readmore05.on-click .open {
    display: none
}
.readmore05 .close {
    display: none
}
.readmore05.on-click .close {
    display: block
}
@media all and (max-width:750px) {
    .readmore {
        padding-bottom: 6rem
    }
    .readmore05 {
        padding-bottom: 6rem
    }
}
.blue-marker {
    background: linear-gradient(transparent 70%, rgba(0, 160, 233, .5) 70%)
}
.pink-marker {
    font-size: 110%;
    font-weight: 700;
    color: #f04;
    margin-top: 5px
}
.boshu ul {
    list-style: disc;
    padding-left: 1.25em
}
.namber_list ol {
    margin: 0;
    padding: 0;
    list-style: none
}
.namber_list ol li {
    list-style: none;
    padding-left: 1.3em;
    text-indent: -1.3em
}
.btn-flat-border {
    display: inline;
    padding: .1em .5em .2em .5em;
    text-decoration: none;
    color: #fff;
    background-color: #00347c;
    border-radius: 5px;
    transition: .4s;
    margin-right: 10px;
    font-size: 80%
}
.btn-flat-border:hover {
    background: #67c5ff;
    color: #fff
}
.red-big-text {
    color: #f04;
    font-size: 110%;
    font-weight: 700
}
@media all and (min-width:751px) {
    .about6 {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 20px
    }
    .about5 {
        width: calc(50% - 10px);
        margin: 0
    }
}
@media all and (max-width:750px) {
    .about6 {
        display: flex;
        flex-direction: column;
        gap: 20px
    }
    .about5 {
        width: 100%
    }
}

/*共通*/
/* nav */

@media all and (max-width:750px) {
	
/*========= ナビゲーションのためのCSS ===============*/

#g-nav{
  position: fixed;
  z-index: -1;
  display: none;
  top: 0;
  width: 100%;
  height: 100vh;
  background: rgb(54 154 219 / 95%);
  transition: all 0.3s;
}

/*アクティブクラスがついたら透過なしにして最前面へ*/
#g-nav.panelactive{
display: block;
z-index:999;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list{
/*ナビの数が増えた場合縦スクロール*/
position: fixed;
z-index: 999; 
width: 100%;
height: 100vh;/*表示する高さ*/
overflow: auto;
-webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
display: none;
/*ナビゲーション天地中央揃え*/
z-index: 999;
}

#g-nav.panelactive ul {
width: 90%;
display: flex !important;
flex-wrap: wrap;
justify-content: space-between;
margin: 7rem auto 0;
}

/*リストのレイアウト設定*/

#g-nav li{
  list-style: none;
  text-align: center;
  width: 95%;
  margin: 0 auto 2rem;
}

#g-nav li a{
  color: #000;
  text-decoration: none;
  padding: 1.2rem 1rem;
  display: flex;
  text-transform: uppercase;
  letter-spacing: 0;
  font-weight: 500;
  font-size: 1.5rem;
  background: #fff;
  border-radius: 3px;
  width: 100%;
  margin: 0 auto;
  height: 7rem;
  justify-content: center;
  align-items: center;
  line-height: 1.3
}

#g-nav.panelactive ul li ul{
width: 23rem;
display: flex !important;
flex-wrap: wrap;
justify-content: space-between;
margin: 2vw auto 0;
}

#g-nav.panelactive ul li ul li{
width: 10.6rem;
align-items: stretch;
display: flex;
}

#g-nav.panelactive ul li ul li a{
font-size: 1.4rem;
background: #fff;
line-height: 1.2;
padding: 2vw 1vw;
border-radius: 5px;
}

#g-nav.panelactive ul li ul li img{
width: 40%;
border-radius: 10px;
}

/*========= ボタンのためのCSS ===============*/
.openbtn{
position: fixed;
z-index: 9999;
top: 0;
right: 0;
cursor: pointer;
width: 50px;
height: 50px;
border-radius: 0 0 0 3px;
}

/*×に変化*/	
.openbtn span{
  display: inline-block;
  transition: all .4s;
  position: absolute;
  right: 1.5rem;
  height: 3px;
  border-radius: 2px;
  background-color: #2b71b0;
  width: 3rem;
}

.active span{
display: inline-block;
transition: all .4s;
position: absolute;
  right: 1.25rem;
  height: 3px;
border-radius: 2px;
background-color: #fff !important;
  width: 3rem;
}

.openbtn span:nth-of-type(1) {
top:2.2rem;	
}

.openbtn span:nth-of-type(2) {
top:3.2rem;	
}

.openbtn span:nth-of-type(3) {
top:4.2rem;
}

.openbtn.active span:nth-of-type(1) {
top: 18px;
transform: translateY(6px) rotate(-45deg);
width: 50%;
}

.openbtn.active span:nth-of-type(2) {
opacity: 0;
}

.openbtn.active span:nth-of-type(3){
top: 30px;
transform: translateY(-6px) rotate(45deg);
width: 50%;
}


nav ul li.has-child dt{
overflow: hidden;
margin: 0 0 1vw 0;
}

nav ul li.has-child dd{
padding: 1vw 0;
font-weight: 500;
letter-spacing: -.05rem;
}

nav ul li.has-child dd.has-child-last{
padding: 0;
}

#g-nav li.navbnr a{
background: #02b2bf;
color: #fff;
}

.spnavinfo__w{
width: 100%;
display: flex;
flex-wrap: wrap;
align-content: center;
}

.spnavinfo1{

}

.spnavinfo2{

}
}
/* nav */

/*取り消し線*/
.txt-strikethrough {
  text-decoration: line-through;
}

/*アコーディオン：みんなのSDGs連携賞応募一覧*/
.accordion-block {
  width: 800px;
  margin: 0 auto 70px;
}

.accordion-title {
  background: linear-gradient(135deg, #0070c0 0%, #00a0e9 100%);
  color: #fff;
  padding: 15px 50px 15px 20px;
  font-size: 1.6rem;
  font-weight: 700;
  cursor: pointer;
  position: relative;
  border-radius: 5px;
  transition: all 0.3s ease;
}

.accordion-title:hover {
  opacity: 0.85;
}

.accordion-title::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 10px solid #fff;
  transition: transform 0.3s ease;
}

.accordion-title.active::after {
  transform: translateY(-50%) rotate(180deg);
}

.accordion-content {
  display: none;
  padding: 20px 0;
}

.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.renkei-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 1.4rem;
  min-width: 800px;
}

.renkei-table thead {
  background: #f0f8ff;
}

.renkei-table th,
.renkei-table td {
  padding: 12px 10px;
  border: 1px solid #ccc;
  text-align: left;
  vertical-align: middle;
}

.renkei-table th {
  font-weight: 700;
  white-space: nowrap;
  color: #333;
}

.renkei-table tbody tr:nth-child(odd) {
  background: #fff;
}

.renkei-table tbody tr:nth-child(even) {
  background: #fafafa;
}

.renkei-table tbody tr:hover {
  background: #f5f5dc;
}

.renkei-table .col-no {
  width: 50px;
  text-align: center;
}

.renkei-table .col-company {
  width: 200px;
}

.renkei-table .col-title {
  width: auto;
}

.renkei-table .col-partner {
  width: 180px;
}

.renkei-table .col-other {
  width: 180px;
}

@media all and (max-width:750px) {
  .accordion-block {
    width: 100%;
    padding: 0 3rem;
    box-sizing: border-box;
  }

  .accordion-title {
    font-size: 1.4rem;
    padding: 12px 45px 12px 15px;
  }

  .accordion-title::after {
    right: 15px;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 8px solid #fff;
  }

  .accordion-content {
    padding: 15px 10px;
  }

  .renkei-table {
    font-size: 1.2rem;
    min-width: 700px;
  }

  .renkei-table th,
  .renkei-table td {
    padding: 8px 6px;
  }

  .renkei-table .col-no {
    width: 40px;
  }

  .renkei-table .col-company {
    width: 150px;
  }

  .renkei-table .col-partner {
    width: 140px;
  }

  .renkei-table .col-other {
    width: 140px;
  }
}

/* 投票CTAボタン */
.vote-cta {
    width: 800px;
    margin: 0 auto 5rem;
    text-align: center;
}

.vote-cta a {
    display: inline-block;
    background: linear-gradient(135deg, #ed6a02 0%, #ff8e1a 100%);
    color: #fff;
    font-size: 1.8rem;
    font-weight: 700;
    text-decoration: none;
    border-radius: 50px;
    padding: 2rem 4rem;
    position: relative;
    box-shadow: 0 4px 15px rgba(237, 106, 2, 0.4);
    transition: all 0.3s ease;
}

.vote-cta a:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(237, 106, 2, 0.5);
}

.vote-cta a .vote-cta-text {
    position: relative;
    padding-right: 2rem;
}

.vote-cta a .vote-cta-text::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 10px;
    height: 10px;
    margin-top: -5px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: rotate(45deg);
}

@media all and (max-width:750px) {
    .vote-cta {
        width: 100%;
        padding: 0 3rem;
        box-sizing: border-box;
    }

    .vote-cta a {
        display: block;
        font-size: 1.5rem;
        padding: 1.8rem 2.5rem;
    }
}